[libc-commits] [libc] [libc] add support for function level	attributes (PR #79891)
    Nick Desaulniers via libc-commits 
    libc-commits at lists.llvm.org
       
    Mon Feb 12 08:56:27 PST 2024
    
    
  
================
@@ -170,10 +170,33 @@ class ArgSpec<Type type, list<Annotation> annotations = [], string name = ""> {
   string Name = name;
 }
 
-class FunctionSpec<string name, RetValSpec return, list<ArgSpec> args> {
+// The following classes are used to describe function attributes.
+// In the future, we may consider supporting parameter attributes as well.
+// https://clang.llvm.org/docs/AttributeReference.html
+class FunctionAttr<string style, string attr> {
+  string Attr = attr;
+  // The style of the attribute, e.g. "gnu", "cxx11", "declspec".
+  // - "gnu" is for GNU-style attributes: __attribute__((...))
+  // - "cxx11" is for C++11-style attributes: [[...]]
+  // - "declspec" is for Microsoft-style attributes: __declspec(...)
+  string Style = style;
+}
+class GnuFunctionAttr<string attr> : FunctionAttr<"gnu", attr> {}
+class Cxx11FunctionAttr<string attr, string namespace> : FunctionAttr<"cxx11", attr> {
+  // The namespace of the attribute, e.g. "gnu" or "clang".
+  string Namespace = namespace;
----------------
nickdesaulniers wrote:
And I think the namespace can even be optional (i.e. for the standardized attributes such as `noreturn` and `carries_dependency`.
https://github.com/llvm/llvm-project/pull/79891
    
    
More information about the libc-commits
mailing list