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: AbstractBasicReader.h
//==--- AbstractBasiceReader.h - Abstract basic value deserialization -----===// // // 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 // //===----------------------------------------------------------------------===// #ifndef CLANG_AST_ABSTRACTBASICREADER_H #define CLANG_AST_ABSTRACTBASICREADER_H #include "clang/AST/DeclTemplate.h" namespace clang { namespace serialization { template <class T> inline T makeNullableFromOptional(const Optional<T> &value) { return (value ? *value : T()); } template <class T> inline T *makePointerFromOptional(Optional<T *> value) { return (value ? *value : nullptr); } // PropertyReader is a class concept that requires the following method: // BasicReader find(llvm::StringRef propertyName); // where BasicReader is some class conforming to the BasicReader concept. // An abstract AST-node reader is created with a PropertyReader and // performs a sequence of calls like so: // propertyReader.find(propertyName).read##TypeName() // to read the properties of the node it is deserializing. // BasicReader is a class concept that requires methods like: // ValueType read##TypeName(); // where TypeName is the name of a PropertyType node from PropertiesBase.td // and ValueType is the corresponding C++ type name. The read method may // require one or more buffer arguments. // // In addition to the concrete type names, BasicReader is expected to // implement these methods: // // template <class EnumType> // void writeEnum(T value); // // Reads an enum value from the current property. EnumType will always // be an enum type. Only necessary if the BasicReader doesn't provide // type-specific readers for all the enum types. // // template <class ValueType> // Optional<ValueType> writeOptional(); // // Reads an optional value from the current property. // // template <class ValueType> // ArrayRef<ValueType> readArray(llvm::SmallVectorImpl<ValueType> &buffer); // // Reads an array of values from the current property. // // PropertyReader readObject(); // // Reads an object from the current property; the returned property // reader will be subjected to a sequence of property reads and then // discarded before any other properties are reader from the "outer" // property reader (which need not be the same type). The sub-reader // will be used as if with the following code: // // { // auto &&widget = W.find("widget").readObject(); // auto kind = widget.find("kind").readWidgetKind(); // auto declaration = widget.find("declaration").readDeclRef(); // return Widget(kind, declaration); // } // ReadDispatcher does type-based forwarding to one of the read methods // on the BasicReader passed in: // // template <class ValueType> // struct ReadDispatcher { // template <class BasicReader, class... BufferTypes> // static ValueType read(BasicReader &R, BufferTypes &&...); // }; // BasicReaderBase provides convenience implementations of the read methods // for EnumPropertyType and SubclassPropertyType types that just defer to // the "underlying" implementations (for UInt32 and the base class, // respectively). // // template <class Impl> // class BasicReaderBase { // protected: // BasicReaderBase(ASTContext &ctx); // Impl &asImpl(); // public: // ASTContext &getASTContext(); // ... // }; // The actual classes are auto-generated; see ClangASTPropertiesEmitter.cpp. #include "clang/AST/AbstractBasicReader.inc" /// DataStreamBasicReader provides convenience implementations for many /// BasicReader methods based on the assumption that the /// ultimate reader implementation is based on a variable-length stream /// of unstructured data (like Clang's module files). It is designed /// to pair with DataStreamBasicWriter. /// /// This class can also act as a PropertyReader, implementing find("...") /// by simply forwarding to itself. /// /// Unimplemented methods: /// readBool /// readUInt32 /// readUInt64 /// readIdentifier /// readSelector /// readSourceLocation /// readQualType /// readStmtRef /// readDeclRef template <class Impl> class DataStreamBasicReader : public BasicReaderBase<Impl> { protected: using BasicReaderBase<Impl>::asImpl; DataStreamBasicReader(ASTContext &ctx) : BasicReaderBase<Impl>(ctx) {} public: using BasicReaderBase<Impl>::getASTContext; /// Implement property-find by ignoring it. We rely on properties being /// serialized and deserialized in a reliable order instead. Impl &find(const char *propertyName) { return asImpl(); } template <class T> T readEnum() { return T(asImpl().readUInt32()); } // Implement object reading by forwarding to this, collapsing the // structure into a single data stream. Impl &readObject() { return asImpl(); } template <class T> llvm::ArrayRef<T> readArray(llvm::SmallVectorImpl<T> &buffer) { assert(buffer.empty()); uint32_t size = asImpl().readUInt32(); buffer.reserve(size); for (uint32_t i = 0; i != size; ++i) { buffer.push_back(ReadDispatcher<T>::read(asImpl())); } return buffer; } template <class T, class... Args> llvm::Optional<T> readOptional(Args &&...args) { return UnpackOptionalValue<T>::unpack( ReadDispatcher<T>::read(asImpl(), std::forward<Args>(args)...)); } llvm::APSInt readAPSInt() { bool isUnsigned = asImpl().readBool(); llvm::APInt value = asImpl().readAPInt(); return llvm::APSInt(std::move(value), isUnsigned); } llvm::APInt readAPInt() { unsigned bitWidth = asImpl().readUInt32(); unsigned numWords = llvm::APInt::getNumWords(bitWidth); llvm::SmallVector<uint64_t, 4> data; for (uint32_t i = 0; i != numWords; ++i) data.push_back(asImpl().readUInt64()); return llvm::APInt(bitWidth, numWords, &data[0]); } Qualifiers readQualifiers() { static_assert(sizeof(Qualifiers().getAsOpaqueValue()) <= sizeof(uint32_t), "update this if the value size changes"); uint32_t value = asImpl().readUInt32(); return Qualifiers::fromOpaqueValue(value); } FunctionProtoType::ExceptionSpecInfo readExceptionSpecInfo(llvm::SmallVectorImpl<QualType> &buffer) { FunctionProtoType::ExceptionSpecInfo esi; esi.Type = ExceptionSpecificationType(asImpl().readUInt32()); if (esi.Type == EST_Dynamic) { esi.Exceptions = asImpl().template readArray<QualType>(buffer); } else if (isComputedNoexcept(esi.Type)) { esi.NoexceptExpr = asImpl().readExprRef(); } else if (esi.Type == EST_Uninstantiated) { esi.SourceDecl = asImpl().readFunctionDeclRef(); esi.SourceTemplate = asImpl().readFunctionDeclRef(); } else if (esi.Type == EST_Unevaluated) { esi.SourceDecl = asImpl().readFunctionDeclRef(); } return esi; } FunctionProtoType::ExtParameterInfo readExtParameterInfo() { static_assert(sizeof(FunctionProtoType::ExtParameterInfo().getOpaqueValue()) <= sizeof(uint32_t), "opaque value doesn't fit into uint32_t"); uint32_t value = asImpl().readUInt32(); return FunctionProtoType::ExtParameterInfo::getFromOpaqueValue(value); } NestedNameSpecifier *readNestedNameSpecifier() { auto &ctx = getASTContext(); // We build this up iteratively. NestedNameSpecifier *cur = nullptr; uint32_t depth = asImpl().readUInt32(); for (uint32_t i = 0; i != depth; ++i) { auto kind = asImpl().readNestedNameSpecifierKind(); switch (kind) { case NestedNameSpecifier::Identifier: cur = NestedNameSpecifier::Create(ctx, cur, asImpl().readIdentifier()); continue; case NestedNameSpecifier::Namespace: cur = NestedNameSpecifier::Create(ctx, cur, asImpl().readNamespaceDeclRef()); continue; case NestedNameSpecifier::NamespaceAlias: cur = NestedNameSpecifier::Create(ctx, cur, asImpl().readNamespaceAliasDeclRef()); continue; case NestedNameSpecifier::TypeSpec: case NestedNameSpecifier::TypeSpecWithTemplate: cur = NestedNameSpecifier::Create(ctx, cur, kind == NestedNameSpecifier::TypeSpecWithTemplate, asImpl().readQualType().getTypePtr()); continue; case NestedNameSpecifier::Global: cur = NestedNameSpecifier::GlobalSpecifier(ctx); continue; case NestedNameSpecifier::Super: cur = NestedNameSpecifier::SuperSpecifier(ctx, asImpl().readCXXRecordDeclRef()); continue; } llvm_unreachable("bad nested name specifier kind"); } return cur; } }; } // end namespace serialization } // end namespace clang #endif
Upload File
Create Folder