From 560e7d618dd1398b67c53787ee1561186a03bbed Mon Sep 17 00:00:00 2001 From: Dmitry-Me Date: Tue, 26 Jul 2016 16:42:17 +0300 Subject: [PATCH] Get rid of "magic" patterns set * magic should match "knownPatterns" but it didn't * two identical sets are of no use --- lib/checkinternal.cpp | 36 +++++++++--------------------------- 1 file changed, 9 insertions(+), 27 deletions(-) diff --git a/lib/checkinternal.cpp b/lib/checkinternal.cpp index 30136da7c..6220750c4 100644 --- a/lib/checkinternal.cpp +++ b/lib/checkinternal.cpp @@ -153,7 +153,7 @@ void CheckInternal::checkTokenSimpleMatchPatterns() } namespace { - const std::set magics = make_container< std::set > () + const std::set knownPatterns = make_container< std::set > () << "%any%" << "%assign%" << "%bool%" @@ -167,6 +167,7 @@ namespace { << "%str%" << "%type%" << "%name%" + << "%var%" << "%varid%"; } @@ -188,17 +189,17 @@ void CheckInternal::checkMissingPercentCharacter() const std::string pattern = patternTok->strValue(); - std::set::const_iterator magic, magics_end = magics.end(); - for (magic = magics.begin(); magic != magics_end; ++magic) { - const std::string broken_magic = (*magic).substr(0, (*magic).size() - 1); + std::set::const_iterator knownPattern, knownPatternsEnd = knownPatterns.end(); + for (knownPattern = knownPatterns.begin(); knownPattern != knownPatternsEnd; ++knownPattern) { + const std::string brokenPattern = (*knownPattern).substr(0, (*knownPattern).size() - 1); std::string::size_type pos = 0; - while ((pos = pattern.find(broken_magic, pos)) != std::string::npos) { + while ((pos = pattern.find(brokenPattern, pos)) != std::string::npos) { // Check if it's the full pattern - if (pattern.find(*magic, pos) != pos) { + if (pattern.find(*knownPattern, pos) != pos) { // Known whitelist of substrings - if ((broken_magic == "%var" && pattern.find("%varid%", pos) == pos) || - (broken_magic == "%or" && pattern.find("%oror%", pos) == pos)) { + if ((brokenPattern == "%var" && pattern.find("%varid%", pos) == pos) || + (brokenPattern == "%or" && pattern.find("%oror%", pos) == pos)) { ++pos; continue; } @@ -213,25 +214,6 @@ void CheckInternal::checkMissingPercentCharacter() } } -namespace { - const std::set knownPatterns = make_container< std::set > () - << "%any%" - << "%assign%" - << "%bool%" - << "%char%" - << "%comp%" - << "%name%" - << "%num%" - << "%op%" - << "%cop%" - << "%or%" - << "%oror%" - << "%str%" - << "%type%" - << "%var%" - << "%varid%"; -} - void CheckInternal::checkUnknownPattern() { const SymbolDatabase *symbolDatabase = _tokenizer->getSymbolDatabase();