================
@@ -376,4 +376,88 @@ bool areAlignedAttrsEqual(const AlignedAttr &A1, const
AlignedAttr &A2,
}
} // namespace
+namespace {
+// Machinery to unique attributes based on the arguments.
+// The construction mirrors the equivalent testing code above.
+// The content of the arguments are added to the FoldingSetNodeID instance,
+// which allows the AttributedTypes to unique the attributes based on
+// the value of the arguments.
+
+#define USE_DEFAULT_PROFILE
\
+ (std::is_same_v<T, StringRef> || std::is_same_v<T, VersionTuple> ||
\
+ std::is_same_v<T, IdentifierInfo *> ||
\
+ std::is_same_v<T, const IdentifierInfo *> || std::is_enum_v<T> ||
\
+ std::is_integral_v<T>)
+
+template <class T>
+typename std::enable_if_t<!USE_DEFAULT_PROFILE>
+profileAttrArg(llvm::FoldingSetNodeID &, const ASTContext &, T) {}
----------------
Xazax-hun wrote:
Is it OK to silently not do anything for some types? Or should this be a
declaration only to trigger a linker error in that case?
https://github.com/llvm/llvm-project/pull/200961
_______________________________________________
cfe-commits mailing list
[email protected]
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits