mirror of
https://github.com/correl/rebar.git
synced 2024-11-23 19:19:54 +00:00
Adapt arch string to versioning scheme changes (>= 17.x)
This commit is contained in:
parent
6f60256138
commit
873d236ce9
2 changed files with 65 additions and 1 deletions
|
@ -66,6 +66,9 @@
|
||||||
processing_base_dir/2,
|
processing_base_dir/2,
|
||||||
patch_env/2]).
|
patch_env/2]).
|
||||||
|
|
||||||
|
%% for internal use only
|
||||||
|
-export([otp_release/0]).
|
||||||
|
|
||||||
-include("rebar.hrl").
|
-include("rebar.hrl").
|
||||||
|
|
||||||
%% ====================================================================
|
%% ====================================================================
|
||||||
|
@ -86,7 +89,7 @@ is_arch(ArchRegex) ->
|
||||||
|
|
||||||
get_arch() ->
|
get_arch() ->
|
||||||
Words = wordsize(),
|
Words = wordsize(),
|
||||||
erlang:system_info(otp_release) ++ "-"
|
otp_release() ++ "-"
|
||||||
++ erlang:system_info(system_architecture) ++ "-" ++ Words.
|
++ erlang:system_info(system_architecture) ++ "-" ++ Words.
|
||||||
|
|
||||||
wordsize() ->
|
wordsize() ->
|
||||||
|
@ -372,6 +375,24 @@ patch_env(Config, [E | Rest]) ->
|
||||||
%% Internal functions
|
%% Internal functions
|
||||||
%% ====================================================================
|
%% ====================================================================
|
||||||
|
|
||||||
|
otp_release() ->
|
||||||
|
otp_release1(erlang:system_info(otp_release)).
|
||||||
|
|
||||||
|
%% If OTP <= R16, otp_release is already what we want.
|
||||||
|
otp_release1([$R,N|_]=Rel) when is_integer(N) ->
|
||||||
|
Rel;
|
||||||
|
%% If OTP >= 17.x, erlang:system_info(otp_release) returns just the
|
||||||
|
%% major version number, we have to read the full version from
|
||||||
|
%% a file. See http://www.erlang.org/doc/system_principles/versions.html
|
||||||
|
otp_release1(Rel) ->
|
||||||
|
File = filename:join([code:root_dir(), "releases", Rel, "OTP_VERSION"]),
|
||||||
|
{ok, Vsn} = file:read_file(File),
|
||||||
|
%% NOTE: It's fine to rely on the binary module here because we
|
||||||
|
%% can be sure that it's available when the otp_release string
|
||||||
|
%% does not begin with $R.
|
||||||
|
%% Return as list without the "\n".
|
||||||
|
binary:bin_to_list(Vsn, {0, byte_size(Vsn) - 1}).
|
||||||
|
|
||||||
get_deprecated_3(Get, Config, OldOpt, NewOpt, Default, When) ->
|
get_deprecated_3(Get, Config, OldOpt, NewOpt, Default, When) ->
|
||||||
case Get(Config, NewOpt, Default) of
|
case Get(Config, NewOpt, Default) of
|
||||||
Default ->
|
Default ->
|
||||||
|
|
43
test/rebar_otp_release_tests.erl
Normal file
43
test/rebar_otp_release_tests.erl
Normal file
|
@ -0,0 +1,43 @@
|
||||||
|
%% -*- erlang-indent-level: 4;indent-tabs-mode: nil -*-
|
||||||
|
%% ex: ts=4 sw=4 et
|
||||||
|
%% -------------------------------------------------------------------
|
||||||
|
%%
|
||||||
|
%% rebar: Erlang Build Tools
|
||||||
|
%%
|
||||||
|
%% Copyright (c) 2014 Tuncer Ayaz
|
||||||
|
%%
|
||||||
|
%% Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
%% of this software and associated documentation files (the "Software"), to deal
|
||||||
|
%% in the Software without restriction, including without limitation the rights
|
||||||
|
%% to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
%% copies of the Software, and to permit persons to whom the Software is
|
||||||
|
%% furnished to do so, subject to the following conditions:
|
||||||
|
%%
|
||||||
|
%% The above copyright notice and this permission notice shall be included in
|
||||||
|
%% all copies or substantial portions of the Software.
|
||||||
|
%%
|
||||||
|
%% THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
%% IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
%% FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
%% AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
%% LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
%% OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
|
%% THE SOFTWARE.
|
||||||
|
%% -------------------------------------------------------------------
|
||||||
|
-module(rebar_otp_release_tests).
|
||||||
|
|
||||||
|
-include_lib("eunit/include/eunit.hrl").
|
||||||
|
|
||||||
|
otp_release_test() ->
|
||||||
|
?_assert(check_otp_release()).
|
||||||
|
|
||||||
|
check_otp_release() ->
|
||||||
|
case rebar_utils:otp_release() of
|
||||||
|
%% <= R16
|
||||||
|
[$R,N|_] when is_integer(N) ->
|
||||||
|
true;
|
||||||
|
%% >= 17.x
|
||||||
|
[N|_]=Rel when is_integer(N) ->
|
||||||
|
%% Check that it has at least Major.Minor
|
||||||
|
length(string:tokens(Rel, ".")) > 1
|
||||||
|
end.
|
Loading…
Reference in a new issue