// 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-error{{'always_inline' and 'optnone' attributes are not compatible}} int quz() __attribute__((optnone)) __attribute__((always_inline)); // expected-error{{'optnone' and 'always_inline' attributes are not compatible}} __forceinline __attribute__((optnone)) int bax(); // expected-error{{'__forceinline' and 'optnone' attributes are not compatible}} __attribute__((optnone)) __forceinline int qux(); // expected-error{{'optnone' and '__forceinline' attributes are not compatible}} 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]] int baz2() __attribute__((always_inline)); // expected-error{{'always_inline' and 'optnone' attributes are not compatible}} [[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(); };