aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorTristan Sloughter <[email protected]>2019-05-27 07:01:30 -0600
committerGitHub <[email protected]>2019-05-27 07:01:30 -0600
commit492290827f47aea259323340a4412d9af7584486 (patch)
treeb37b8e3c9c1afa48cb94a5a5e6c0b72e8cf1ff34 /src
parentececf1ff9e362571637fb05ab1eea854e2ecf839 (diff)
parent6283605584fd08502f48f34ee8d34622e57a9242 (diff)
downloadrelx-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.erl15
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().