kazu created this revision. Herald added subscribers: Moerafaat, zero9178, bzcheeseman, ayermolo, sdasgup3, carlosgalvezp, wenzhicui, wrengr, cota, teijeong, rdzhabarov, tatianashp, msifontes, jurahul, Kayjukh, grosul1, Joonsoo, liufengdb, aartbik, mgester, arpith-jacob, antiagainst, shauheen, rriddle, mehdi_amini, kadircet, arphaman, hiraditya. Herald added a reviewer: rriddle. Herald added a reviewer: rafauler. Herald added a reviewer: Amir. Herald added a reviewer: maksfb. Herald added a reviewer: NoQ. Herald added a reviewer: njames93. Herald added a project: All. kazu requested review of this revision. Herald added subscribers: cfe-commits, llvm-commits, lldb-commits, yota9, stephenneuendorffer, nicolasvasilache. Herald added projects: clang, LLDB, MLIR, LLVM, clang-tools-extra.
This patch replaces those occurrences of NoneType that would trigger an error if the definition of NoneType were missing in None.h. To keep this patch focused, I am deliberately not replacing None with std::nullopt in this patch or updating comments. They will be addressed in subsequent patches. This is part of an effort to migrate from llvm::Optional to std::optional: https://discourse.llvm.org/t/deprecating-llvm-optional-x-hasvalue-getvalue-getvalueor/63716 Repository: rG LLVM Github Monorepo https://reviews.llvm.org/D138539 Files: bolt/lib/Profile/DataAggregator.cpp bolt/lib/Profile/YAMLProfileWriter.cpp clang-tools-extra/clang-tidy/utils/RenamerClangTidyCheck.cpp clang-tools-extra/clangd/support/ThreadsafeFS.h clang/include/clang/Analysis/Analyses/PostOrderCFGView.h clang/include/clang/Basic/DirectoryEntry.h clang/include/clang/Basic/FileEntry.h clang/include/clang/Sema/Template.h clang/lib/AST/ExprConstant.cpp clang/lib/Tooling/Transformer/Parsing.cpp lldb/include/lldb/Utility/Timeout.h lldb/source/Plugins/TypeSystem/Clang/TypeSystemClang.cpp lldb/source/Plugins/TypeSystem/Clang/TypeSystemClang.h llvm/include/llvm/ADT/ArrayRef.h llvm/include/llvm/ADT/Optional.h llvm/include/llvm/ADT/StringMapEntry.h llvm/include/llvm/ADT/StringSet.h llvm/include/llvm/FuzzMutate/OpDescriptor.h llvm/include/llvm/Support/SMLoc.h llvm/lib/CodeGen/MIRParser/MILexer.cpp llvm/lib/Support/Optional.cpp mlir/include/mlir/IR/OpDefinition.h mlir/include/mlir/IR/OperationSupport.h mlir/include/mlir/Support/Timing.h mlir/lib/Support/Timing.cpp
Index: mlir/lib/Support/Timing.cpp =================================================================== --- mlir/lib/Support/Timing.cpp +++ mlir/lib/Support/Timing.cpp @@ -50,7 +50,7 @@ llvm::sys::SmartRWMutex<true> identifierMutex; /// A thread local cache of identifiers to reduce lock contention. - ThreadLocalCache<llvm::StringMap<llvm::StringMapEntry<llvm::NoneType> *>> + ThreadLocalCache<llvm::StringMap<llvm::StringMapEntry<std::nullopt_t> *>> localIdentifierCache; TimingManagerImpl() : identifiers(identifierAllocator) {} Index: mlir/include/mlir/Support/Timing.h =================================================================== --- mlir/include/mlir/Support/Timing.h +++ mlir/include/mlir/Support/Timing.h @@ -43,7 +43,7 @@ /// This is a POD type with pointer size, so it should be passed around by /// value. The underlying data is owned by the `TimingManager`. class TimingIdentifier { - using EntryType = llvm::StringMapEntry<llvm::NoneType>; + using EntryType = llvm::StringMapEntry<std::nullopt_t>; public: TimingIdentifier(const TimingIdentifier &) = default; Index: mlir/include/mlir/IR/OperationSupport.h =================================================================== --- mlir/include/mlir/IR/OperationSupport.h +++ mlir/include/mlir/IR/OperationSupport.h @@ -490,7 +490,7 @@ using size_type = size_t; NamedAttrList() : dictionarySorted({}, true) {} - NamedAttrList(llvm::NoneType none) : NamedAttrList() {} + NamedAttrList(std::nullopt_t none) : NamedAttrList() {} NamedAttrList(ArrayRef<NamedAttribute> attributes); NamedAttrList(DictionaryAttr attributes); NamedAttrList(const_iterator inStart, const_iterator inEnd); @@ -759,7 +759,7 @@ class OpPrintingFlags { public: OpPrintingFlags(); - OpPrintingFlags(llvm::NoneType) : OpPrintingFlags() {} + OpPrintingFlags(std::nullopt_t) : OpPrintingFlags() {} /// Enables the elision of large elements attributes by printing a lexically /// valid but otherwise meaningless form instead of the element data. The Index: mlir/include/mlir/IR/OpDefinition.h =================================================================== --- mlir/include/mlir/IR/OpDefinition.h +++ mlir/include/mlir/IR/OpDefinition.h @@ -41,7 +41,7 @@ OptionalParseResult(ParseResult result) : impl(result) {} OptionalParseResult(const InFlightDiagnostic &) : OptionalParseResult(failure()) {} - OptionalParseResult(llvm::NoneType) : impl(llvm::None) {} + OptionalParseResult(std::nullopt_t) : impl(llvm::None) {} /// Returns true if we contain a valid ParseResult value. bool has_value() const { return impl.has_value(); } Index: llvm/lib/Support/Optional.cpp =================================================================== --- llvm/lib/Support/Optional.cpp +++ llvm/lib/Support/Optional.cpp @@ -9,6 +9,6 @@ #include "llvm/ADT/Optional.h" #include "llvm/Support/raw_ostream.h" -llvm::raw_ostream &llvm::operator<<(raw_ostream &OS, NoneType) { +llvm::raw_ostream &llvm::operator<<(raw_ostream &OS, std::nullopt_t) { return OS << "None"; } Index: llvm/lib/CodeGen/MIRParser/MILexer.cpp =================================================================== --- llvm/lib/CodeGen/MIRParser/MILexer.cpp +++ llvm/lib/CodeGen/MIRParser/MILexer.cpp @@ -33,7 +33,7 @@ const char *End = nullptr; public: - Cursor(NoneType) {} + Cursor(std::nullopt_t) {} explicit Cursor(StringRef Str) { Ptr = Str.data(); Index: llvm/include/llvm/Support/SMLoc.h =================================================================== --- llvm/include/llvm/Support/SMLoc.h +++ llvm/include/llvm/Support/SMLoc.h @@ -50,7 +50,7 @@ SMLoc Start, End; SMRange() = default; - SMRange(NoneType) {} + SMRange(std::nullopt_t) {} SMRange(SMLoc St, SMLoc En) : Start(St), End(En) { assert(Start.isValid() == End.isValid() && "Start and End should either both be valid or both be invalid!"); Index: llvm/include/llvm/FuzzMutate/OpDescriptor.h =================================================================== --- llvm/include/llvm/FuzzMutate/OpDescriptor.h +++ llvm/include/llvm/FuzzMutate/OpDescriptor.h @@ -57,7 +57,7 @@ public: /// Create a fully general source predicate. SourcePred(PredT Pred, MakeT Make) : Pred(Pred), Make(Make) {} - SourcePred(PredT Pred, NoneType) : Pred(Pred) { + SourcePred(PredT Pred, std::nullopt_t) : Pred(Pred) { Make = [Pred](ArrayRef<Value *> Cur, ArrayRef<Type *> BaseTypes) { // Default filter just calls Pred on each of the base types. std::vector<Constant *> Result; Index: llvm/include/llvm/ADT/StringSet.h =================================================================== --- llvm/include/llvm/ADT/StringSet.h +++ llvm/include/llvm/ADT/StringSet.h @@ -20,8 +20,8 @@ /// StringSet - A wrapper for StringMap that provides set-like functionality. template <class AllocatorTy = MallocAllocator> -class StringSet : public StringMap<NoneType, AllocatorTy> { - using Base = StringMap<NoneType, AllocatorTy>; +class StringSet : public StringMap<std::nullopt_t, AllocatorTy> { + using Base = StringMap<std::nullopt_t, AllocatorTy>; public: StringSet() = default; Index: llvm/include/llvm/ADT/StringMapEntry.h =================================================================== --- llvm/include/llvm/ADT/StringMapEntry.h +++ llvm/include/llvm/ADT/StringMapEntry.h @@ -85,13 +85,14 @@ void setValue(const ValueTy &V) { second = V; } }; -template <> class StringMapEntryStorage<NoneType> : public StringMapEntryBase { +template <> +class StringMapEntryStorage<std::nullopt_t> : public StringMapEntryBase { public: - explicit StringMapEntryStorage(size_t keyLength, NoneType = None) + explicit StringMapEntryStorage(size_t keyLength, std::nullopt_t = None) : StringMapEntryBase(keyLength) {} StringMapEntryStorage(StringMapEntryStorage &entry) = delete; - NoneType getValue() const { return None; } + std::nullopt_t getValue() const { return None; } }; /// StringMapEntry - This is used to represent one value that is inserted into Index: llvm/include/llvm/ADT/Optional.h =================================================================== --- llvm/include/llvm/ADT/Optional.h +++ llvm/include/llvm/ADT/Optional.h @@ -239,7 +239,7 @@ using value_type = T; constexpr Optional() = default; - constexpr Optional(NoneType) {} + constexpr Optional(std::nullopt_t) {} constexpr Optional(const T &y) : Storage(std::in_place, y) {} constexpr Optional(const Optional &O) = default; @@ -396,58 +396,62 @@ } template <typename T> -constexpr bool operator==(const Optional<T> &X, NoneType) { +constexpr bool operator==(const Optional<T> &X, std::nullopt_t) { return !X; } template <typename T> -constexpr bool operator==(NoneType, const Optional<T> &X) { +constexpr bool operator==(std::nullopt_t, const Optional<T> &X) { return X == None; } template <typename T> -constexpr bool operator!=(const Optional<T> &X, NoneType) { +constexpr bool operator!=(const Optional<T> &X, std::nullopt_t) { return !(X == None); } template <typename T> -constexpr bool operator!=(NoneType, const Optional<T> &X) { +constexpr bool operator!=(std::nullopt_t, const Optional<T> &X) { return X != None; } -template <typename T> constexpr bool operator<(const Optional<T> &, NoneType) { +template <typename T> +constexpr bool operator<(const Optional<T> &, std::nullopt_t) { return false; } -template <typename T> constexpr bool operator<(NoneType, const Optional<T> &X) { +template <typename T> +constexpr bool operator<(std::nullopt_t, const Optional<T> &X) { return X.has_value(); } template <typename T> -constexpr bool operator<=(const Optional<T> &X, NoneType) { +constexpr bool operator<=(const Optional<T> &X, std::nullopt_t) { return !(None < X); } template <typename T> -constexpr bool operator<=(NoneType, const Optional<T> &X) { +constexpr bool operator<=(std::nullopt_t, const Optional<T> &X) { return !(X < None); } -template <typename T> constexpr bool operator>(const Optional<T> &X, NoneType) { +template <typename T> +constexpr bool operator>(const Optional<T> &X, std::nullopt_t) { return None < X; } -template <typename T> constexpr bool operator>(NoneType, const Optional<T> &X) { +template <typename T> +constexpr bool operator>(std::nullopt_t, const Optional<T> &X) { return X < None; } template <typename T> -constexpr bool operator>=(const Optional<T> &X, NoneType) { +constexpr bool operator>=(const Optional<T> &X, std::nullopt_t) { return None <= X; } template <typename T> -constexpr bool operator>=(NoneType, const Optional<T> &X) { +constexpr bool operator>=(std::nullopt_t, const Optional<T> &X) { return X <= None; } @@ -511,7 +515,7 @@ return !(X < Y); } -raw_ostream &operator<<(raw_ostream &OS, NoneType); +raw_ostream &operator<<(raw_ostream &OS, std::nullopt_t); template <typename T, typename = decltype(std::declval<raw_ostream &>() << std::declval<const T &>())> Index: llvm/include/llvm/ADT/ArrayRef.h =================================================================== --- llvm/include/llvm/ADT/ArrayRef.h +++ llvm/include/llvm/ADT/ArrayRef.h @@ -68,7 +68,7 @@ /*implicit*/ ArrayRef() = default; /// Construct an empty ArrayRef from None. - /*implicit*/ ArrayRef(NoneType) {} + /*implicit*/ ArrayRef(std::nullopt_t) {} /// Construct an ArrayRef from a single element. /*implicit*/ ArrayRef(const T &OneElt) @@ -321,7 +321,7 @@ /*implicit*/ MutableArrayRef() = default; /// Construct an empty MutableArrayRef from None. - /*implicit*/ MutableArrayRef(NoneType) : ArrayRef<T>() {} + /*implicit*/ MutableArrayRef(std::nullopt_t) : ArrayRef<T>() {} /// Construct a MutableArrayRef from a single element. /*implicit*/ MutableArrayRef(T &OneElt) : ArrayRef<T>(OneElt) {} Index: lldb/source/Plugins/TypeSystem/Clang/TypeSystemClang.h =================================================================== --- lldb/source/Plugins/TypeSystem/Clang/TypeSystemClang.h +++ lldb/source/Plugins/TypeSystem/Clang/TypeSystemClang.h @@ -1145,7 +1145,7 @@ /// Alias for requesting the default scratch TypeSystemClang in GetForTarget. // This isn't constexpr as gtest/llvm::Optional comparison logic is trying // to get the address of this for pretty-printing. - static const llvm::NoneType DefaultAST; + static const std::nullopt_t DefaultAST; /// Infers the appropriate sub-AST from Clang's LangOptions. static llvm::Optional<IsolatedASTKind> Index: lldb/source/Plugins/TypeSystem/Clang/TypeSystemClang.cpp =================================================================== --- lldb/source/Plugins/TypeSystem/Clang/TypeSystemClang.cpp +++ lldb/source/Plugins/TypeSystem/Clang/TypeSystemClang.cpp @@ -9878,7 +9878,7 @@ } // namespace char ScratchTypeSystemClang::ID; -const llvm::NoneType ScratchTypeSystemClang::DefaultAST = llvm::None; +const std::nullopt_t ScratchTypeSystemClang::DefaultAST = llvm::None; ScratchTypeSystemClang::ScratchTypeSystemClang(Target &target, llvm::Triple triple) Index: lldb/include/lldb/Utility/Timeout.h =================================================================== --- lldb/include/lldb/Utility/Timeout.h +++ lldb/include/lldb/Utility/Timeout.h @@ -36,7 +36,7 @@ using Base = llvm::Optional<Dur<Ratio>>; public: - Timeout(llvm::NoneType none) : Base(none) {} + Timeout(std::nullopt_t none) : Base(none) {} template <typename Ratio2, typename = typename EnableIf<int64_t, Ratio2>::type> Index: clang/lib/Tooling/Transformer/Parsing.cpp =================================================================== --- clang/lib/Tooling/Transformer/Parsing.cpp +++ clang/lib/Tooling/Transformer/Parsing.cpp @@ -152,7 +152,7 @@ // Parses a single expected character \c c from \c State, skipping preceding // whitespace. Error if the expected character isn't found. -static ExpectedProgress<llvm::NoneType> parseChar(char c, ParseState State) { +static ExpectedProgress<std::nullopt_t> parseChar(char c, ParseState State) { State.Input = consumeWhitespace(State.Input); if (State.Input.empty() || State.Input.front() != c) return makeParseError(State, Index: clang/lib/AST/ExprConstant.cpp =================================================================== --- clang/lib/AST/ExprConstant.cpp +++ clang/lib/AST/ExprConstant.cpp @@ -7044,14 +7044,14 @@ // Emit an unsupported bit_cast type error. Sema refuses to build a bit_cast // with an invalid type, so anything left is a deficiency on our part (FIXME). // Ideally this will be unreachable. - llvm::NoneType unsupportedType(QualType Ty) { + std::nullopt_t unsupportedType(QualType Ty) { Info.FFDiag(BCE->getBeginLoc(), diag::note_constexpr_bit_cast_unsupported_type) << Ty; return None; } - llvm::NoneType unrepresentableValue(QualType Ty, const APSInt &Val) { + std::nullopt_t unrepresentableValue(QualType Ty, const APSInt &Val) { Info.FFDiag(BCE->getBeginLoc(), diag::note_constexpr_bit_cast_unrepresentable_value) << Ty << toString(Val, /*Radix=*/10); Index: clang/include/clang/Sema/Template.h =================================================================== --- clang/include/clang/Sema/Template.h +++ clang/include/clang/Sema/Template.h @@ -222,7 +222,7 @@ TemplateArgumentLists.push_back({{}, Args}); } - void addOuterTemplateArguments(llvm::NoneType) { + void addOuterTemplateArguments(std::nullopt_t) { assert(!NumRetainedOuterLevels && "substituted args outside retained args?"); TemplateArgumentLists.push_back({}); Index: clang/include/clang/Basic/FileEntry.h =================================================================== --- clang/include/clang/Basic/FileEntry.h +++ clang/include/clang/Basic/FileEntry.h @@ -308,13 +308,13 @@ OptionalFileEntryRefDegradesToFileEntryPtr & operator=(const OptionalFileEntryRefDegradesToFileEntryPtr &) = default; - OptionalFileEntryRefDegradesToFileEntryPtr(llvm::NoneType) {} + OptionalFileEntryRefDegradesToFileEntryPtr(std::nullopt_t) {} OptionalFileEntryRefDegradesToFileEntryPtr(FileEntryRef Ref) : Optional<FileEntryRef>(Ref) {} OptionalFileEntryRefDegradesToFileEntryPtr(Optional<FileEntryRef> MaybeRef) : Optional<FileEntryRef>(MaybeRef) {} - OptionalFileEntryRefDegradesToFileEntryPtr &operator=(llvm::NoneType) { + OptionalFileEntryRefDegradesToFileEntryPtr &operator=(std::nullopt_t) { Optional<FileEntryRef>::operator=(None); return *this; } Index: clang/include/clang/Basic/DirectoryEntry.h =================================================================== --- clang/include/clang/Basic/DirectoryEntry.h +++ clang/include/clang/Basic/DirectoryEntry.h @@ -264,13 +264,14 @@ OptionalDirectoryEntryRefDegradesToDirectoryEntryPtr & operator=(const OptionalDirectoryEntryRefDegradesToDirectoryEntryPtr &) = default; - OptionalDirectoryEntryRefDegradesToDirectoryEntryPtr(llvm::NoneType) {} + OptionalDirectoryEntryRefDegradesToDirectoryEntryPtr(std::nullopt_t) {} OptionalDirectoryEntryRefDegradesToDirectoryEntryPtr(DirectoryEntryRef Ref) : Optional<DirectoryEntryRef>(Ref) {} OptionalDirectoryEntryRefDegradesToDirectoryEntryPtr(Optional<DirectoryEntryRef> MaybeRef) : Optional<DirectoryEntryRef>(MaybeRef) {} - OptionalDirectoryEntryRefDegradesToDirectoryEntryPtr &operator=(llvm::NoneType) { + OptionalDirectoryEntryRefDegradesToDirectoryEntryPtr & + operator=(std::nullopt_t) { Optional<DirectoryEntryRef>::operator=(None); return *this; } Index: clang/include/clang/Analysis/Analyses/PostOrderCFGView.h =================================================================== --- clang/include/clang/Analysis/Analyses/PostOrderCFGView.h +++ clang/include/clang/Analysis/Analyses/PostOrderCFGView.h @@ -48,7 +48,7 @@ /// Set the bit associated with a particular CFGBlock. /// This is the important method for the SetType template parameter. - std::pair<llvm::NoneType, bool> insert(const CFGBlock *Block) { + std::pair<std::nullopt_t, bool> insert(const CFGBlock *Block) { // Note that insert() is called by po_iterator, which doesn't check to // make sure that Block is non-null. Moreover, the CFGBlock iterator will // occasionally hand out null pointers for pruned edges, so we catch those Index: clang-tools-extra/clangd/support/ThreadsafeFS.h =================================================================== --- clang-tools-extra/clangd/support/ThreadsafeFS.h +++ clang-tools-extra/clangd/support/ThreadsafeFS.h @@ -30,7 +30,7 @@ /// Obtain a vfs::FileSystem with an arbitrary initial working directory. llvm::IntrusiveRefCntPtr<llvm::vfs::FileSystem> - view(llvm::NoneType CWD) const { + view(std::nullopt_t CWD) const { return viewImpl(); } Index: clang-tools-extra/clang-tidy/utils/RenamerClangTidyCheck.cpp =================================================================== --- clang-tools-extra/clang-tidy/utils/RenamerClangTidyCheck.cpp +++ clang-tools-extra/clang-tidy/utils/RenamerClangTidyCheck.cpp @@ -214,7 +214,7 @@ public: explicit NameLookup(const NamedDecl *ND) : Data(ND, false) {} - explicit NameLookup(llvm::NoneType) : Data(nullptr, true) {} + explicit NameLookup(std::nullopt_t) : Data(nullptr, true) {} explicit NameLookup(std::nullptr_t) : Data(nullptr, false) {} NameLookup() : NameLookup(nullptr) {} Index: bolt/lib/Profile/YAMLProfileWriter.cpp =================================================================== --- bolt/lib/Profile/YAMLProfileWriter.cpp +++ bolt/lib/Profile/YAMLProfileWriter.cpp @@ -161,7 +161,7 @@ StringSet<> EventNames = RI.getProfileReader()->getEventNames(); if (!EventNames.empty()) { std::string Sep; - for (const StringMapEntry<NoneType> &EventEntry : EventNames) { + for (const StringMapEntry<std::nullopt_t> &EventEntry : EventNames) { BP.Header.EventNames += Sep + EventEntry.first().str(); Sep = ","; } Index: bolt/lib/Profile/DataAggregator.cpp =================================================================== --- bolt/lib/Profile/DataAggregator.cpp +++ bolt/lib/Profile/DataAggregator.cpp @@ -2233,7 +2233,7 @@ OutFile << "boltedcollection\n"; if (opts::BasicAggregation) { OutFile << "no_lbr"; - for (const StringMapEntry<NoneType> &Entry : EventNames) + for (const StringMapEntry<std::nullopt_t> &Entry : EventNames) OutFile << " " << Entry.getKey(); OutFile << "\n";
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits