17 auto RegisterClassMatch = hasType(
18 cxxRecordDecl(hasName(
"::llvm::Register")).bind(
"registerClassDecl"));
22 valueDecl(hasType(qualType(isUnsignedInteger()).bind(
"varType")),
23 varDecl(hasInitializer(exprWithCleanups(
24 has(implicitCastExpr(has(cxxMemberCallExpr(
25 on(RegisterClassMatch),
26 has(memberExpr(hasDeclaration(
27 cxxConversionDecl()))))))))))
33 const MatchFinder::MatchResult &Result) {
34 const auto *VarType = Result.Nodes.getNodeAs<QualType>(
"varType");
35 const auto *UserVarDecl = Result.Nodes.getNodeAs<VarDecl>(
"var");
37 bool NeedsQualification =
true;
38 const DeclContext *Context = UserVarDecl->getDeclContext();
40 if (
const auto *Namespace = dyn_cast<NamespaceDecl>(Context))
41 if (isa<TranslationUnitDecl>(Namespace->getDeclContext()) &&
42 Namespace->getName() ==
"llvm")
43 NeedsQualification =
false;
44 for (
const auto *UsingDirective : Context->using_directives()) {
45 const NamespaceDecl *Namespace = UsingDirective->getNominatedNamespace();
46 if (isa<TranslationUnitDecl>(Namespace->getDeclContext()) &&
47 Namespace->getName() ==
"llvm")
48 NeedsQualification =
false;
50 Context = Context->getParent();
52 diag(UserVarDecl->getLocation(),
53 "variable %0 declared as %1; use '%select{|llvm::}2Register' instead")
54 << UserVarDecl << *VarType << NeedsQualification
55 << FixItHint::CreateReplacement(
56 UserVarDecl->getTypeSourceInfo()->getTypeLoc().getSourceRange(),
57 NeedsQualification ?
"llvm::Register" :
"Register");