summaryrefslogtreecommitdiffstats
path: root/llvm/test
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2011-01-25 01:15:41 +0000
committerDouglas Gregor <dgregor@apple.com>2011-01-25 01:15:41 +0000
commita7b224140784fb4694109e9a6d62097d246bdcd1 (patch)
tree8270aeb631edc6a88bc947927879aa2f00ca05da /llvm/test
parent86b84c25d10860bbb0257630d5ecaeb061d31ca9 (diff)
downloadbcm5719-llvm-a7b224140784fb4694109e9a6d62097d246bdcd1.tar.gz
bcm5719-llvm-a7b224140784fb4694109e9a6d62097d246bdcd1.zip
Eliminate the C++0x-only is_convertible testing function that accepts
a cv-qualifier rvalue reference to the type, e.g., template <class _Tp> char __test(const volatile typename remove_reference<_Tp>::type&&); The use of this function signature rather than the more straightforward one used in C++98/03 mode, e.g., template <class _Tp> char __test(_Tp); is broken in two ways: 1) An rvalue reference cannot bind to lvalues, so is_convertible<X&, X&>::value would be false. This breaks two of the unique_ptr tests on Clang and GCC >= 4.5. Prior GCC's seem to have allowed rvalue references to bind to lvalues, allowing this bug to slip in. 2) By adding cv-qualifiers to the type we're converting to, we get some incorrect "true" results for, e.g., is_convertible<const X&, X&>::value. llvm-svn: 124166
Diffstat (limited to 'llvm/test')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud