// RUN: %clang_cc1 %s -triple=i686-apple-darwin9 -verify -DVERIFY // RUN: %clang_cc1 %s -E -triple=i686-apple-darwin9 #ifndef __has_feature #error Should have __has_feature #endif #if __has_feature(something_we_dont_have) #error Bad #endif #if !__has_builtin(__builtin_huge_val) || \ !__has_builtin(__builtin_shufflevector) || \ !__has_builtin(__builtin_convertvector) || \ !__has_builtin(__builtin_trap) || \ !__has_builtin(__c11_atomic_init) || \ !__has_builtin(__builtin_launder) || \ !__has_feature(attribute_analyzer_noreturn) || \ !__has_feature(attribute_overloadable) #error Clang should have these #endif // These are technically implemented as keywords, but __has_builtin should // still return true. #if !__has_builtin(__builtin_LINE) || \ !__has_builtin(__builtin_FILE) || \ !__has_builtin(__builtin_FUNCTION) || \ !__has_builtin(__builtin_COLUMN) #error Clang should have these #endif #if __has_builtin(__builtin_insanity) #error Clang should not have this #endif #if !__has_feature(__attribute_deprecated_with_message__) #error Feature name in double underscores does not work #endif // Make sure we have x86 builtins only (forced with target triple). #if !__has_builtin(__builtin_ia32_emms) || \ __has_builtin(__builtin_altivec_abs_v4sf) #error Broken handling of target-specific builtins #endif // Macro expansion does not occur in the parameter to __has_builtin, // __has_feature, etc. (as is also expected behaviour for ordinary // macros), so the following should not expand: #define MY_ALIAS_BUILTIN __c11_atomic_init #define MY_ALIAS_FEATURE attribute_overloadable #if __has_builtin(MY_ALIAS_BUILTIN) || __has_feature(MY_ALIAS_FEATURE) #error Alias expansion not allowed #endif // But deferring should expand: #define HAS_BUILTIN(X) __has_builtin(X) #define HAS_FEATURE(X) __has_feature(X) #if !HAS_BUILTIN(MY_ALIAS_BUILTIN) || !HAS_FEATURE(MY_ALIAS_FEATURE) #error Expansion should have occurred #endif #ifdef VERIFY // expected-error@+1 {{builtin feature check macro requires a parenthesized identifier}} #if __has_feature('x') #endif // The following are not identifiers: _Static_assert(!__is_identifier("string"), "oops"); _Static_assert(!__is_identifier('c'), "oops"); _Static_assert(!__is_identifier(123), "oops"); _Static_assert(!__is_identifier(int), "oops"); // The following are: _Static_assert(__is_identifier(abc /* comment */), "oops"); _Static_assert(__is_identifier /* comment */ (xyz), "oops"); // expected-error@+1 {{too few arguments}} #if __is_identifier() #endif // expected-error@+1 {{too many arguments}} #if __is_identifier(,()) #endif // expected-error@+1 {{missing ')' after 'abc'}} #if __is_identifier(abc xyz) // expected-note {{to match this '('}} #endif // expected-error@+1 {{missing ')' after 'abc'}} #if __is_identifier(abc()) // expected-note {{to match this '('}} #endif // expected-error@+1 {{missing ')' after '.'}} #if __is_identifier(.abc) // expected-note {{to match this '('}} #endif // expected-error@+1 {{nested parentheses not permitted in '__is_identifier'}} #if __is_identifier((abc)) #endif // expected-error@+1 {{missing '(' after '__is_identifier'}} expected-error@+1 {{expected value}} #if __is_identifier #endif // expected-error@+1 {{unterminated}} expected-error@+1 {{expected value}} #if __is_identifier( #endif #endif