mirror of
https://github.com/correl/rebar.git
synced 2024-11-23 19:19:54 +00:00
Merge pull request #157 from Vagabond/adt-lib-dir
Don't over-aggressively clean the code path in the presence of lib_dir directives
This commit is contained in:
commit
9a158d37fc
13 changed files with 114 additions and 4 deletions
3
inttest/tdeps3/a.erl
Normal file
3
inttest/tdeps3/a.erl
Normal file
|
@ -0,0 +1,3 @@
|
|||
-module({{module}}).
|
||||
|
||||
-include_lib("{{dep}}/include/{{dep}}.hrl").
|
4
inttest/tdeps3/a.rebar.config
Normal file
4
inttest/tdeps3/a.rebar.config
Normal file
|
@ -0,0 +1,4 @@
|
|||
{deps, [
|
||||
{b, "1", {git, "../repo/b"}},
|
||||
{f, "1", {git, "../repo/f"}}
|
||||
]}.
|
1
inttest/tdeps3/b.hrl
Normal file
1
inttest/tdeps3/b.hrl
Normal file
|
@ -0,0 +1 @@
|
|||
-include_lib("c/include/c.hrl").
|
5
inttest/tdeps3/b.rebar.config
Normal file
5
inttest/tdeps3/b.rebar.config
Normal file
|
@ -0,0 +1,5 @@
|
|||
{deps, [
|
||||
{c, "1", {git, "../repo/c"}}
|
||||
]}.
|
||||
|
||||
{lib_dirs, [apps]}.
|
1
inttest/tdeps3/c.hrl
Normal file
1
inttest/tdeps3/c.hrl
Normal file
|
@ -0,0 +1 @@
|
|||
-include_lib("d/include/d.hrl").
|
1
inttest/tdeps3/c.rebar.config
Normal file
1
inttest/tdeps3/c.rebar.config
Normal file
|
@ -0,0 +1 @@
|
|||
{deps, [{d, "1", {git, "../repo/d"}}]}.
|
1
inttest/tdeps3/d.hrl
Normal file
1
inttest/tdeps3/d.hrl
Normal file
|
@ -0,0 +1 @@
|
|||
-include_lib("e/include/e.hrl").
|
1
inttest/tdeps3/d.rebar.config
Normal file
1
inttest/tdeps3/d.rebar.config
Normal file
|
@ -0,0 +1 @@
|
|||
{deps, [{e, "1", {git, "../repo/e"}}]}.
|
1
inttest/tdeps3/e.hrl
Normal file
1
inttest/tdeps3/e.hrl
Normal file
|
@ -0,0 +1 @@
|
|||
-define(HELLO, hello).
|
1
inttest/tdeps3/f.hrl
Normal file
1
inttest/tdeps3/f.hrl
Normal file
|
@ -0,0 +1 @@
|
|||
-include_lib("e/include/e.hrl").
|
1
inttest/tdeps3/root.rebar.config
Normal file
1
inttest/tdeps3/root.rebar.config
Normal file
|
@ -0,0 +1 @@
|
|||
{sub_dirs, ["apps/a"]}.
|
89
inttest/tdeps3/tdeps3_rt.erl
Normal file
89
inttest/tdeps3/tdeps3_rt.erl
Normal file
|
@ -0,0 +1,89 @@
|
|||
-module(tdeps3_rt).
|
||||
|
||||
-compile(export_all).
|
||||
|
||||
%% Exercise transitive dependencies where there are multiple files
|
||||
%% depending on the same set of deps as well as lib_dir directives
|
||||
%% A -> B -> C -> D -> E
|
||||
%% |--> G(via lib_dir)
|
||||
%% |--> F -> D -> E
|
||||
|
||||
files() ->
|
||||
[
|
||||
%% A1 application
|
||||
{create, "ebin/a.app", app(a, [a])},
|
||||
{template, "a.erl", "src/a.erl", dict:from_list([{module, a}, {dep, b}])},
|
||||
|
||||
{copy, "a.rebar.config", "rebar.config"},
|
||||
{copy, "../../rebar", "rebar"},
|
||||
|
||||
%% B application
|
||||
{create, "repo/b/ebin/b.app", app(b, [b])},
|
||||
{template, "a.erl", "repo/b/src/b.erl", dict:from_list([{module, b}, {dep, b}])},
|
||||
{copy, "b.rebar.config", "repo/b/rebar.config"},
|
||||
{copy, "b.hrl", "repo/b/include/b.hrl"},
|
||||
|
||||
%% C application
|
||||
{create, "repo/c/ebin/c.app", app(c, [c])},
|
||||
{template, "a.erl", "repo/c/src/c.erl", dict:from_list([{module, c}, {dep, d}])},
|
||||
{copy, "c.rebar.config", "repo/c/rebar.config"},
|
||||
{copy, "c.hrl", "repo/c/include/c.hrl"},
|
||||
|
||||
%% D application
|
||||
{create, "repo/d/ebin/d.app", app(d, [d])},
|
||||
{template, "a.erl", "repo/d/src/d.erl", dict:from_list([{module, d}, {dep, e}])},
|
||||
{copy, "d.rebar.config", "repo/d/rebar.config"},
|
||||
{copy, "d.hrl", "repo/d/include/d.hrl"},
|
||||
|
||||
%% E application
|
||||
{create, "repo/e/ebin/e.app", app(e, [])},
|
||||
{copy, "e.hrl", "repo/e/include/e.hrl"},
|
||||
|
||||
|
||||
%% F application
|
||||
{create, "repo/f/ebin/f.app", app(f, [f])},
|
||||
{template, "a.erl", "repo/f/src/f.erl", dict:from_list([{module, f}, {dep, d}])},
|
||||
{copy, "c.rebar.config", "repo/f/rebar.config"},
|
||||
{copy, "f.hrl", "repo/f/include/f.hrl"},
|
||||
|
||||
%% G application, which is part of the B repo, in a lib_dir
|
||||
{create, "repo/b/apps/g/ebin/g.app", app(g, [])},
|
||||
{copy, "e.hrl", "repo/b/apps/g/include/g.hrl"}
|
||||
|
||||
].
|
||||
|
||||
apply_cmds([], _Params) ->
|
||||
ok;
|
||||
apply_cmds([Cmd | Rest], Params) ->
|
||||
io:format("Running: ~s (~p)\n", [Cmd, Params]),
|
||||
{ok, _} = retest_sh:run(Cmd, Params),
|
||||
apply_cmds(Rest, Params).
|
||||
|
||||
run(_Dir) ->
|
||||
%% Initialize the b/c apps as git repos so that dependencies pull
|
||||
%% properly
|
||||
GitCmds = ["git init",
|
||||
"git add -A",
|
||||
"git config user.email 'tdeps@example.com'",
|
||||
"git config user.name 'tdeps'",
|
||||
"git commit -a -m 'Initial Commit'"],
|
||||
ok = apply_cmds(GitCmds, [{dir, "repo/b"}]),
|
||||
ok = apply_cmds(GitCmds, [{dir, "repo/c"}]),
|
||||
ok = apply_cmds(GitCmds, [{dir, "repo/d"}]),
|
||||
ok = apply_cmds(GitCmds, [{dir, "repo/e"}]),
|
||||
ok = apply_cmds(GitCmds, [{dir, "repo/f"}]),
|
||||
|
||||
{ok, _} = retest_sh:run("./rebar -v get-deps compile", []),
|
||||
ok.
|
||||
|
||||
%%
|
||||
%% Generate the contents of a simple .app file
|
||||
%%
|
||||
app(Name, Modules) ->
|
||||
App = {application, Name,
|
||||
[{description, atom_to_list(Name)},
|
||||
{vsn, "1"},
|
||||
{modules, Modules},
|
||||
{registered, []},
|
||||
{applications, [kernel, stdlib]}]},
|
||||
io_lib:format("~p.\n", [App]).
|
|
@ -399,18 +399,19 @@ update_code_path(Config) ->
|
|||
[] ->
|
||||
no_change;
|
||||
Paths ->
|
||||
OldPath = code:get_path(),
|
||||
LibPaths = expand_lib_dirs(Paths, rebar_utils:get_cwd(), []),
|
||||
ok = code:add_pathsa(LibPaths),
|
||||
{old, OldPath}
|
||||
%% track just the paths we added, so we can remove them without
|
||||
%% removing other paths added by this dep
|
||||
{added, LibPaths}
|
||||
end.
|
||||
|
||||
restore_code_path(no_change) ->
|
||||
ok;
|
||||
restore_code_path({old, Path}) ->
|
||||
restore_code_path({added, Paths}) ->
|
||||
%% Verify that all of the paths still exist -- some dynamically
|
||||
%% added paths can get blown away during clean.
|
||||
true = code:set_path([F || F <- Path, erl_prim_loader_is_file(F)]),
|
||||
[code:del_path(F) || F <- Paths, erl_prim_loader_is_file(F)],
|
||||
ok.
|
||||
|
||||
erl_prim_loader_is_file(File) ->
|
||||
|
|
Loading…
Reference in a new issue