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