diff options
author | Douglas Gregor <dgregor@apple.com> | 2011-01-21 22:52:47 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2011-01-21 22:52:47 +0000 |
commit | 3f9047e321040cd2bd215e6b29b3f7f26ba29aee (patch) | |
tree | 964310256eb43c8d58810e7d163634cdfcc6a531 | |
parent | 33d4b5eb6622197257bd069f42f8bf007c658515 (diff) | |
download | bcm5719-llvm-3f9047e321040cd2bd215e6b29b3f7f26ba29aee.tar.gz bcm5719-llvm-3f9047e321040cd2bd215e6b29b3f7f26ba29aee.zip |
Add a test for "perfect" forwarding
llvm-svn: 124005
-rw-r--r-- | clang/test/SemaCXX/rval-references-examples.cpp | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/clang/test/SemaCXX/rval-references-examples.cpp b/clang/test/SemaCXX/rval-references-examples.cpp index 778924d6575..f4921a9b516 100644 --- a/clang/test/SemaCXX/rval-references-examples.cpp +++ b/clang/test/SemaCXX/rval-references-examples.cpp @@ -88,3 +88,25 @@ unique_ptr<int> test_unique_ptr() { return p; } + +namespace perfect_forwarding { + struct A { }; + + struct F0 { + void operator()(A&, const A&, A&&, const A&&, A&&, const A&&); // expected-note{{candidate function not viable: 5th argument ('const perfect_forwarding::A') would lose const qualifier}} + }; + + template<typename F, typename ...Args> + void forward(F f, Args &&...args) { + f(static_cast<Args&&>(args)...); // expected-error{{no matching function for call to object of type 'perfect_forwarding::F0'}} + } + + template<typename T> T get(); + + void test_forward() { + forward(F0(), get<A&>(), get<A const&>(), get<A>(), get<const A>(), + get<A&&>(), get<const A&&>()); + forward(F0(), get<A&>(), get<A const&>(), get<A>(), get<const A>(), // expected-note{{in instantiation of function template specialization 'perfect_forwarding::forward<perfect_forwarding::F0, perfect_forwarding::A &, const perfect_forwarding::A &, perfect_forwarding::A, const perfect_forwarding::A, const perfect_forwarding::A, const perfect_forwarding::A>' requested here}} + get<const A&&>(), get<const A&&>()); + } +}; |