Fix improperly failing test - and the code it was testing. Thanks to Stephan Lavavej...
authorMarshall Clow <mclow.lists@gmail.com>
Thu, 22 Mar 2018 18:27:28 +0000 (18:27 +0000)
committerMarshall Clow <mclow.lists@gmail.com>
Thu, 22 Mar 2018 18:27:28 +0000 (18:27 +0000)
llvm-svn: 328225

libcxx/include/ostream
libcxx/test/std/utilities/memory/unique.ptr/unique.ptr.special/io.fail.cpp

index f3250a7080dd98539bf958f9328dca2a8d44dcd8..197636eac61e5899e55d7d70ad054d2f7863bedb 100644 (file)
@@ -1071,19 +1071,17 @@ operator<<(basic_ostream<_CharT, _Traits>& __os, shared_ptr<_Yp> const& __p)
     return __os << __p.get();
 }
 
-#ifndef _LIBCPP_HAS_NO_DECLTYPE
 template<class _CharT, class _Traits, class _Yp, class _Dp>
 inline _LIBCPP_INLINE_VISIBILITY
 typename enable_if
 <
-    is_same<void, typename __void_t<decltype(declval<basic_ostream<_CharT, _Traits>&>() << declval<_Yp>())>::type>::value,
+    is_same<void, typename __void_t<decltype((declval<basic_ostream<_CharT, _Traits>&>() << declval<typename unique_ptr<_Yp, _Dp>::pointer>()))>::type>::value,
     basic_ostream<_CharT, _Traits>&
 >::type
 operator<<(basic_ostream<_CharT, _Traits>& __os, unique_ptr<_Yp, _Dp> const& __p)
 {
     return __os << __p.get();
 }
-#endif
 
 template <class _CharT, class _Traits, size_t _Size>
 basic_ostream<_CharT, _Traits>&
index 48c90f7b9661d2f7605cb6bf7308328f5ae6ce51..54c85e94338c21229fe5d93c4b6a867ec4117546 100644 (file)
 #include <sstream>
 #include <cassert>
 
-class A {};
+#include "min_allocator.h"
+#include "deleter_types.h"
 
 int main()
 {
-    std::unique_ptr<A> p(new A);
+    std::unique_ptr<int, PointerDeleter<int>> p;
     std::ostringstream os;
-    os << p;
+    os << p; // expected-error {{invalid operands to binary expression}}
 }