summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFred Hebert <mononcqc@ferd.ca>2015-11-01 21:07:58 -0500
committerFred Hebert <mononcqc@ferd.ca>2015-11-01 21:07:58 -0500
commit8fcfbfc4beb39e546559574b04312318f0b07740 (patch)
treede1776c7c130f2ba42def7ff02848d58ec50a9a1
parentf7326f0b9086ff6faec5aae6750ef763860db38f (diff)
parente5aa04f27800ee83a5d5e76fd95c9f31e6aff090 (diff)
Merge pull request #906 from tsloughter/plugins_list_fix
fix #903: use app discover of entire plugins dir when listing
-rw-r--r--.travis.yml2
-rw-r--r--src/rebar_prv_plugins.erl27
2 files changed, 16 insertions, 13 deletions
diff --git a/.travis.yml b/.travis.yml
index f435a71..7530a98 100644
--- a/.travis.yml
+++ b/.travis.yml
@@ -13,7 +13,7 @@ branches:
- master
cache:
directories:
- - $HOME/.cache/rebar3/hex/com/amazonaws/s3/s3.hex.pm/tarballs/packages/
+ - $HOME/.cache/rebar3/hex/default
before_deploy: "rm -rf !(rebar3)"
deploy:
on:
diff --git a/src/rebar_prv_plugins.erl b/src/rebar_prv_plugins.erl
index 20bc1ea..7e6b88e 100644
--- a/src/rebar_prv_plugins.erl
+++ b/src/rebar_prv_plugins.erl
@@ -34,34 +34,37 @@ do(State) ->
GlobalConfigFile = rebar_dir:global_config(),
GlobalConfig = rebar_state:new(rebar_config:consult_file(GlobalConfigFile)),
GlobalPlugins = rebar_state:get(GlobalConfig, plugins, []),
- GlobalPluginsDir = filename:join(rebar_dir:global_cache_dir(rebar_state:opts(State)), "plugins"),
- display_plugins("Global plugins", GlobalPluginsDir, GlobalPlugins),
+ GlobalPluginsDir = filename:join([rebar_dir:global_cache_dir(rebar_state:opts(State)), "plugins", "*"]),
+ GlobalApps = rebar_app_discover:find_apps([GlobalPluginsDir], all),
+ display_plugins("Global plugins", GlobalApps, GlobalPlugins),
Plugins = rebar_state:get(State, plugins, []),
- PluginsDir =rebar_dir:plugins_dir(State),
- display_plugins("Local plugins", PluginsDir, Plugins),
+ PluginsDir = filename:join(rebar_dir:plugins_dir(State), "*"),
+ CheckoutsDir = filename:join(rebar_dir:checkouts_dir(State), "*"),
+ Apps = rebar_app_discover:find_apps([CheckoutsDir, PluginsDir], all),
+ display_plugins("Local plugins", Apps, Plugins),
{ok, State}.
-spec format_error(any()) -> iolist().
format_error(Reason) ->
io_lib:format("~p", [Reason]).
-display_plugins(_Header, _Dir, []) ->
+display_plugins(_Header, _Apps, []) ->
ok;
-display_plugins(Header, Dir, Plugins) ->
+display_plugins(Header, Apps, Plugins) ->
?CONSOLE("--- ~s ---", [Header]),
- display_plugins(Dir, Plugins),
+ display_plugins(Apps, Plugins),
?CONSOLE("", []).
-display_plugins(Dir, Plugins) ->
+display_plugins(Apps, Plugins) ->
lists:foreach(fun(Plugin) ->
- Name = if is_atom(Plugin) -> Plugin;
- is_tuple(Plugin) -> element(1, Plugin)
+ Name = if is_atom(Plugin) -> ec_cnv:to_binary(Plugin);
+ is_tuple(Plugin) -> ec_cnv:to_binary(element(1, Plugin))
end,
- case rebar_app_info:discover(filename:join(Dir, Name)) of
+ case rebar_app_utils:find(Name, Apps) of
{ok, _App} ->
?CONSOLE("~s", [Name]);
- not_found ->
+ error ->
?DEBUG("Unable to find plugin ~s", [Name])
end
end, Plugins).