diff options
author | Tristan Sloughter <[email protected]> | 2019-05-27 07:01:30 -0600 |
---|---|---|
committer | GitHub <[email protected]> | 2019-05-27 07:01:30 -0600 |
commit | 492290827f47aea259323340a4412d9af7584486 (patch) | |
tree | b37b8e3c9c1afa48cb94a5a5e6c0b72e8cf1ff34 /src | |
parent | ececf1ff9e362571637fb05ab1eea854e2ecf839 (diff) | |
parent | 6283605584fd08502f48f34ee8d34622e57a9242 (diff) | |
download | relx-492290827f47aea259323340a4412d9af7584486.tar.gz relx-492290827f47aea259323340a4412d9af7584486.tar.bz2 relx-492290827f47aea259323340a4412d9af7584486.zip |
Merge pull request #722 from tsloughter/new-start-clean
include apps in start_clean release but don't load in console_clean
Diffstat (limited to 'src')
-rw-r--r-- | src/rlx_release.erl | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/src/rlx_release.erl b/src/rlx_release.erl index e22fdd4..78e5970 100644 --- a/src/rlx_release.erl +++ b/src/rlx_release.erl @@ -197,14 +197,23 @@ start_clean_metadata(#release_t{name=Name, vsn=Vsn, erts=ErtsVsn, applications=A realized=Realized}) -> case Realized of true -> - Kernel = lists:keyfind(kernel, 1, Apps), - StdLib = lists:keyfind(stdlib, 1, Apps), + {value, Kernel, Apps1} = lists:keytake(kernel, 1, Apps), + {value, StdLib, Apps2} = lists:keytake(stdlib, 1, Apps1), {ok, {release, {erlang:atom_to_list(Name), Vsn}, {erts, ErtsVsn}, - [Kernel, StdLib]}}; + [Kernel, StdLib | none_type_apps(Apps2)]}}; false -> ?RLX_ERROR({not_realized, Name, Vsn}) end. +none_type_apps([]) -> + []; +none_type_apps([{Name, Version} | Rest]) -> + [{Name, Version, none} | none_type_apps(Rest)]; +none_type_apps([{Name, Version, _} | Rest]) -> + [{Name, Version, none} | none_type_apps(Rest)]; +none_type_apps([{Name, Version, _, _} | Rest]) -> + [{Name, Version, none} | none_type_apps(Rest)]. + %% The no_dot_erlang.rel.src file is a literal copy of start_clean.rel.src %% in Erlang/OTP itself. -spec no_dot_erlang_metadata(t()) -> term(). |