From 5e213b62e504f967af7de692b55a12aa5ac3505d Mon Sep 17 00:00:00 2001 From: paulklint Date: Wed, 25 Sep 2024 23:09:54 +0200 Subject: [PATCH] Improved getModuleName for use with library modules --- src/org/rascalmpl/library/util/Reflective.rsc | 45 ++++++++++++------- 1 file changed, 30 insertions(+), 15 deletions(-) diff --git a/src/org/rascalmpl/library/util/Reflective.rsc b/src/org/rascalmpl/library/util/Reflective.rsc index 2a9a3f7d5ab..14e1e76d7b0 100644 --- a/src/org/rascalmpl/library/util/Reflective.rsc +++ b/src/org/rascalmpl/library/util/Reflective.rsc @@ -135,6 +135,7 @@ loc getModuleLocation(str qualifiedModuleName, PathConfig pcfg){ fileName = makeFileName(qualifiedModuleName, extension="tpl"); for(loc dir <- pcfg.libs){ fileLoc = dir + fileName; + if(exists(fileLoc)){ return fileLoc; } @@ -170,15 +171,11 @@ int commonPrefix(list[str] rdir, list[str] rm){ str getModuleName(loc moduleLoc, PathConfig pcfg){ modulePath = moduleLoc.path; - if(!endsWith(modulePath, "rsc")){ - throw "Not a Rascal source file: "; + if(!(endsWith(modulePath, "rsc") || endsWith(modulePath, "tpl"))){ + throw "Not a Rascal .src or .tpl file: "; } - = splitFileExtension(modulePath); - if(modulePathNoExt[0] == "/"){ - modulePathNoExt = modulePathNoExt[1..]; - } - modulePathAsList = split("/", modulePathNoExt); - modulePathAsListReversed = reverse(modulePathAsList); + + // Find matching .rsc file in source directories for(loc dir <- pcfg.srcs){ if(moduleLoc.authority == dir.authority && startsWith(modulePath, dir.path)) { @@ -191,25 +188,43 @@ str getModuleName(loc moduleLoc, PathConfig pcfg){ return moduleName; } } - + + // Find longest matching .tpl file in library directories + + = splitFileExtension(modulePath); + while(modulePathNoExt[0] == "/"){ + modulePathNoExt = modulePathNoExt[1..]; + } + modulePathAsList = split("/", modulePathNoExt); + modulePathReversed = reverse(modulePathAsList); + int longestSuffix = 0; for(loc dir <- pcfg.libs){ dir = dir + "rascal"; + dpath = dir.path; + + while(dpath[0] == "/"){ + dpath = dpath[1..]; + } + for(loc file <- find(dir, "tpl")){ - candidate = replaceFirst(file.path, dir.path, ""); - candidate = replaceLast(candidate, "$", ""); - if(candidate[0] == "/"){ + candidate = replaceFirst(file.path, dpath, ""); + = splitFileExtension(candidate); + while(candidate[0] == "/"){ + candidate = candidate[1..]; + } + if(candidate[0] == "$"){ candidate = candidate[1..]; } - = splitFileExtension(candidate); candidateAsList = split("/", candidate); - n = commonPrefix(reverse(candidateAsList), modulePathAsListReversed); - //println(", =\> "); + n = commonPrefix(reverse(candidateAsList), modulePathReversed); + if(n > longestSuffix){ longestSuffix = n; } } } + if(longestSuffix > 0){ return intercalate("::", modulePathAsList[size(modulePathAsList) - longestSuffix .. ]); }