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/StringMap.h" 19 #include "llvm/ADT/StringRef.h" 20 #include "llvm/Support/ManagedStatic.h" 21 #include <set> 22 #include <utility> 23 24 using namespace clang::ast_type_traits; 25 26 namespace clang { 27 namespace ast_matchers { 28 namespace dynamic { 29 namespace { 30 31 using internal::MatcherDescriptor; 32 33 typedef llvm::StringMap<const MatcherDescriptor *> ConstructorMap; 34 class RegistryMaps { 35 public: 36 RegistryMaps(); 37 ~RegistryMaps(); 38 39 const ConstructorMap &constructors() const { return Constructors; } 40 41 private: 42 void registerMatcher(StringRef MatcherName, MatcherDescriptor *Callback); 43 ConstructorMap Constructors; 44 }; 45 46 void RegistryMaps::registerMatcher(StringRef MatcherName, 47 MatcherDescriptor *Callback) { 48 assert(Constructors.find(MatcherName) == Constructors.end()); 49 Constructors[MatcherName] = Callback; 50 } 51 52 #define REGISTER_MATCHER(name) \ 53 registerMatcher(#name, internal::makeMatcherAutoMarshall( \ 54 ::clang::ast_matchers::name, #name)); 55 56 #define SPECIFIC_MATCHER_OVERLOAD(name, Id) \ 57 static_cast< ::clang::ast_matchers::name##_Type##Id>( \ 58 ::clang::ast_matchers::name) 59 60 #define REGISTER_OVERLOADED_2(name) \ 61 do { \ 62 MatcherDescriptor *Callbacks[] = { \ 63 internal::makeMatcherAutoMarshall(SPECIFIC_MATCHER_OVERLOAD(name, 0), \ 64 #name), \ 65 internal::makeMatcherAutoMarshall(SPECIFIC_MATCHER_OVERLOAD(name, 1), \ 66 #name) \ 67 }; \ 68 registerMatcher(#name, \ 69 new internal::OverloadedMatcherDescriptor(Callbacks)); \ 70 } while (0) 71 72 /// \brief Generate a registry map with all the known matchers. 73 RegistryMaps::RegistryMaps() { 74 // TODO: Here is the list of the missing matchers, grouped by reason. 75 // 76 // Need Variant/Parser fixes: 77 // ofKind 78 // 79 // Polymorphic + argument overload: 80 // findAll 81 // 82 // Other: 83 // equals 84 // equalsNode 85 86 REGISTER_OVERLOADED_2(callee); 87 REGISTER_OVERLOADED_2(hasPrefix); 88 REGISTER_OVERLOADED_2(hasType); 89 REGISTER_OVERLOADED_2(isDerivedFrom); 90 REGISTER_OVERLOADED_2(isSameOrDerivedFrom); 91 REGISTER_OVERLOADED_2(loc); 92 REGISTER_OVERLOADED_2(pointsTo); 93 REGISTER_OVERLOADED_2(references); 94 REGISTER_OVERLOADED_2(thisPointerType); 95 96 REGISTER_MATCHER(accessSpecDecl); 97 REGISTER_MATCHER(alignOfExpr); 98 REGISTER_MATCHER(allOf); 99 REGISTER_MATCHER(anyOf); 100 REGISTER_MATCHER(anything); 101 REGISTER_MATCHER(argumentCountIs); 102 REGISTER_MATCHER(arraySubscriptExpr); 103 REGISTER_MATCHER(arrayType); 104 REGISTER_MATCHER(asString); 105 REGISTER_MATCHER(asmStmt); 106 REGISTER_MATCHER(atomicType); 107 REGISTER_MATCHER(autoType); 108 REGISTER_MATCHER(binaryOperator); 109 REGISTER_MATCHER(bindTemporaryExpr); 110 REGISTER_MATCHER(blockPointerType); 111 REGISTER_MATCHER(boolLiteral); 112 REGISTER_MATCHER(breakStmt); 113 REGISTER_MATCHER(builtinType); 114 REGISTER_MATCHER(cStyleCastExpr); 115 REGISTER_MATCHER(callExpr); 116 REGISTER_MATCHER(caseStmt); 117 REGISTER_MATCHER(castExpr); 118 REGISTER_MATCHER(catchStmt); 119 REGISTER_MATCHER(characterLiteral); 120 REGISTER_MATCHER(classTemplateDecl); 121 REGISTER_MATCHER(classTemplateSpecializationDecl); 122 REGISTER_MATCHER(complexType); 123 REGISTER_MATCHER(compoundLiteralExpr); 124 REGISTER_MATCHER(compoundStmt); 125 REGISTER_MATCHER(conditionalOperator); 126 REGISTER_MATCHER(constCastExpr); 127 REGISTER_MATCHER(constantArrayType); 128 REGISTER_MATCHER(constructExpr); 129 REGISTER_MATCHER(constructorDecl); 130 REGISTER_MATCHER(containsDeclaration); 131 REGISTER_MATCHER(continueStmt); 132 REGISTER_MATCHER(ctorInitializer); 133 REGISTER_MATCHER(decl); 134 REGISTER_MATCHER(declCountIs); 135 REGISTER_MATCHER(declRefExpr); 136 REGISTER_MATCHER(declStmt); 137 REGISTER_MATCHER(declaratorDecl); 138 REGISTER_MATCHER(defaultArgExpr); 139 REGISTER_MATCHER(defaultStmt); 140 REGISTER_MATCHER(deleteExpr); 141 REGISTER_MATCHER(dependentSizedArrayType); 142 REGISTER_MATCHER(destructorDecl); 143 REGISTER_MATCHER(doStmt); 144 REGISTER_MATCHER(dynamicCastExpr); 145 REGISTER_MATCHER(eachOf); 146 REGISTER_MATCHER(elaboratedType); 147 REGISTER_MATCHER(enumConstantDecl); 148 REGISTER_MATCHER(enumDecl); 149 REGISTER_MATCHER(equalsBoundNode); 150 REGISTER_MATCHER(explicitCastExpr); 151 REGISTER_MATCHER(expr); 152 REGISTER_MATCHER(fieldDecl); 153 REGISTER_MATCHER(floatLiteral); 154 REGISTER_MATCHER(forEach); 155 REGISTER_MATCHER(forEachConstructorInitializer); 156 REGISTER_MATCHER(forEachDescendant); 157 REGISTER_MATCHER(forEachSwitchCase); 158 REGISTER_MATCHER(forField); 159 REGISTER_MATCHER(forRangeStmt); 160 REGISTER_MATCHER(forStmt); 161 REGISTER_MATCHER(friendDecl); 162 REGISTER_MATCHER(functionDecl); 163 REGISTER_MATCHER(functionTemplateDecl); 164 REGISTER_MATCHER(functionType); 165 REGISTER_MATCHER(functionalCastExpr); 166 REGISTER_MATCHER(gotoStmt); 167 REGISTER_MATCHER(has); 168 REGISTER_MATCHER(hasAncestor); 169 REGISTER_MATCHER(hasAnyArgument); 170 REGISTER_MATCHER(hasAnyConstructorInitializer); 171 REGISTER_MATCHER(hasAnyParameter); 172 REGISTER_MATCHER(hasAnySubstatement); 173 REGISTER_MATCHER(hasAnyTemplateArgument); 174 REGISTER_MATCHER(hasAnyUsingShadowDecl); 175 REGISTER_MATCHER(hasArgument); 176 REGISTER_MATCHER(hasArgumentOfType); 177 REGISTER_MATCHER(hasBase); 178 REGISTER_MATCHER(hasBody); 179 REGISTER_MATCHER(hasCanonicalType); 180 REGISTER_MATCHER(hasCaseConstant); 181 REGISTER_MATCHER(hasCondition); 182 REGISTER_MATCHER(hasConditionVariableStatement); 183 REGISTER_MATCHER(hasDeclContext); 184 REGISTER_MATCHER(hasDeclaration); 185 REGISTER_MATCHER(hasDeducedType); 186 REGISTER_MATCHER(hasDescendant); 187 REGISTER_MATCHER(hasDestinationType); 188 REGISTER_MATCHER(hasEitherOperand); 189 REGISTER_MATCHER(hasElementType); 190 REGISTER_MATCHER(hasFalseExpression); 191 REGISTER_MATCHER(hasImplicitDestinationType); 192 REGISTER_MATCHER(hasIncrement); 193 REGISTER_MATCHER(hasIndex); 194 REGISTER_MATCHER(hasInitializer); 195 REGISTER_MATCHER(hasLHS); 196 REGISTER_MATCHER(hasLocalQualifiers); 197 REGISTER_MATCHER(hasLoopInit); 198 REGISTER_MATCHER(hasMethod); 199 REGISTER_MATCHER(hasName); 200 REGISTER_MATCHER(hasObjectExpression); 201 REGISTER_MATCHER(hasOperatorName); 202 REGISTER_MATCHER(hasOverloadedOperatorName); 203 REGISTER_MATCHER(hasParameter); 204 REGISTER_MATCHER(hasParent); 205 REGISTER_MATCHER(hasQualifier); 206 REGISTER_MATCHER(hasRHS); 207 REGISTER_MATCHER(hasSingleDecl); 208 REGISTER_MATCHER(hasSize); 209 REGISTER_MATCHER(hasSizeExpr); 210 REGISTER_MATCHER(hasSourceExpression); 211 REGISTER_MATCHER(hasTargetDecl); 212 REGISTER_MATCHER(hasTemplateArgument); 213 REGISTER_MATCHER(hasTrueExpression); 214 REGISTER_MATCHER(hasTypeLoc); 215 REGISTER_MATCHER(hasUnaryOperand); 216 REGISTER_MATCHER(hasValueType); 217 REGISTER_MATCHER(ifStmt); 218 REGISTER_MATCHER(ignoringImpCasts); 219 REGISTER_MATCHER(ignoringParenCasts); 220 REGISTER_MATCHER(ignoringParenImpCasts); 221 REGISTER_MATCHER(implicitCastExpr); 222 REGISTER_MATCHER(incompleteArrayType); 223 REGISTER_MATCHER(initListExpr); 224 REGISTER_MATCHER(innerType); 225 REGISTER_MATCHER(integerLiteral); 226 REGISTER_MATCHER(isArrow); 227 REGISTER_MATCHER(isConst); 228 REGISTER_MATCHER(isConstQualified); 229 REGISTER_MATCHER(isDefinition); 230 REGISTER_MATCHER(isExplicitTemplateSpecialization); 231 REGISTER_MATCHER(isExpr); 232 REGISTER_MATCHER(isExternC); 233 REGISTER_MATCHER(isImplicit); 234 REGISTER_MATCHER(isInteger); 235 REGISTER_MATCHER(isListInitialization); 236 REGISTER_MATCHER(isOverride); 237 REGISTER_MATCHER(isPrivate); 238 REGISTER_MATCHER(isProtected); 239 REGISTER_MATCHER(isPublic); 240 REGISTER_MATCHER(isTemplateInstantiation); 241 REGISTER_MATCHER(isVirtual); 242 REGISTER_MATCHER(isWritten); 243 REGISTER_MATCHER(lValueReferenceType); 244 REGISTER_MATCHER(labelStmt); 245 REGISTER_MATCHER(lambdaExpr); 246 REGISTER_MATCHER(matchesName); 247 REGISTER_MATCHER(materializeTemporaryExpr); 248 REGISTER_MATCHER(member); 249 REGISTER_MATCHER(memberCallExpr); 250 REGISTER_MATCHER(memberExpr); 251 REGISTER_MATCHER(memberPointerType); 252 REGISTER_MATCHER(methodDecl); 253 REGISTER_MATCHER(namedDecl); 254 REGISTER_MATCHER(namesType); 255 REGISTER_MATCHER(namespaceDecl); 256 REGISTER_MATCHER(nestedNameSpecifier); 257 REGISTER_MATCHER(nestedNameSpecifierLoc); 258 REGISTER_MATCHER(newExpr); 259 REGISTER_MATCHER(nullPtrLiteralExpr); 260 REGISTER_MATCHER(nullStmt); 261 REGISTER_MATCHER(ofClass); 262 REGISTER_MATCHER(on); 263 REGISTER_MATCHER(onImplicitObjectArgument); 264 REGISTER_MATCHER(operatorCallExpr); 265 REGISTER_MATCHER(parameterCountIs); 266 REGISTER_MATCHER(parenType); 267 REGISTER_MATCHER(parmVarDecl); 268 REGISTER_MATCHER(pointee); 269 REGISTER_MATCHER(pointerType); 270 REGISTER_MATCHER(qualType); 271 REGISTER_MATCHER(rValueReferenceType); 272 REGISTER_MATCHER(recordDecl); 273 REGISTER_MATCHER(recordType); 274 REGISTER_MATCHER(referenceType); 275 REGISTER_MATCHER(refersToDeclaration); 276 REGISTER_MATCHER(refersToType); 277 REGISTER_MATCHER(reinterpretCastExpr); 278 REGISTER_MATCHER(returnStmt); 279 REGISTER_MATCHER(returns); 280 REGISTER_MATCHER(sizeOfExpr); 281 REGISTER_MATCHER(specifiesNamespace); 282 REGISTER_MATCHER(specifiesType); 283 REGISTER_MATCHER(specifiesTypeLoc); 284 REGISTER_MATCHER(statementCountIs); 285 REGISTER_MATCHER(staticCastExpr); 286 REGISTER_MATCHER(stmt); 287 REGISTER_MATCHER(stringLiteral); 288 REGISTER_MATCHER(switchCase); 289 REGISTER_MATCHER(switchStmt); 290 REGISTER_MATCHER(templateSpecializationType); 291 REGISTER_MATCHER(temporaryObjectExpr); 292 REGISTER_MATCHER(thisExpr); 293 REGISTER_MATCHER(throughUsingDecl); 294 REGISTER_MATCHER(throwExpr); 295 REGISTER_MATCHER(to); 296 REGISTER_MATCHER(tryStmt); 297 REGISTER_MATCHER(type); 298 REGISTER_MATCHER(typeLoc); 299 REGISTER_MATCHER(typedefType); 300 REGISTER_MATCHER(unaryExprOrTypeTraitExpr); 301 REGISTER_MATCHER(unaryOperator); 302 REGISTER_MATCHER(unaryTransformType); 303 REGISTER_MATCHER(unless); 304 REGISTER_MATCHER(unresolvedConstructExpr); 305 REGISTER_MATCHER(unresolvedUsingValueDecl); 306 REGISTER_MATCHER(userDefinedLiteral); 307 REGISTER_MATCHER(usingDecl); 308 REGISTER_MATCHER(varDecl); 309 REGISTER_MATCHER(variableArrayType); 310 REGISTER_MATCHER(whileStmt); 311 REGISTER_MATCHER(withInitializer); 312 } 313 314 RegistryMaps::~RegistryMaps() { 315 for (ConstructorMap::iterator it = Constructors.begin(), 316 end = Constructors.end(); 317 it != end; ++it) { 318 delete it->second; 319 } 320 } 321 322 static llvm::ManagedStatic<RegistryMaps> RegistryData; 323 324 } // anonymous namespace 325 326 // static 327 llvm::Optional<MatcherCtor> 328 Registry::lookupMatcherCtor(StringRef MatcherName, const SourceRange &NameRange, 329 Diagnostics *Error) { 330 ConstructorMap::const_iterator it = 331 RegistryData->constructors().find(MatcherName); 332 if (it == RegistryData->constructors().end()) { 333 Error->addError(NameRange, Error->ET_RegistryNotFound) << MatcherName; 334 return llvm::Optional<MatcherCtor>(); 335 } 336 337 return it->second; 338 } 339 340 namespace { 341 342 llvm::raw_ostream &operator<<(llvm::raw_ostream &OS, 343 const std::set<ASTNodeKind> &KS) { 344 unsigned Count = 0; 345 for (std::set<ASTNodeKind>::const_iterator I = KS.begin(), E = KS.end(); 346 I != E; ++I) { 347 if (I != KS.begin()) 348 OS << "|"; 349 if (Count++ == 3) { 350 OS << "..."; 351 break; 352 } 353 OS << *I; 354 } 355 return OS; 356 } 357 358 struct ReverseSpecificityThenName { 359 bool operator()(const std::pair<unsigned, std::string> &A, 360 const std::pair<unsigned, std::string> &B) const { 361 return A.first > B.first || (A.first == B.first && A.second < B.second); 362 } 363 }; 364 365 } 366 367 std::vector<MatcherCompletion> Registry::getCompletions( 368 llvm::ArrayRef<std::pair<MatcherCtor, unsigned> > Context) { 369 ASTNodeKind InitialTypes[] = { 370 ASTNodeKind::getFromNodeKind<Decl>(), 371 ASTNodeKind::getFromNodeKind<QualType>(), 372 ASTNodeKind::getFromNodeKind<Type>(), 373 ASTNodeKind::getFromNodeKind<Stmt>(), 374 ASTNodeKind::getFromNodeKind<NestedNameSpecifier>(), 375 ASTNodeKind::getFromNodeKind<NestedNameSpecifierLoc>(), 376 ASTNodeKind::getFromNodeKind<TypeLoc>() 377 }; 378 llvm::ArrayRef<ASTNodeKind> InitialTypesRef(InitialTypes); 379 380 // Starting with the above seed of acceptable top-level matcher types, compute 381 // the acceptable type set for the argument indicated by each context element. 382 std::set<ASTNodeKind> TypeSet(InitialTypesRef.begin(), InitialTypesRef.end()); 383 for (llvm::ArrayRef<std::pair<MatcherCtor, unsigned> >::iterator 384 CtxI = Context.begin(), 385 CtxE = Context.end(); 386 CtxI != CtxE; ++CtxI) { 387 std::vector<internal::ArgKind> NextTypeSet; 388 for (std::set<ASTNodeKind>::iterator I = TypeSet.begin(), E = TypeSet.end(); 389 I != E; ++I) { 390 if (CtxI->first->isConvertibleTo(*I) && 391 (CtxI->first->isVariadic() || 392 CtxI->second < CtxI->first->getNumArgs())) 393 CtxI->first->getArgKinds(*I, CtxI->second, NextTypeSet); 394 } 395 TypeSet.clear(); 396 for (std::vector<internal::ArgKind>::iterator I = NextTypeSet.begin(), 397 E = NextTypeSet.end(); 398 I != E; ++I) { 399 if (I->getArgKind() == internal::ArgKind::AK_Matcher) 400 TypeSet.insert(I->getMatcherKind()); 401 } 402 } 403 404 typedef std::map<std::pair<unsigned, std::string>, MatcherCompletion, 405 ReverseSpecificityThenName> CompletionsTy; 406 CompletionsTy Completions; 407 408 // TypeSet now contains the list of acceptable types for the argument we are 409 // completing. Search the registry for acceptable matchers. 410 for (ConstructorMap::const_iterator I = RegistryData->constructors().begin(), 411 E = RegistryData->constructors().end(); 412 I != E; ++I) { 413 std::set<ASTNodeKind> RetKinds; 414 unsigned NumArgs = I->second->isVariadic() ? 1 : I->second->getNumArgs(); 415 bool IsPolymorphic = I->second->isPolymorphic(); 416 std::vector<std::vector<internal::ArgKind> > ArgsKinds(NumArgs); 417 unsigned MaxSpecificity = 0; 418 for (std::set<ASTNodeKind>::iterator TI = TypeSet.begin(), 419 TE = TypeSet.end(); 420 TI != TE; ++TI) { 421 unsigned Specificity; 422 ASTNodeKind LeastDerivedKind; 423 if (I->second->isConvertibleTo(*TI, &Specificity, &LeastDerivedKind)) { 424 if (MaxSpecificity < Specificity) 425 MaxSpecificity = Specificity; 426 RetKinds.insert(LeastDerivedKind); 427 for (unsigned Arg = 0; Arg != NumArgs; ++Arg) 428 I->second->getArgKinds(*TI, Arg, ArgsKinds[Arg]); 429 if (IsPolymorphic) 430 break; 431 } 432 } 433 434 if (!RetKinds.empty() && MaxSpecificity > 0) { 435 std::string Decl; 436 llvm::raw_string_ostream OS(Decl); 437 438 if (IsPolymorphic) { 439 OS << "Matcher<T> " << I->first() << "(Matcher<T>"; 440 } else { 441 OS << "Matcher<" << RetKinds << "> " << I->first() << "("; 442 for (std::vector<std::vector<internal::ArgKind> >::iterator 443 KI = ArgsKinds.begin(), 444 KE = ArgsKinds.end(); 445 KI != KE; ++KI) { 446 if (KI != ArgsKinds.begin()) 447 OS << ", "; 448 // This currently assumes that a matcher may not overload a 449 // non-matcher, and all non-matcher overloads have identical 450 // arguments. 451 if ((*KI)[0].getArgKind() == internal::ArgKind::AK_Matcher) { 452 std::set<ASTNodeKind> MatcherKinds; 453 std::transform( 454 KI->begin(), KI->end(), 455 std::inserter(MatcherKinds, MatcherKinds.end()), 456 std::mem_fun_ref(&internal::ArgKind::getMatcherKind)); 457 OS << "Matcher<" << MatcherKinds << ">"; 458 } else { 459 OS << (*KI)[0].asString(); 460 } 461 } 462 } 463 if (I->second->isVariadic()) 464 OS << "..."; 465 OS << ")"; 466 467 std::string TypedText = I->first(); 468 TypedText += "("; 469 if (ArgsKinds.empty()) 470 TypedText += ")"; 471 else if (ArgsKinds[0][0].getArgKind() == internal::ArgKind::AK_String) 472 TypedText += "\""; 473 474 Completions[std::make_pair(MaxSpecificity, I->first())] = 475 MatcherCompletion(TypedText, OS.str()); 476 } 477 } 478 479 std::vector<MatcherCompletion> RetVal; 480 for (CompletionsTy::iterator I = Completions.begin(), E = Completions.end(); 481 I != E; ++I) 482 RetVal.push_back(I->second); 483 return RetVal; 484 } 485 486 // static 487 VariantMatcher Registry::constructMatcher(MatcherCtor Ctor, 488 const SourceRange &NameRange, 489 ArrayRef<ParserValue> Args, 490 Diagnostics *Error) { 491 return Ctor->create(NameRange, Args, Error); 492 } 493 494 // static 495 VariantMatcher Registry::constructBoundMatcher(MatcherCtor Ctor, 496 const SourceRange &NameRange, 497 StringRef BindID, 498 ArrayRef<ParserValue> Args, 499 Diagnostics *Error) { 500 VariantMatcher Out = constructMatcher(Ctor, NameRange, Args, Error); 501 if (Out.isNull()) return Out; 502 503 llvm::Optional<DynTypedMatcher> Result = Out.getSingleMatcher(); 504 if (Result.hasValue()) { 505 llvm::Optional<DynTypedMatcher> Bound = Result->tryBind(BindID); 506 if (Bound.hasValue()) { 507 return VariantMatcher::SingleMatcher(*Bound); 508 } 509 } 510 Error->addError(NameRange, Error->ET_RegistryNotBindable); 511 return VariantMatcher(); 512 } 513 514 } // namespace dynamic 515 } // namespace ast_matchers 516 } // namespace clang 517