1 | |
2 | |
3 | |
4 | |
5 | |
6 | |
7 | |
8 | |
9 | |
10 | |
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 | |
34 | using namespace clang::ast_type_traits; |
35 | |
36 | namespace clang { |
37 | namespace ast_matchers { |
38 | namespace dynamic { |
39 | |
40 | namespace { |
41 | |
42 | using internal::MatcherDescriptor; |
43 | |
44 | using ConstructorMap = llvm::StringMap<std::unique_ptr<const MatcherDescriptor>>; |
45 | |
46 | class RegistryMaps { |
47 | public: |
48 | RegistryMaps(); |
49 | ~RegistryMaps(); |
50 | |
51 | const ConstructorMap &constructors() const { return Constructors; } |
52 | |
53 | private: |
54 | void registerMatcher(StringRef MatcherName, |
55 | std::unique_ptr<MatcherDescriptor> Callback); |
56 | |
57 | ConstructorMap Constructors; |
58 | }; |
59 | |
60 | } |
61 | |
62 | void RegistryMaps::registerMatcher( |
63 | StringRef MatcherName, std::unique_ptr<MatcherDescriptor> Callback) { |
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 | |
93 | |
94 | RegistryMaps::RegistryMaps() { |
95 | |
96 | |
97 | |
98 | |
99 | |
100 | |
101 | |
102 | |
103 | |
104 | |
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<MatcherDescriptor> equalsCallbacks[] = { |
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 | |
520 | RegistryMaps::~RegistryMaps() = default; |
521 | |
522 | static llvm::ManagedStatic<RegistryMaps> RegistryData; |
523 | |
524 | |
525 | llvm::Optional<MatcherCtor> Registry::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 | |
532 | static 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 | |
548 | std::vector<ArgKind> Registry::getAcceptedCompletionTypes( |
549 | ArrayRef<std::pair<MatcherCtor, unsigned>> 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 | |
560 | |
561 | std::set<ArgKind> TypeSet(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 | |
578 | std::vector<MatcherCompletion> |
579 | Registry::getMatcherCompletions(ArrayRef<ArgKind> AcceptedTypes) { |
580 | std::vector<MatcherCompletion> Completions; |
581 | |
582 | |
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 | |
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 | |
657 | VariantMatcher Registry::constructMatcher(MatcherCtor Ctor, |
658 | SourceRange NameRange, |
659 | ArrayRef<ParserValue> Args, |
660 | Diagnostics *Error) { |
661 | return Ctor->create(NameRange, Args, Error); |
662 | } |
663 | |
664 | VariantMatcher Registry::constructBoundMatcher(MatcherCtor Ctor, |
665 | SourceRange NameRange, |
666 | StringRef BindID, |
667 | ArrayRef<ParserValue> Args, |
668 | Diagnostics *Error) { |
669 | VariantMatcher Out = constructMatcher(Ctor, NameRange, Args, Error); |
670 | if (Out.isNull()) return Out; |
671 | |
672 | llvm::Optional<DynTypedMatcher> Result = Out.getSingleMatcher(); |
673 | if (Result.hasValue()) { |
674 | llvm::Optional<DynTypedMatcher> Bound = Result->tryBind(BindID); |
675 | if (Bound.hasValue()) { |
676 | return VariantMatcher::SingleMatcher(*Bound); |
677 | } |
678 | } |
679 | Error->addError(NameRange, Error->ET_RegistryNotBindable); |
680 | return VariantMatcher(); |
681 | } |
682 | |
683 | } |
684 | } |
685 | } |
686 | |