diff options
author | Tristan Sloughter <tristan.sloughter@gmail.com> | 2015-04-11 19:53:53 -0500 |
---|---|---|
committer | Tristan Sloughter <tristan.sloughter@gmail.com> | 2015-04-11 19:53:53 -0500 |
commit | 0ad833b700f59bd5fd5e3b34aab2f887424671f3 (patch) | |
tree | ebaf2b2c639509b9211528c15a2337f27b965c9f /src/rebar_packages.erl | |
parent | f88bb57cd34f3636217a1d1ae5f63eb32ba448d6 (diff) | |
parent | 4fb9207d9a7bd4e8d227c05ba2eb6089ca98322c (diff) |
Merge pull request #330 from tsloughter/wip_single_atom_deps
support single atoms for pkg deps, fetch highest version available
Diffstat (limited to 'src/rebar_packages.erl')
-rw-r--r-- | src/rebar_packages.erl | 55 |
1 files changed, 54 insertions, 1 deletions
diff --git a/src/rebar_packages.erl b/src/rebar_packages.erl index 5c67600..8982573 100644 --- a/src/rebar_packages.erl +++ b/src/rebar_packages.erl @@ -1,6 +1,8 @@ -module(rebar_packages). --export([get_packages/1]). +-export([get_packages/1 + ,registry/1 + ,find_highest_matching/3]). -export_type([package/0]). @@ -37,3 +39,54 @@ get_packages(State) -> ?ERROR("Bad packages index, try to fix with `rebar3 update`", []), {dict:new(), digraph:new()} end. + +registry(State) -> + Dir = rebar_dir:global_cache_dir(State), + RegistryDir = filename:join(Dir, "packages"), + HexFile = filename:join(RegistryDir, "registry"), + case ets:file2tab(HexFile) of + {ok, T} -> + {ok, T}; + {error, Reason} -> + ?DEBUG("Error loading registry: ~p", [Reason]), + error + end. + + +%% Hex supports use of ~> to specify the version required for a dependency. +%% Since rebar3 requires exact versions to choose from we find the highest +%% available version of the dep that passes the constraint. + +%% `~>` will never include pre-release versions of its upper bound. +%% It can also be used to set an upper bound on only the major +%% version part. See the table below for `~>` requirements and +%% their corresponding translation. +%% `~>` | Translation +%% :------------- | :--------------------- +%% `~> 2.0.0` | `>= 2.0.0 and < 2.1.0` +%% `~> 2.1.2` | `>= 2.1.2 and < 2.2.0` +%% `~> 2.1.3-dev` | `>= 2.1.3-dev and < 2.2.0` +%% `~> 2.0` | `>= 2.0.0 and < 3.0.0` +%% `~> 2.1` | `>= 2.1.0 and < 3.0.0` +find_highest_matching(Dep, Constraint, T) -> + case ets:lookup(T, Dep) of + [{Dep, [[Vsn]]}] -> + case ec_semver:pes(Vsn, Constraint) of + true -> + Vsn; + false -> + ?WARN("Only existing version of ~s is ~s which does not match constraint ~~> ~s. " + "Using anyway, but it is not guarenteed to work.", [Dep, Vsn, Constraint]), + Vsn + end; + [{Dep, [[HeadVsn | VsnTail]]}] -> + lists:foldl(fun(Version, Highest) -> + case ec_semver:pes(Version, Constraint) andalso + ec_semver:gt(Version, Highest) of + true -> + Version; + false -> + Highest + end + end, HeadVsn, VsnTail) + end. |