From f09294c09fe7b73cd2332ff25e7f808727716f3c Mon Sep 17 00:00:00 2001 From: Aaron Ballman Date: Wed, 3 Jan 2018 22:22:48 +0000 Subject: [PATCH] Introduce some infrastructure for adding C attributes with [[]] syntax. This patch adds support to the attribute tablegen for specifying a [[]] attribute is allowed in C mode. This patch also adds the annotate attribute to the list of double square bracket attributes we support in C mode. Eventually, I anticipate that this logic will be reversed (you have to opt out of allowing an attribute in C rather than opting in), but I want to see how the design plays out as more attributes are considered. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@321763 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/clang/Basic/Attr.td | 11 +++++++---- test/Sema/annotate.c | 6 +++++- utils/TableGen/ClangAttrEmitter.cpp | 2 ++ 3 files changed, 14 insertions(+), 5 deletions(-) diff --git a/include/clang/Basic/Attr.td b/include/clang/Basic/Attr.td index 8b84c4b8b5..7bb6c30807 100644 --- a/include/clang/Basic/Attr.td +++ b/include/clang/Basic/Attr.td @@ -231,9 +231,12 @@ class GCC : Spelling { let KnownToGCC = 1; } -// The Clang spelling implies GNU and CXX11<"clang", name>. This spelling -// should be used for any Clang-specific attributes. -class Clang : Spelling; +// The Clang spelling implies GNU, CXX11<"clang", name>, and optionally, +// C2x<"clang", name>. This spelling should be used for any Clang-specific +// attributes. +class Clang : Spelling { + bit AllowInC = allowInC; +} class Accessor spellings> { string Name = name; @@ -618,7 +621,7 @@ def AnalyzerNoReturn : InheritableAttr { } def Annotate : InheritableParamAttr { - let Spellings = [Clang<"annotate">]; + let Spellings = [Clang<"annotate", 1>]; let Args = [StringArgument<"Annotation">]; // Ensure that the annotate attribute can be used with // '#pragma clang attribute' even though it has no subject list. diff --git a/test/Sema/annotate.c b/test/Sema/annotate.c index 4a786d0a01..0d1a1c29a3 100644 --- a/test/Sema/annotate.c +++ b/test/Sema/annotate.c @@ -1,9 +1,13 @@ -// RUN: %clang_cc1 %s -fsyntax-only -verify +// RUN: %clang_cc1 %s -fsyntax-only -fdouble-square-bracket-attributes -verify void __attribute__((annotate("foo"))) foo(float *a) { __attribute__((annotate("bar"))) int x; + [[clang::annotate("bar")]] int x2; __attribute__((annotate(1))) int y; // expected-error {{'annotate' attribute requires a string}} + [[clang::annotate(1)]] int y2; // expected-error {{'annotate' attribute requires a string}} __attribute__((annotate("bar", 1))) int z; // expected-error {{'annotate' attribute takes one argument}} + [[clang::annotate("bar", 1)]] int z2; // expected-error {{'annotate' attribute takes one argument}} + int u = __builtin_annotation(z, (char*) 0); // expected-error {{second argument to __builtin_annotation must be a non-wide string constant}} int v = __builtin_annotation(z, (char*) L"bar"); // expected-error {{second argument to __builtin_annotation must be a non-wide string constant}} int w = __builtin_annotation(z, "foo"); diff --git a/utils/TableGen/ClangAttrEmitter.cpp b/utils/TableGen/ClangAttrEmitter.cpp index b0e2ddd913..2a8b891e64 100644 --- a/utils/TableGen/ClangAttrEmitter.cpp +++ b/utils/TableGen/ClangAttrEmitter.cpp @@ -87,6 +87,8 @@ GetFlattenedSpellings(const Record &Attr) { } else if (Variety == "Clang") { Ret.emplace_back("GNU", Name, "", false); Ret.emplace_back("CXX11", Name, "clang", false); + if (Spelling->getValueAsBit("AllowInC")) + Ret.emplace_back("C2x", Name, "clang", false); } else Ret.push_back(FlattenedSpelling(*Spelling)); } -- 2.50.1