diff options
author | James Fish <james@fishcakez.com> | 2016-07-11 14:28:38 +0100 |
---|---|---|
committer | James Fish <james@fishcakez.com> | 2016-07-11 15:52:42 +0100 |
commit | e334f211e373c9f019c68d5d35cc8b6aa0a1723a (patch) | |
tree | 47a5b8129e191e9536b8821492c0f4ca437b1caf /src | |
parent | 8f6c13deada198f39cc4ac3b35e56a572ed143ba (diff) |
Handle empty PLTs
Diffstat (limited to 'src')
-rw-r--r-- | src/rebar_prv_dialyzer.erl | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/src/rebar_prv_dialyzer.erl b/src/rebar_prv_dialyzer.erl index 622ee60..f7e3f21 100644 --- a/src/rebar_prv_dialyzer.erl +++ b/src/rebar_prv_dialyzer.erl @@ -353,8 +353,19 @@ update_base_plt(State, BasePlt, Output, BaseFiles) -> build_plt(State, BasePlt, Output, BaseFiles) end. +build_plt(State, Plt, _, []) -> + ?INFO("Building with no files in ~p...", [Plt]), + Opts = [{get_warnings, false}, + {output_plt, Plt}, + {apps, [erts]}], + % Create a PLT with erts files and then remove erts files to be left with an + % empty PLT. Dialyzer will crash when trying to build a PLT with an empty + % file list. + _ = dialyzer:run([{analysis_type, plt_build} | Opts]), + _ = dialyzer:run([{analysis_type, plt_remove}, {init_plt, Plt} | Opts]), + {0, State}; build_plt(State, Plt, Output, Files) -> - ?INFO("Adding ~b files to ~p...", [length(Files), Plt]), + ?INFO("Building with ~b files in ~p...", [length(Files), Plt]), GetWarnings = get_config(State, get_warnings, false), Opts = [{analysis_type, plt_build}, {get_warnings, GetWarnings}, |