summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAdam Kocoloski <adam@cloudant.com>2010-11-30 00:46:50 +0100
committerTuncer Ayaz <tuncer.ayaz@gmail.com>2010-11-30 01:18:48 +0100
commit8118083122e5661e1f289b7beba4eefef82b0de1 (patch)
tree18eb34d2b45161b1fc4c031caff1767896c44286
parentbb6d07011ff1a8ee51bc0c9f04afd5d027402367 (diff)
Return descriptive errors from is_app_available()
-rw-r--r--src/rebar_deps.erl20
1 files changed, 10 insertions, 10 deletions
diff --git a/src/rebar_deps.erl b/src/rebar_deps.erl
index a7baae9..317814f 100644
--- a/src/rebar_deps.erl
+++ b/src/rebar_deps.erl
@@ -158,7 +158,7 @@ update_deps_code_path([Dep | Rest]) ->
Dir = filename:join(Dep#dep.dir, "ebin"),
ok = filelib:ensure_dir(filename:join(Dir, "dummy")),
true = code:add_patha(Dir);
- false ->
+ {false, _} ->
true
end,
update_deps_code_path(Rest).
@@ -179,12 +179,12 @@ find_deps([{App, VsnRegex, Source} | Rest], {Avail, Missing}) ->
case is_app_available(App, VsnRegex) of
{true, AppDir} ->
find_deps(Rest, {[Dep#dep { dir = AppDir } | Avail], Missing});
- false ->
+ {false, _} ->
AppDir = filename:join(get_deps_dir(), Dep#dep.app),
case is_app_available(App, VsnRegex, AppDir) of
{true, AppDir} ->
find_deps(Rest, {[Dep#dep { dir = AppDir } | Avail], Missing});
- false ->
+ {false, _} ->
find_deps(Rest, {Avail, [Dep#dep { dir = AppDir } | Missing]})
end
end;
@@ -209,7 +209,7 @@ require_source_engine(Source) ->
is_app_available(App, VsnRegex) ->
case code:lib_dir(App) of
{error, bad_name} ->
- false;
+ {false, bad_name};
Path ->
is_app_available(App, VsnRegex, Path)
end.
@@ -228,16 +228,16 @@ is_app_available(App, VsnRegex, Path) ->
nomatch ->
?WARN("~s has version ~p; requested regex was ~s\n",
[AppFile, Vsn, VsnRegex]),
- false
+ {false, version_mismatch}
end;
OtherApp ->
?WARN("~s has application id ~p; expected ~p\n", [AppFile, OtherApp, App]),
- false
+ {false, name_mismatch}
end;
false ->
?WARN("Expected ~s to be an app dir (containing ebin/*.app), but no .app found.\n",
[Path]),
- false
+ {false, missing_app_file}
end.
use_source(Dep) ->
@@ -257,11 +257,11 @@ use_source(Dep, Count) ->
%% add the app dir to our code path
true = code:add_patha(Dir),
Dep;
- false ->
+ {false, Reason} ->
%% The app that was downloaded doesn't match up (or had
%% errors or something). For the time being, abort.
- ?ABORT("Dependency dir ~s does not satisfy version regex ~s.\n",
- [Dep#dep.dir, Dep#dep.vsn_regex])
+ ?ABORT("Dependency dir ~s failed application validation "
+ "with reason ~p.\n", [Dep#dep.dir, Reason])
end;
false ->
?CONSOLE("Pulling ~p from ~p\n", [Dep#dep.app, Dep#dep.source]),