aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity
diff options
context:
space:
mode:
authormestorlx <github@martindiz.com.ar>2018-10-12 05:21:49 +0800
committermestorlx <github@martindiz.com.ar>2018-10-13 20:54:07 +0800
commit1ce9566e504f3ce14978a9df5e8b37b74e6f621e (patch)
tree872c5f9562d88aaba4b2dd419af838a72f7e2bc0 /libsolidity
parent26dc876c28718613ad64961e65374ace1139010b (diff)
downloaddexon-solidity-1ce9566e504f3ce14978a9df5e8b37b74e6f621e.tar
dexon-solidity-1ce9566e504f3ce14978a9df5e8b37b74e6f621e.tar.gz
dexon-solidity-1ce9566e504f3ce14978a9df5e8b37b74e6f621e.tar.bz2
dexon-solidity-1ce9566e504f3ce14978a9df5e8b37b74e6f621e.tar.lz
dexon-solidity-1ce9566e504f3ce14978a9df5e8b37b74e6f621e.tar.xz
dexon-solidity-1ce9566e504f3ce14978a9df5e8b37b74e6f621e.tar.zst
dexon-solidity-1ce9566e504f3ce14978a9df5e8b37b74e6f621e.zip
Updated MAXIMUM_STRING_DISTANCE to non static maximumStringDistance taking into account length of the identifier
Diffstat (limited to 'libsolidity')
-rw-r--r--libsolidity/analysis/DeclarationContainer.cpp8
1 files changed, 4 insertions, 4 deletions
diff --git a/libsolidity/analysis/DeclarationContainer.cpp b/libsolidity/analysis/DeclarationContainer.cpp
index 5f980788..cf12a49d 100644
--- a/libsolidity/analysis/DeclarationContainer.cpp
+++ b/libsolidity/analysis/DeclarationContainer.cpp
@@ -137,23 +137,23 @@ vector<Declaration const*> DeclarationContainer::resolveName(ASTString const& _n
vector<ASTString> DeclarationContainer::similarNames(ASTString const& _name) const
{
- static size_t const MAXIMUM_EDIT_DISTANCE = 2;
+
// because the function below has quadratic runtime - it will not magically improve once a better algorithm is discovered ;)
// since 80 is the suggested line length limit, we use 80^2 as length threshold
static size_t const MAXIMUM_LENGTH_THRESHOLD = 80 * 80;
vector<ASTString> similar;
-
+ size_t maximumEditDistance = _name.size() > 3 ? 2 : _name.size() / 2;
for (auto const& declaration: m_declarations)
{
string const& declarationName = declaration.first;
- if (stringWithinDistance(_name, declarationName, MAXIMUM_EDIT_DISTANCE, MAXIMUM_LENGTH_THRESHOLD))
+ if (stringWithinDistance(_name, declarationName, maximumEditDistance, MAXIMUM_LENGTH_THRESHOLD))
similar.push_back(declarationName);
}
for (auto const& declaration: m_invisibleDeclarations)
{
string const& declarationName = declaration.first;
- if (stringWithinDistance(_name, declarationName, MAXIMUM_EDIT_DISTANCE, MAXIMUM_LENGTH_THRESHOLD))
+ if (stringWithinDistance(_name, declarationName, maximumEditDistance, MAXIMUM_LENGTH_THRESHOLD))
similar.push_back(declarationName);
}