// RUN: %clang_cc1 -fsyntax-only -verify %s #pragma clang attribute pop // expected-error {{'#pragma clang attribute pop' with no matching '#pragma clang attribute push'}} // Don't verify unused attributes. #pragma clang attribute push (__attribute__((annotate)), apply_to = function) // expected-warning {{unused attribute 'annotate' in '#pragma clang attribute push' region}} #pragma clang attribute pop // expected-note {{'#pragma clang attribute push' regions ends here}} // Ensure we only report any errors once. #pragma clang attribute push (__attribute__((annotate)), apply_to = function) // expected-error 4 {{'annotate' attribute takes one argument}} void test5_begin(); // expected-note {{when applied to this declaration}} void test5_1(); // expected-note {{when applied to this declaration}} #pragma clang attribute push (__attribute__((annotate())), apply_to = function) // expected-error 2 {{'annotate' attribute takes one argument}} void test5_2(); // expected-note 2 {{when applied to this declaration}} #pragma clang attribute push (__attribute__((annotate("hello", "world"))), apply_to = function) // expected-error {{'annotate' attribute takes one argument}} void test5_3(); // expected-note 3 {{when applied to this declaration}} #pragma clang attribute pop #pragma clang attribute pop #pragma clang attribute pop // Verify that the warnings are reported for each receiver declaration #pragma clang attribute push (__attribute__((optnone)), apply_to = function) // expected-note 2 {{conflicting attribute is here}} __attribute__((always_inline)) void optnone1() { } // expected-warning {{'always_inline' attribute ignored}} // expected-note@-1 {{when applied to this declaration}} void optnone2() { } __attribute__((always_inline)) void optnone3() { } // expected-warning {{'always_inline' attribute ignored}} // expected-note@-1 {{when applied to this declaration}} #pragma clang attribute pop #pragma clang attribute push (__attribute__((annotate())), apply_to = function) // expected-error{{'annotate' attribute takes one argument}} #pragma clang attribute (__attribute__((annotate())), apply_to = function) // expected-error{{'annotate' attribute takes one argument}} void fun(); // expected-note 2 {{when applied to this declaration}} #pragma clang attribute pop #pragma clang attribute pop // expected-error{{'#pragma clang attribute pop' with no matching '#pragma clang attribute push'}} #pragma clang attribute push #pragma clang attribute (__attribute__((annotate())), apply_to = function) // expected-error 2 {{'annotate' attribute takes one argument}} void fun2(); // expected-note {{when applied to this declaration}} #pragma clang attribute push (__attribute__((annotate())), apply_to = function) // expected-error{{'annotate' attribute takes one argument}} void fun3(); // expected-note 2 {{when applied to this declaration}} #pragma clang attribute pop #pragma clang attribute pop #pragma clang attribute pop // expected-error{{'#pragma clang attribute pop' with no matching '#pragma clang attribute push'}} #pragma clang attribute (__attribute__((annotate)), apply_to = function) // expected-error{{'#pragma clang attribute' attribute with no matching '#pragma clang attribute push}} #pragma clang attribute push ([[]], apply_to = function) // A noop #pragma clang attribute pop // expected-error {{'#pragma clang attribute pop' with no matching '#pragma clang attribute push'}} #pragma clang attribute push (__attribute__((annotate("func"))), apply_to = function) // expected-error {{unterminated '#pragma clang attribute push' at end of file}} void function();