From 91147596414d94e39c2d04a2f91a13bda877093c Mon Sep 17 00:00:00 2001 From: Peter Collingbourne Date: Fri, 15 Apr 2011 00:35:48 +0000 Subject: C1X: implement generic selections As an extension, generic selection support has been added for all supported languages. The syntax is the same as for C1X. llvm-svn: 129554 --- clang/test/SemaCXX/generic-selection.cpp | 46 ++++++++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100644 clang/test/SemaCXX/generic-selection.cpp (limited to 'clang/test/SemaCXX/generic-selection.cpp') diff --git a/clang/test/SemaCXX/generic-selection.cpp b/clang/test/SemaCXX/generic-selection.cpp new file mode 100644 index 00000000000..b171fce540d --- /dev/null +++ b/clang/test/SemaCXX/generic-selection.cpp @@ -0,0 +1,46 @@ +// RUN: %clang_cc1 -std=c++0x -fsyntax-only -verify %s + +template +struct A { + enum { + id = _Generic(T(), // expected-error {{controlling expression type 'char' not compatible with any generic association type}} + int: 1, // expected-note {{compatible type 'int' specified here}} + float: 2, + U: 3) // expected-error {{type 'int' in generic association compatible with previously specified type 'int'}} + }; +}; + +static_assert(A::id == 1, "fail"); +static_assert(A::id == 2, "fail"); +static_assert(A::id == 3, "fail"); + +A a1; // expected-note {{in instantiation of template class 'A' requested here}} +A a2; // expected-note {{in instantiation of template class 'A' requested here}} + +template +struct B { + enum { + id = _Generic(T(), + int: 1, // expected-note {{compatible type 'int' specified here}} + int: 2, // expected-error {{type 'int' in generic association compatible with previously specified type 'int'}} + U: 3) + }; +}; + +template struct Or { + enum { result = Arg | Or::result }; +}; + +template struct Or { + enum { result = Arg }; +}; + +template struct TypeMask { + enum { + result = Or<_Generic(Args(), int: 1, long: 2, short: 4, float: 8)...>::result + }; +}; + +static_assert(TypeMask::result == 7, "fail"); +static_assert(TypeMask::result == 12, "fail"); +static_assert(TypeMask::result == 9, "fail"); -- cgit v1.2.3