diff options
author | thegeorg <thegeorg@yandex-team.com> | 2024-03-13 13:58:24 +0300 |
---|---|---|
committer | thegeorg <thegeorg@yandex-team.com> | 2024-03-13 14:11:53 +0300 |
commit | 11a895b7e15d1c5a1f52706396b82e3f9db953cb (patch) | |
tree | fabc6d883b0f946151f61ae7865cee9f529a1fdd /contrib/libs/clang16/tools/extra/clang-tidy/llvm/PreferRegisterOverUnsignedCheck.cpp | |
parent | 9685917341315774aad5733b1793b1e533a88bbb (diff) | |
download | ydb-11a895b7e15d1c5a1f52706396b82e3f9db953cb.tar.gz |
Export clang-format16 via ydblib project
6e6be3a95868fde888d801b7590af4044049563f
Diffstat (limited to 'contrib/libs/clang16/tools/extra/clang-tidy/llvm/PreferRegisterOverUnsignedCheck.cpp')
-rw-r--r-- | contrib/libs/clang16/tools/extra/clang-tidy/llvm/PreferRegisterOverUnsignedCheck.cpp | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/contrib/libs/clang16/tools/extra/clang-tidy/llvm/PreferRegisterOverUnsignedCheck.cpp b/contrib/libs/clang16/tools/extra/clang-tidy/llvm/PreferRegisterOverUnsignedCheck.cpp new file mode 100644 index 0000000000..5d1955575a --- /dev/null +++ b/contrib/libs/clang16/tools/extra/clang-tidy/llvm/PreferRegisterOverUnsignedCheck.cpp @@ -0,0 +1,62 @@ +//===--- PreferRegisterOverUnsignedCheck.cpp - clang-tidy -----------------===// +// +// 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 +// +//===----------------------------------------------------------------------===// + +#include "PreferRegisterOverUnsignedCheck.h" +#include "clang/AST/ASTContext.h" +#include "clang/ASTMatchers/ASTMatchFinder.h" + +using namespace clang::ast_matchers; + +namespace clang::tidy::llvm_check { + +void PreferRegisterOverUnsignedCheck::registerMatchers(MatchFinder *Finder) { + auto RegisterClassMatch = hasType( + cxxRecordDecl(hasName("::llvm::Register")).bind("registerClassDecl")); + + Finder->addMatcher( + traverse(TK_AsIs, + valueDecl(allOf( + hasType(qualType(isUnsignedInteger()).bind("varType")), + varDecl(hasInitializer(exprWithCleanups( + has(implicitCastExpr(has(cxxMemberCallExpr( + allOf(on(RegisterClassMatch), + has(memberExpr(hasDeclaration( + cxxConversionDecl()))))))))))) + .bind("var")))), + this); +} + +void PreferRegisterOverUnsignedCheck::check( + const MatchFinder::MatchResult &Result) { + const auto *VarType = Result.Nodes.getNodeAs<QualType>("varType"); + const auto *UserVarDecl = Result.Nodes.getNodeAs<VarDecl>("var"); + + bool NeedsQualification = true; + const DeclContext *Context = UserVarDecl->getDeclContext(); + while (Context) { + if (const auto *Namespace = dyn_cast<NamespaceDecl>(Context)) + if (isa<TranslationUnitDecl>(Namespace->getDeclContext()) && + Namespace->getName() == "llvm") + NeedsQualification = false; + for (const auto *UsingDirective : Context->using_directives()) { + const NamespaceDecl *Namespace = UsingDirective->getNominatedNamespace(); + if (isa<TranslationUnitDecl>(Namespace->getDeclContext()) && + Namespace->getName() == "llvm") + NeedsQualification = false; + } + Context = Context->getParent(); + } + diag(UserVarDecl->getLocation(), + "variable %0 declared as %1; use '%select{|llvm::}2Register' instead") + << UserVarDecl << *VarType << NeedsQualification + << FixItHint::CreateReplacement( + UserVarDecl->getTypeSourceInfo()->getTypeLoc().getSourceRange(), + NeedsQualification ? "llvm::Register" : "Register"); +} + +} // namespace clang::tidy::llvm_check |