From a4047b7e8a2256e8f85486fd7db6d0eaf073a5ed Mon Sep 17 00:00:00 2001 From: Andrew Mayorov Date: Thu, 21 Dec 2023 15:15:09 +0100 Subject: [PATCH] Respect appdirs when prioritizing module candidates. (#1418) This might be helpful in situations when tooling (e.g. `rebar3`) makes "shadow copies" in the indexable project directories. Before this change files having `_build/` in filepath were preferred over those having `apps/` or `src/` for example. --- apps/els_core/src/els_utils.erl | 32 ++++++++++++++++++++++---------- 1 file changed, 22 insertions(+), 10 deletions(-) diff --git a/apps/els_core/src/els_utils.erl b/apps/els_core/src/els_utils.erl index faee111b6..a1fe0ea5e 100644 --- a/apps/els_core/src/els_utils.erl +++ b/apps/els_core/src/els_utils.erl @@ -374,18 +374,30 @@ cmd_receive(Port) -> -spec prioritize_uris([uri()]) -> [uri()]. prioritize_uris(Uris) -> Root = els_config:get(root_uri), - Order = fun - (nomatch) -> - 3; - (Cont) -> - case string:find(Cont, "/src/") of - nomatch -> 1; - _ -> 0 - end - end, - Prio = [{Order(string:prefix(Uri, Root)), Uri} || Uri <- Uris], + AppsPaths = els_config:get(apps_paths), + Prio = [{score_uri(Uri, Root, AppsPaths), Uri} || Uri <- Uris], [Uri || {_, Uri} <- lists:sort(Prio)]. +-spec score_uri(uri(), uri(), [file:name()]) -> tuple(). +score_uri(Uri, RootUri, AppsPaths) -> + Path = els_uri:path(Uri), + Prefix = string:prefix(Uri, RootUri), + %% prefer files under project root + S1 = + case Prefix of + nomatch -> 1; + _Rest -> 0 + end, + %% among those, prefer files under some project app directory (e.g. + %% deprioritize dependencies and shadow copies) + S2 = length([ + AP + || S1 == 0, + AP <- AppsPaths, + string:prefix(Path, AP) /= nomatch + ]), + {S1, -S2}. + %%============================================================================== %% This section excerpted from the rebar3 sources, rebar_dir.erl %% Pending resolution of https://github.com/erlang/rebar3/issues/2223