diff options
author | Tristan Sloughter <t@crashfast.com> | 2014-08-28 10:48:54 -0500 |
---|---|---|
committer | Tristan Sloughter <t@crashfast.com> | 2014-08-28 10:48:54 -0500 |
commit | e940d6583ab17f1467c4740c9cc206f72b6cc7ce (patch) | |
tree | 9ebb1ea18d4e5f77bf203d18a7fcdb9291a57bc8 | |
parent | 393abe92d01040a847bfc42a80d61b33f0254ca7 (diff) |
restrict packages to those that work on users system
-rw-r--r-- | src/rebar_prv_update.erl | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/src/rebar_prv_update.erl b/src/rebar_prv_update.erl index 081a3b0..042a069 100644 --- a/src/rebar_prv_update.erl +++ b/src/rebar_prv_update.erl @@ -52,7 +52,8 @@ do(State) -> {ok, State1}; [] -> ?INFO("Updating package index...", []), - Url = rebar_state:get(State, rebar_packages_url, "http://polar-caverns-6802.herokuapp.com/"), + Url = url(State), + io:format("Url ~s~n", [Url]), ec_file:mkdir_p(filename:join([os:getenv("HOME"), ".rebar"])), PackagesFile = filename:join([os:getenv("HOME"), ".rebar", "packages"]), {ok, RequestId} = httpc:request(get, {Url, []}, [], [{stream, PackagesFile}, {sync, false}]), @@ -68,3 +69,15 @@ wait(RequestId, State) -> io:format("."), wait(RequestId, State) end. + +url(State) -> + SystemArch = erlang:system_info(system_architecture), + ErtsVsn = erlang:system_info(version), + {glibc, GlibcVsn, _, _} = erlang:system_info(allocator), + GlibcVsnStr = io_lib:format("~p.~p", GlibcVsn), + + Qs = [io_lib:format("~s=~s", [X, Y]) || {X, Y} <- [{"arch", SystemArch} + ,{"erts", ErtsVsn} + ,{"glibc", GlibcVsnStr}]], + Url = rebar_state:get(State, rebar_packages_url, "http://polar-caverns-6802.herokuapp.com"), + Url ++ "?" ++ string:join(Qs, "&"). |