// RUN: %clang_cc1 -std=c++11 -fms-compatibility -fsyntax-only -verify %s int foo() __attribute__((optnone)); int bar() __attribute__((optnone)) __attribute__((noinline)); int baz() __attribute__((always_inline)) __attribute__((optnone)); // expected-warning{{'always_inline' attribute ignored}} expected-note{{conflicting attribute is here}} int quz() __attribute__((optnone)) __attribute__((always_inline)); // expected-warning{{'always_inline' attribute ignored}} expected-note{{conflicting attribute is here}} __attribute__((always_inline)) int baz1(); // expected-warning{{'always_inline' attribute ignored}} __attribute__((optnone)) int baz1() { return 1; } // expected-note{{conflicting attribute is here}} __attribute__((optnone)) int quz1(); // expected-note{{conflicting attribute is here}} __attribute__((always_inline)) int quz1() { return 1; } // expected-warning{{'always_inline' attribute ignored}} int bay() __attribute__((minsize)) __attribute__((optnone)); // expected-warning{{'minsize' attribute ignored}} expected-note{{conflicting}} int quy() __attribute__((optnone)) __attribute__((minsize)); // expected-warning{{'minsize' attribute ignored}} expected-note{{conflicting}} __attribute__((minsize)) int bay1(); // expected-warning{{'minsize' attribute ignored}} __attribute__((optnone)) int bay1() { return 1; } // expected-note{{conflicting attribute is here}} __attribute__((optnone)) int quy1(); // expected-note{{conflicting attribute is here}} __attribute__((minsize)) int quy1() { return 1; } // expected-warning{{'minsize' attribute ignored}} __attribute__((always_inline)) // expected-warning{{'always_inline' attribute ignored}} __attribute__((minsize)) // expected-warning{{'minsize' attribute ignored}} void bay2(); __attribute__((optnone)) // expected-note 2 {{conflicting}} void bay2() {} __forceinline __attribute__((optnone)) int bax(); // expected-warning{{'__forceinline' attribute ignored}} expected-note{{conflicting}} __attribute__((optnone)) __forceinline int qux(); // expected-warning{{'__forceinline' attribute ignored}} expected-note{{conflicting}} __forceinline int bax2(); // expected-warning{{'__forceinline' attribute ignored}} __attribute__((optnone)) int bax2() { return 1; } // expected-note{{conflicting}} __attribute__((optnone)) int qux2(); // expected-note{{conflicting}} __forceinline int qux2() { return 1; } // expected-warning{{'__forceinline' attribute ignored}} int globalVar __attribute__((optnone)); // expected-warning{{'optnone' attribute only applies to functions}} int fubar(int __attribute__((optnone)), int); // expected-warning{{'optnone' attribute only applies to functions}} struct A { int aField __attribute__((optnone)); // expected-warning{{'optnone' attribute only applies to functions}} }; struct B { void foo() __attribute__((optnone)); static void bar() __attribute__((optnone)); }; // Verify that we can specify the [[clang::optnone]] syntax as well. [[clang::optnone]] int foo2(); [[clang::optnone]] int bar2() __attribute__((noinline)); [[clang::optnone]] // expected-note {{conflicting}} int baz2() __attribute__((always_inline)); // expected-warning{{'always_inline' attribute ignored}} [[clang::optnone]] int globalVar2; //expected-warning{{'optnone' attribute only applies to functions}} struct A2 { [[clang::optnone]] int aField; // expected-warning{{'optnone' attribute only applies to functions}} }; struct B2 { [[clang::optnone]] void foo(); [[clang::optnone]] static void bar(); }; // Verify that we can handle the [[_Clang::optnone]] and // [[__clang__::optnone]] spellings, as well as [[clang::__optnone__]]. [[_Clang::optnone]] int foo3(); [[__clang__::optnone]] int foo4(); // expected-warning {{'__clang__' is a predefined macro name, not an attribute scope specifier; did you mean '_Clang' instead?}} [[clang::__optnone__]] int foo5(); [[_Clang::__optnone__]] int foo6(); [[_Clang::optnone]] int foo7; // expected-warning {{'optnone' attribute only applies to functions}}