aboutsummaryrefslogtreecommitdiffstats
path: root/core/deps.mk
diff options
context:
space:
mode:
authorLoïc Hoguin <[email protected]>2023-05-09 17:11:22 +0200
committerLoïc Hoguin <[email protected]>2023-05-09 17:11:22 +0200
commitdcc2741b6026a66c457fd2193cda8a42a3874839 (patch)
tree8d8fefc32c4857fb789e53e5fe703669ca63148a /core/deps.mk
parent48e8768c02d6e4b99732d85966d0a44fdb92f97b (diff)
downloaderlang.mk-dcc2741b6026a66c457fd2193cda8a42a3874839.tar.gz
erlang.mk-dcc2741b6026a66c457fd2193cda8a42a3874839.tar.bz2
erlang.mk-dcc2741b6026a66c457fd2193cda8a42a3874839.zip
Autopatch: better handle COMPILE_FIRST/erl_first_files
This is still a bit hackish but it appears that some projects have wrong erl_first_files entries (module exists but not at the location configured) and so we have to do a bit of manipulation before we can find the module. We also need to be cautious about .yrl/.xrl because their corresponding .erl files may not exist in the repository before compilation yet can be listed in erl_first_files.
Diffstat (limited to 'core/deps.mk')
-rw-r--r--core/deps.mk7
1 files changed, 5 insertions, 2 deletions
diff --git a/core/deps.mk b/core/deps.mk
index 5b01b8d..c848224 100644
--- a/core/deps.mk
+++ b/core/deps.mk
@@ -468,13 +468,16 @@ define dep_autopatch_rebar.erl
fun() ->
case lists:keyfind(erl_first_files, 1, Conf) of
false -> ok;
- {_, Files} ->
+ {_, Files0} ->
+ Files = [begin
+ hd(filelib:wildcard("$(call core_native_path,$(DEPS_DIR)/$1/src/**/" ++ filename:rootname(F) ++ ".*rl")))
+ end || "src/" ++ F <- Files0],
Names = [[" ", case lists:reverse(F) of
"lre." ++ Elif -> lists:reverse(Elif);
"lrx." ++ Elif -> lists:reverse(Elif);
"lry." ++ Elif -> lists:reverse(Elif);
Elif -> lists:reverse(Elif)
- end] || "src/" ++ F <- Files],
+ end] || "$(call core_native_path,$(DEPS_DIR)/$1/src/)" ++ F <- Files],
Write(io_lib:format("COMPILE_FIRST +=~s\n", [Names]))
end
end(),