Fixed #2382 (Catching exceptions by value instead of reference)
This commit is contained in:
parent
2da3fea1b8
commit
68700b3561
|
@ -319,8 +319,7 @@ void CheckOther::checkCatchExceptionByValue()
|
||||||
// Find a pass-by-value declaration in the catch(), excluding basic types
|
// Find a pass-by-value declaration in the catch(), excluding basic types
|
||||||
// e.g. catch (std::exception err)
|
// e.g. catch (std::exception err)
|
||||||
const Token *tokType = Token::findmatch(tok, "%type% %var% )", endTok);
|
const Token *tokType = Token::findmatch(tok, "%type% %var% )", endTok);
|
||||||
if (tokType &&
|
if (tokType && !tokType->isStandardType())
|
||||||
!Token::Match(tokType, "bool|char|double|enum|float|int|long|short|size_t|wchar_t"))
|
|
||||||
{
|
{
|
||||||
catchExceptionByValueError(tokType);
|
catchExceptionByValueError(tokType);
|
||||||
}
|
}
|
||||||
|
@ -2800,7 +2799,7 @@ void CheckOther::misusedScopeObjectError(const Token *tok, const std::string& va
|
||||||
void CheckOther::catchExceptionByValueError(const Token *tok)
|
void CheckOther::catchExceptionByValueError(const Token *tok)
|
||||||
{
|
{
|
||||||
reportError(tok, Severity::style,
|
reportError(tok, Severity::style,
|
||||||
"catchExceptionByStyle", "Exception should be caught by reference.\n"
|
"catchExceptionByValue", "Exception should be caught by reference.\n"
|
||||||
"The exception is caught as a value. It could be caught "
|
"The exception is caught as a value. It could be caught "
|
||||||
"as a (const) reference which is usually recommended in C++.");
|
"as a (const) reference which is usually recommended in C++.");
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue