Clang Project

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