Merge pull request #135 from acmyo/gcc346
fix misspellings & gcc v3.4.6 warnings
This commit is contained in:
commit
e18888cd4d
|
@ -220,7 +220,7 @@ unsigned int ThreadExecutor::check()
|
||||||
if (FD_ISSET(*rp, &rfds)) {
|
if (FD_ISSET(*rp, &rfds)) {
|
||||||
int readRes = handleRead(*rp, result);
|
int readRes = handleRead(*rp, result);
|
||||||
if (readRes == -1) {
|
if (readRes == -1) {
|
||||||
long size = 0;
|
std::size_t size = 0;
|
||||||
std::map<int, std::string>::iterator p = pipeFile.find(*rp);
|
std::map<int, std::string>::iterator p = pipeFile.find(*rp);
|
||||||
if (p != pipeFile.end()) {
|
if (p != pipeFile.end()) {
|
||||||
std::string name = p->second;
|
std::string name = p->second;
|
||||||
|
@ -408,7 +408,7 @@ unsigned int __stdcall ThreadExecutor::threadProc(void *args)
|
||||||
|
|
||||||
}
|
}
|
||||||
const std::string &file = it->first;
|
const std::string &file = it->first;
|
||||||
const int fileSize = it->second;
|
const std::size_t fileSize = it->second;
|
||||||
it++;
|
it++;
|
||||||
|
|
||||||
LeaveCriticalSection(&threadExecutor->_fileSync);
|
LeaveCriticalSection(&threadExecutor->_fileSync);
|
||||||
|
|
|
@ -27,7 +27,7 @@
|
||||||
static const char ProjectElementName[] = "project";
|
static const char ProjectElementName[] = "project";
|
||||||
static const char ProjectVersionAttrib[] = "version";
|
static const char ProjectVersionAttrib[] = "version";
|
||||||
static const char ProjectFileVersion[] = "1";
|
static const char ProjectFileVersion[] = "1";
|
||||||
static const char IncludDirElementName[] = "includedir";
|
static const char IncludeDirElementName[] = "includedir";
|
||||||
static const char DirElementName[] = "dir";
|
static const char DirElementName[] = "dir";
|
||||||
static const char DirNameAttrib[] = "name";
|
static const char DirNameAttrib[] = "name";
|
||||||
static const char DefinesElementName[] = "defines";
|
static const char DefinesElementName[] = "defines";
|
||||||
|
@ -84,7 +84,7 @@ bool ProjectFile::Read(const QString &filename)
|
||||||
ReadCheckPaths(xmlReader);
|
ReadCheckPaths(xmlReader);
|
||||||
|
|
||||||
// Find include directory from inside project element
|
// Find include directory from inside project element
|
||||||
if (insideProject && xmlReader.name() == IncludDirElementName)
|
if (insideProject && xmlReader.name() == IncludeDirElementName)
|
||||||
ReadIncludeDirs(xmlReader);
|
ReadIncludeDirs(xmlReader);
|
||||||
|
|
||||||
// Find preprocessor define from inside project element
|
// Find preprocessor define from inside project element
|
||||||
|
@ -187,7 +187,7 @@ void ProjectFile::ReadIncludeDirs(QXmlStreamReader &reader)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case QXmlStreamReader::EndElement:
|
case QXmlStreamReader::EndElement:
|
||||||
if (reader.name().toString() == IncludDirElementName)
|
if (reader.name().toString() == IncludeDirElementName)
|
||||||
allRead = true;
|
allRead = true;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -369,7 +369,7 @@ bool ProjectFile::Write(const QString &filename)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!mIncludeDirs.isEmpty()) {
|
if (!mIncludeDirs.isEmpty()) {
|
||||||
xmlWriter.writeStartElement(IncludDirElementName);
|
xmlWriter.writeStartElement(IncludeDirElementName);
|
||||||
foreach(QString incdir, mIncludeDirs) {
|
foreach(QString incdir, mIncludeDirs) {
|
||||||
xmlWriter.writeStartElement(DirElementName);
|
xmlWriter.writeStartElement(DirElementName);
|
||||||
xmlWriter.writeAttribute(DirNameAttrib, incdir);
|
xmlWriter.writeAttribute(DirNameAttrib, incdir);
|
||||||
|
|
|
@ -218,7 +218,7 @@ public:
|
||||||
/**
|
/**
|
||||||
* @brief %Check if there is a "!var" match inside a condition
|
* @brief %Check if there is a "!var" match inside a condition
|
||||||
* @param tok first token to match
|
* @param tok first token to match
|
||||||
* @param varid variabla id
|
* @param varid variable id
|
||||||
* @param endpar if this is true the "!var" must be followed by ")"
|
* @param endpar if this is true the "!var" must be followed by ")"
|
||||||
* @return true if match
|
* @return true if match
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -246,7 +246,7 @@ void CheckOther::clarifyConditionError(const Token *tok, bool assign, bool boolo
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
// Clarify (meaningless) statements like *foo++; with parantheses.
|
// Clarify (meaningless) statements like *foo++; with parentheses.
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
void CheckOther::clarifyStatement()
|
void CheckOther::clarifyStatement()
|
||||||
{
|
{
|
||||||
|
@ -1933,8 +1933,8 @@ void CheckOther::lookupVar(const Token *tok, const Variable* var)
|
||||||
tok = tok->next();
|
tok = tok->next();
|
||||||
|
|
||||||
// Check if the variable is used in this indentlevel..
|
// Check if the variable is used in this indentlevel..
|
||||||
bool used1 = false; // used in one sub-scope -> reducable
|
bool used1 = false; // used in one sub-scope -> reducible
|
||||||
bool used2 = false; // used in more sub-scopes -> not reducable
|
bool used2 = false; // used in more sub-scopes -> not reducible
|
||||||
unsigned int indentlevel = 0;
|
unsigned int indentlevel = 0;
|
||||||
int parlevel = 0;
|
int parlevel = 0;
|
||||||
bool for_or_while = false; // is sub-scope a "for/while/etc". anything that is not "if"
|
bool for_or_while = false; // is sub-scope a "for/while/etc". anything that is not "if"
|
||||||
|
|
|
@ -119,7 +119,7 @@ public:
|
||||||
checkOther.checkSuspiciousEqualityComparison();
|
checkOther.checkSuspiciousEqualityComparison();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** To check the dead code in a program, which is unaccessible due to the counter-conditions check in nested-if statements **/
|
/** To check the dead code in a program, which is inaccessible due to the counter-conditions check in nested-if statements **/
|
||||||
void oppositeInnerCondition();
|
void oppositeInnerCondition();
|
||||||
|
|
||||||
/** @brief Clarify calculation for ".. a * b ? .." */
|
/** @brief Clarify calculation for ".. a * b ? .." */
|
||||||
|
@ -183,7 +183,7 @@ public:
|
||||||
/** @brief %Check for suspicious calculations with sizeof results */
|
/** @brief %Check for suspicious calculations with sizeof results */
|
||||||
void suspiciousSizeofCalculation();
|
void suspiciousSizeofCalculation();
|
||||||
|
|
||||||
/** @brief copying to memory or assigning to a variablen twice */
|
/** @brief copying to memory or assigning to a variable twice */
|
||||||
void checkRedundantAssignment();
|
void checkRedundantAssignment();
|
||||||
|
|
||||||
/** @brief %Check for assigning to the same variable twice in a switch statement*/
|
/** @brief %Check for assigning to the same variable twice in a switch statement*/
|
||||||
|
@ -470,7 +470,7 @@ private:
|
||||||
"* subsequent assignment or copying to a variable or buffer\n"
|
"* subsequent assignment or copying to a variable or buffer\n"
|
||||||
|
|
||||||
// style
|
// style
|
||||||
"* Find dead code which is unaccessible due to the counter-conditions check in nested if statements\n"
|
"* Find dead code which is inaccessible due to the counter-conditions check in nested if statements\n"
|
||||||
"* C-style pointer cast in cpp file\n"
|
"* C-style pointer cast in cpp file\n"
|
||||||
"* casting between incompatible pointer types\n"
|
"* casting between incompatible pointer types\n"
|
||||||
"* redundant if\n"
|
"* redundant if\n"
|
||||||
|
@ -481,7 +481,7 @@ private:
|
||||||
"* [[charvar|check how signed char variables are used]]\n"
|
"* [[charvar|check how signed char variables are used]]\n"
|
||||||
"* variable scope can be limited\n"
|
"* variable scope can be limited\n"
|
||||||
"* condition that is always true/false\n"
|
"* condition that is always true/false\n"
|
||||||
"* unusal pointer arithmetic. For example: \"abc\" + 'd'\n"
|
"* unusual pointer arithmetic. For example: \"abc\" + 'd'\n"
|
||||||
"* redundant assignment in a switch statement\n"
|
"* redundant assignment in a switch statement\n"
|
||||||
"* redundant pre/post operation in a switch statement\n"
|
"* redundant pre/post operation in a switch statement\n"
|
||||||
"* redundant bitwise operation in a switch statement\n"
|
"* redundant bitwise operation in a switch statement\n"
|
||||||
|
|
|
@ -705,7 +705,7 @@ void CheckStl::invalidPointerError(const Token *tok, const std::string &func, co
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void CheckStl::stlBoundries()
|
void CheckStl::stlBoundaries()
|
||||||
{
|
{
|
||||||
const SymbolDatabase* const symbolDatabase = _tokenizer->getSymbolDatabase();
|
const SymbolDatabase* const symbolDatabase = _tokenizer->getSymbolDatabase();
|
||||||
const std::size_t functions = symbolDatabase->functionScopes.size();
|
const std::size_t functions = symbolDatabase->functionScopes.size();
|
||||||
|
@ -729,9 +729,9 @@ void CheckStl::stlBoundries()
|
||||||
const Token* const end = tok->scope()->classEnd;
|
const Token* const end = tok->scope()->classEnd;
|
||||||
for (const Token *tok2 = tok; tok2 != end; tok2 = tok2->next()) {
|
for (const Token *tok2 = tok; tok2 != end; tok2 = tok2->next()) {
|
||||||
if (Token::Match(tok2, "!!* %varid% <", iteratorid)) {
|
if (Token::Match(tok2, "!!* %varid% <", iteratorid)) {
|
||||||
stlBoundriesError(tok2, container_name);
|
stlBoundariesError(tok2, container_name);
|
||||||
} else if (Token::Match(tok2, "> %varid% !!.", iteratorid)) {
|
} else if (Token::Match(tok2, "> %varid% !!.", iteratorid)) {
|
||||||
stlBoundriesError(tok2, container_name);
|
stlBoundariesError(tok2, container_name);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -741,9 +741,9 @@ void CheckStl::stlBoundries()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Error message for bad boundary usage..
|
// Error message for bad boundary usage..
|
||||||
void CheckStl::stlBoundriesError(const Token *tok, const std::string &container_name)
|
void CheckStl::stlBoundariesError(const Token *tok, const std::string &container_name)
|
||||||
{
|
{
|
||||||
reportError(tok, Severity::error, "stlBoundries",
|
reportError(tok, Severity::error, "stlBoundaries",
|
||||||
"Dangerous iterator comparison using operator< on 'std::" + container_name + "'.\n"
|
"Dangerous iterator comparison using operator< on 'std::" + container_name + "'.\n"
|
||||||
"Iterator of container 'std::" + container_name + "' compared with operator<. "
|
"Iterator of container 'std::" + container_name + "' compared with operator<. "
|
||||||
"This is dangerous since the order of items in the container is not guaranteed. "
|
"This is dangerous since the order of items in the container is not guaranteed. "
|
||||||
|
@ -885,7 +885,7 @@ void CheckStl::if_findError(const Token *tok, bool str)
|
||||||
if (str)
|
if (str)
|
||||||
reportError(tok, Severity::performance, "stlIfStrFind",
|
reportError(tok, Severity::performance, "stlIfStrFind",
|
||||||
"Inefficient usage of string::find() in condition; string::compare() would be faster.\n"
|
"Inefficient usage of string::find() in condition; string::compare() would be faster.\n"
|
||||||
"Either inefficent or wrong usage of string::find(). string::compare() will be faster if "
|
"Either inefficient or wrong usage of string::find(). string::compare() will be faster if "
|
||||||
"string::find's result is compared with 0, because it will not scan the whole "
|
"string::find's result is compared with 0, because it will not scan the whole "
|
||||||
"string. If your intention is to check that there are no findings in the string, "
|
"string. If your intention is to check that there are no findings in the string, "
|
||||||
"you should compare with std::string::npos.");
|
"you should compare with std::string::npos.");
|
||||||
|
|
|
@ -55,7 +55,7 @@ public:
|
||||||
checkStl.mismatchingContainers();
|
checkStl.mismatchingContainers();
|
||||||
checkStl.erase();
|
checkStl.erase();
|
||||||
checkStl.pushback();
|
checkStl.pushback();
|
||||||
checkStl.stlBoundries();
|
checkStl.stlBoundaries();
|
||||||
checkStl.if_find();
|
checkStl.if_find();
|
||||||
checkStl.string_c_str();
|
checkStl.string_c_str();
|
||||||
checkStl.checkAutoPointer();
|
checkStl.checkAutoPointer();
|
||||||
|
@ -101,7 +101,7 @@ public:
|
||||||
/**
|
/**
|
||||||
* bad condition.. "it < alist.end()"
|
* bad condition.. "it < alist.end()"
|
||||||
*/
|
*/
|
||||||
void stlBoundries();
|
void stlBoundaries();
|
||||||
|
|
||||||
/** if (a.find(x)) - possibly incorrect condition */
|
/** if (a.find(x)) - possibly incorrect condition */
|
||||||
void if_find();
|
void if_find();
|
||||||
|
@ -164,7 +164,7 @@ private:
|
||||||
void mismatchingContainersError(const Token *tok);
|
void mismatchingContainersError(const Token *tok);
|
||||||
void invalidIteratorError(const Token *tok, const std::string &func, const std::string &iterator_name);
|
void invalidIteratorError(const Token *tok, const std::string &func, const std::string &iterator_name);
|
||||||
void invalidPointerError(const Token *tok, const std::string &func, const std::string &pointer_name);
|
void invalidPointerError(const Token *tok, const std::string &func, const std::string &pointer_name);
|
||||||
void stlBoundriesError(const Token *tok, const std::string &container_name);
|
void stlBoundariesError(const Token *tok, const std::string &container_name);
|
||||||
void if_findError(const Token *tok, bool str);
|
void if_findError(const Token *tok, bool str);
|
||||||
void sizeError(const Token *tok);
|
void sizeError(const Token *tok);
|
||||||
void redundantIfRemoveError(const Token *tok);
|
void redundantIfRemoveError(const Token *tok);
|
||||||
|
@ -188,7 +188,7 @@ private:
|
||||||
c.stlOutOfBoundsError(0, "i", "foo", false);
|
c.stlOutOfBoundsError(0, "i", "foo", false);
|
||||||
c.invalidIteratorError(0, "push_back|push_front|insert", "iterator");
|
c.invalidIteratorError(0, "push_back|push_front|insert", "iterator");
|
||||||
c.invalidPointerError(0, "push_back", "pointer");
|
c.invalidPointerError(0, "push_back", "pointer");
|
||||||
c.stlBoundriesError(0, "container");
|
c.stlBoundariesError(0, "container");
|
||||||
c.if_findError(0, false);
|
c.if_findError(0, false);
|
||||||
c.if_findError(0, true);
|
c.if_findError(0, true);
|
||||||
c.string_c_strError(0);
|
c.string_c_strError(0);
|
||||||
|
|
|
@ -1923,14 +1923,14 @@ std::string Preprocessor::handleIncludes(const std::string &code, const std::str
|
||||||
const std::string path(filePath.substr(0, 1 + filePath.find_last_of("\\/")));
|
const std::string path(filePath.substr(0, 1 + filePath.find_last_of("\\/")));
|
||||||
|
|
||||||
// current #if indent level.
|
// current #if indent level.
|
||||||
unsigned int indent = 0;
|
std::stack<bool>::size_type indent = 0;
|
||||||
|
|
||||||
// how deep does the #if match? this can never be bigger than "indent".
|
// how deep does the #if match? this can never be bigger than "indent".
|
||||||
unsigned int indentmatch = 0;
|
std::stack<bool>::size_type indentmatch = 0;
|
||||||
|
|
||||||
// has there been a true #if condition at the current indentmatch level?
|
// has there been a true #if condition at the current indentmatch level?
|
||||||
// then no more #elif or #else can be true before the #endif is seen.
|
// then no more #elif or #else can be true before the #endif is seen.
|
||||||
std::vector<bool> elseIsTrueStack;
|
std::stack<bool> elseIsTrueStack;
|
||||||
|
|
||||||
unsigned int linenr = 0;
|
unsigned int linenr = 0;
|
||||||
|
|
||||||
|
@ -1951,8 +1951,15 @@ std::string Preprocessor::handleIncludes(const std::string &code, const std::str
|
||||||
|
|
||||||
// has there been a true #if condition at the current indentmatch level?
|
// has there been a true #if condition at the current indentmatch level?
|
||||||
// then no more #elif or #else can be true before the #endif is seen.
|
// then no more #elif or #else can be true before the #endif is seen.
|
||||||
elseIsTrueStack.resize(1U + indentmatch, true);
|
while (elseIsTrueStack.size() != indentmatch + 1) {
|
||||||
std::vector<bool>::reference elseIsTrue = elseIsTrueStack[indentmatch];
|
if (elseIsTrueStack.size() < indentmatch + 1) {
|
||||||
|
elseIsTrueStack.push(true);
|
||||||
|
} else {
|
||||||
|
elseIsTrueStack.pop();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
std::stack<bool>::reference elseIsTrue = elseIsTrueStack.top();
|
||||||
|
|
||||||
if (line.compare(0,7,"#ifdef ") == 0) {
|
if (line.compare(0,7,"#ifdef ") == 0) {
|
||||||
if (indent == indentmatch) {
|
if (indent == indentmatch) {
|
||||||
|
|
|
@ -62,7 +62,7 @@ public:
|
||||||
* @param istr The (file/string) stream to read from.
|
* @param istr The (file/string) stream to read from.
|
||||||
* @param result The map that will get the results
|
* @param result The map that will get the results
|
||||||
* @param filename The name of the file to check e.g. "src/main.cpp"
|
* @param filename The name of the file to check e.g. "src/main.cpp"
|
||||||
* @param includePaths List of paths where incude files should be searched from,
|
* @param includePaths List of paths where include files should be searched from,
|
||||||
* single path can be e.g. in format "include/".
|
* single path can be e.g. in format "include/".
|
||||||
* There must be a path separator at the end. Default parameter is empty list.
|
* There must be a path separator at the end. Default parameter is empty list.
|
||||||
* Note that if path from given filename is also extracted and that is used as
|
* Note that if path from given filename is also extracted and that is used as
|
||||||
|
@ -81,7 +81,7 @@ public:
|
||||||
* @param resultConfigurations List of configurations. Pass these one by one
|
* @param resultConfigurations List of configurations. Pass these one by one
|
||||||
* to getcode() with processedFile.
|
* to getcode() with processedFile.
|
||||||
* @param filename The name of the file to check e.g. "src/main.cpp"
|
* @param filename The name of the file to check e.g. "src/main.cpp"
|
||||||
* @param includePaths List of paths where incude files should be searched from,
|
* @param includePaths List of paths where include files should be searched from,
|
||||||
* single path can be e.g. in format "include/".
|
* single path can be e.g. in format "include/".
|
||||||
* There must be a path separator at the end. Default parameter is empty list.
|
* There must be a path separator at the end. Default parameter is empty list.
|
||||||
* Note that if path from given filename is also extracted and that is used as
|
* Note that if path from given filename is also extracted and that is used as
|
||||||
|
@ -253,7 +253,7 @@ private:
|
||||||
* file
|
* file
|
||||||
* @param code The source code to modify
|
* @param code The source code to modify
|
||||||
* @param filePath Relative path to file to check e.g. "src/main.cpp"
|
* @param filePath Relative path to file to check e.g. "src/main.cpp"
|
||||||
* @param includePaths List of paths where incude files should be searched from,
|
* @param includePaths List of paths where include files should be searched from,
|
||||||
* single path can be e.g. in format "include/".
|
* single path can be e.g. in format "include/".
|
||||||
* There must be a path separator at the end. Default parameter is empty list.
|
* There must be a path separator at the end. Default parameter is empty list.
|
||||||
* Note that if path from given filename is also extracted and that is used as
|
* Note that if path from given filename is also extracted and that is used as
|
||||||
|
|
|
@ -139,7 +139,7 @@ bool Suppressions::FileMatcher::match(const std::string &pattern, const std::str
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// If there are no other paths to tray, then fail
|
// If there are no other paths to try, then fail
|
||||||
if (backtrack.empty()) {
|
if (backtrack.empty()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -223,8 +223,13 @@ std::string Suppressions::addSuppression(const std::string &errorId, const std::
|
||||||
return "Failed to add suppression. No id.";
|
return "Failed to add suppression. No id.";
|
||||||
}
|
}
|
||||||
if (errorId != "*") {
|
if (errorId != "*") {
|
||||||
|
// Support "stlBoundries", as that was the name of the errorId until v1.59.
|
||||||
|
if (errorId == "stlBoundries") {
|
||||||
|
return _suppressions["stlBoundaries"].addFile(file, line);
|
||||||
|
}
|
||||||
|
|
||||||
for (std::string::size_type pos = 0; pos < errorId.length(); ++pos) {
|
for (std::string::size_type pos = 0; pos < errorId.length(); ++pos) {
|
||||||
if (errorId[pos] < 0 || (!std::isalnum(errorId[pos]) && errorId[pos] != '_')) {
|
if (errorId[pos] < 0 || (!std::isalnum(errorId[pos]) && errorId[pos] != '_')) {
|
||||||
return "Failed to add suppression. Invalid id \"" + errorId + "\"";
|
return "Failed to add suppression. Invalid id \"" + errorId + "\"";
|
||||||
}
|
}
|
||||||
if (pos == 0 && std::isdigit(errorId[pos])) {
|
if (pos == 0 && std::isdigit(errorId[pos])) {
|
||||||
|
|
|
@ -91,7 +91,7 @@ public:
|
||||||
std::string addSuppressionLine(const std::string &line);
|
std::string addSuppressionLine(const std::string &line);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Don't show this error. If file and/or line are optional. In which case
|
* @brief Don't show this error. File and/or line are optional. In which case
|
||||||
* the errorId alone is used for filtering.
|
* the errorId alone is used for filtering.
|
||||||
* @param errorId the id for the error, e.g. "arrayIndexOutOfBounds"
|
* @param errorId the id for the error, e.g. "arrayIndexOutOfBounds"
|
||||||
* @param file File name with the path, e.g. "src/main.cpp"
|
* @param file File name with the path, e.g. "src/main.cpp"
|
||||||
|
|
|
@ -50,7 +50,7 @@ struct Dimension {
|
||||||
|
|
||||||
const Token *start; // size start token
|
const Token *start; // size start token
|
||||||
const Token *end; // size end token
|
const Token *end; // size end token
|
||||||
MathLib::bigint num; // (assumpted) dimension length when size is a number, 0 if not known
|
MathLib::bigint num; // (assumed) dimension length when size is a number, 0 if not known
|
||||||
bool known; // Known size
|
bool known; // Known size
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -162,7 +162,7 @@ public:
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get index of variable in declared order.
|
* Get index of variable in declared order.
|
||||||
* @return varaible index
|
* @return variable index
|
||||||
*/
|
*/
|
||||||
std::size_t index() const {
|
std::size_t index() const {
|
||||||
return _index;
|
return _index;
|
||||||
|
|
|
@ -589,7 +589,7 @@ void TemplateSimplifier::expandTemplate(
|
||||||
const std::string &name,
|
const std::string &name,
|
||||||
std::vector<const Token *> &typeParametersInDeclaration,
|
std::vector<const Token *> &typeParametersInDeclaration,
|
||||||
const std::string &newName,
|
const std::string &newName,
|
||||||
std::vector<const Token *> &typesUsedInTemplateInstantion,
|
std::vector<const Token *> &typesUsedInTemplateInstantiation,
|
||||||
std::list<Token *> &templateInstantiations)
|
std::list<Token *> &templateInstantiations)
|
||||||
{
|
{
|
||||||
for (const Token *tok3 = tokenlist.front(); tok3; tok3 = tok3->next()) {
|
for (const Token *tok3 = tokenlist.front(); tok3; tok3 = tok3->next()) {
|
||||||
|
@ -624,7 +624,7 @@ void TemplateSimplifier::expandTemplate(
|
||||||
|
|
||||||
// replace type with given type..
|
// replace type with given type..
|
||||||
if (itype < typeParametersInDeclaration.size()) {
|
if (itype < typeParametersInDeclaration.size()) {
|
||||||
for (const Token *typetok = typesUsedInTemplateInstantion[itype];
|
for (const Token *typetok = typesUsedInTemplateInstantiation[itype];
|
||||||
typetok && !Token::Match(typetok, "[,>]");
|
typetok && !Token::Match(typetok, "[,>]");
|
||||||
typetok = typetok->next()) {
|
typetok = typetok->next()) {
|
||||||
tokenlist.addtoken(typetok, tok3->linenr(), tok3->fileIndex());
|
tokenlist.addtoken(typetok, tok3->linenr(), tok3->fileIndex());
|
||||||
|
@ -965,7 +965,7 @@ bool TemplateSimplifier::simplifyCalculations(Token *_tokens)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool TemplateSimplifier::simplifyTemplateInstantions(
|
bool TemplateSimplifier::simplifyTemplateInstantiations(
|
||||||
TokenList& tokenlist,
|
TokenList& tokenlist,
|
||||||
ErrorLogger& errorlogger,
|
ErrorLogger& errorlogger,
|
||||||
const Settings *_settings,
|
const Settings *_settings,
|
||||||
|
@ -1030,7 +1030,7 @@ bool TemplateSimplifier::simplifyTemplateInstantions(
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
// New type..
|
// New type..
|
||||||
std::vector<const Token *> typesUsedInTemplateInstantion;
|
std::vector<const Token *> typesUsedInTemplateInstantiation;
|
||||||
std::string typeForNewNameStr;
|
std::string typeForNewNameStr;
|
||||||
std::string templateMatchPattern(name + " < ");
|
std::string templateMatchPattern(name + " < ");
|
||||||
unsigned int indentlevel = 0;
|
unsigned int indentlevel = 0;
|
||||||
|
@ -1052,7 +1052,7 @@ bool TemplateSimplifier::simplifyTemplateInstantions(
|
||||||
templateMatchPattern += tok3->str();
|
templateMatchPattern += tok3->str();
|
||||||
templateMatchPattern += " ";
|
templateMatchPattern += " ";
|
||||||
if (indentlevel == 0 && Token::Match(tok3->previous(), "[<,]"))
|
if (indentlevel == 0 && Token::Match(tok3->previous(), "[<,]"))
|
||||||
typesUsedInTemplateInstantion.push_back(tok3);
|
typesUsedInTemplateInstantiation.push_back(tok3);
|
||||||
// add additional type information
|
// add additional type information
|
||||||
if (tok3->isUnsigned())
|
if (tok3->isUnsigned())
|
||||||
typeForNewNameStr += "unsigned";
|
typeForNewNameStr += "unsigned";
|
||||||
|
@ -1065,7 +1065,7 @@ bool TemplateSimplifier::simplifyTemplateInstantions(
|
||||||
templateMatchPattern += ">";
|
templateMatchPattern += ">";
|
||||||
const std::string typeForNewName(typeForNewNameStr);
|
const std::string typeForNewName(typeForNewNameStr);
|
||||||
|
|
||||||
if (typeForNewName.empty() || typeParametersInDeclaration.size() != typesUsedInTemplateInstantion.size()) {
|
if (typeForNewName.empty() || typeParametersInDeclaration.size() != typesUsedInTemplateInstantiation.size()) {
|
||||||
if (_settings->debugwarnings) {
|
if (_settings->debugwarnings) {
|
||||||
std::list<const Token *> callstack(1, tok);
|
std::list<const Token *> callstack(1, tok);
|
||||||
errorlogger.reportErr(ErrorLogger::ErrorMessage(callstack, &tokenlist, Severity::debug, "debg",
|
errorlogger.reportErr(ErrorLogger::ErrorMessage(callstack, &tokenlist, Severity::debug, "debg",
|
||||||
|
@ -1081,7 +1081,7 @@ bool TemplateSimplifier::simplifyTemplateInstantions(
|
||||||
|
|
||||||
if (expandedtemplates.find(newName) == expandedtemplates.end()) {
|
if (expandedtemplates.find(newName) == expandedtemplates.end()) {
|
||||||
expandedtemplates.insert(newName);
|
expandedtemplates.insert(newName);
|
||||||
TemplateSimplifier::expandTemplate(tokenlist, tok,name,typeParametersInDeclaration,newName,typesUsedInTemplateInstantion,templateInstantiations);
|
TemplateSimplifier::expandTemplate(tokenlist, tok,name,typeParametersInDeclaration,newName,typesUsedInTemplateInstantiation,templateInstantiations);
|
||||||
instantiated = true;
|
instantiated = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1090,8 +1090,8 @@ bool TemplateSimplifier::simplifyTemplateInstantions(
|
||||||
for (Token *tok4 = tok2; tok4; tok4 = tok4->next()) {
|
for (Token *tok4 = tok2; tok4; tok4 = tok4->next()) {
|
||||||
if (Token::simpleMatch(tok4, templateMatchPattern.c_str())) {
|
if (Token::simpleMatch(tok4, templateMatchPattern.c_str())) {
|
||||||
Token * tok5 = tok4->tokAt(2);
|
Token * tok5 = tok4->tokAt(2);
|
||||||
unsigned int typeCountInInstantion = 1U; // There is always at least one type
|
unsigned int typeCountInInstantiation = 1U; // There is always at least one type
|
||||||
const Token *typetok = (!typesUsedInTemplateInstantion.empty()) ? typesUsedInTemplateInstantion[0] : 0;
|
const Token *typetok = (!typesUsedInTemplateInstantiation.empty()) ? typesUsedInTemplateInstantiation[0] : 0;
|
||||||
unsigned int indentlevel5 = 0; // indentlevel for tok5
|
unsigned int indentlevel5 = 0; // indentlevel for tok5
|
||||||
while (tok5 && (indentlevel5 > 0 || tok5->str() != ">")) {
|
while (tok5 && (indentlevel5 > 0 || tok5->str() != ">")) {
|
||||||
if (tok5->str() == "<" && templateParameters(tok5) > 0)
|
if (tok5->str() == "<" && templateParameters(tok5) > 0)
|
||||||
|
@ -1109,8 +1109,8 @@ bool TemplateSimplifier::simplifyTemplateInstantions(
|
||||||
|
|
||||||
typetok = typetok ? typetok->next() : 0;
|
typetok = typetok ? typetok->next() : 0;
|
||||||
} else {
|
} else {
|
||||||
typetok = (typeCountInInstantion < typesUsedInTemplateInstantion.size()) ? typesUsedInTemplateInstantion[typeCountInInstantion] : 0;
|
typetok = (typeCountInInstantiation < typesUsedInTemplateInstantiation.size()) ? typesUsedInTemplateInstantiation[typeCountInInstantiation] : 0;
|
||||||
++typeCountInInstantion;
|
++typeCountInInstantiation;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
tok5 = tok5->next();
|
tok5 = tok5->next();
|
||||||
|
@ -1118,7 +1118,7 @@ bool TemplateSimplifier::simplifyTemplateInstantions(
|
||||||
|
|
||||||
// matching template usage => replace tokens..
|
// matching template usage => replace tokens..
|
||||||
// Foo < int > => Foo<int>
|
// Foo < int > => Foo<int>
|
||||||
if (tok5 && tok5->str() == ">" && typeCountInInstantion == typesUsedInTemplateInstantion.size()) {
|
if (tok5 && tok5->str() == ">" && typeCountInInstantiation == typesUsedInTemplateInstantiation.size()) {
|
||||||
tok4->str(newName);
|
tok4->str(newName);
|
||||||
for (Token *tok6 = tok4->next(); tok6 != tok5; tok6 = tok6->next()) {
|
for (Token *tok6 = tok4->next(); tok6 != tok5; tok6 = tok6->next()) {
|
||||||
if (tok6->isName())
|
if (tok6->isName())
|
||||||
|
@ -1191,7 +1191,7 @@ void TemplateSimplifier::simplifyTemplates(
|
||||||
//done = true;
|
//done = true;
|
||||||
std::list<Token *> templates2;
|
std::list<Token *> templates2;
|
||||||
for (std::list<Token *>::reverse_iterator iter1 = templates.rbegin(); iter1 != templates.rend(); ++iter1) {
|
for (std::list<Token *>::reverse_iterator iter1 = templates.rbegin(); iter1 != templates.rend(); ++iter1) {
|
||||||
bool instantiated = TemplateSimplifier::simplifyTemplateInstantions(tokenlist,
|
bool instantiated = TemplateSimplifier::simplifyTemplateInstantiations(tokenlist,
|
||||||
errorlogger,
|
errorlogger,
|
||||||
_settings,
|
_settings,
|
||||||
*iter1,
|
*iter1,
|
||||||
|
|
|
@ -114,11 +114,11 @@ public:
|
||||||
const std::string &name,
|
const std::string &name,
|
||||||
std::vector<const Token *> &typeParametersInDeclaration,
|
std::vector<const Token *> &typeParametersInDeclaration,
|
||||||
const std::string &newName,
|
const std::string &newName,
|
||||||
std::vector<const Token *> &typesUsedInTemplateInstantion,
|
std::vector<const Token *> &typesUsedInTemplateInstantiation,
|
||||||
std::list<Token *> &templateInstantiations);
|
std::list<Token *> &templateInstantiations);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Simplify templates : expand all instantiatiations for a template
|
* Simplify templates : expand all instantiations for a template
|
||||||
* @todo It seems that inner templates should be instantiated recursively
|
* @todo It seems that inner templates should be instantiated recursively
|
||||||
* @param tokenlist token list
|
* @param tokenlist token list
|
||||||
* @param errorlogger error logger
|
* @param errorlogger error logger
|
||||||
|
@ -128,7 +128,7 @@ public:
|
||||||
* @param expandedtemplates all templates that has been expanded so far. The full names are stored.
|
* @param expandedtemplates all templates that has been expanded so far. The full names are stored.
|
||||||
* @return true if the template was instantiated
|
* @return true if the template was instantiated
|
||||||
*/
|
*/
|
||||||
static bool simplifyTemplateInstantions(
|
static bool simplifyTemplateInstantiations(
|
||||||
TokenList& tokenlist,
|
TokenList& tokenlist,
|
||||||
ErrorLogger& errorlogger,
|
ErrorLogger& errorlogger,
|
||||||
const Settings *_settings,
|
const Settings *_settings,
|
||||||
|
@ -159,7 +159,7 @@ public:
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Simplify constant calculations such as "1+2" => "3".
|
* Simplify constant calculations such as "1+2" => "3".
|
||||||
* This also perform simple cleanup of parantheses etc.
|
* This also performs simple cleanup of parentheses etc.
|
||||||
* @param _tokens start token
|
* @param _tokens start token
|
||||||
* @return true if modifications to token-list are done.
|
* @return true if modifications to token-list are done.
|
||||||
* false if no modifications are done.
|
* false if no modifications are done.
|
||||||
|
|
|
@ -980,7 +980,7 @@ std::string Token::stringifyList(bool varid, bool attributes, bool linenumbers,
|
||||||
std::ostringstream ret;
|
std::ostringstream ret;
|
||||||
|
|
||||||
unsigned int lineNumber = _linenr;
|
unsigned int lineNumber = _linenr;
|
||||||
int fileInd = files?-1:_fileIndex;
|
int fileInd = files ? -1 : static_cast<int>(_fileIndex);
|
||||||
std::map<int, unsigned int> lineNumbers;
|
std::map<int, unsigned int> lineNumbers;
|
||||||
for (const Token *tok = this; tok != end; tok = tok->next()) {
|
for (const Token *tok = this; tok != end; tok = tok->next()) {
|
||||||
bool fileChange = false;
|
bool fileChange = false;
|
||||||
|
|
|
@ -411,7 +411,7 @@ private:
|
||||||
ASSERT_EQUALS(Settings::C, settings.enforcedLang);
|
ASSERT_EQUALS(Settings::C, settings.enforcedLang);
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
const char *argv[] = {"cppcheck", "--language=unknwonLanguage", "file.cpp"};
|
const char *argv[] = {"cppcheck", "--language=unknownLanguage", "file.cpp"};
|
||||||
Settings settings;
|
Settings settings;
|
||||||
CmdLineParser parser(&settings);
|
CmdLineParser parser(&settings);
|
||||||
ASSERT(!parser.ParseFromArgs(3, argv));
|
ASSERT(!parser.ParseFromArgs(3, argv));
|
||||||
|
|
|
@ -3072,7 +3072,7 @@ private:
|
||||||
}
|
}
|
||||||
|
|
||||||
void testMisusedScopeObjectDoesNotPickConstructorDeclaration() {
|
void testMisusedScopeObjectDoesNotPickConstructorDeclaration() {
|
||||||
check("class Something : public SomthingElse\n"
|
check("class Something : public SomethingElse\n"
|
||||||
"{\n"
|
"{\n"
|
||||||
"public:\n"
|
"public:\n"
|
||||||
"~Something ( ) ;\n"
|
"~Something ( ) ;\n"
|
||||||
|
|
|
@ -2412,7 +2412,7 @@ private:
|
||||||
}
|
}
|
||||||
|
|
||||||
void templateParameters1() {
|
void templateParameters1() {
|
||||||
// #4169 - semgentation fault (invalid code)
|
// #4169 - segmentation fault (invalid code)
|
||||||
const char code[] = "volatile true , test < test < #ifdef __ppc__ true ,";
|
const char code[] = "volatile true , test < test < #ifdef __ppc__ true ,";
|
||||||
// do not crash on invalid code
|
// do not crash on invalid code
|
||||||
ASSERT_EQUALS(0, templateParameters(code));
|
ASSERT_EQUALS(0, templateParameters(code));
|
||||||
|
|
|
@ -89,10 +89,10 @@ private:
|
||||||
|
|
||||||
TEST_CASE(invalidcode);
|
TEST_CASE(invalidcode);
|
||||||
|
|
||||||
TEST_CASE(stlBoundries1);
|
TEST_CASE(stlBoundaries1);
|
||||||
TEST_CASE(stlBoundries2);
|
TEST_CASE(stlBoundaries2);
|
||||||
TEST_CASE(stlBoundries3);
|
TEST_CASE(stlBoundaries3);
|
||||||
TEST_CASE(stlBoundries4); // #4364
|
TEST_CASE(stlBoundaries4); // #4364
|
||||||
|
|
||||||
// if (str.find("ab"))
|
// if (str.find("ab"))
|
||||||
TEST_CASE(if_find);
|
TEST_CASE(if_find);
|
||||||
|
@ -1200,7 +1200,7 @@ private:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void stlBoundries1() {
|
void stlBoundaries1() {
|
||||||
const int STL_CONTAINER_LIST = 9;
|
const int STL_CONTAINER_LIST = 9;
|
||||||
const std::string stlCont[STL_CONTAINER_LIST] = {
|
const std::string stlCont[STL_CONTAINER_LIST] = {
|
||||||
"deque", "list", "set", "multiset", "map",
|
"deque", "list", "set", "multiset", "map",
|
||||||
|
@ -1225,7 +1225,7 @@ private:
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (error) Dangerous iterator comparison using operator< on 'std::forward_list'.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3]: (error) Dangerous iterator comparison using operator< on 'std::forward_list'.\n", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
void stlBoundries2() {
|
void stlBoundaries2() {
|
||||||
check("void f()\n"
|
check("void f()\n"
|
||||||
"{\n"
|
"{\n"
|
||||||
" std::vector<std::string> files;\n"
|
" std::vector<std::string> files;\n"
|
||||||
|
@ -1237,7 +1237,7 @@ private:
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
void stlBoundries3() {
|
void stlBoundaries3() {
|
||||||
check("void f()\n"
|
check("void f()\n"
|
||||||
"{\n"
|
"{\n"
|
||||||
" set<int> files;\n"
|
" set<int> files;\n"
|
||||||
|
@ -1257,7 +1257,7 @@ private:
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (error) Invalid iterator 'current' used.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3]: (error) Invalid iterator 'current' used.\n", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
void stlBoundries4() {
|
void stlBoundaries4() {
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" std::forward_list<std::vector<std::vector<int>>>::iterator it;\n"
|
" std::forward_list<std::vector<std::vector<int>>>::iterator it;\n"
|
||||||
|
|
|
@ -34,7 +34,7 @@ private:
|
||||||
std::vector<std::string> arithmeticalOps;
|
std::vector<std::string> arithmeticalOps;
|
||||||
std::vector<std::string> logicalOps;
|
std::vector<std::string> logicalOps;
|
||||||
std::vector<std::string> bitOps;
|
std::vector<std::string> bitOps;
|
||||||
std::vector<std::string> comparisionOps;
|
std::vector<std::string> comparisonOps;
|
||||||
std::vector<std::string> extendedOps;
|
std::vector<std::string> extendedOps;
|
||||||
std::vector<std::string> assignmentOps;
|
std::vector<std::string> assignmentOps;
|
||||||
|
|
||||||
|
@ -484,12 +484,12 @@ private:
|
||||||
logicalOps.push_back("&&");
|
logicalOps.push_back("&&");
|
||||||
logicalOps.push_back("||");
|
logicalOps.push_back("||");
|
||||||
logicalOps.push_back("!");
|
logicalOps.push_back("!");
|
||||||
comparisionOps.push_back("==");
|
comparisonOps.push_back("==");
|
||||||
comparisionOps.push_back("!=");
|
comparisonOps.push_back("!=");
|
||||||
comparisionOps.push_back("<");
|
comparisonOps.push_back("<");
|
||||||
comparisionOps.push_back("<=");
|
comparisonOps.push_back("<=");
|
||||||
comparisionOps.push_back(">");
|
comparisonOps.push_back(">");
|
||||||
comparisionOps.push_back(">=");
|
comparisonOps.push_back(">=");
|
||||||
bitOps.push_back("&");
|
bitOps.push_back("&");
|
||||||
bitOps.push_back("|");
|
bitOps.push_back("|");
|
||||||
bitOps.push_back("^");
|
bitOps.push_back("^");
|
||||||
|
@ -520,7 +520,7 @@ private:
|
||||||
std::vector<std::string> test_ops;
|
std::vector<std::string> test_ops;
|
||||||
append_vector(test_ops, arithmeticalOps);
|
append_vector(test_ops, arithmeticalOps);
|
||||||
append_vector(test_ops, bitOps);
|
append_vector(test_ops, bitOps);
|
||||||
append_vector(test_ops, comparisionOps);
|
append_vector(test_ops, comparisonOps);
|
||||||
append_vector(test_ops, logicalOps);
|
append_vector(test_ops, logicalOps);
|
||||||
|
|
||||||
std::vector<std::string>::const_iterator test_op, test_ops_end = test_ops.end();
|
std::vector<std::string>::const_iterator test_op, test_ops_end = test_ops.end();
|
||||||
|
@ -550,7 +550,7 @@ private:
|
||||||
// Negative test against other operators
|
// Negative test against other operators
|
||||||
std::vector<std::string> other_ops;
|
std::vector<std::string> other_ops;
|
||||||
append_vector(other_ops, bitOps);
|
append_vector(other_ops, bitOps);
|
||||||
append_vector(other_ops, comparisionOps);
|
append_vector(other_ops, comparisonOps);
|
||||||
append_vector(other_ops, logicalOps);
|
append_vector(other_ops, logicalOps);
|
||||||
append_vector(other_ops, extendedOps);
|
append_vector(other_ops, extendedOps);
|
||||||
append_vector(other_ops, assignmentOps);
|
append_vector(other_ops, assignmentOps);
|
||||||
|
@ -567,7 +567,7 @@ private:
|
||||||
std::vector<std::string> test_ops;
|
std::vector<std::string> test_ops;
|
||||||
append_vector(test_ops, arithmeticalOps);
|
append_vector(test_ops, arithmeticalOps);
|
||||||
append_vector(test_ops, bitOps);
|
append_vector(test_ops, bitOps);
|
||||||
append_vector(test_ops, comparisionOps);
|
append_vector(test_ops, comparisonOps);
|
||||||
append_vector(test_ops, logicalOps);
|
append_vector(test_ops, logicalOps);
|
||||||
|
|
||||||
std::vector<std::string>::const_iterator test_op, test_ops_end = test_ops.end();
|
std::vector<std::string>::const_iterator test_op, test_ops_end = test_ops.end();
|
||||||
|
@ -594,7 +594,7 @@ private:
|
||||||
std::vector<std::string> test_ops;
|
std::vector<std::string> test_ops;
|
||||||
append_vector(test_ops, arithmeticalOps);
|
append_vector(test_ops, arithmeticalOps);
|
||||||
append_vector(test_ops, bitOps);
|
append_vector(test_ops, bitOps);
|
||||||
append_vector(test_ops, comparisionOps);
|
append_vector(test_ops, comparisonOps);
|
||||||
append_vector(test_ops, logicalOps);
|
append_vector(test_ops, logicalOps);
|
||||||
append_vector(test_ops, extendedOps);
|
append_vector(test_ops, extendedOps);
|
||||||
|
|
||||||
|
@ -626,7 +626,7 @@ private:
|
||||||
std::vector<std::string> other_ops;
|
std::vector<std::string> other_ops;
|
||||||
append_vector(other_ops, arithmeticalOps);
|
append_vector(other_ops, arithmeticalOps);
|
||||||
append_vector(other_ops, bitOps);
|
append_vector(other_ops, bitOps);
|
||||||
append_vector(other_ops, comparisionOps);
|
append_vector(other_ops, comparisonOps);
|
||||||
append_vector(other_ops, logicalOps);
|
append_vector(other_ops, logicalOps);
|
||||||
append_vector(other_ops, extendedOps);
|
append_vector(other_ops, extendedOps);
|
||||||
|
|
||||||
|
@ -655,7 +655,7 @@ private:
|
||||||
tok.str(*test_op);
|
tok.str(*test_op);
|
||||||
ASSERT_EQUALS(Token::eBitOp, tok.type());
|
ASSERT_EQUALS(Token::eBitOp, tok.type());
|
||||||
}
|
}
|
||||||
for (test_op = comparisionOps.begin(); test_op != comparisionOps.end(); ++test_op) {
|
for (test_op = comparisonOps.begin(); test_op != comparisonOps.end(); ++test_op) {
|
||||||
Token tok(NULL);
|
Token tok(NULL);
|
||||||
tok.str(*test_op);
|
tok.str(*test_op);
|
||||||
ASSERT_EQUALS(Token::eComparisonOp, tok.type());
|
ASSERT_EQUALS(Token::eComparisonOp, tok.type());
|
||||||
|
|
|
@ -5983,20 +5983,20 @@ private:
|
||||||
tokenizer.tokenize(istr, "test.cpp");
|
tokenizer.tokenize(istr, "test.cpp");
|
||||||
const Token *tok = tokenizer.tokens();
|
const Token *tok = tokenizer.tokens();
|
||||||
// template<
|
// template<
|
||||||
ASSERT_EQUALS((long long)tok->tokAt(6), (long long)tok->linkAt(4));
|
ASSERT_EQUALS(true, tok->tokAt(6) == tok->linkAt(4));
|
||||||
ASSERT_EQUALS((long long)tok->tokAt(4), (long long)tok->linkAt(6));
|
ASSERT_EQUALS(true, tok->tokAt(4) == tok->linkAt(6));
|
||||||
|
|
||||||
// bar<
|
// bar<
|
||||||
ASSERT_EQUALS((long long)tok->tokAt(17), (long long)tok->linkAt(10));
|
ASSERT_EQUALS(true, tok->tokAt(17) == tok->linkAt(10));
|
||||||
ASSERT_EQUALS((long long)tok->tokAt(10), (long long)tok->linkAt(17));
|
ASSERT_EQUALS(true, tok->tokAt(10) == tok->linkAt(17));
|
||||||
|
|
||||||
// x<
|
// x<
|
||||||
ASSERT_EQUALS((long long)tok->tokAt(16), (long long)tok->linkAt(14));
|
ASSERT_EQUALS(true, tok->tokAt(16) == tok->linkAt(14));
|
||||||
ASSERT_EQUALS((long long)tok->tokAt(14), (long long)tok->linkAt(16));
|
ASSERT_EQUALS(true, tok->tokAt(14) == tok->linkAt(16));
|
||||||
|
|
||||||
// a<b && b>f
|
// a<b && b>f
|
||||||
ASSERT_EQUALS(0, (long long)tok->linkAt(28));
|
ASSERT_EQUALS(true, 0 == tok->linkAt(28));
|
||||||
ASSERT_EQUALS(0, (long long)tok->linkAt(32));
|
ASSERT_EQUALS(true, 0 == tok->linkAt(32));
|
||||||
|
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
|
@ -6013,8 +6013,8 @@ private:
|
||||||
const Token *tok = tokenizer.tokens();
|
const Token *tok = tokenizer.tokens();
|
||||||
|
|
||||||
// static_cast<
|
// static_cast<
|
||||||
ASSERT_EQUALS((long long)tok->tokAt(9), (long long)tok->linkAt(7));
|
ASSERT_EQUALS(true, tok->tokAt(9) == tok->linkAt(7));
|
||||||
ASSERT_EQUALS((long long)tok->tokAt(7), (long long)tok->linkAt(9));
|
ASSERT_EQUALS(true, tok->tokAt(7) == tok->linkAt(9));
|
||||||
|
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
|
@ -6031,8 +6031,8 @@ private:
|
||||||
const Token *tok = tokenizer.tokens();
|
const Token *tok = tokenizer.tokens();
|
||||||
|
|
||||||
// nvwa<(x > y)>
|
// nvwa<(x > y)>
|
||||||
ASSERT_EQUALS((long long)tok->tokAt(12), (long long)tok->linkAt(6));
|
ASSERT_EQUALS(true, tok->tokAt(12) == tok->linkAt(6));
|
||||||
ASSERT_EQUALS((long long)tok->tokAt(6), (long long)tok->linkAt(12));
|
ASSERT_EQUALS(true, tok->tokAt(6) == tok->linkAt(12));
|
||||||
|
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue