diff options
author | Alexander Kornienko <alexfh@google.com> | 2018-03-15 08:26:47 +0000 |
---|---|---|
committer | Alexander Kornienko <alexfh@google.com> | 2018-03-15 08:26:47 +0000 |
commit | 68fb65f413111de82311c3ebcccebdbfc75d5dc0 (patch) | |
tree | 1e1aa1fdae0dcf15d3706433b9296ac2ae7ad267 /clang-tools-extra/clang-tidy/misc/SizeofContainerCheck.cpp | |
parent | 3273888536db25dd5cd3d2e7ebc5138632e6e8a8 (diff) | |
download | bcm5719-llvm-68fb65f413111de82311c3ebcccebdbfc75d5dc0.tar.gz bcm5719-llvm-68fb65f413111de82311c3ebcccebdbfc75d5dc0.zip |
[clang-tidy] rename_check.py misc-sizeof-container bugprone-sizeof-container
llvm-svn: 327608
Diffstat (limited to 'clang-tools-extra/clang-tidy/misc/SizeofContainerCheck.cpp')
-rw-r--r-- | clang-tools-extra/clang-tidy/misc/SizeofContainerCheck.cpp | 49 |
1 files changed, 0 insertions, 49 deletions
diff --git a/clang-tools-extra/clang-tidy/misc/SizeofContainerCheck.cpp b/clang-tools-extra/clang-tidy/misc/SizeofContainerCheck.cpp deleted file mode 100644 index de4e8ad1b33..00000000000 --- a/clang-tools-extra/clang-tidy/misc/SizeofContainerCheck.cpp +++ /dev/null @@ -1,49 +0,0 @@ -//===--- SizeofContainerCheck.cpp - clang-tidy-----------------------------===// -// -// The LLVM Compiler Infrastructure -// -// This file is distributed under the University of Illinois Open Source -// License. See LICENSE.TXT for details. -// -//===----------------------------------------------------------------------===// - -#include "SizeofContainerCheck.h" -#include "clang/AST/ASTContext.h" -#include "clang/ASTMatchers/ASTMatchFinder.h" - -using namespace clang::ast_matchers; - -namespace clang { -namespace tidy { -namespace misc { - -void SizeofContainerCheck::registerMatchers(MatchFinder *Finder) { - Finder->addMatcher( - expr(unless(isInTemplateInstantiation()), - expr(sizeOfExpr(has(ignoringParenImpCasts( - expr(hasType(hasCanonicalType(hasDeclaration(cxxRecordDecl( - matchesName("^(::std::|::string)"), - unless(matchesName("^::std::(bitset|array)$")), - hasMethod(cxxMethodDecl(hasName("size"), isPublic(), - isConst()))))))))))) - .bind("sizeof"), - // Ignore ARRAYSIZE(<array of containers>) pattern. - unless(hasAncestor(binaryOperator( - anyOf(hasOperatorName("/"), hasOperatorName("%")), - hasLHS(ignoringParenCasts(sizeOfExpr(expr()))), - hasRHS(ignoringParenCasts(equalsBoundNode("sizeof"))))))), - this); -} - -void SizeofContainerCheck::check(const MatchFinder::MatchResult &Result) { - const auto *SizeOf = - Result.Nodes.getNodeAs<UnaryExprOrTypeTraitExpr>("sizeof"); - - auto Diag = - diag(SizeOf->getLocStart(), "sizeof() doesn't return the size of the " - "container; did you mean .size()?"); -} - -} // namespace misc -} // namespace tidy -} // namespace clang |