003 File Manager
Current Path:
/usr/src/contrib/llvm-project/clang/include/clang/AST
usr
/
src
/
contrib
/
llvm-project
/
clang
/
include
/
clang
/
AST
/
📁
..
📄
APValue.h
(20.92 KB)
📄
AST.h
(907 B)
📄
ASTConcept.h
(7.02 KB)
📄
ASTConsumer.h
(5.99 KB)
📄
ASTContext.h
(122.68 KB)
📄
ASTContextAllocate.h
(1.33 KB)
📄
ASTDiagnostic.h
(1.34 KB)
📄
ASTDumper.h
(1.59 KB)
📄
ASTDumperUtils.h
(3.49 KB)
📄
ASTFwd.h
(1.01 KB)
📄
ASTImporter.h
(22.86 KB)
📄
ASTImporterLookupTable.h
(2.7 KB)
📄
ASTImporterSharedState.h
(2.51 KB)
📄
ASTLambda.h
(3.04 KB)
📄
ASTMutationListener.h
(5.84 KB)
📄
ASTNodeTraverser.h
(21.38 KB)
📄
ASTStructuralEquivalence.h
(5.08 KB)
📄
ASTTypeTraits.h
(19.65 KB)
📄
ASTUnresolvedSet.h
(3.37 KB)
📄
ASTVector.h
(11.75 KB)
📄
AbstractBasicReader.h
(8.82 KB)
📄
AbstractBasicWriter.h
(7.97 KB)
📄
AbstractTypeReader.h
(922 B)
📄
AbstractTypeWriter.h
(944 B)
📄
Attr.h
(11.87 KB)
📄
AttrIterator.h
(4.14 KB)
📄
AttrVisitor.h
(2.56 KB)
📄
Availability.h
(1.97 KB)
📄
BaseSubobject.h
(2.74 KB)
📄
BuiltinTypes.def
(9.91 KB)
📄
CXXInheritance.h
(14.87 KB)
📄
CXXRecordDeclDefinitionBits.def
(9.23 KB)
📄
CanonicalType.h
(24.86 KB)
📄
CharUnits.h
(8.02 KB)
📄
Comment.h
(31.03 KB)
📄
CommentBriefParser.h
(1.39 KB)
📄
CommentCommandTraits.h
(5.86 KB)
📄
CommentCommands.td
(9.27 KB)
📄
CommentDiagnostic.h
(509 B)
📄
CommentHTMLNamedCharacterReferences.td
(4.98 KB)
📄
CommentHTMLTags.td
(2.17 KB)
📄
CommentLexer.h
(9.96 KB)
📄
CommentParser.h
(3.24 KB)
📄
CommentSema.h
(9.87 KB)
📄
CommentVisitor.h
(2.38 KB)
📄
ComparisonCategories.h
(7.41 KB)
📄
ComputeDependence.h
(7.41 KB)
📄
CurrentSourceLocExprScope.h
(2.43 KB)
📄
DataCollection.h
(2.45 KB)
📄
Decl.h
(168.07 KB)
📄
DeclAccessPair.h
(1.77 KB)
📄
DeclBase.h
(93.13 KB)
📄
DeclCXX.h
(151.69 KB)
📄
DeclContextInternals.h
(8.22 KB)
📄
DeclFriend.h
(8.06 KB)
📄
DeclGroup.h
(4.11 KB)
📄
DeclLookups.h
(3.64 KB)
📄
DeclObjC.h
(101.2 KB)
📄
DeclObjCCommon.h
(1.72 KB)
📄
DeclOpenMP.h
(19.33 KB)
📄
DeclTemplate.h
(122.19 KB)
📄
DeclVisitor.h
(2.51 KB)
📄
DeclarationName.h
(33.77 KB)
📄
DependenceFlags.h
(10.99 KB)
📄
DependentDiagnostic.h
(5.4 KB)
📄
EvaluatedExprVisitor.h
(4.45 KB)
📄
Expr.h
(234.85 KB)
📄
ExprCXX.h
(169.78 KB)
📄
ExprConcepts.h
(19.62 KB)
📄
ExprObjC.h
(58.96 KB)
📄
ExprOpenMP.h
(15.48 KB)
📄
ExternalASTMerger.h
(8.11 KB)
📄
ExternalASTSource.h
(20.55 KB)
📄
FormatString.h
(22.81 KB)
📄
GlobalDecl.h
(7.16 KB)
📄
JSONNodeDumper.h
(17.53 KB)
📄
LambdaCapture.h
(4.71 KB)
📄
LexicallyOrderedRecursiveASTVisitor.h
(5.92 KB)
📄
LocInfoType.h
(1.84 KB)
📄
Mangle.h
(10.65 KB)
📄
MangleNumberingContext.h
(2 KB)
📄
NSAPI.h
(9.23 KB)
📄
NestedNameSpecifier.h
(18.53 KB)
📄
NonTrivialTypeVisitor.h
(4 KB)
📄
ODRHash.h
(3.42 KB)
📄
OSLog.h
(5.08 KB)
📄
OpenMPClause.h
(276.08 KB)
📄
OperationKinds.def
(14.91 KB)
📄
OperationKinds.h
(1.5 KB)
📄
OptionalDiagnostic.h
(2.39 KB)
📄
ParentMap.h
(1.89 KB)
📄
ParentMapContext.h
(4.74 KB)
📄
PrettyDeclStackTrace.h
(1.39 KB)
📄
PrettyPrinter.h
(8.47 KB)
📄
PropertiesBase.td
(17.03 KB)
📄
QualTypeNames.h
(3.15 KB)
📄
RawCommentList.h
(6.6 KB)
📄
RecordLayout.h
(11.49 KB)
📄
RecursiveASTVisitor.h
(124.41 KB)
📄
Redeclarable.h
(14.34 KB)
📄
SelectorLocationsKind.h
(3.28 KB)
📄
Stmt.h
(113 KB)
📄
StmtCXX.h
(17.59 KB)
📄
StmtDataCollectors.td
(5.64 KB)
📄
StmtGraphTraits.h
(2.18 KB)
📄
StmtIterator.h
(4.2 KB)
📄
StmtObjC.h
(12.86 KB)
📄
StmtOpenMP.h
(189.5 KB)
📄
StmtVisitor.h
(8.74 KB)
📄
TemplateArgumentVisitor.h
(3.38 KB)
📄
TemplateBase.h
(22.86 KB)
📄
TemplateName.h
(19.34 KB)
📄
TextNodeDumper.h
(15.7 KB)
📄
Type.h
(248.38 KB)
📄
TypeLoc.h
(73.03 KB)
📄
TypeLocNodes.def
(1.45 KB)
📄
TypeLocVisitor.h
(1.76 KB)
📄
TypeOrdering.h
(2.38 KB)
📄
TypeProperties.td
(25.87 KB)
📄
TypeVisitor.h
(3.32 KB)
📄
UnresolvedSet.h
(5.25 KB)
📄
VTTBuilder.h
(5.19 KB)
📄
VTableBuilder.h
(20.31 KB)
Editing: LexicallyOrderedRecursiveASTVisitor.h
//===--- LexicallyOrderedRecursiveASTVisitor.h - ----------------*- C++ -*-===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // This file defines the LexicallyOrderedRecursiveASTVisitor interface, which // recursively traverses the entire AST in a lexical order. // //===----------------------------------------------------------------------===// #ifndef LLVM_CLANG_AST_LEXICALLY_ORDERED_RECURSIVEASTVISITOR_H #define LLVM_CLANG_AST_LEXICALLY_ORDERED_RECURSIVEASTVISITOR_H #include "clang/AST/RecursiveASTVisitor.h" #include "clang/Basic/LLVM.h" #include "clang/Basic/SourceManager.h" #include "llvm/Support/SaveAndRestore.h" namespace clang { /// A RecursiveASTVisitor subclass that guarantees that AST traversal is /// performed in a lexical order (i.e. the order in which declarations are /// written in the source). /// /// RecursiveASTVisitor doesn't guarantee lexical ordering because there are /// some declarations, like Objective-C @implementation declarations /// that might be represented in the AST differently to how they were written /// in the source. /// In particular, Objective-C @implementation declarations may contain /// non-Objective-C declarations, like functions: /// /// @implementation MyClass /// /// - (void) method { } /// void normalFunction() { } /// /// @end /// /// Clang's AST stores these declarations outside of the @implementation /// declaration, so the example above would be represented using the following /// AST: /// |-ObjCImplementationDecl ... MyClass /// | `-ObjCMethodDecl ... method /// | ... /// `-FunctionDecl ... normalFunction /// ... /// /// This class ensures that these declarations are traversed before the /// corresponding TraverseDecl for the @implementation returns. This ensures /// that the lexical parent relationship between these declarations and the /// @implementation is preserved while traversing the AST. Note that the /// current implementation doesn't mix these declarations with the declarations /// contained in the @implementation, so the traversal of all of the /// declarations in the @implementation still doesn't follow the lexical order. template <typename Derived> class LexicallyOrderedRecursiveASTVisitor : public RecursiveASTVisitor<Derived> { using BaseType = RecursiveASTVisitor<Derived>; public: LexicallyOrderedRecursiveASTVisitor(const SourceManager &SM) : SM(SM) {} bool TraverseObjCImplementationDecl(ObjCImplementationDecl *D) { // Objective-C @implementation declarations should not trigger early exit // until the additional decls are traversed as their children are not // lexically ordered. bool Result = BaseType::TraverseObjCImplementationDecl(D); return TraverseAdditionalLexicallyNestedDeclarations() ? Result : false; } bool TraverseObjCCategoryImplDecl(ObjCCategoryImplDecl *D) { bool Result = BaseType::TraverseObjCCategoryImplDecl(D); return TraverseAdditionalLexicallyNestedDeclarations() ? Result : false; } bool TraverseDeclContextHelper(DeclContext *DC) { if (!DC) return true; for (auto I = DC->decls_begin(), E = DC->decls_end(); I != E;) { Decl *Child = *I; if (BaseType::canIgnoreChildDeclWhileTraversingDeclContext(Child)) { ++I; continue; } if (!isa<ObjCImplementationDecl>(Child) && !isa<ObjCCategoryImplDecl>(Child)) { if (!BaseType::getDerived().TraverseDecl(Child)) return false; ++I; continue; } // Gather declarations that follow the Objective-C implementation // declarations but are lexically contained in the implementation. LexicallyNestedDeclarations.clear(); for (++I; I != E; ++I) { Decl *Sibling = *I; if (!SM.isBeforeInTranslationUnit(Sibling->getBeginLoc(), Child->getEndLoc())) break; if (!BaseType::canIgnoreChildDeclWhileTraversingDeclContext(Sibling)) LexicallyNestedDeclarations.push_back(Sibling); } if (!BaseType::getDerived().TraverseDecl(Child)) return false; } return true; } Stmt::child_range getStmtChildren(Stmt *S) { return S->children(); } SmallVector<Stmt *, 8> getStmtChildren(CXXOperatorCallExpr *CE) { SmallVector<Stmt *, 8> Children(CE->children()); bool Swap; // Switch the operator and the first operand for all infix and postfix // operations. switch (CE->getOperator()) { case OO_Arrow: case OO_Call: case OO_Subscript: Swap = true; break; case OO_PlusPlus: case OO_MinusMinus: // These are postfix unless there is exactly one argument. Swap = Children.size() != 2; break; default: Swap = CE->isInfixBinaryOp(); break; } if (Swap && Children.size() > 1) std::swap(Children[0], Children[1]); return Children; } private: bool TraverseAdditionalLexicallyNestedDeclarations() { // FIXME: Ideally the gathered declarations and the declarations in the // @implementation should be mixed and sorted to get a true lexical order, // but right now we only care about getting the correct lexical parent, so // we can traverse the gathered nested declarations after the declarations // in the decl context. assert(!BaseType::getDerived().shouldTraversePostOrder() && "post-order traversal is not supported for lexically ordered " "recursive ast visitor"); for (Decl *D : LexicallyNestedDeclarations) { if (!BaseType::getDerived().TraverseDecl(D)) return false; } return true; } const SourceManager &SM; llvm::SmallVector<Decl *, 8> LexicallyNestedDeclarations; }; } // end namespace clang #endif // LLVM_CLANG_AST_LEXICALLY_ORDERED_RECURSIVEASTVISITOR_H
Upload File
Create Folder