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: ComparisonCategories.h
//===- ComparisonCategories.h - Three Way Comparison Data -------*- 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 Comparison Category enum and data types, which // store the types and expressions needed to support operator<=> // //===----------------------------------------------------------------------===// #ifndef LLVM_CLANG_AST_COMPARISONCATEGORIES_H #define LLVM_CLANG_AST_COMPARISONCATEGORIES_H #include "clang/Basic/LLVM.h" #include "llvm/ADT/APSInt.h" #include "llvm/ADT/DenseMap.h" #include <array> #include <cassert> namespace llvm { class StringRef; class APSInt; } namespace clang { class ASTContext; class VarDecl; class CXXRecordDecl; class Sema; class QualType; class NamespaceDecl; /// An enumeration representing the different comparison categories /// types. /// /// C++2a [cmp.categories.pre] The types weak_equality, strong_equality, /// partial_ordering, weak_ordering, and strong_ordering are collectively /// termed the comparison category types. enum class ComparisonCategoryType : unsigned char { PartialOrdering, WeakOrdering, StrongOrdering, First = PartialOrdering, Last = StrongOrdering }; /// Determine the common comparison type, as defined in C++2a /// [class.spaceship]p4. inline ComparisonCategoryType commonComparisonType(ComparisonCategoryType A, ComparisonCategoryType B) { return A < B ? A : B; } /// Get the comparison category that should be used when comparing values of /// type \c T. Optional<ComparisonCategoryType> getComparisonCategoryForBuiltinCmp(QualType T); /// An enumeration representing the possible results of a three-way /// comparison. These values map onto instances of comparison category types /// defined in the standard library. e.g. 'std::strong_ordering::less'. enum class ComparisonCategoryResult : unsigned char { Equal, Equivalent, Less, Greater, Unordered, Last = Unordered }; class ComparisonCategoryInfo { friend class ComparisonCategories; friend class Sema; public: ComparisonCategoryInfo(const ASTContext &Ctx, CXXRecordDecl *RD, ComparisonCategoryType Kind) : Ctx(Ctx), Record(RD), Kind(Kind) {} struct ValueInfo { ComparisonCategoryResult Kind; VarDecl *VD; ValueInfo(ComparisonCategoryResult Kind, VarDecl *VD) : Kind(Kind), VD(VD) {} /// True iff we've successfully evaluated the variable as a constant /// expression and extracted its integer value. bool hasValidIntValue() const; /// Get the constant integer value used by this variable to represent /// the comparison category result type. llvm::APSInt getIntValue() const; }; private: const ASTContext &Ctx; /// A map containing the comparison category result decls from the /// standard library. The key is a value of ComparisonCategoryResult. mutable llvm::SmallVector< ValueInfo, static_cast<unsigned>(ComparisonCategoryResult::Last) + 1> Objects; /// Lookup the ValueInfo struct for the specified ValueKind. If the /// VarDecl for the value cannot be found, nullptr is returned. /// /// If the ValueInfo does not have a valid integer value the variable /// is evaluated as a constant expression to determine that value. ValueInfo *lookupValueInfo(ComparisonCategoryResult ValueKind) const; public: /// The declaration for the comparison category type from the /// standard library. // FIXME: Make this const CXXRecordDecl *Record = nullptr; /// The Kind of the comparison category type ComparisonCategoryType Kind; public: QualType getType() const; const ValueInfo *getValueInfo(ComparisonCategoryResult ValueKind) const { ValueInfo *Info = lookupValueInfo(ValueKind); assert(Info && "comparison category does not contain the specified result kind"); assert(Info->hasValidIntValue() && "couldn't determine the integer constant for this value"); return Info; } /// True iff the comparison is "strong". i.e. it checks equality and /// not equivalence. bool isStrong() const { using CCK = ComparisonCategoryType; return Kind == CCK::StrongOrdering; } /// True iff the comparison is not totally ordered. bool isPartial() const { using CCK = ComparisonCategoryType; return Kind == CCK::PartialOrdering; } /// Converts the specified result kind into the the correct result kind /// for this category. Specifically it lowers strong equality results to /// weak equivalence if needed. ComparisonCategoryResult makeWeakResult(ComparisonCategoryResult Res) const { using CCR = ComparisonCategoryResult; if (!isStrong() && Res == CCR::Equal) return CCR::Equivalent; return Res; } const ValueInfo *getEqualOrEquiv() const { return getValueInfo(makeWeakResult(ComparisonCategoryResult::Equal)); } const ValueInfo *getLess() const { return getValueInfo(ComparisonCategoryResult::Less); } const ValueInfo *getGreater() const { return getValueInfo(ComparisonCategoryResult::Greater); } const ValueInfo *getUnordered() const { assert(isPartial()); return getValueInfo(ComparisonCategoryResult::Unordered); } }; class ComparisonCategories { public: static StringRef getCategoryString(ComparisonCategoryType Kind); static StringRef getResultString(ComparisonCategoryResult Kind); /// Return the list of results which are valid for the specified /// comparison category type. static std::vector<ComparisonCategoryResult> getPossibleResultsForType(ComparisonCategoryType Type); /// Return the comparison category information for the category /// specified by 'Kind'. const ComparisonCategoryInfo &getInfo(ComparisonCategoryType Kind) const { const ComparisonCategoryInfo *Result = lookupInfo(Kind); assert(Result != nullptr && "information for specified comparison category has not been built"); return *Result; } /// Return the comparison category information as specified by /// `getCategoryForType(Ty)`. If the information is not already cached, /// the declaration is looked up and a cache entry is created. /// NOTE: Lookup is expected to succeed. Use lookupInfo if failure is /// possible. const ComparisonCategoryInfo &getInfoForType(QualType Ty) const; public: /// Return the cached comparison category information for the /// specified 'Kind'. If no cache entry is present the comparison category /// type is looked up. If lookup fails nullptr is returned. Otherwise, a /// new cache entry is created and returned const ComparisonCategoryInfo *lookupInfo(ComparisonCategoryType Kind) const; ComparisonCategoryInfo *lookupInfo(ComparisonCategoryType Kind) { const auto &This = *this; return const_cast<ComparisonCategoryInfo *>(This.lookupInfo(Kind)); } const ComparisonCategoryInfo *lookupInfoForType(QualType Ty) const; private: friend class ASTContext; explicit ComparisonCategories(const ASTContext &Ctx) : Ctx(Ctx) {} const ASTContext &Ctx; /// A map from the ComparisonCategoryType (represented as 'char') to the /// cached information for the specified category. mutable llvm::DenseMap<char, ComparisonCategoryInfo> Data; mutable NamespaceDecl *StdNS = nullptr; }; } // namespace clang #endif
Upload File
Create Folder