mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-19 11:35:51 -04:00

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. llvm-svn: 321763
16 lines
1.1 KiB
C
16 lines
1.1 KiB
C
// 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");
|
|
float b = __builtin_annotation(*a, "foo"); // expected-error {{first argument to __builtin_annotation must be an integer}}
|
|
}
|