diff options
Diffstat (limited to 'clang/test/Sema')
-rw-r--r-- | clang/test/Sema/128bitfloat.cpp | 16 | ||||
-rw-r--r-- | clang/test/Sema/float128-ld-incompatibility.cpp | 36 |
2 files changed, 8 insertions, 44 deletions
diff --git a/clang/test/Sema/128bitfloat.cpp b/clang/test/Sema/128bitfloat.cpp index 779c59dfd4a..cb76dac9600 100644 --- a/clang/test/Sema/128bitfloat.cpp +++ b/clang/test/Sema/128bitfloat.cpp @@ -2,23 +2,23 @@ // RUN: %clang_cc1 -fsyntax-only -verify -std=c++11 %s #if !defined(__STRICT_ANSI__) -__float128 f; // expected-error {{__float128 is not supported on this target}} +__float128 f; // expected-error {{support for type '__float128' is not yet implemented}} // But this should work: template<typename> struct __is_floating_point_helper {}; -template<> struct __is_floating_point_helper<__float128> {}; // expected-error {{__float128 is not supported on this target}} +template<> struct __is_floating_point_helper<__float128> {}; // FIXME: This could have a better diag. -int g(int x, __float128 *y) { // expected-error {{__float128 is not supported on this target}} - return x + *y; +void g(int x, __float128 *y) { + x + *y; // expected-error {{invalid operands to binary expression ('int' and '__float128')}} } #else -__float128 f; // expected-error {{__float128 is not supported on this target}} +__float128 f; // expected-error {{unknown type name '__float128'}} template<typename> struct __is_floating_point_helper {}; -template<> struct __is_floating_point_helper<__float128> {}; // expected-error {{__float128 is not supported on this target}} +template<> struct __is_floating_point_helper<__float128> {}; // expected-error {{use of undeclared identifier '__float128'}} -int g(int x, __float128 *y) { // expected-error {{__float128 is not supported on this target}} - return x + *y; +void g(int x, __float128 *y) { // expected-error {{unknown type name '__float128'}} + x + *y; } #endif diff --git a/clang/test/Sema/float128-ld-incompatibility.cpp b/clang/test/Sema/float128-ld-incompatibility.cpp deleted file mode 100644 index d993ed7b081..00000000000 --- a/clang/test/Sema/float128-ld-incompatibility.cpp +++ /dev/null @@ -1,36 +0,0 @@ -// RUN: %clang_cc1 -fsyntax-only -verify -std=c++11 \ -// RUN: -triple powerpc64le-unknown-linux-gnu -target-cpu pwr8 \ -// RUN: -target-feature +float128 %s - -__float128 qf(); -long double ldf(); - -// FIXME: once operations between long double and __float128 are implemented for -// targets where the types are different, these next two will change -long double ld{qf()}; // expected-error {{cannot initialize a variable of type 'long double' with an rvalue of type '__float128'}} -__float128 q{ldf()}; // expected-error {{cannot initialize a variable of type '__float128' with an rvalue of type 'long double'}} - -auto test1(__float128 q, long double ld) -> decltype(q + ld) { // expected-error {{invalid operands to binary expression ('__float128' and 'long double')}} - return q + ld; // expected-error {{invalid operands to binary expression ('__float128' and 'long double')}} -} - -auto test2(long double a, __float128 b) -> decltype(a + b) { // expected-error {{invalid operands to binary expression ('long double' and '__float128')}} - return a + b; // expected-error {{invalid operands to binary expression ('long double' and '__float128')}} -} - -void test3(bool b) { - long double ld; - __float128 q; - - ld + q; // expected-error {{invalid operands to binary expression ('long double' and '__float128')}} - q + ld; // expected-error {{invalid operands to binary expression ('__float128' and 'long double')}} - ld - q; // expected-error {{invalid operands to binary expression ('long double' and '__float128')}} - q - ld; // expected-error {{invalid operands to binary expression ('__float128' and 'long double')}} - ld * q; // expected-error {{invalid operands to binary expression ('long double' and '__float128')}} - q * ld; // expected-error {{invalid operands to binary expression ('__float128' and 'long double')}} - ld / q; // expected-error {{invalid operands to binary expression ('long double' and '__float128')}} - q / ld; // expected-error {{invalid operands to binary expression ('__float128' and 'long double')}} - ld = q; // expected-error {{assigning to 'long double' from incompatible type '__float128'}} - q = ld; // expected-error {{assigning to '__float128' from incompatible type 'long double'}} - q + b ? q : ld; // expected-error {{incompatible operand types ('__float128' and 'long double')}} -} |