Registry.cpp revision 321369
1//===--- Registry.cpp - Matcher registry -------------------------===// 2// 3// The LLVM Compiler Infrastructure 4// 5// This file is distributed under the University of Illinois Open Source 6// License. See LICENSE.TXT for details. 7// 8//===------------------------------------------------------------===// 9/// 10/// \file 11/// \brief Registry map populated at static initialization time. 12/// 13//===------------------------------------------------------------===// 14 15#include "clang/ASTMatchers/Dynamic/Registry.h" 16#include "Marshallers.h" 17#include "clang/ASTMatchers/ASTMatchers.h" 18#include "llvm/ADT/STLExtras.h" 19#include "llvm/ADT/StringMap.h" 20#include "llvm/ADT/StringRef.h" 21#include "llvm/Support/ManagedStatic.h" 22#include <set> 23#include <utility> 24 25using namespace clang::ast_type_traits; 26 27namespace clang { 28namespace ast_matchers { 29namespace dynamic { 30namespace { 31 32using internal::MatcherDescriptor; 33 34typedef llvm::StringMap<std::unique_ptr<const MatcherDescriptor>> ConstructorMap; 35class RegistryMaps { 36public: 37 RegistryMaps(); 38 ~RegistryMaps(); 39 40 const ConstructorMap &constructors() const { return Constructors; } 41 42private: 43 void registerMatcher(StringRef MatcherName, 44 std::unique_ptr<MatcherDescriptor> Callback); 45 46 ConstructorMap Constructors; 47}; 48 49void RegistryMaps::registerMatcher( 50 StringRef MatcherName, std::unique_ptr<MatcherDescriptor> Callback) { 51 assert(Constructors.find(MatcherName) == Constructors.end()); 52 Constructors[MatcherName] = std::move(Callback); 53} 54 55#define REGISTER_MATCHER(name) \ 56 registerMatcher(#name, internal::makeMatcherAutoMarshall( \ 57 ::clang::ast_matchers::name, #name)); 58 59#define REGISTER_MATCHER_OVERLOAD(name) \ 60 registerMatcher(#name, \ 61 llvm::make_unique<internal::OverloadedMatcherDescriptor>(name##Callbacks)) 62 63#define SPECIFIC_MATCHER_OVERLOAD(name, Id) \ 64 static_cast<::clang::ast_matchers::name##_Type##Id>( \ 65 ::clang::ast_matchers::name) 66 67#define MATCHER_OVERLOAD_ENTRY(name, Id) \ 68 internal::makeMatcherAutoMarshall(SPECIFIC_MATCHER_OVERLOAD(name, Id), \ 69 #name) 70 71#define REGISTER_OVERLOADED_2(name) \ 72 do { \ 73 std::unique_ptr<MatcherDescriptor> name##Callbacks[] = { \ 74 MATCHER_OVERLOAD_ENTRY(name, 0), \ 75 MATCHER_OVERLOAD_ENTRY(name, 1)}; \ 76 REGISTER_MATCHER_OVERLOAD(name); \ 77 } while (0) 78 79/// \brief Generate a registry map with all the known matchers. 80RegistryMaps::RegistryMaps() { 81 // TODO: Here is the list of the missing matchers, grouped by reason. 82 // 83 // Need Variant/Parser fixes: 84 // ofKind 85 // 86 // Polymorphic + argument overload: 87 // findAll 88 // 89 // Other: 90 // equalsNode 91 92 REGISTER_OVERLOADED_2(callee); 93 REGISTER_OVERLOADED_2(hasPrefix); 94 REGISTER_OVERLOADED_2(hasType); 95 REGISTER_OVERLOADED_2(isDerivedFrom); 96 REGISTER_OVERLOADED_2(isSameOrDerivedFrom); 97 REGISTER_OVERLOADED_2(loc); 98 REGISTER_OVERLOADED_2(pointsTo); 99 REGISTER_OVERLOADED_2(references); 100 REGISTER_OVERLOADED_2(thisPointerType); 101 102 std::unique_ptr<MatcherDescriptor> equalsCallbacks[] = { 103 MATCHER_OVERLOAD_ENTRY(equals, 0), 104 MATCHER_OVERLOAD_ENTRY(equals, 1), 105 MATCHER_OVERLOAD_ENTRY(equals, 2), 106 }; 107 REGISTER_MATCHER_OVERLOAD(equals); 108 109 REGISTER_MATCHER(accessSpecDecl); 110 REGISTER_MATCHER(addrLabelExpr); 111 REGISTER_MATCHER(alignOfExpr); 112 REGISTER_MATCHER(allOf); 113 REGISTER_MATCHER(anyOf); 114 REGISTER_MATCHER(anything); 115 REGISTER_MATCHER(argumentCountIs); 116 REGISTER_MATCHER(arraySubscriptExpr); 117 REGISTER_MATCHER(arrayType); 118 REGISTER_MATCHER(asmStmt); 119 REGISTER_MATCHER(asString); 120 REGISTER_MATCHER(atomicExpr); 121 REGISTER_MATCHER(atomicType); 122 REGISTER_MATCHER(autoType); 123 REGISTER_MATCHER(binaryOperator); 124 REGISTER_MATCHER(binaryConditionalOperator); 125 REGISTER_MATCHER(blockPointerType); 126 REGISTER_MATCHER(booleanType); 127 REGISTER_MATCHER(breakStmt); 128 REGISTER_MATCHER(builtinType); 129 REGISTER_MATCHER(callExpr); 130 REGISTER_MATCHER(caseStmt); 131 REGISTER_MATCHER(castExpr); 132 REGISTER_MATCHER(characterLiteral); 133 REGISTER_MATCHER(classTemplateDecl); 134 REGISTER_MATCHER(classTemplateSpecializationDecl); 135 REGISTER_MATCHER(complexType); 136 REGISTER_MATCHER(compoundLiteralExpr); 137 REGISTER_MATCHER(compoundStmt); 138 REGISTER_MATCHER(conditionalOperator); 139 REGISTER_MATCHER(constantArrayType); 140 REGISTER_MATCHER(containsDeclaration); 141 REGISTER_MATCHER(continueStmt); 142 REGISTER_MATCHER(cStyleCastExpr); 143 REGISTER_MATCHER(cudaKernelCallExpr); 144 REGISTER_MATCHER(cxxBindTemporaryExpr); 145 REGISTER_MATCHER(cxxBoolLiteral); 146 REGISTER_MATCHER(cxxCatchStmt); 147 REGISTER_MATCHER(cxxConstCastExpr); 148 REGISTER_MATCHER(cxxConstructExpr); 149 REGISTER_MATCHER(cxxConstructorDecl); 150 REGISTER_MATCHER(cxxConversionDecl); 151 REGISTER_MATCHER(cxxCtorInitializer); 152 REGISTER_MATCHER(cxxDefaultArgExpr); 153 REGISTER_MATCHER(cxxDeleteExpr); 154 REGISTER_MATCHER(cxxDestructorDecl); 155 REGISTER_MATCHER(cxxDynamicCastExpr); 156 REGISTER_MATCHER(cxxForRangeStmt); 157 REGISTER_MATCHER(cxxFunctionalCastExpr); 158 REGISTER_MATCHER(cxxMemberCallExpr); 159 REGISTER_MATCHER(cxxMethodDecl); 160 REGISTER_MATCHER(cxxNewExpr); 161 REGISTER_MATCHER(cxxNullPtrLiteralExpr); 162 REGISTER_MATCHER(cxxOperatorCallExpr); 163 REGISTER_MATCHER(cxxRecordDecl); 164 REGISTER_MATCHER(cxxReinterpretCastExpr); 165 REGISTER_MATCHER(cxxStaticCastExpr); 166 REGISTER_MATCHER(cxxStdInitializerListExpr); 167 REGISTER_MATCHER(cxxTemporaryObjectExpr); 168 REGISTER_MATCHER(cxxThisExpr); 169 REGISTER_MATCHER(cxxThrowExpr); 170 REGISTER_MATCHER(cxxTryStmt); 171 REGISTER_MATCHER(cxxUnresolvedConstructExpr); 172 REGISTER_MATCHER(decayedType); 173 REGISTER_MATCHER(decl); 174 REGISTER_MATCHER(declaratorDecl); 175 REGISTER_MATCHER(declCountIs); 176 REGISTER_MATCHER(declRefExpr); 177 REGISTER_MATCHER(declStmt); 178 REGISTER_MATCHER(defaultStmt); 179 REGISTER_MATCHER(dependentSizedArrayType); 180 REGISTER_MATCHER(designatedInitExpr); 181 REGISTER_MATCHER(designatorCountIs); 182 REGISTER_MATCHER(doStmt); 183 REGISTER_MATCHER(eachOf); 184 REGISTER_MATCHER(elaboratedType); 185 REGISTER_MATCHER(enumConstantDecl); 186 REGISTER_MATCHER(enumDecl); 187 REGISTER_MATCHER(enumType); 188 REGISTER_MATCHER(equalsBoundNode); 189 REGISTER_MATCHER(equalsIntegralValue); 190 REGISTER_MATCHER(explicitCastExpr); 191 REGISTER_MATCHER(expr); 192 REGISTER_MATCHER(exprWithCleanups); 193 REGISTER_MATCHER(fieldDecl); 194 REGISTER_MATCHER(floatLiteral); 195 REGISTER_MATCHER(forEach); 196 REGISTER_MATCHER(forEachArgumentWithParam); 197 REGISTER_MATCHER(forEachConstructorInitializer); 198 REGISTER_MATCHER(forEachDescendant); 199 REGISTER_MATCHER(forEachSwitchCase); 200 REGISTER_MATCHER(forField); 201 REGISTER_MATCHER(forFunction); 202 REGISTER_MATCHER(forStmt); 203 REGISTER_MATCHER(friendDecl); 204 REGISTER_MATCHER(functionDecl); 205 REGISTER_MATCHER(functionProtoType); 206 REGISTER_MATCHER(functionTemplateDecl); 207 REGISTER_MATCHER(functionType); 208 REGISTER_MATCHER(gnuNullExpr); 209 REGISTER_MATCHER(gotoStmt); 210 REGISTER_MATCHER(has); 211 REGISTER_MATCHER(hasAncestor); 212 REGISTER_MATCHER(hasAnyArgument); 213 REGISTER_MATCHER(hasAnyConstructorInitializer); 214 REGISTER_MATCHER(hasAnyDeclaration); 215 REGISTER_MATCHER(hasAnyName); 216 REGISTER_MATCHER(hasAnyParameter); 217 REGISTER_MATCHER(hasAnySubstatement); 218 REGISTER_MATCHER(hasAnyTemplateArgument); 219 REGISTER_MATCHER(hasAnyUsingShadowDecl); 220 REGISTER_MATCHER(hasArgument); 221 REGISTER_MATCHER(hasArgumentOfType); 222 REGISTER_MATCHER(hasAttr); 223 REGISTER_MATCHER(hasAutomaticStorageDuration); 224 REGISTER_MATCHER(hasBase); 225 REGISTER_MATCHER(hasBitWidth); 226 REGISTER_MATCHER(hasBody); 227 REGISTER_MATCHER(hasCanonicalType); 228 REGISTER_MATCHER(hasCaseConstant); 229 REGISTER_MATCHER(hasCastKind); 230 REGISTER_MATCHER(hasCondition); 231 REGISTER_MATCHER(hasConditionVariableStatement); 232 REGISTER_MATCHER(hasDecayedType); 233 REGISTER_MATCHER(hasDeclaration); 234 REGISTER_MATCHER(hasDeclContext); 235 REGISTER_MATCHER(hasDeducedType); 236 REGISTER_MATCHER(hasDescendant); 237 REGISTER_MATCHER(hasDestinationType); 238 REGISTER_MATCHER(hasDynamicExceptionSpec); 239 REGISTER_MATCHER(hasEitherOperand); 240 REGISTER_MATCHER(hasElementType); 241 REGISTER_MATCHER(hasElse); 242 REGISTER_MATCHER(hasExternalFormalLinkage); 243 REGISTER_MATCHER(hasFalseExpression); 244 REGISTER_MATCHER(hasGlobalStorage); 245 REGISTER_MATCHER(hasImplicitDestinationType); 246 REGISTER_MATCHER(hasInClassInitializer); 247 REGISTER_MATCHER(hasIncrement); 248 REGISTER_MATCHER(hasIndex); 249 REGISTER_MATCHER(hasInitializer); 250 REGISTER_MATCHER(hasKeywordSelector); 251 REGISTER_MATCHER(hasLHS); 252 REGISTER_MATCHER(hasLocalQualifiers); 253 REGISTER_MATCHER(hasLocalStorage); 254 REGISTER_MATCHER(hasLoopInit); 255 REGISTER_MATCHER(hasLoopVariable); 256 REGISTER_MATCHER(hasMethod); 257 REGISTER_MATCHER(hasName); 258 REGISTER_MATCHER(hasNullSelector); 259 REGISTER_MATCHER(hasObjectExpression); 260 REGISTER_MATCHER(hasOperatorName); 261 REGISTER_MATCHER(hasOverloadedOperatorName); 262 REGISTER_MATCHER(hasParameter); 263 REGISTER_MATCHER(hasParent); 264 REGISTER_MATCHER(hasQualifier); 265 REGISTER_MATCHER(hasRangeInit); 266 REGISTER_MATCHER(hasReceiverType); 267 REGISTER_MATCHER(hasReplacementType); 268 REGISTER_MATCHER(hasReturnValue); 269 REGISTER_MATCHER(hasRHS); 270 REGISTER_MATCHER(hasSelector); 271 REGISTER_MATCHER(hasSingleDecl); 272 REGISTER_MATCHER(hasSize); 273 REGISTER_MATCHER(hasSizeExpr); 274 REGISTER_MATCHER(hasSourceExpression); 275 REGISTER_MATCHER(hasStaticStorageDuration); 276 REGISTER_MATCHER(hasSyntacticForm); 277 REGISTER_MATCHER(hasTargetDecl); 278 REGISTER_MATCHER(hasTemplateArgument); 279 REGISTER_MATCHER(hasThen); 280 REGISTER_MATCHER(hasThreadStorageDuration); 281 REGISTER_MATCHER(hasTrueExpression); 282 REGISTER_MATCHER(hasTypeLoc); 283 REGISTER_MATCHER(hasUnaryOperand); 284 REGISTER_MATCHER(hasUnarySelector); 285 REGISTER_MATCHER(hasUnderlyingDecl); 286 REGISTER_MATCHER(hasUnqualifiedDesugaredType); 287 REGISTER_MATCHER(hasValueType); 288 REGISTER_MATCHER(ifStmt); 289 REGISTER_MATCHER(ignoringImplicit); 290 REGISTER_MATCHER(ignoringImpCasts); 291 REGISTER_MATCHER(ignoringParenCasts); 292 REGISTER_MATCHER(ignoringParenImpCasts); 293 REGISTER_MATCHER(ignoringParens); 294 REGISTER_MATCHER(implicitCastExpr); 295 REGISTER_MATCHER(implicitValueInitExpr); 296 REGISTER_MATCHER(incompleteArrayType); 297 REGISTER_MATCHER(initListExpr); 298 REGISTER_MATCHER(injectedClassNameType); 299 REGISTER_MATCHER(innerType); 300 REGISTER_MATCHER(integerLiteral); 301 REGISTER_MATCHER(isAnonymous); 302 REGISTER_MATCHER(isAnyCharacter); 303 REGISTER_MATCHER(isAnyPointer); 304 REGISTER_MATCHER(isArrow); 305 REGISTER_MATCHER(isBaseInitializer); 306 REGISTER_MATCHER(isBitField); 307 REGISTER_MATCHER(isCatchAll); 308 REGISTER_MATCHER(isClass); 309 REGISTER_MATCHER(isConst); 310 REGISTER_MATCHER(isConstexpr); 311 REGISTER_MATCHER(isConstQualified); 312 REGISTER_MATCHER(isCopyAssignmentOperator); 313 REGISTER_MATCHER(isCopyConstructor); 314 REGISTER_MATCHER(isDefaultConstructor); 315 REGISTER_MATCHER(isDefaulted); 316 REGISTER_MATCHER(isDefinition); 317 REGISTER_MATCHER(isDeleted); 318 REGISTER_MATCHER(isExceptionVariable); 319 REGISTER_MATCHER(isExplicit); 320 REGISTER_MATCHER(isExplicitTemplateSpecialization); 321 REGISTER_MATCHER(isExpr); 322 REGISTER_MATCHER(isExternC); 323 REGISTER_MATCHER(isFinal); 324 REGISTER_MATCHER(isInline); 325 REGISTER_MATCHER(isImplicit); 326 REGISTER_MATCHER(isExpansionInFileMatching); 327 REGISTER_MATCHER(isExpansionInMainFile); 328 REGISTER_MATCHER(isInstantiated); 329 REGISTER_MATCHER(isExpansionInSystemHeader); 330 REGISTER_MATCHER(isInteger); 331 REGISTER_MATCHER(isIntegral); 332 REGISTER_MATCHER(isInTemplateInstantiation); 333 REGISTER_MATCHER(isLambda); 334 REGISTER_MATCHER(isListInitialization); 335 REGISTER_MATCHER(isMemberInitializer); 336 REGISTER_MATCHER(isMoveAssignmentOperator); 337 REGISTER_MATCHER(isMoveConstructor); 338 REGISTER_MATCHER(isNoThrow); 339 REGISTER_MATCHER(isOverride); 340 REGISTER_MATCHER(isPrivate); 341 REGISTER_MATCHER(isProtected); 342 REGISTER_MATCHER(isPublic); 343 REGISTER_MATCHER(isPure); 344 REGISTER_MATCHER(isSignedInteger); 345 REGISTER_MATCHER(isStaticStorageClass); 346 REGISTER_MATCHER(isStruct); 347 REGISTER_MATCHER(isTemplateInstantiation); 348 REGISTER_MATCHER(isUnion); 349 REGISTER_MATCHER(isUnsignedInteger); 350 REGISTER_MATCHER(isVariadic); 351 REGISTER_MATCHER(isVirtual); 352 REGISTER_MATCHER(isVirtualAsWritten); 353 REGISTER_MATCHER(isVolatileQualified); 354 REGISTER_MATCHER(isWritten); 355 REGISTER_MATCHER(labelDecl); 356 REGISTER_MATCHER(labelStmt); 357 REGISTER_MATCHER(lambdaExpr); 358 REGISTER_MATCHER(lValueReferenceType); 359 REGISTER_MATCHER(matchesName); 360 REGISTER_MATCHER(matchesSelector); 361 REGISTER_MATCHER(materializeTemporaryExpr); 362 REGISTER_MATCHER(member); 363 REGISTER_MATCHER(memberExpr); 364 REGISTER_MATCHER(memberPointerType); 365 REGISTER_MATCHER(namedDecl); 366 REGISTER_MATCHER(namespaceAliasDecl); 367 REGISTER_MATCHER(namespaceDecl); 368 REGISTER_MATCHER(namesType); 369 REGISTER_MATCHER(nestedNameSpecifier); 370 REGISTER_MATCHER(nestedNameSpecifierLoc); 371 REGISTER_MATCHER(nullPointerConstant); 372 REGISTER_MATCHER(nullStmt); 373 REGISTER_MATCHER(numSelectorArgs); 374 REGISTER_MATCHER(ofClass); 375 REGISTER_MATCHER(objcCategoryDecl); 376 REGISTER_MATCHER(objcInterfaceDecl); 377 REGISTER_MATCHER(objcIvarDecl); 378 REGISTER_MATCHER(objcMessageExpr); 379 REGISTER_MATCHER(objcMethodDecl); 380 REGISTER_MATCHER(objcObjectPointerType); 381 REGISTER_MATCHER(objcPropertyDecl); 382 REGISTER_MATCHER(objcProtocolDecl); 383 REGISTER_MATCHER(on); 384 REGISTER_MATCHER(onImplicitObjectArgument); 385 REGISTER_MATCHER(opaqueValueExpr); 386 REGISTER_MATCHER(parameterCountIs); 387 REGISTER_MATCHER(parenExpr); 388 REGISTER_MATCHER(parenListExpr); 389 REGISTER_MATCHER(parenType); 390 REGISTER_MATCHER(parmVarDecl); 391 REGISTER_MATCHER(pointee); 392 REGISTER_MATCHER(pointerType); 393 REGISTER_MATCHER(predefinedExpr); 394 REGISTER_MATCHER(qualType); 395 REGISTER_MATCHER(realFloatingPointType); 396 REGISTER_MATCHER(recordDecl); 397 REGISTER_MATCHER(recordType); 398 REGISTER_MATCHER(referenceType); 399 REGISTER_MATCHER(refersToDeclaration); 400 REGISTER_MATCHER(refersToIntegralType); 401 REGISTER_MATCHER(refersToType); 402 REGISTER_MATCHER(requiresZeroInitialization); 403 REGISTER_MATCHER(returns); 404 REGISTER_MATCHER(returnStmt); 405 REGISTER_MATCHER(rValueReferenceType); 406 REGISTER_MATCHER(sizeOfExpr); 407 REGISTER_MATCHER(specifiesNamespace); 408 REGISTER_MATCHER(specifiesType); 409 REGISTER_MATCHER(specifiesTypeLoc); 410 REGISTER_MATCHER(statementCountIs); 411 REGISTER_MATCHER(staticAssertDecl); 412 REGISTER_MATCHER(stmt); 413 REGISTER_MATCHER(stmtExpr); 414 REGISTER_MATCHER(stringLiteral); 415 REGISTER_MATCHER(substNonTypeTemplateParmExpr); 416 REGISTER_MATCHER(substTemplateTypeParmType); 417 REGISTER_MATCHER(switchCase); 418 REGISTER_MATCHER(switchStmt); 419 REGISTER_MATCHER(templateArgument); 420 REGISTER_MATCHER(templateName); 421 REGISTER_MATCHER(templateArgumentCountIs); 422 REGISTER_MATCHER(templateSpecializationType); 423 REGISTER_MATCHER(templateTypeParmDecl); 424 REGISTER_MATCHER(templateTypeParmType); 425 REGISTER_MATCHER(throughUsingDecl); 426 REGISTER_MATCHER(to); 427 REGISTER_MATCHER(translationUnitDecl); 428 REGISTER_MATCHER(type); 429 REGISTER_MATCHER(typedefDecl); 430 REGISTER_MATCHER(typedefNameDecl); 431 REGISTER_MATCHER(typedefType); 432 REGISTER_MATCHER(typeAliasDecl); 433 REGISTER_MATCHER(typeAliasTemplateDecl); 434 REGISTER_MATCHER(typeLoc); 435 REGISTER_MATCHER(unaryExprOrTypeTraitExpr); 436 REGISTER_MATCHER(unaryOperator); 437 REGISTER_MATCHER(unaryTransformType); 438 REGISTER_MATCHER(unless); 439 REGISTER_MATCHER(unresolvedLookupExpr); 440 REGISTER_MATCHER(unresolvedUsingTypenameDecl); 441 REGISTER_MATCHER(unresolvedUsingValueDecl); 442 REGISTER_MATCHER(userDefinedLiteral); 443 REGISTER_MATCHER(usingDecl); 444 REGISTER_MATCHER(usingDirectiveDecl); 445 REGISTER_MATCHER(valueDecl); 446 REGISTER_MATCHER(varDecl); 447 REGISTER_MATCHER(variableArrayType); 448 REGISTER_MATCHER(voidType); 449 REGISTER_MATCHER(whileStmt); 450 REGISTER_MATCHER(withInitializer); 451} 452 453RegistryMaps::~RegistryMaps() {} 454 455static llvm::ManagedStatic<RegistryMaps> RegistryData; 456 457} // anonymous namespace 458 459// static 460llvm::Optional<MatcherCtor> Registry::lookupMatcherCtor(StringRef MatcherName) { 461 auto it = RegistryData->constructors().find(MatcherName); 462 return it == RegistryData->constructors().end() 463 ? llvm::Optional<MatcherCtor>() 464 : it->second.get(); 465} 466 467namespace { 468 469llvm::raw_ostream &operator<<(llvm::raw_ostream &OS, 470 const std::set<ASTNodeKind> &KS) { 471 unsigned Count = 0; 472 for (std::set<ASTNodeKind>::const_iterator I = KS.begin(), E = KS.end(); 473 I != E; ++I) { 474 if (I != KS.begin()) 475 OS << "|"; 476 if (Count++ == 3) { 477 OS << "..."; 478 break; 479 } 480 OS << *I; 481 } 482 return OS; 483} 484 485} // namespace 486 487std::vector<ArgKind> Registry::getAcceptedCompletionTypes( 488 ArrayRef<std::pair<MatcherCtor, unsigned>> Context) { 489 ASTNodeKind InitialTypes[] = { 490 ASTNodeKind::getFromNodeKind<Decl>(), 491 ASTNodeKind::getFromNodeKind<QualType>(), 492 ASTNodeKind::getFromNodeKind<Type>(), 493 ASTNodeKind::getFromNodeKind<Stmt>(), 494 ASTNodeKind::getFromNodeKind<NestedNameSpecifier>(), 495 ASTNodeKind::getFromNodeKind<NestedNameSpecifierLoc>(), 496 ASTNodeKind::getFromNodeKind<TypeLoc>()}; 497 498 // Starting with the above seed of acceptable top-level matcher types, compute 499 // the acceptable type set for the argument indicated by each context element. 500 std::set<ArgKind> TypeSet(std::begin(InitialTypes), std::end(InitialTypes)); 501 for (const auto &CtxEntry : Context) { 502 MatcherCtor Ctor = CtxEntry.first; 503 unsigned ArgNumber = CtxEntry.second; 504 std::vector<ArgKind> NextTypeSet; 505 for (const ArgKind &Kind : TypeSet) { 506 if (Kind.getArgKind() == Kind.AK_Matcher && 507 Ctor->isConvertibleTo(Kind.getMatcherKind()) && 508 (Ctor->isVariadic() || ArgNumber < Ctor->getNumArgs())) 509 Ctor->getArgKinds(Kind.getMatcherKind(), ArgNumber, NextTypeSet); 510 } 511 TypeSet.clear(); 512 TypeSet.insert(NextTypeSet.begin(), NextTypeSet.end()); 513 } 514 return std::vector<ArgKind>(TypeSet.begin(), TypeSet.end()); 515} 516 517std::vector<MatcherCompletion> 518Registry::getMatcherCompletions(ArrayRef<ArgKind> AcceptedTypes) { 519 std::vector<MatcherCompletion> Completions; 520 521 // Search the registry for acceptable matchers. 522 for (const auto &M : RegistryData->constructors()) { 523 const MatcherDescriptor& Matcher = *M.getValue(); 524 StringRef Name = M.getKey(); 525 526 std::set<ASTNodeKind> RetKinds; 527 unsigned NumArgs = Matcher.isVariadic() ? 1 : Matcher.getNumArgs(); 528 bool IsPolymorphic = Matcher.isPolymorphic(); 529 std::vector<std::vector<ArgKind>> ArgsKinds(NumArgs); 530 unsigned MaxSpecificity = 0; 531 for (const ArgKind& Kind : AcceptedTypes) { 532 if (Kind.getArgKind() != Kind.AK_Matcher) 533 continue; 534 unsigned Specificity; 535 ASTNodeKind LeastDerivedKind; 536 if (Matcher.isConvertibleTo(Kind.getMatcherKind(), &Specificity, 537 &LeastDerivedKind)) { 538 if (MaxSpecificity < Specificity) 539 MaxSpecificity = Specificity; 540 RetKinds.insert(LeastDerivedKind); 541 for (unsigned Arg = 0; Arg != NumArgs; ++Arg) 542 Matcher.getArgKinds(Kind.getMatcherKind(), Arg, ArgsKinds[Arg]); 543 if (IsPolymorphic) 544 break; 545 } 546 } 547 548 if (!RetKinds.empty() && MaxSpecificity > 0) { 549 std::string Decl; 550 llvm::raw_string_ostream OS(Decl); 551 552 if (IsPolymorphic) { 553 OS << "Matcher<T> " << Name << "(Matcher<T>"; 554 } else { 555 OS << "Matcher<" << RetKinds << "> " << Name << "("; 556 for (const std::vector<ArgKind> &Arg : ArgsKinds) { 557 if (&Arg != &ArgsKinds[0]) 558 OS << ", "; 559 560 bool FirstArgKind = true; 561 std::set<ASTNodeKind> MatcherKinds; 562 // Two steps. First all non-matchers, then matchers only. 563 for (const ArgKind &AK : Arg) { 564 if (AK.getArgKind() == ArgKind::AK_Matcher) { 565 MatcherKinds.insert(AK.getMatcherKind()); 566 } else { 567 if (!FirstArgKind) OS << "|"; 568 FirstArgKind = false; 569 OS << AK.asString(); 570 } 571 } 572 if (!MatcherKinds.empty()) { 573 if (!FirstArgKind) OS << "|"; 574 OS << "Matcher<" << MatcherKinds << ">"; 575 } 576 } 577 } 578 if (Matcher.isVariadic()) 579 OS << "..."; 580 OS << ")"; 581 582 std::string TypedText = Name; 583 TypedText += "("; 584 if (ArgsKinds.empty()) 585 TypedText += ")"; 586 else if (ArgsKinds[0][0].getArgKind() == ArgKind::AK_String) 587 TypedText += "\""; 588 589 Completions.emplace_back(TypedText, OS.str(), MaxSpecificity); 590 } 591 } 592 593 return Completions; 594} 595 596// static 597VariantMatcher Registry::constructMatcher(MatcherCtor Ctor, 598 SourceRange NameRange, 599 ArrayRef<ParserValue> Args, 600 Diagnostics *Error) { 601 return Ctor->create(NameRange, Args, Error); 602} 603 604// static 605VariantMatcher Registry::constructBoundMatcher(MatcherCtor Ctor, 606 SourceRange NameRange, 607 StringRef BindID, 608 ArrayRef<ParserValue> Args, 609 Diagnostics *Error) { 610 VariantMatcher Out = constructMatcher(Ctor, NameRange, Args, Error); 611 if (Out.isNull()) return Out; 612 613 llvm::Optional<DynTypedMatcher> Result = Out.getSingleMatcher(); 614 if (Result.hasValue()) { 615 llvm::Optional<DynTypedMatcher> Bound = Result->tryBind(BindID); 616 if (Bound.hasValue()) { 617 return VariantMatcher::SingleMatcher(*Bound); 618 } 619 } 620 Error->addError(NameRange, Error->ET_RegistryNotBindable); 621 return VariantMatcher(); 622} 623 624} // namespace dynamic 625} // namespace ast_matchers 626} // namespace clang 627