Improved the error message related to virtual destructors

This commit is contained in:
Reijo Tomperi 2008-12-20 20:52:15 +00:00
parent 92c1914951
commit 8af4efb1df
1 changed files with 4 additions and 2 deletions

View File

@ -689,6 +689,8 @@ void CheckClass::virtualDestructor()
} }
} }
const TOKEN *derivedClass = derived->tokAt(1);
// Iterate through each base class... // Iterate through each base class...
derived = derived->tokAt(3); derived = derived->tokAt(3);
while ( TOKEN::Match(derived, "%var%") ) while ( TOKEN::Match(derived, "%var%") )
@ -729,7 +731,7 @@ void CheckClass::virtualDestructor()
if ( base ) if ( base )
{ {
std::ostringstream errmsg; std::ostringstream errmsg;
errmsg << _tokenizer->fileLine(base) << ": Base class " << baseName[0] << " doesn't have a virtual destructor"; errmsg << _tokenizer->fileLine(base) << ": Class " << baseName[0] << " which is inherited by class " << derivedClass->str() << " does not have a virtual destructor";
_errorLogger->reportErr(errmsg.str()); _errorLogger->reportErr(errmsg.str());
} }
} }
@ -738,7 +740,7 @@ void CheckClass::virtualDestructor()
else if ( ! TOKEN::Match(base, "virtual") ) else if ( ! TOKEN::Match(base, "virtual") )
{ {
std::ostringstream errmsg; std::ostringstream errmsg;
errmsg << _tokenizer->fileLine(base) << ": The destructor for the base class " << baseName[0] << " is not virtual"; errmsg << _tokenizer->fileLine(base) << ": Class " << baseName[0] << " which is inherited by class " << derivedClass->str() << " does not have a virtual destructor";
_errorLogger->reportErr(errmsg.str()); _errorLogger->reportErr(errmsg.str());
} }
} }