diff options
author | VoR0220 <rj@erisindustries.com> | 2017-01-12 01:45:14 +0800 |
---|---|---|
committer | VoR0220 <rj@erisindustries.com> | 2017-01-12 01:45:14 +0800 |
commit | 4542f459f165502ed9537bb570de44640cdc4228 (patch) | |
tree | 36be3a43e4b04b30ea2903a48aea717d3ef6007d /libsolidity/interface/CompilerStack.cpp | |
parent | 4585bfdce7716cd4837f71b565bb9a6dff8c2d7e (diff) | |
download | dexon-solidity-4542f459f165502ed9537bb570de44640cdc4228.tar dexon-solidity-4542f459f165502ed9537bb570de44640cdc4228.tar.gz dexon-solidity-4542f459f165502ed9537bb570de44640cdc4228.tar.bz2 dexon-solidity-4542f459f165502ed9537bb570de44640cdc4228.tar.lz dexon-solidity-4542f459f165502ed9537bb570de44640cdc4228.tar.xz dexon-solidity-4542f459f165502ed9537bb570de44640cdc4228.tar.zst dexon-solidity-4542f459f165502ed9537bb570de44640cdc4228.zip |
added fix and a test for order independence of nested prefixing
Signed-off-by: VoR0220 <rj@erisindustries.com>
Diffstat (limited to 'libsolidity/interface/CompilerStack.cpp')
-rw-r--r-- | libsolidity/interface/CompilerStack.cpp | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/libsolidity/interface/CompilerStack.cpp b/libsolidity/interface/CompilerStack.cpp index 1e571cae..e4c351ff 100644 --- a/libsolidity/interface/CompilerStack.cpp +++ b/libsolidity/interface/CompilerStack.cpp @@ -523,7 +523,7 @@ string CompilerStack::applyRemapping(string const& _path, string const& _context if (!isPrefixOf(context, _context)) continue; // Skip if we already have a closer prefix match. - if (prefix.length() < longestPrefix) + if (prefix.length() < longestPrefix && context.length() == longestContext) continue; // Skip if the prefix does not match. if (!isPrefixOf(prefix, _path)) @@ -534,7 +534,7 @@ string CompilerStack::applyRemapping(string const& _path, string const& _context bestMatchTarget = redir.target; } - string path = longestPrefixTarget; + string path = bestMatchTarget; path.append(_path.begin() + longestPrefix, _path.end()); return path; } |