Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 17 Aug 2016 19:36:25 +0000 (UTC)
From:      Dimitry Andric <dim@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-vendor@freebsd.org
Subject:   svn commit: r304304 - in vendor/libc++/dist: include test/std/experimental/filesystem/fs.op.funcs/fs.op.last_write_time test/std/iterators/iterator.range test/std/numerics/complex.number/complex.tr...
Message-ID:  <201608171936.u7HJaPgi083191@repo.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: dim
Date: Wed Aug 17 19:36:25 2016
New Revision: 304304
URL: https://svnweb.freebsd.org/changeset/base/304304

Log:
  Vendor import of libc++ release_39 branch r278877:
  https://llvm.org/svn/llvm-project/libcxx/branches/release_39@278877

Added:
  vendor/libc++/dist/test/std/iterators/iterator.range/begin-end.fail.cpp   (contents, props changed)
Modified:
  vendor/libc++/dist/include/iterator
  vendor/libc++/dist/test/std/experimental/filesystem/fs.op.funcs/fs.op.last_write_time/last_write_time.pass.cpp
  vendor/libc++/dist/test/std/numerics/complex.number/complex.transcendentals/asin.pass.cpp

Modified: vendor/libc++/dist/include/iterator
==============================================================================
--- vendor/libc++/dist/include/iterator	Wed Aug 17 19:36:01 2016	(r304303)
+++ vendor/libc++/dist/include/iterator	Wed Aug 17 19:36:25 2016	(r304304)
@@ -1632,16 +1632,16 @@ reverse_iterator<const _Ep*> rend(initia
 
 template <class _Cp>
 inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
-auto cbegin(const _Cp& __c) -> decltype(begin(__c))
+auto cbegin(const _Cp& __c) -> decltype(_VSTD::begin(__c))
 {
-    return begin(__c);
+    return _VSTD::begin(__c);
 }
 
 template <class _Cp>
 inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
-auto cend(const _Cp& __c) -> decltype(end(__c))
+auto cend(const _Cp& __c) -> decltype(_VSTD::end(__c))
 {
-    return end(__c);
+    return _VSTD::end(__c);
 }
 
 template <class _Cp>
@@ -1674,16 +1674,16 @@ auto rend(const _Cp& __c) -> decltype(__
 
 template <class _Cp>
 inline _LIBCPP_INLINE_VISIBILITY
-auto crbegin(const _Cp& __c) -> decltype(rbegin(__c))
+auto crbegin(const _Cp& __c) -> decltype(_VSTD::rbegin(__c))
 {
-    return rbegin(__c);
+    return _VSTD::rbegin(__c);
 }
 
 template <class _Cp>
 inline _LIBCPP_INLINE_VISIBILITY
-auto crend(const _Cp& __c) -> decltype(rend(__c))
+auto crend(const _Cp& __c) -> decltype(_VSTD::rend(__c))
 {
-    return rend(__c);
+    return _VSTD::rend(__c);
 }
 
 #endif

Modified: vendor/libc++/dist/test/std/experimental/filesystem/fs.op.funcs/fs.op.last_write_time/last_write_time.pass.cpp
==============================================================================
--- vendor/libc++/dist/test/std/experimental/filesystem/fs.op.funcs/fs.op.last_write_time/last_write_time.pass.cpp	Wed Aug 17 19:36:01 2016	(r304303)
+++ vendor/libc++/dist/test/std/experimental/filesystem/fs.op.funcs/fs.op.last_write_time/last_write_time.pass.cpp	Wed Aug 17 19:36:25 2016	(r304304)
@@ -158,7 +158,8 @@ TEST_CASE(get_last_write_time_dynamic_en
 
     TEST_CHECK(ftime2 > ftime);
     TEST_CHECK(dtime2 > dtime);
-    TEST_CHECK(LastAccessTime(file) == file_access_time);
+    TEST_CHECK(LastAccessTime(file) == file_access_time ||
+               LastAccessTime(file) == Clock::to_time_t(ftime2));
     TEST_CHECK(LastAccessTime(dir) == dir_access_time);
 }
 

Added: vendor/libc++/dist/test/std/iterators/iterator.range/begin-end.fail.cpp
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ vendor/libc++/dist/test/std/iterators/iterator.range/begin-end.fail.cpp	Wed Aug 17 19:36:25 2016	(r304304)
@@ -0,0 +1,51 @@
+//===----------------------------------------------------------------------===//
+//
+//                     The LLVM Compiler Infrastructure
+//
+// This file is dual licensed under the MIT and the University of Illinois Open
+// Source Licenses. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+#include "test_macros.h"
+
+#if TEST_STD_VER < 11
+#error
+#else
+
+// <iterator>
+// template <class C> auto begin(C& c) -> decltype(c.begin());
+// template <class C> auto begin(const C& c) -> decltype(c.begin());
+// template <class C> auto end(C& c) -> decltype(c.end());
+// template <class C> auto end(const C& c) -> decltype(c.end());
+// template <class E> reverse_iterator<const E*> rbegin(initializer_list<E> il);
+// template <class E> reverse_iterator<const E*> rend(initializer_list<E> il);
+
+
+#include <iterator>
+#include <cassert>
+
+namespace Foo {
+	struct FakeContainer {};
+	typedef int FakeIter;
+
+	FakeIter begin(const FakeContainer &)   { return 1; }
+	FakeIter end  (const FakeContainer &)   { return 2; }
+	FakeIter rbegin(const FakeContainer &)  { return 3; }
+	FakeIter rend  (const FakeContainer &)  { return 4; }
+
+	FakeIter cbegin(const FakeContainer &)  { return 11; }
+	FakeIter cend  (const FakeContainer &)  { return 12; }
+	FakeIter crbegin(const FakeContainer &) { return 13; }
+	FakeIter crend  (const FakeContainer &) { return 14; }
+}
+	
+
+int main(){
+// Bug #28927 - shouldn't find these via ADL
+	(void) std::cbegin (Foo::FakeContainer());
+	(void) std::cend   (Foo::FakeContainer());
+	(void) std::crbegin(Foo::FakeContainer());
+	(void) std::crend  (Foo::FakeContainer());	
+}
+#endif

Modified: vendor/libc++/dist/test/std/numerics/complex.number/complex.transcendentals/asin.pass.cpp
==============================================================================
--- vendor/libc++/dist/test/std/numerics/complex.number/complex.transcendentals/asin.pass.cpp	Wed Aug 17 19:36:01 2016	(r304303)
+++ vendor/libc++/dist/test/std/numerics/complex.number/complex.transcendentals/asin.pass.cpp	Wed Aug 17 19:36:25 2016	(r304304)
@@ -91,7 +91,6 @@ void test_edges()
         {
             assert(std::isnan(r.real()));
             assert(std::isnan(r.imag()));
-            assert(std::signbit(testcases[i].imag()) == std::signbit(r.imag()));
         }
         else if (std::isnan(testcases[i].real()) && std::isinf(testcases[i].imag()))
         {



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201608171936.u7HJaPgi083191>