2015-10-10 04:42:44 +08:00
|
|
|
//===--- ThrowByValueCatchByReferenceCheck.h - clang-tidy--------*- C++ -*-===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2015-10-10 04:42:44 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MISC_THROW_BY_VALUE_CATCH_BY_REFERENCE_H
|
|
|
|
#define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MISC_THROW_BY_VALUE_CATCH_BY_REFERENCE_H
|
|
|
|
|
2019-03-25 20:38:26 +08:00
|
|
|
#include "../ClangTidyCheck.h"
|
2015-10-10 04:42:44 +08:00
|
|
|
|
|
|
|
namespace clang {
|
|
|
|
namespace tidy {
|
2016-05-03 02:00:29 +08:00
|
|
|
namespace misc {
|
2015-10-10 04:42:44 +08:00
|
|
|
|
Remove \brief commands from doxygen comments.
Summary:
We've been running doxygen with the autobrief option for a couple of
years now. This makes the \brief markers into our comments
redundant. Since they are a visual distraction and we don't want to
encourage more \brief markers in new code either, this patch removes
them all.
Patch produced by
for i in $(git grep -l '\\brief'); do perl -pi -e 's/\\brief //g' $i & done
[This is analogous to LLVM r331272 and CFE r331834]
Subscribers: srhines, nemanjai, javed.absar, kbarton, MaskRay, jkorous, arphaman, jfb, kadircet, jsji, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D66578
llvm-svn: 369643
2019-08-22 19:32:57 +08:00
|
|
|
///checks for locations that do not throw by value
|
2015-10-10 04:42:44 +08:00
|
|
|
// or catch by reference.
|
|
|
|
// The check is C++ only. It checks that all throw locations
|
|
|
|
// throw by value and not by pointer. Additionally it
|
|
|
|
// contains an option ("CheckThrowTemporaries", default value "true") that
|
|
|
|
// checks that thrown objects are anonymous temporaries. It is also
|
|
|
|
// acceptable for this check to throw string literals.
|
|
|
|
// This test checks that exceptions are caught by reference
|
|
|
|
// and not by value or pointer. It will not warn when catching
|
|
|
|
// pointer to char, wchar_t, char16_t or char32_t. This is
|
|
|
|
// due to not warning on throwing string literals.
|
|
|
|
class ThrowByValueCatchByReferenceCheck : public ClangTidyCheck {
|
|
|
|
public:
|
|
|
|
ThrowByValueCatchByReferenceCheck(StringRef Name, ClangTidyContext *Context);
|
[clang-tidy] Change checks to use new isLanguageVersionSupported restriction
Summary: Modifies all checks that are language version dependent to use `isLanguageVersionSupported`
Reviewers: jdoerfert, lebedev.ri, aaron.ballman, gribozavr2, Eugene.Zelenko
Reviewed By: gribozavr2
Subscribers: wuzish, nemanjai, xazax.hun, hiraditya, kbarton, steven_wu, dexonsmith, arphaman, lebedev.ri, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D75340
2020-03-04 00:39:32 +08:00
|
|
|
bool isLanguageVersionSupported(const LangOptions &LangOpts) const override {
|
|
|
|
return LangOpts.CPlusPlus;
|
|
|
|
}
|
2015-10-10 04:42:44 +08:00
|
|
|
void storeOptions(ClangTidyOptions::OptionMap &Opts) override;
|
|
|
|
void registerMatchers(ast_matchers::MatchFinder *Finder) override;
|
|
|
|
void check(const ast_matchers::MatchFinder::MatchResult &Result) override;
|
|
|
|
|
|
|
|
private:
|
|
|
|
void diagnoseThrowLocations(const CXXThrowExpr *throwExpr);
|
|
|
|
void diagnoseCatchLocations(const CXXCatchStmt *catchStmt,
|
|
|
|
ASTContext &context);
|
|
|
|
bool isFunctionParameter(const DeclRefExpr *declRefExpr);
|
|
|
|
bool isCatchVariable(const DeclRefExpr *declRefExpr);
|
|
|
|
bool isFunctionOrCatchVar(const DeclRefExpr *declRefExpr);
|
|
|
|
const bool CheckAnonymousTemporaries;
|
2019-05-21 15:25:06 +08:00
|
|
|
const bool WarnOnLargeObject;
|
2020-06-22 02:01:09 +08:00
|
|
|
const uint64_t MaxSizeOptions; // The raw value read from the options.
|
2019-05-21 15:25:06 +08:00
|
|
|
uint64_t MaxSize; // No `const` because we have to set it in two steps.
|
2015-10-10 04:42:44 +08:00
|
|
|
};
|
|
|
|
|
2016-05-03 02:00:29 +08:00
|
|
|
} // namespace misc
|
2015-10-10 04:42:44 +08:00
|
|
|
} // namespace tidy
|
|
|
|
} // namespace clang
|
|
|
|
|
|
|
|
#endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MISC_THROW_BY_VALUE_CATCH_BY_REFERENCE_H
|