From 554fd8c5195424bdbcabf5de30fdc183aba391bd Mon Sep 17 00:00:00 2001 From: upstream source tree Date: Sun, 15 Mar 2015 20:14:05 -0400 Subject: obtained gcc-4.6.4.tar.bz2 from upstream website; verified gcc-4.6.4.tar.bz2.sig; imported gcc-4.6.4 source tree from verified upstream tarball. downloading a git-generated archive based on the 'upstream' tag should provide you with a source tree that is binary identical to the one extracted from the above tarball. if you have obtained the source via the command 'git clone', however, do note that line-endings of files in your working directory might differ from line-endings of the respective files in the upstream repository. --- gcc/testsuite/g++.dg/cpp0x/variadic-lambda.C | 79 ++++++++++++++++++++++++++++ 1 file changed, 79 insertions(+) create mode 100644 gcc/testsuite/g++.dg/cpp0x/variadic-lambda.C (limited to 'gcc/testsuite/g++.dg/cpp0x/variadic-lambda.C') diff --git a/gcc/testsuite/g++.dg/cpp0x/variadic-lambda.C b/gcc/testsuite/g++.dg/cpp0x/variadic-lambda.C new file mode 100644 index 000000000..705d44149 --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp0x/variadic-lambda.C @@ -0,0 +1,79 @@ +// { dg-options "-std=c++0x" } + +struct int_placeholder; + +template +struct do_replace +{ + typedef T type; +}; + +template<> +struct do_replace +{ + typedef int type; +}; + +template struct lambdalike +{ + typedef T type; +}; + +template class TT, typename... Args> +struct lambdalike > { + typedef TT::type...> type; +}; + + +template +struct is_same +{ + static const bool value = false; +}; + +template +struct is_same +{ + static const bool value = true; +}; + +template struct tuple; +template struct pair; + +static_assert(is_same>::type, + tuple>::value, + "MPL lambda-like replacement on tuple"); +static_assert(is_same>::type, + pair>::value, + "MPL lambda-like replacement on pair"); + + +struct _1 {}; + +template +struct eval +{ + typedef Lambda type; +}; + +template +struct eval +{ + typedef Arg0 type; +}; + +template class T, typename... Pack> +struct eval > +{ + typedef T< typename eval::type... > type; +}; + +static_assert(is_same>::type, + tuple>::value, "eval tuple"); +static_assert(is_same>::type, + pair>::value, "eval pair"); +static_assert(is_same, pair, + pair>>::type, + tuple, pair, pair>>::value, + "recursive eval"); -- cgit v1.2.3