Explorar el Código

fix #903: use app discover of entire plugins dir when listing

pull/906/head
Tristan Sloughter hace 9 años
padre
commit
e5aa04f278
Se han modificado 2 ficheros con 16 adiciones y 13 borrados
  1. +1
    -1
      .travis.yml
  2. +15
    -12
      src/rebar_prv_plugins.erl

+ 1
- 1
.travis.yml Ver fichero

@ -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:

+ 15
- 12
src/rebar_prv_plugins.erl Ver fichero

@ -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).

Cargando…
Cancelar
Guardar