summaryrefslogtreecommitdiff
path: root/src/rebar_erlc_compiler.erl
diff options
context:
space:
mode:
Diffstat (limited to 'src/rebar_erlc_compiler.erl')
-rw-r--r--src/rebar_erlc_compiler.erl47
1 files changed, 47 insertions, 0 deletions
diff --git a/src/rebar_erlc_compiler.erl b/src/rebar_erlc_compiler.erl
index 0320380..760111f 100644
--- a/src/rebar_erlc_compiler.erl
+++ b/src/rebar_erlc_compiler.erl
@@ -40,6 +40,14 @@
-spec compile(Config::#config{}, AppFile::string()) -> 'ok'.
compile(Config, _AppFile) ->
+ rebar_base_compiler:run(Config,
+ rebar_config:get_list(Config, xrl_first_files, []),
+ "src", ".xrl", "src", ".erl",
+ fun compile_xrl/3),
+ rebar_base_compiler:run(Config,
+ rebar_config:get_list(Config, yrl_first_files, []),
+ "src", ".yrl", "src", ".erl",
+ fun compile_yrl/3),
doterl_compile(Config, "ebin"),
rebar_base_compiler:run(Config, rebar_config:get_list(Config, mib_first_files, []),
"mibs", ".mib", "priv/mibs", ".bin",
@@ -52,6 +60,11 @@ clean(_Config, _AppFile) ->
%% much slower.
ok = rebar_file_utils:rm_rf("ebin/*.beam priv/mibs/*.bin"),
+ YrlFiles = rebar_utils:find_files("src", "^.*\\.[x|y]rl\$"),
+ rebar_file_utils:delete_each(
+ [ binary_to_list(iolist_to_binary(re:replace(F, "\\.[x|y]rl$", ".erl")))
+ || F <- YrlFiles ]),
+
%% Erlang compilation is recursive, so it's possible that we have a nested
%% directory structure in ebin with .beam files within. As such, we want
%% to scan whatever is left in the ebin/ directory for sub-dirs which
@@ -198,6 +211,40 @@ compile_mib(Source, Target, Config) ->
?FAIL
end.
+-spec compile_xrl(Source::string(), Target::string(), Config::#config{}) -> 'ok'.
+compile_xrl(Source, Target, Config) ->
+ Opts = [{scannerfile, Target}, {return, true}
+ |rebar_config:get(Config, xrl_opts, [])],
+ compile_xrl_yrl(Source, Target, Config, Opts, leex).
+
+-spec compile_yrl(Source::string(), Target::string(), Config::#config{}) -> 'ok'.
+compile_yrl(Source, Target, Config) ->
+ Opts = [{parserfile, Target}, {return, true}
+ |rebar_config:get(Config, yrl_opts, [])],
+ compile_xrl_yrl(Source, Target, Config, Opts, yecc).
+
+-spec compile_xrl_yrl(Source::string(), Target::string(), Config::#config{},
+ Opts::list(), Mod::atom()) -> 'ok'.
+compile_xrl_yrl(Source, Target, Config, Opts, Mod) ->
+ case needs_compile(Source, Target, []) of
+ true ->
+ case Mod:file(Source, Opts) of
+ {ok, _, []} ->
+ ok;
+ {ok, _, _Warnings} ->
+ case lists:member(fail_on_warnings, Config) of
+ true ->
+ ?FAIL;
+ false ->
+ ok
+ end;
+ _X ->
+ ?FAIL
+ end;
+ false ->
+ skipped
+ end.
+
gather_src([], Srcs) ->
Srcs;
gather_src([Dir|Rest], Srcs) ->