aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Changelog.md3
-rw-r--r--libsolidity/interface/CompilerStack.cpp24
-rw-r--r--libsolidity/interface/CompilerStack.h5
3 files changed, 16 insertions, 16 deletions
diff --git a/Changelog.md b/Changelog.md
index c06313ba..52f86d40 100644
--- a/Changelog.md
+++ b/Changelog.md
@@ -1,8 +1,7 @@
### 0.4.8 (unreleased)
BugFixes:
- * Remappings: a=b would overwrite c:a=d. This has now been fixed to all modules except
- c using b as their target, with c using d as the target.
+ * Remappings: Prefer longer context over longer prefix.
* Type checker, code generator: enable access to events of base contracts' names.
* Imports: ``import ".dir/a"`` is not a relative path. Relative paths begin with directory ``.`` or ``..``.
diff --git a/libsolidity/interface/CompilerStack.cpp b/libsolidity/interface/CompilerStack.cpp
index 30abad07..1e571cae 100644
--- a/libsolidity/interface/CompilerStack.cpp
+++ b/libsolidity/interface/CompilerStack.cpp
@@ -510,28 +510,28 @@ string CompilerStack::applyRemapping(string const& _path, string const& _context
size_t longestPrefix = 0;
size_t longestContext = 0;
- string longestPrefixTarget;
+ string bestMatchTarget;
for (auto const& redir: m_remappings)
{
- string contextFileString = sanitizePath(redir.context);
- string prefixFileString = sanitizePath(redir.prefix);
- // Skip if there is a prefix collision and the current context is closer
- if (longestContext > 0 && contextFileString.length() < longestContext)
+ string context = sanitizePath(redir.context);
+ string prefix = sanitizePath(redir.prefix);
+ // Skip if current context is closer
+ if (context.length() < longestContext)
continue;
// Skip if redir.context is not a prefix of _context
- if (!isPrefixOf(contextFileString, _context))
+ if (!isPrefixOf(context, _context))
continue;
- // Skip if we already have a closer match.
- if (prefixFileString.length() < longestPrefix)
+ // Skip if we already have a closer prefix match.
+ if (prefix.length() < longestPrefix)
continue;
// Skip if the prefix does not match.
- if (!isPrefixOf(prefixFileString, _path))
+ if (!isPrefixOf(prefix, _path))
continue;
- longestContext = contextFileString.length();
- longestPrefix = prefixFileString.length();
- longestPrefixTarget = redir.target;
+ longestContext = context.length();
+ longestPrefix = prefix.length();
+ bestMatchTarget = redir.target;
}
string path = longestPrefixTarget;
diff --git a/libsolidity/interface/CompilerStack.h b/libsolidity/interface/CompilerStack.h
index ef0aa6fe..d49a8df1 100644
--- a/libsolidity/interface/CompilerStack.h
+++ b/libsolidity/interface/CompilerStack.h
@@ -235,13 +235,14 @@ private:
bool checkLibraryNameClashes();
/// @returns the absolute path corresponding to @a _path relative to @a _reference.
std::string absolutePath(std::string const& _path, std::string const& _reference) const;
+ /// Helper function to return path converted strings.
+ std::string sanitizePath(std::string const& _path) const { return boost::filesystem::path(_path).generic_string(); }
+
/// Compile a single contract and put the result in @a _compiledContracts.
void compileContract(
ContractDefinition const& _contract,
std::map<ContractDefinition const*, eth::Assembly const*>& _compiledContracts
);
- /// Helper function to return path converted strings.
- std::string sanitizePath(std::string const& _path) { return boost::filesystem::path(_path).generic_string(); }
void link();
Contract const& contract(std::string const& _contractName = "") const;