Compare commits
	
		
			139 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 828c2bb86d | ||
|   | 1d41df08d3 | ||
|   | 85c01426ad | ||
|   | 3006f595eb | ||
|   | 84fd172cd6 | ||
|   | 9b3829cb5b | ||
|   | da9c0f1fba | ||
|   | a9ad2ca8bd | ||
|   | 8ffa5d58e0 | ||
|   | 791e11cf33 | ||
|   | 4d933b2b44 | ||
|   | 4f598034d2 | ||
|   | fa06d75e8d | ||
|   | 2644a7b3da | ||
|   | 099084d52f | ||
|   | b3296ae5bc | ||
|   | bf6666f7a0 | ||
|   | 541cb301a1 | ||
|   | 13aaf422e4 | ||
|   | e6440c6fa2 | ||
|   | 737a351850 | ||
|   | 2d81f3d1f3 | ||
|   | 464aa5cad3 | ||
|   | bcbbd4d14f | ||
|   | 9a2078137f | ||
|   | a78264f872 | ||
|   | f3907e6cc0 | ||
|   | 912012e949 | ||
|   | 22ba71b8ef | ||
|   | 8d75632ad0 | ||
|   | c97da3a590 | ||
|   | 0389c53f44 | ||
|   | 66f2641ac9 | ||
|   | 2bf1c08510 | ||
|   | 6f0342cf2e | ||
|   | e59f724f79 | ||
|   | 62a6ac33a2 | ||
|   | 043fe1d931 | ||
|   | cb05a0801a | ||
|   | ac6de546bd | ||
|   | 12c3d374a5 | ||
|   | 9f66bffdbe | ||
|   | 3c8894b078 | ||
|   | f03c3b4612 | ||
|   | 90d7785eba | ||
|   | 74248888ab | ||
|   | 61aa6013c3 | ||
|   | 0949eedbd6 | ||
|   | d318d49e5c | ||
|   | a2a08b43ee | ||
|   | 35d2fcfc8e | ||
|   | f5d76a7afc | ||
|   | 7604fea08c | ||
|   | d4b957820c | ||
|   | 2b1b2d40d7 | ||
|   | 8f5f2563aa | ||
|   | c7c3891199 | ||
|   | c28dbeee52 | ||
|   | 58cd8231d8 | ||
|   | 6a09441022 | ||
|   | 04dae1df22 | ||
|   | 5f2f14c5d2 | ||
|   | 8b53768dac | ||
|   | b2e2a8f6f3 | ||
|   | 7686add61e | ||
|   | d1d27a4afa | ||
|   | 53f7d4cc62 | ||
|   | c560727d5e | ||
|   | b965fed10b | ||
|   | 009b2c4583 | ||
|   | 93f2764b16 | ||
|   | 18884f4e9f | ||
|   | 0a612b0891 | ||
|   | 8790cabd86 | ||
|   | a12beb35e5 | ||
|   | aabf28721b | ||
|   | d737382dfd | ||
|   | 083ba5f5ca | ||
|   | f0562af9dd | ||
|   | 20eda8b563 | ||
|   | c983454d30 | ||
|   | c26fd8061e | ||
|   | a6119a86c5 | ||
|   | d5fed03778 | ||
|   | ad1a5cc5f0 | ||
|   | 0687adca37 | ||
|   | 0667433587 | ||
|   | 756a1763d1 | ||
|   | 603d2c0989 | ||
|   | 1694d23e23 | ||
|   | 10f25d2739 | ||
|   | a5e0121b8d | ||
|   | e9b2c2d669 | ||
|   | 1e15fd1856 | ||
|   | 19ce6a4792 | ||
|   | ed56921d6e | ||
|   | 4b7a43da34 | ||
|   | 8feadca3fa | ||
|   | 1122fec973 | ||
|   | 20542c0b94 | ||
|   | ef54251a84 | ||
|   | e003ce4899 | ||
|   | bd89e4b0dd | ||
|   | 0148a838d0 | ||
|   | 57cff290a4 | ||
|   | 3dd965bdf9 | ||
|   | 932209b344 | ||
|   | fead2e2de9 | ||
|   | 6b9826b2dc | ||
|   | 6cbf9f9b25 | ||
|   | 97ecd64913 | ||
|   | ad935d583d | ||
|   | 656bdc3667 | ||
|   | ed22f562e5 | ||
|   | 941138f8c9 | ||
|   | 496934a803 | ||
|   | 37c53b6221 | ||
|   | 5ec7f5a518 | ||
|   | e06b9965ad | ||
|   | f6cc833ae7 | ||
|   | 783b810cae | ||
|   | a5a0ba86c8 | ||
|   | e80c36e27b | ||
|   | d515df2a50 | ||
|   | f1151efcb1 | ||
|   | 2d01bf0665 | ||
|   | 0a111118a6 | ||
|   | 11a58a68e1 | ||
|   | 6063ec176d | ||
|   | 0cfa1f7cbd | ||
|   | 9e604b442c | ||
|   | d5c2f255c5 | ||
|   | 7bbce3c0e7 | ||
|   | 6b41c6047b | ||
|   | 5d37fb32d2 | ||
|   | 3666695f0d | ||
|   | d982028b92 | ||
|   | ffadfd4c1e | ||
|   | c6e08d6c44 | 
| @@ -16,3 +16,8 @@ N: Marshall Clow | |||||||
| E: marshall@idio.com | E: marshall@idio.com | ||||||
| E: mclow@qualcomm.com | E: mclow@qualcomm.com | ||||||
| D: Minor patches and bug fixes. | D: Minor patches and bug fixes. | ||||||
|  |  | ||||||
|  | N: Bjorn Reese | ||||||
|  | E: breese@users.sourceforge.net | ||||||
|  | D: Initial regex prototype | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										57
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										57
									
								
								Makefile
									
									
									
									
									
								
							| @@ -9,6 +9,15 @@ OBJROOT=. | |||||||
| SYMROOT=. | SYMROOT=. | ||||||
| export TRIPLE=-apple- | export TRIPLE=-apple- | ||||||
|  |  | ||||||
|  | ifeq (,$(RC_INDIGO)) | ||||||
|  | 	INSTALL_PREFIX="" | ||||||
|  | else | ||||||
|  | 	INSTALL_PREFIX="$(SDKROOT)" | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | help:: | ||||||
|  | 	echo Use make install DSTROOT=<destination> | ||||||
|  |  | ||||||
| installsrc:: $(SRCROOT) | installsrc:: $(SRCROOT) | ||||||
|  |  | ||||||
| 	ditto $(SRCDIRS)/include $(SRCROOT)/include | 	ditto $(SRCDIRS)/include $(SRCROOT)/include | ||||||
| @@ -20,19 +29,47 @@ clean:: | |||||||
|  |  | ||||||
| installhdrs:: | installhdrs:: | ||||||
|  |  | ||||||
| 	mkdir -p $(DSTROOT)/usr/include/c++/v1/ext | 	mkdir -p $(DSTROOT)/$(INSTALL_PREFIX)/usr/lib/c++/v1/ext | ||||||
| 	rsync -r --exclude=".*" $(SRCDIRS)/include/* $(DSTROOT)/usr/include/c++/v1/ | 	mkdir -p $(DSTROOT)/$(INSTALL_PREFIX)/Developer/usr/clang-ide/lib/c++/v1/ext | ||||||
| 	chown -R root:wheel $(DSTROOT)/usr/include | 	mkdir -p $(DSTROOT)/$(INSTALL_PREFIX)/Developer/usr/lib/c++/v1/ext | ||||||
| 	chmod 755 $(DSTROOT)/usr/include/c++/v1 | 	mkdir -p $(DSTROOT)/$(INSTALL_PREFIX)/Developer/Platforms/iPhoneOS.platform/usr/lib/c++/v1/ext | ||||||
| 	chmod 644 $(DSTROOT)/usr/include/c++/v1/* | 	mkdir -p $(DSTROOT)/$(INSTALL_PREFIX)/Developer/Platforms/iPhoneOS.platform/Developer/usr/lib/c++/v1/ext | ||||||
| 	chmod 755 $(DSTROOT)/usr/include/c++/v1/ext | 	rsync -r --exclude=".*" $(SRCDIRS)/include/* $(DSTROOT)/$(INSTALL_PREFIX)/usr/lib/c++/v1/ | ||||||
| 	chmod 644 $(DSTROOT)/usr/include/c++/v1/ext/* | 	rsync -r --exclude=".*" $(SRCDIRS)/include/* $(DSTROOT)/$(INSTALL_PREFIX)/Developer/usr/clang-ide/lib/c++/v1/ | ||||||
|  | 	rsync -r --exclude=".*" $(SRCDIRS)/include/* $(DSTROOT)/$(INSTALL_PREFIX)/Developer/usr/lib/c++/v1/ | ||||||
|  | 	rsync -r --exclude=".*" $(SRCDIRS)/include/* $(DSTROOT)/$(INSTALL_PREFIX)/Developer/Platforms/iPhoneOS.platform/usr/lib/c++/v1/ | ||||||
|  | 	rsync -r --exclude=".*" $(SRCDIRS)/include/* $(DSTROOT)/$(INSTALL_PREFIX)/Developer/Platforms/iPhoneOS.platform/Developer/usr/lib/c++/v1/ | ||||||
|  | 	chown -R root:wheel $(DSTROOT)/$(INSTALL_PREFIX)/usr/lib/c++ | ||||||
|  | 	chown -R root:wheel $(DSTROOT)/$(INSTALL_PREFIX)/Developer/usr/clang-ide/lib/c++ | ||||||
|  | 	chown -R root:wheel $(DSTROOT)/$(INSTALL_PREFIX)/Developer/usr/lib/c++ | ||||||
|  | 	chown -R root:wheel $(DSTROOT)/$(INSTALL_PREFIX)/Developer/Platforms/iPhoneOS.platform/usr/lib/c++ | ||||||
|  | 	chown -R root:wheel $(DSTROOT)/$(INSTALL_PREFIX)/Developer/Platforms/iPhoneOS.platform/Developer/usr/lib/c++ | ||||||
|  | 	chmod 755 $(DSTROOT)/$(INSTALL_PREFIX)/usr/lib/c++/v1 | ||||||
|  | 	chmod 755 $(DSTROOT)/$(INSTALL_PREFIX)/Developer/usr/clang-ide/lib/c++/v1 | ||||||
|  | 	chmod 755 $(DSTROOT)/$(INSTALL_PREFIX)/Developer/usr/lib/c++/v1 | ||||||
|  | 	chmod 755 $(DSTROOT)/$(INSTALL_PREFIX)/Developer/Platforms/iPhoneOS.platform/usr/lib/c++/v1 | ||||||
|  | 	chmod 755 $(DSTROOT)/$(INSTALL_PREFIX)/Developer/Platforms/iPhoneOS.platform/Developer/usr/lib/c++/v1 | ||||||
|  | 	chmod 644 $(DSTROOT)/$(INSTALL_PREFIX)/usr/lib/c++/v1/* | ||||||
|  | 	chmod 644 $(DSTROOT)/$(INSTALL_PREFIX)/Developer/usr/clang-ide/lib/c++/v1/* | ||||||
|  | 	chmod 644 $(DSTROOT)/$(INSTALL_PREFIX)/Developer/usr/lib/c++/v1/* | ||||||
|  | 	chmod 644 $(DSTROOT)/$(INSTALL_PREFIX)/Developer/Platforms/iPhoneOS.platform/usr/lib/c++/v1/* | ||||||
|  | 	chmod 644 $(DSTROOT)/$(INSTALL_PREFIX)/Developer/Platforms/iPhoneOS.platform/Developer/usr/lib/c++/v1/* | ||||||
|  | 	chmod 755 $(DSTROOT)/$(INSTALL_PREFIX)/usr/lib/c++/v1/ext | ||||||
|  | 	chmod 755 $(DSTROOT)/$(INSTALL_PREFIX)/Developer/usr/clang-ide/lib/c++/v1/ext | ||||||
|  | 	chmod 755 $(DSTROOT)/$(INSTALL_PREFIX)/Developer/usr/lib/c++/v1/ext | ||||||
|  | 	chmod 755 $(DSTROOT)/$(INSTALL_PREFIX)/Developer/Platforms/iPhoneOS.platform/usr/lib/c++/v1/ext | ||||||
|  | 	chmod 755 $(DSTROOT)/$(INSTALL_PREFIX)/Developer/Platforms/iPhoneOS.platform/Developer/usr/lib/c++/v1/ext | ||||||
|  | 	chmod 644 $(DSTROOT)/$(INSTALL_PREFIX)/usr/lib/c++/v1/ext/* | ||||||
|  | 	chmod 644 $(DSTROOT)/$(INSTALL_PREFIX)/Developer/usr/clang-ide/lib/c++/v1/ext/* | ||||||
|  | 	chmod 644 $(DSTROOT)/$(INSTALL_PREFIX)/Developer/usr/lib/c++/v1/ext/* | ||||||
|  | 	chmod 644 $(DSTROOT)/$(INSTALL_PREFIX)/Developer/Platforms/iPhoneOS.platform/usr/lib/c++/v1/ext/* | ||||||
|  | 	chmod 644 $(DSTROOT)/$(INSTALL_PREFIX)/Developer/Platforms/iPhoneOS.platform/Developer/usr/lib/c++/v1/ext/* | ||||||
|  |  | ||||||
| install:: installhdrs $(DESTDIR) | install:: installhdrs $(DESTDIR) | ||||||
|  |  | ||||||
| 	cd lib && ./buildit | 	cd lib && ./buildit | ||||||
| 	ditto lib/libc++.1.dylib $(SYMROOT)/usr/lib/libc++.1.dylib | 	ditto lib/libc++.1.dylib $(SYMROOT)/usr/lib/libc++.1.dylib | ||||||
| 	cd lib && dsymutil -o $(SYMROOT)/libc++.1.dylib.dSYM  $(SYMROOT)/usr/lib/libc++.1.dylib | 	cd lib && dsymutil -o $(SYMROOT)/libc++.1.dylib.dSYM  $(SYMROOT)/usr/lib/libc++.1.dylib | ||||||
| 	mkdir -p $(DSTROOT)/usr/lib | 	mkdir -p $(DSTROOT)/$(INSTALL_PREFIX)/usr/lib | ||||||
| 	strip -S -o $(DSTROOT)/usr/lib/libc++.1.dylib $(SYMROOT)/usr/lib/libc++.1.dylib | 	strip -S -o $(DSTROOT)/$(INSTALL_PREFIX)/usr/lib/libc++.1.dylib $(SYMROOT)/usr/lib/libc++.1.dylib | ||||||
| 	cd $(DSTROOT)/usr/lib && ln -s libc++.1.dylib libc++.dylib | 	cd $(DSTROOT)/$(INSTALL_PREFIX)/usr/lib && ln -s libc++.1.dylib libc++.dylib | ||||||
|   | |||||||
| @@ -25,6 +25,7 @@ check_cxx_compiler_flag(/GR-                  LIBCXX_HAS_NO_GR_FLAG) | |||||||
| check_library_exists(pthread pthread_create "" LIBCXX_HAS_PTHREAD_LIB) | check_library_exists(pthread pthread_create "" LIBCXX_HAS_PTHREAD_LIB) | ||||||
| check_library_exists(c printf "" LIBCXX_HAS_C_LIB) | check_library_exists(c printf "" LIBCXX_HAS_C_LIB) | ||||||
| check_library_exists(m ccos "" LIBCXX_HAS_M_LIB) | check_library_exists(m ccos "" LIBCXX_HAS_M_LIB) | ||||||
|  | check_library_exists(rt clock_gettime "" LIBCXX_HAS_RT_LIB) | ||||||
| check_library_exists(gcc_s __gcc_personality_v0 "" LIBCXX_HAS_GCC_S_LIB) | check_library_exists(gcc_s __gcc_personality_v0 "" LIBCXX_HAS_GCC_S_LIB) | ||||||
|  |  | ||||||
| # Check C++0x features | # Check C++0x features | ||||||
|   | |||||||
| @@ -21,7 +21,13 @@ _LIBCPP_BEGIN_NAMESPACE_STD | |||||||
| template <class _C, bool _IsConst> class __bit_iterator; | template <class _C, bool _IsConst> class __bit_iterator; | ||||||
| template <class _C> class __bit_const_reference; | template <class _C> class __bit_const_reference; | ||||||
|  |  | ||||||
| template <class _C> | template <class _Tp> | ||||||
|  | struct __has_storage_type | ||||||
|  | { | ||||||
|  |     static const bool value = false; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | template <class _C, bool = __has_storage_type<_C>::value> | ||||||
| class __bit_reference | class __bit_reference | ||||||
| { | { | ||||||
|     typedef typename _C::__storage_type    __storage_type; |     typedef typename _C::__storage_type    __storage_type; | ||||||
| @@ -38,11 +44,13 @@ class __bit_reference | |||||||
|     friend class __bit_const_reference<_C>; |     friend class __bit_const_reference<_C>; | ||||||
|     friend class __bit_iterator<_C, false>; |     friend class __bit_iterator<_C, false>; | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY operator bool() const {return static_cast<bool>(*__seg_ & __mask_);} |     _LIBCPP_INLINE_VISIBILITY operator bool() const _NOEXCEPT | ||||||
|     _LIBCPP_INLINE_VISIBILITY bool operator ~() const {return !static_cast<bool>(*this);} |         {return static_cast<bool>(*__seg_ & __mask_);} | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY bool operator ~() const _NOEXCEPT | ||||||
|  |         {return !static_cast<bool>(*this);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __bit_reference& operator=(bool __x) |     __bit_reference& operator=(bool __x) _NOEXCEPT | ||||||
|     { |     { | ||||||
|         if (__x) |         if (__x) | ||||||
|             *__seg_ |= __mask_; |             *__seg_ |= __mask_; | ||||||
| @@ -52,20 +60,27 @@ public: | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __bit_reference& operator=(const __bit_reference& __x) {return operator=(static_cast<bool>(__x));} |     __bit_reference& operator=(const __bit_reference& __x) _NOEXCEPT | ||||||
|  |         {return operator=(static_cast<bool>(__x));} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY void flip() {*__seg_ ^= __mask_;} |     _LIBCPP_INLINE_VISIBILITY void flip() _NOEXCEPT {*__seg_ ^= __mask_;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY __bit_iterator<_C, false> operator&() const |     _LIBCPP_INLINE_VISIBILITY __bit_iterator<_C, false> operator&() const _NOEXCEPT | ||||||
|         {return __bit_iterator<_C, false>(__seg_, static_cast<unsigned>(__ctz(__mask_)));} |         {return __bit_iterator<_C, false>(__seg_, static_cast<unsigned>(__ctz(__mask_)));} | ||||||
| private: | private: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __bit_reference(__storage_pointer __s, __storage_type __m) : __seg_(__s), __mask_(__m) {} |     __bit_reference(__storage_pointer __s, __storage_type __m) _NOEXCEPT | ||||||
|  |         : __seg_(__s), __mask_(__m) {} | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | template <class _C> | ||||||
|  | class __bit_reference<_C, false> | ||||||
|  | { | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _C, class _D> | template <class _C, class _D> | ||||||
| _LIBCPP_INLINE_VISIBILITY inline | _LIBCPP_INLINE_VISIBILITY inline | ||||||
| void | void | ||||||
| swap(__bit_reference<_C> __x, __bit_reference<_D> __y) | swap(__bit_reference<_C> __x, __bit_reference<_D> __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     bool __t = __x; |     bool __t = __x; | ||||||
|     __x = __y; |     __x = __y; | ||||||
| @@ -75,7 +90,7 @@ swap(__bit_reference<_C> __x, __bit_reference<_D> __y) | |||||||
| template <class _C> | template <class _C> | ||||||
| _LIBCPP_INLINE_VISIBILITY inline | _LIBCPP_INLINE_VISIBILITY inline | ||||||
| void | void | ||||||
| swap(__bit_reference<_C> __x, bool& __y) | swap(__bit_reference<_C> __x, bool& __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     bool __t = __x; |     bool __t = __x; | ||||||
|     __x = __y; |     __x = __y; | ||||||
| @@ -85,7 +100,7 @@ swap(__bit_reference<_C> __x, bool& __y) | |||||||
| template <class _C> | template <class _C> | ||||||
| _LIBCPP_INLINE_VISIBILITY inline | _LIBCPP_INLINE_VISIBILITY inline | ||||||
| void | void | ||||||
| swap(bool& __x, __bit_reference<_C> __y) | swap(bool& __x, __bit_reference<_C> __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     bool __t = __x; |     bool __t = __x; | ||||||
|     __x = __y; |     __x = __y; | ||||||
| @@ -109,16 +124,18 @@ class __bit_const_reference | |||||||
|     friend class __bit_iterator<_C, true>; |     friend class __bit_iterator<_C, true>; | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __bit_const_reference(const __bit_reference<_C>& __x) |     __bit_const_reference(const __bit_reference<_C>& __x) _NOEXCEPT | ||||||
|         : __seg_(__x.__seg_), __mask_(__x.__mask_) {} |         : __seg_(__x.__seg_), __mask_(__x.__mask_) {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY operator bool() const {return static_cast<bool>(*__seg_ & __mask_);} |     _LIBCPP_INLINE_VISIBILITY operator bool() const _NOEXCEPT | ||||||
|  |         {return static_cast<bool>(*__seg_ & __mask_);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY __bit_iterator<_C, true> operator&() const |     _LIBCPP_INLINE_VISIBILITY __bit_iterator<_C, true> operator&() const _NOEXCEPT | ||||||
|         {return __bit_iterator<_C, true>(__seg_, static_cast<unsigned>(__ctz(__mask_)));} |         {return __bit_iterator<_C, true>(__seg_, static_cast<unsigned>(__ctz(__mask_)));} | ||||||
| private: | private: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __bit_const_reference(__storage_pointer __s, __storage_type __m) : __seg_(__s), __mask_(__m) {} |     __bit_const_reference(__storage_pointer __s, __storage_type __m) _NOEXCEPT | ||||||
|  |         : __seg_(__s), __mask_(__m) {} | ||||||
|  |  | ||||||
|     __bit_const_reference& operator=(const __bit_const_reference& __x); |     __bit_const_reference& operator=(const __bit_const_reference& __x); | ||||||
| }; | }; | ||||||
| @@ -136,25 +153,25 @@ __find_bool_true(__bit_iterator<_C, false> __first, typename _C::size_type __n) | |||||||
|     if (__first.__ctz_ != 0) |     if (__first.__ctz_ != 0) | ||||||
|     { |     { | ||||||
|         __storage_type __clz_f = static_cast<__storage_type>(__bits_per_word - __first.__ctz_); |         __storage_type __clz_f = static_cast<__storage_type>(__bits_per_word - __first.__ctz_); | ||||||
|         __storage_type __dn = _STD::min(__clz_f, __n); |         __storage_type __dn = _VSTD::min(__clz_f, __n); | ||||||
|         __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz_f - __dn)); |         __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz_f - __dn)); | ||||||
|         __storage_type __b = *__first.__seg_ & __m; |         __storage_type __b = *__first.__seg_ & __m; | ||||||
|         if (__b) |         if (__b) | ||||||
|             return _It(__first.__seg_, static_cast<unsigned>(_STD::__ctz(__b))); |             return _It(__first.__seg_, static_cast<unsigned>(_VSTD::__ctz(__b))); | ||||||
|         __n -= __dn; |         __n -= __dn; | ||||||
|         ++__first.__seg_; |         ++__first.__seg_; | ||||||
|     } |     } | ||||||
|     // do middle whole words |     // do middle whole words | ||||||
|     for (; __n >= __bits_per_word; ++__first.__seg_, __n -= __bits_per_word) |     for (; __n >= __bits_per_word; ++__first.__seg_, __n -= __bits_per_word) | ||||||
|         if (*__first.__seg_) |         if (*__first.__seg_) | ||||||
|             return _It(__first.__seg_, static_cast<unsigned>(_STD::__ctz(*__first.__seg_))); |             return _It(__first.__seg_, static_cast<unsigned>(_VSTD::__ctz(*__first.__seg_))); | ||||||
|     // do last partial word |     // do last partial word | ||||||
|     if (__n > 0) |     if (__n > 0) | ||||||
|     { |     { | ||||||
|         __storage_type __m = ~__storage_type(0) >> (__bits_per_word - __n); |         __storage_type __m = ~__storage_type(0) >> (__bits_per_word - __n); | ||||||
|         __storage_type __b = *__first.__seg_ & __m; |         __storage_type __b = *__first.__seg_ & __m; | ||||||
|         if (__b) |         if (__b) | ||||||
|             return _It(__first.__seg_, static_cast<unsigned>(_STD::__ctz(__b))); |             return _It(__first.__seg_, static_cast<unsigned>(_VSTD::__ctz(__b))); | ||||||
|     } |     } | ||||||
|     return _It(__first.__seg_, static_cast<unsigned>(__n)); |     return _It(__first.__seg_, static_cast<unsigned>(__n)); | ||||||
| } | } | ||||||
| @@ -170,11 +187,11 @@ __find_bool_false(__bit_iterator<_C, false> __first, typename _C::size_type __n) | |||||||
|     if (__first.__ctz_ != 0) |     if (__first.__ctz_ != 0) | ||||||
|     { |     { | ||||||
|         __storage_type __clz_f = static_cast<__storage_type>(__bits_per_word - __first.__ctz_); |         __storage_type __clz_f = static_cast<__storage_type>(__bits_per_word - __first.__ctz_); | ||||||
|         __storage_type __dn = _STD::min(__clz_f, __n); |         __storage_type __dn = _VSTD::min(__clz_f, __n); | ||||||
|         __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz_f - __dn)); |         __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz_f - __dn)); | ||||||
|         __storage_type __b = ~(*__first.__seg_ & __m); |         __storage_type __b = ~(*__first.__seg_ & __m); | ||||||
|         if (__b) |         if (__b) | ||||||
|             return _It(__first.__seg_, static_cast<unsigned>(_STD::__ctz(__b))); |             return _It(__first.__seg_, static_cast<unsigned>(_VSTD::__ctz(__b))); | ||||||
|         __n -= __dn; |         __n -= __dn; | ||||||
|         ++__first.__seg_; |         ++__first.__seg_; | ||||||
|     } |     } | ||||||
| @@ -183,7 +200,7 @@ __find_bool_false(__bit_iterator<_C, false> __first, typename _C::size_type __n) | |||||||
|     { |     { | ||||||
|         __storage_type __b = ~*__first.__seg_; |         __storage_type __b = ~*__first.__seg_; | ||||||
|         if (__b) |         if (__b) | ||||||
|             return _It(__first.__seg_, static_cast<unsigned>(_STD::__ctz(__b))); |             return _It(__first.__seg_, static_cast<unsigned>(_VSTD::__ctz(__b))); | ||||||
|     } |     } | ||||||
|     // do last partial word |     // do last partial word | ||||||
|     if (__n > 0) |     if (__n > 0) | ||||||
| @@ -191,7 +208,7 @@ __find_bool_false(__bit_iterator<_C, false> __first, typename _C::size_type __n) | |||||||
|         __storage_type __m = ~__storage_type(0) >> (__bits_per_word - __n); |         __storage_type __m = ~__storage_type(0) >> (__bits_per_word - __n); | ||||||
|         __storage_type __b = ~(*__first.__seg_ & __m); |         __storage_type __b = ~(*__first.__seg_ & __m); | ||||||
|         if (__b) |         if (__b) | ||||||
|             return _It(__first.__seg_, static_cast<unsigned>(_STD::__ctz(__b))); |             return _It(__first.__seg_, static_cast<unsigned>(_VSTD::__ctz(__b))); | ||||||
|     } |     } | ||||||
|     return _It(__first.__seg_, static_cast<unsigned>(__n)); |     return _It(__first.__seg_, static_cast<unsigned>(__n)); | ||||||
| } | } | ||||||
| @@ -221,20 +238,20 @@ __count_bool_true(__bit_iterator<_C, false> __first, typename _C::size_type __n) | |||||||
|     if (__first.__ctz_ != 0) |     if (__first.__ctz_ != 0) | ||||||
|     { |     { | ||||||
|         __storage_type __clz_f = static_cast<__storage_type>(__bits_per_word - __first.__ctz_); |         __storage_type __clz_f = static_cast<__storage_type>(__bits_per_word - __first.__ctz_); | ||||||
|         __storage_type __dn = _STD::min(__clz_f, __n); |         __storage_type __dn = _VSTD::min(__clz_f, __n); | ||||||
|         __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz_f - __dn)); |         __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz_f - __dn)); | ||||||
|         __r = _STD::__pop_count(*__first.__seg_ & __m); |         __r = _VSTD::__pop_count(*__first.__seg_ & __m); | ||||||
|         __n -= __dn; |         __n -= __dn; | ||||||
|         ++__first.__seg_; |         ++__first.__seg_; | ||||||
|     } |     } | ||||||
|     // do middle whole words |     // do middle whole words | ||||||
|     for (; __n >= __bits_per_word; ++__first.__seg_, __n -= __bits_per_word) |     for (; __n >= __bits_per_word; ++__first.__seg_, __n -= __bits_per_word) | ||||||
|         __r += _STD::__pop_count(*__first.__seg_); |         __r += _VSTD::__pop_count(*__first.__seg_); | ||||||
|     // do last partial word |     // do last partial word | ||||||
|     if (__n > 0) |     if (__n > 0) | ||||||
|     { |     { | ||||||
|         __storage_type __m = ~__storage_type(0) >> (__bits_per_word - __n); |         __storage_type __m = ~__storage_type(0) >> (__bits_per_word - __n); | ||||||
|         __r += _STD::__pop_count(*__first.__seg_ & __m); |         __r += _VSTD::__pop_count(*__first.__seg_ & __m); | ||||||
|     } |     } | ||||||
|     return __r; |     return __r; | ||||||
| } | } | ||||||
| @@ -252,20 +269,20 @@ __count_bool_false(__bit_iterator<_C, false> __first, typename _C::size_type __n | |||||||
|     if (__first.__ctz_ != 0) |     if (__first.__ctz_ != 0) | ||||||
|     { |     { | ||||||
|         __storage_type __clz_f = static_cast<__storage_type>(__bits_per_word - __first.__ctz_); |         __storage_type __clz_f = static_cast<__storage_type>(__bits_per_word - __first.__ctz_); | ||||||
|         __storage_type __dn = _STD::min(__clz_f, __n); |         __storage_type __dn = _VSTD::min(__clz_f, __n); | ||||||
|         __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz_f - __dn)); |         __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz_f - __dn)); | ||||||
|         __r = _STD::__pop_count(~(*__first.__seg_ & __m)); |         __r = _VSTD::__pop_count(~(*__first.__seg_ & __m)); | ||||||
|         __n -= __dn; |         __n -= __dn; | ||||||
|         ++__first.__seg_; |         ++__first.__seg_; | ||||||
|     } |     } | ||||||
|     // do middle whole words |     // do middle whole words | ||||||
|     for (; __n >= __bits_per_word; ++__first.__seg_, __n -= __bits_per_word) |     for (; __n >= __bits_per_word; ++__first.__seg_, __n -= __bits_per_word) | ||||||
|         __r += _STD::__pop_count(~*__first.__seg_); |         __r += _VSTD::__pop_count(~*__first.__seg_); | ||||||
|     // do last partial word |     // do last partial word | ||||||
|     if (__n > 0) |     if (__n > 0) | ||||||
|     { |     { | ||||||
|         __storage_type __m = ~__storage_type(0) >> (__bits_per_word - __n); |         __storage_type __m = ~__storage_type(0) >> (__bits_per_word - __n); | ||||||
|         __r += _STD::__pop_count(~(*__first.__seg_ & __m)); |         __r += _VSTD::__pop_count(~(*__first.__seg_ & __m)); | ||||||
|     } |     } | ||||||
|     return __r; |     return __r; | ||||||
| } | } | ||||||
| @@ -293,7 +310,7 @@ __fill_n_false(__bit_iterator<_C, false> __first, typename _C::size_type __n) | |||||||
|     if (__first.__ctz_ != 0) |     if (__first.__ctz_ != 0) | ||||||
|     { |     { | ||||||
|         __storage_type __clz_f = static_cast<__storage_type>(__bits_per_word - __first.__ctz_); |         __storage_type __clz_f = static_cast<__storage_type>(__bits_per_word - __first.__ctz_); | ||||||
|         __storage_type __dn = _STD::min(__clz_f, __n); |         __storage_type __dn = _VSTD::min(__clz_f, __n); | ||||||
|         __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz_f - __dn)); |         __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz_f - __dn)); | ||||||
|         *__first.__seg_ &= ~__m; |         *__first.__seg_ &= ~__m; | ||||||
|         __n -= __dn; |         __n -= __dn; | ||||||
| @@ -301,7 +318,7 @@ __fill_n_false(__bit_iterator<_C, false> __first, typename _C::size_type __n) | |||||||
|     } |     } | ||||||
|     // do middle whole words |     // do middle whole words | ||||||
|     __storage_type __nw = __n / __bits_per_word; |     __storage_type __nw = __n / __bits_per_word; | ||||||
|     _STD::memset(__first.__seg_, 0, __nw * sizeof(__storage_type)); |     _VSTD::memset(__first.__seg_, 0, __nw * sizeof(__storage_type)); | ||||||
|     __n -= __nw * __bits_per_word; |     __n -= __nw * __bits_per_word; | ||||||
|     // do last partial word |     // do last partial word | ||||||
|     if (__n > 0) |     if (__n > 0) | ||||||
| @@ -323,7 +340,7 @@ __fill_n_true(__bit_iterator<_C, false> __first, typename _C::size_type __n) | |||||||
|     if (__first.__ctz_ != 0) |     if (__first.__ctz_ != 0) | ||||||
|     { |     { | ||||||
|         __storage_type __clz_f = static_cast<__storage_type>(__bits_per_word - __first.__ctz_); |         __storage_type __clz_f = static_cast<__storage_type>(__bits_per_word - __first.__ctz_); | ||||||
|         __storage_type __dn = _STD::min(__clz_f, __n); |         __storage_type __dn = _VSTD::min(__clz_f, __n); | ||||||
|         __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz_f - __dn)); |         __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz_f - __dn)); | ||||||
|         *__first.__seg_ |= __m; |         *__first.__seg_ |= __m; | ||||||
|         __n -= __dn; |         __n -= __dn; | ||||||
| @@ -331,7 +348,7 @@ __fill_n_true(__bit_iterator<_C, false> __first, typename _C::size_type __n) | |||||||
|     } |     } | ||||||
|     // do middle whole words |     // do middle whole words | ||||||
|     __storage_type __nw = __n / __bits_per_word; |     __storage_type __nw = __n / __bits_per_word; | ||||||
|     _STD::memset(__first.__seg_, -1, __nw * sizeof(__storage_type)); |     _VSTD::memset(__first.__seg_, -1, __nw * sizeof(__storage_type)); | ||||||
|     __n -= __nw * __bits_per_word; |     __n -= __nw * __bits_per_word; | ||||||
|     // do last partial word |     // do last partial word | ||||||
|     if (__n > 0) |     if (__n > 0) | ||||||
| @@ -363,7 +380,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| void | void | ||||||
| fill(__bit_iterator<_C, false> __first, __bit_iterator<_C, false> __last, bool __value) | fill(__bit_iterator<_C, false> __first, __bit_iterator<_C, false> __last, bool __value) | ||||||
| { | { | ||||||
|     _STD::fill_n(__first, static_cast<typename _C::size_type>(__last - __first), __value); |     _VSTD::fill_n(__first, static_cast<typename _C::size_type>(__last - __first), __value); | ||||||
| } | } | ||||||
|  |  | ||||||
| // copy | // copy | ||||||
| @@ -384,7 +401,7 @@ __copy_aligned(__bit_iterator<_C, _IsConst> __first, __bit_iterator<_C, _IsConst | |||||||
|         if (__first.__ctz_ != 0) |         if (__first.__ctz_ != 0) | ||||||
|         { |         { | ||||||
|             unsigned __clz = __bits_per_word - __first.__ctz_; |             unsigned __clz = __bits_per_word - __first.__ctz_; | ||||||
|             difference_type __dn = _STD::min(static_cast<difference_type>(__clz), __n); |             difference_type __dn = _VSTD::min(static_cast<difference_type>(__clz), __n); | ||||||
|             __n -= __dn; |             __n -= __dn; | ||||||
|             __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz - __dn)); |             __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz - __dn)); | ||||||
|             __storage_type __b = *__first.__seg_ & __m; |             __storage_type __b = *__first.__seg_ & __m; | ||||||
| @@ -398,7 +415,7 @@ __copy_aligned(__bit_iterator<_C, _IsConst> __first, __bit_iterator<_C, _IsConst | |||||||
|         // __first.__ctz_ == 0; |         // __first.__ctz_ == 0; | ||||||
|         // do middle words |         // do middle words | ||||||
|         __storage_type __nw = __n / __bits_per_word; |         __storage_type __nw = __n / __bits_per_word; | ||||||
|         _STD::memmove(__result.__seg_, __first.__seg_, __nw * sizeof(__storage_type)); |         _VSTD::memmove(__result.__seg_, __first.__seg_, __nw * sizeof(__storage_type)); | ||||||
|         __n -= __nw * __bits_per_word; |         __n -= __nw * __bits_per_word; | ||||||
|         __result.__seg_ += __nw; |         __result.__seg_ += __nw; | ||||||
|         // do last word |         // do last word | ||||||
| @@ -431,12 +448,12 @@ __copy_unaligned(__bit_iterator<_C, _IsConst> __first, __bit_iterator<_C, _IsCon | |||||||
|         if (__first.__ctz_ != 0) |         if (__first.__ctz_ != 0) | ||||||
|         { |         { | ||||||
|             unsigned __clz_f = __bits_per_word - __first.__ctz_; |             unsigned __clz_f = __bits_per_word - __first.__ctz_; | ||||||
|             difference_type __dn = _STD::min(static_cast<difference_type>(__clz_f), __n); |             difference_type __dn = _VSTD::min(static_cast<difference_type>(__clz_f), __n); | ||||||
|             __n -= __dn; |             __n -= __dn; | ||||||
|             __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz_f - __dn)); |             __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz_f - __dn)); | ||||||
|             __storage_type __b = *__first.__seg_ & __m; |             __storage_type __b = *__first.__seg_ & __m; | ||||||
|             unsigned __clz_r = __bits_per_word - __result.__ctz_; |             unsigned __clz_r = __bits_per_word - __result.__ctz_; | ||||||
|             __storage_type __ddn = _STD::min<__storage_type>(__dn, __clz_r); |             __storage_type __ddn = _VSTD::min<__storage_type>(__dn, __clz_r); | ||||||
|             __m = (~__storage_type(0) << __result.__ctz_) & (~__storage_type(0) >> (__clz_r - __ddn)); |             __m = (~__storage_type(0) << __result.__ctz_) & (~__storage_type(0) >> (__clz_r - __ddn)); | ||||||
|             *__result.__seg_ &= ~__m; |             *__result.__seg_ &= ~__m; | ||||||
|             if (__result.__ctz_ > __first.__ctz_) |             if (__result.__ctz_ > __first.__ctz_) | ||||||
| @@ -474,7 +491,7 @@ __copy_unaligned(__bit_iterator<_C, _IsConst> __first, __bit_iterator<_C, _IsCon | |||||||
|         { |         { | ||||||
|             __m = ~__storage_type(0) >> (__bits_per_word - __n); |             __m = ~__storage_type(0) >> (__bits_per_word - __n); | ||||||
|             __storage_type __b = *__first.__seg_ & __m; |             __storage_type __b = *__first.__seg_ & __m; | ||||||
|             __storage_type __dn = _STD::min(__n, static_cast<difference_type>(__clz_r)); |             __storage_type __dn = _VSTD::min(__n, static_cast<difference_type>(__clz_r)); | ||||||
|             __m = (~__storage_type(0) << __result.__ctz_) & (~__storage_type(0) >> (__clz_r - __dn)); |             __m = (~__storage_type(0) << __result.__ctz_) & (~__storage_type(0) >> (__clz_r - __dn)); | ||||||
|             *__result.__seg_ &= ~__m; |             *__result.__seg_ &= ~__m; | ||||||
|             *__result.__seg_ |= __b << __result.__ctz_; |             *__result.__seg_ |= __b << __result.__ctz_; | ||||||
| @@ -520,7 +537,7 @@ __copy_backward_aligned(__bit_iterator<_C, _IsConst> __first, __bit_iterator<_C, | |||||||
|         // do first word |         // do first word | ||||||
|         if (__last.__ctz_ != 0) |         if (__last.__ctz_ != 0) | ||||||
|         { |         { | ||||||
|             difference_type __dn = _STD::min(static_cast<difference_type>(__last.__ctz_), __n); |             difference_type __dn = _VSTD::min(static_cast<difference_type>(__last.__ctz_), __n); | ||||||
|             __n -= __dn; |             __n -= __dn; | ||||||
|             unsigned __clz = __bits_per_word - __last.__ctz_; |             unsigned __clz = __bits_per_word - __last.__ctz_; | ||||||
|             __storage_type __m = (~__storage_type(0) << (__last.__ctz_ - __dn)) & (~__storage_type(0) >> __clz); |             __storage_type __m = (~__storage_type(0) << (__last.__ctz_ - __dn)) & (~__storage_type(0) >> __clz); | ||||||
| @@ -537,7 +554,7 @@ __copy_backward_aligned(__bit_iterator<_C, _IsConst> __first, __bit_iterator<_C, | |||||||
|         __storage_type __nw = __n / __bits_per_word; |         __storage_type __nw = __n / __bits_per_word; | ||||||
|         __result.__seg_ -= __nw; |         __result.__seg_ -= __nw; | ||||||
|         __last.__seg_ -= __nw; |         __last.__seg_ -= __nw; | ||||||
|         _STD::memmove(__result.__seg_, __last.__seg_, __nw * sizeof(__storage_type)); |         _VSTD::memmove(__result.__seg_, __last.__seg_, __nw * sizeof(__storage_type)); | ||||||
|         __n -= __nw * __bits_per_word; |         __n -= __nw * __bits_per_word; | ||||||
|         // do last word |         // do last word | ||||||
|         if (__n > 0) |         if (__n > 0) | ||||||
| @@ -567,13 +584,13 @@ __copy_backward_unaligned(__bit_iterator<_C, _IsConst> __first, __bit_iterator<_ | |||||||
|         // do first word |         // do first word | ||||||
|         if (__last.__ctz_ != 0) |         if (__last.__ctz_ != 0) | ||||||
|         { |         { | ||||||
|             difference_type __dn = _STD::min(static_cast<difference_type>(__last.__ctz_), __n); |             difference_type __dn = _VSTD::min(static_cast<difference_type>(__last.__ctz_), __n); | ||||||
|             __n -= __dn; |             __n -= __dn; | ||||||
|             unsigned __clz_l = __bits_per_word - __last.__ctz_; |             unsigned __clz_l = __bits_per_word - __last.__ctz_; | ||||||
|             __storage_type __m = (~__storage_type(0) << (__last.__ctz_ - __dn)) & (~__storage_type(0) >> __clz_l); |             __storage_type __m = (~__storage_type(0) << (__last.__ctz_ - __dn)) & (~__storage_type(0) >> __clz_l); | ||||||
|             __storage_type __b = *__last.__seg_ & __m; |             __storage_type __b = *__last.__seg_ & __m; | ||||||
|             unsigned __clz_r = __bits_per_word - __result.__ctz_; |             unsigned __clz_r = __bits_per_word - __result.__ctz_; | ||||||
|             __storage_type __ddn = _STD::min(__dn, static_cast<difference_type>(__result.__ctz_)); |             __storage_type __ddn = _VSTD::min(__dn, static_cast<difference_type>(__result.__ctz_)); | ||||||
|             if (__ddn > 0) |             if (__ddn > 0) | ||||||
|             { |             { | ||||||
|                 __m = (~__storage_type(0) << (__result.__ctz_ - __ddn)) & (~__storage_type(0) >> __clz_r); |                 __m = (~__storage_type(0) << (__result.__ctz_ - __ddn)) & (~__storage_type(0) >> __clz_r); | ||||||
| @@ -617,7 +634,7 @@ __copy_backward_unaligned(__bit_iterator<_C, _IsConst> __first, __bit_iterator<_ | |||||||
|             __m = ~__storage_type(0) << (__bits_per_word - __n); |             __m = ~__storage_type(0) << (__bits_per_word - __n); | ||||||
|             __storage_type __b = *--__last.__seg_ & __m; |             __storage_type __b = *--__last.__seg_ & __m; | ||||||
|             unsigned __clz_r = __bits_per_word - __result.__ctz_; |             unsigned __clz_r = __bits_per_word - __result.__ctz_; | ||||||
|             __storage_type __dn = _STD::min(__n, static_cast<difference_type>(__result.__ctz_)); |             __storage_type __dn = _VSTD::min(__n, static_cast<difference_type>(__result.__ctz_)); | ||||||
|             __m = (~__storage_type(0) << (__result.__ctz_ - __dn)) & (~__storage_type(0) >> __clz_r); |             __m = (~__storage_type(0) << (__result.__ctz_ - __dn)) & (~__storage_type(0) >> __clz_r); | ||||||
|             *__result.__seg_ &= ~__m; |             *__result.__seg_ &= ~__m; | ||||||
|             *__result.__seg_ |= __b >> (__bits_per_word - __result.__ctz_); |             *__result.__seg_ |= __b >> (__bits_per_word - __result.__ctz_); | ||||||
| @@ -655,7 +672,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| __bit_iterator<_C, false> | __bit_iterator<_C, false> | ||||||
| move(__bit_iterator<_C, _IsConst> __first, __bit_iterator<_C, _IsConst> __last, __bit_iterator<_C, false> __result) | move(__bit_iterator<_C, _IsConst> __first, __bit_iterator<_C, _IsConst> __last, __bit_iterator<_C, false> __result) | ||||||
| { | { | ||||||
|     return _STD::copy(__first, __last, __result); |     return _VSTD::copy(__first, __last, __result); | ||||||
| } | } | ||||||
|  |  | ||||||
| // move_backward | // move_backward | ||||||
| @@ -665,7 +682,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| __bit_iterator<_C, false> | __bit_iterator<_C, false> | ||||||
| move_backward(__bit_iterator<_C, _IsConst> __first, __bit_iterator<_C, _IsConst> __last, __bit_iterator<_C, false> __result) | move_backward(__bit_iterator<_C, _IsConst> __first, __bit_iterator<_C, _IsConst> __last, __bit_iterator<_C, false> __result) | ||||||
| { | { | ||||||
|     return _STD::copy(__first, __last, __result); |     return _VSTD::copy(__first, __last, __result); | ||||||
| } | } | ||||||
|  |  | ||||||
| // swap_ranges | // swap_ranges | ||||||
| @@ -686,7 +703,7 @@ __swap_ranges_aligned(__bit_iterator<_C1, false> __first, __bit_iterator<_C1, fa | |||||||
|         if (__first.__ctz_ != 0) |         if (__first.__ctz_ != 0) | ||||||
|         { |         { | ||||||
|             unsigned __clz = __bits_per_word - __first.__ctz_; |             unsigned __clz = __bits_per_word - __first.__ctz_; | ||||||
|             difference_type __dn = _STD::min(static_cast<difference_type>(__clz), __n); |             difference_type __dn = _VSTD::min(static_cast<difference_type>(__clz), __n); | ||||||
|             __n -= __dn; |             __n -= __dn; | ||||||
|             __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz - __dn)); |             __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz - __dn)); | ||||||
|             __storage_type __b1 = *__first.__seg_ & __m; |             __storage_type __b1 = *__first.__seg_ & __m; | ||||||
| @@ -736,13 +753,13 @@ __swap_ranges_unaligned(__bit_iterator<_C1, false> __first, __bit_iterator<_C1, | |||||||
|         if (__first.__ctz_ != 0) |         if (__first.__ctz_ != 0) | ||||||
|         { |         { | ||||||
|             unsigned __clz_f = __bits_per_word - __first.__ctz_; |             unsigned __clz_f = __bits_per_word - __first.__ctz_; | ||||||
|             difference_type __dn = _STD::min(static_cast<difference_type>(__clz_f), __n); |             difference_type __dn = _VSTD::min(static_cast<difference_type>(__clz_f), __n); | ||||||
|             __n -= __dn; |             __n -= __dn; | ||||||
|             __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz_f - __dn)); |             __storage_type __m = (~__storage_type(0) << __first.__ctz_) & (~__storage_type(0) >> (__clz_f - __dn)); | ||||||
|             __storage_type __b1 = *__first.__seg_ & __m; |             __storage_type __b1 = *__first.__seg_ & __m; | ||||||
|             *__first.__seg_ &= ~__m; |             *__first.__seg_ &= ~__m; | ||||||
|             unsigned __clz_r = __bits_per_word - __result.__ctz_; |             unsigned __clz_r = __bits_per_word - __result.__ctz_; | ||||||
|             __storage_type __ddn = _STD::min<__storage_type>(__dn, __clz_r); |             __storage_type __ddn = _VSTD::min<__storage_type>(__dn, __clz_r); | ||||||
|             __m = (~__storage_type(0) << __result.__ctz_) & (~__storage_type(0) >> (__clz_r - __ddn)); |             __m = (~__storage_type(0) << __result.__ctz_) & (~__storage_type(0) >> (__clz_r - __ddn)); | ||||||
|             __storage_type __b2 = *__result.__seg_ & __m; |             __storage_type __b2 = *__result.__seg_ & __m; | ||||||
|             *__result.__seg_ &= ~__m; |             *__result.__seg_ &= ~__m; | ||||||
| @@ -797,7 +814,7 @@ __swap_ranges_unaligned(__bit_iterator<_C1, false> __first, __bit_iterator<_C1, | |||||||
|             __m = ~__storage_type(0) >> (__bits_per_word - __n); |             __m = ~__storage_type(0) >> (__bits_per_word - __n); | ||||||
|             __storage_type __b1 = *__first.__seg_ & __m; |             __storage_type __b1 = *__first.__seg_ & __m; | ||||||
|             *__first.__seg_ &= ~__m; |             *__first.__seg_ &= ~__m; | ||||||
|             __storage_type __dn = _STD::min<__storage_type>(__n, __clz_r); |             __storage_type __dn = _VSTD::min<__storage_type>(__n, __clz_r); | ||||||
|             __m = (~__storage_type(0) << __result.__ctz_) & (~__storage_type(0) >> (__clz_r - __dn)); |             __m = (~__storage_type(0) << __result.__ctz_) & (~__storage_type(0) >> (__clz_r - __dn)); | ||||||
|             __storage_type __b2 = *__result.__seg_ & __m; |             __storage_type __b2 = *__result.__seg_ & __m; | ||||||
|             *__result.__seg_ &= ~__m; |             *__result.__seg_ &= ~__m; | ||||||
| @@ -871,13 +888,13 @@ rotate(__bit_iterator<_C, false> __first, __bit_iterator<_C, false> __middle, __ | |||||||
|             if (__d1 <= __bit_array<_C>::capacity()) |             if (__d1 <= __bit_array<_C>::capacity()) | ||||||
|             { |             { | ||||||
|                 __bit_array<_C> __b(__d1); |                 __bit_array<_C> __b(__d1); | ||||||
|                 _STD::copy(__first, __middle, __b.begin()); |                 _VSTD::copy(__first, __middle, __b.begin()); | ||||||
|                 _STD::copy(__b.begin(), __b.end(), _STD::copy(__middle, __last, __first)); |                 _VSTD::copy(__b.begin(), __b.end(), _VSTD::copy(__middle, __last, __first)); | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             { |             { | ||||||
|                 __bit_iterator<_C, false> __mp = _STD::swap_ranges(__first, __middle, __middle); |                 __bit_iterator<_C, false> __mp = _VSTD::swap_ranges(__first, __middle, __middle); | ||||||
|                 __first = __middle; |                 __first = __middle; | ||||||
|                 __middle = __mp; |                 __middle = __mp; | ||||||
|                 __d2 -= __d1; |                 __d2 -= __d1; | ||||||
| @@ -888,14 +905,14 @@ rotate(__bit_iterator<_C, false> __first, __bit_iterator<_C, false> __middle, __ | |||||||
|             if (__d2 <= __bit_array<_C>::capacity()) |             if (__d2 <= __bit_array<_C>::capacity()) | ||||||
|             { |             { | ||||||
|                 __bit_array<_C> __b(__d2); |                 __bit_array<_C> __b(__d2); | ||||||
|                 _STD::copy(__middle, __last, __b.begin()); |                 _VSTD::copy(__middle, __last, __b.begin()); | ||||||
|                 _STD::copy_backward(__b.begin(), __b.end(), _STD::copy_backward(__first, __middle, __last)); |                 _VSTD::copy_backward(__b.begin(), __b.end(), _VSTD::copy_backward(__first, __middle, __last)); | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             { |             { | ||||||
|                 __bit_iterator<_C, false> __mp = __first + __d2; |                 __bit_iterator<_C, false> __mp = __first + __d2; | ||||||
|                 _STD::swap_ranges(__first, __mp, __middle); |                 _VSTD::swap_ranges(__first, __mp, __middle); | ||||||
|                 __first = __mp; |                 __first = __mp; | ||||||
|                 __d1 -= __d2; |                 __d1 -= __d2; | ||||||
|             } |             } | ||||||
| @@ -922,12 +939,12 @@ __equal_unaligned(__bit_iterator<_C, true> __first1, __bit_iterator<_C, true> __ | |||||||
|         if (__first1.__ctz_ != 0) |         if (__first1.__ctz_ != 0) | ||||||
|         { |         { | ||||||
|             unsigned __clz_f = __bits_per_word - __first1.__ctz_; |             unsigned __clz_f = __bits_per_word - __first1.__ctz_; | ||||||
|             difference_type __dn = _STD::min(static_cast<difference_type>(__clz_f), __n); |             difference_type __dn = _VSTD::min(static_cast<difference_type>(__clz_f), __n); | ||||||
|             __n -= __dn; |             __n -= __dn; | ||||||
|             __storage_type __m = (~__storage_type(0) << __first1.__ctz_) & (~__storage_type(0) >> (__clz_f - __dn)); |             __storage_type __m = (~__storage_type(0) << __first1.__ctz_) & (~__storage_type(0) >> (__clz_f - __dn)); | ||||||
|             __storage_type __b = *__first1.__seg_ & __m; |             __storage_type __b = *__first1.__seg_ & __m; | ||||||
|             unsigned __clz_r = __bits_per_word - __first2.__ctz_; |             unsigned __clz_r = __bits_per_word - __first2.__ctz_; | ||||||
|             __storage_type __ddn = _STD::min<__storage_type>(__dn, __clz_r); |             __storage_type __ddn = _VSTD::min<__storage_type>(__dn, __clz_r); | ||||||
|             __m = (~__storage_type(0) << __first2.__ctz_) & (~__storage_type(0) >> (__clz_r - __ddn)); |             __m = (~__storage_type(0) << __first2.__ctz_) & (~__storage_type(0) >> (__clz_r - __ddn)); | ||||||
|             if (__first2.__ctz_ > __first1.__ctz_) |             if (__first2.__ctz_ > __first1.__ctz_) | ||||||
|                 if ((*__first2.__seg_ & __m) != (__b << (__first2.__ctz_ - __first1.__ctz_))) |                 if ((*__first2.__seg_ & __m) != (__b << (__first2.__ctz_ - __first1.__ctz_))) | ||||||
| @@ -966,7 +983,7 @@ __equal_unaligned(__bit_iterator<_C, true> __first1, __bit_iterator<_C, true> __ | |||||||
|         { |         { | ||||||
|             __m = ~__storage_type(0) >> (__bits_per_word - __n); |             __m = ~__storage_type(0) >> (__bits_per_word - __n); | ||||||
|             __storage_type __b = *__first1.__seg_ & __m; |             __storage_type __b = *__first1.__seg_ & __m; | ||||||
|             __storage_type __dn = _STD::min(__n, static_cast<difference_type>(__clz_r)); |             __storage_type __dn = _VSTD::min(__n, static_cast<difference_type>(__clz_r)); | ||||||
|             __m = (~__storage_type(0) << __first2.__ctz_) & (~__storage_type(0) >> (__clz_r - __dn)); |             __m = (~__storage_type(0) << __first2.__ctz_) & (~__storage_type(0) >> (__clz_r - __dn)); | ||||||
|             if ((*__first2.__seg_ & __m) != (__b << __first2.__ctz_)) |             if ((*__first2.__seg_ & __m) != (__b << __first2.__ctz_)) | ||||||
|                 return false; |                 return false; | ||||||
| @@ -1000,7 +1017,7 @@ __equal_aligned(__bit_iterator<_C, true> __first1, __bit_iterator<_C, true> __la | |||||||
|         if (__first1.__ctz_ != 0) |         if (__first1.__ctz_ != 0) | ||||||
|         { |         { | ||||||
|             unsigned __clz = __bits_per_word - __first1.__ctz_; |             unsigned __clz = __bits_per_word - __first1.__ctz_; | ||||||
|             difference_type __dn = _STD::min(static_cast<difference_type>(__clz), __n); |             difference_type __dn = _VSTD::min(static_cast<difference_type>(__clz), __n); | ||||||
|             __n -= __dn; |             __n -= __dn; | ||||||
|             __storage_type __m = (~__storage_type(0) << __first1.__ctz_) & (~__storage_type(0) >> (__clz - __dn)); |             __storage_type __m = (~__storage_type(0) << __first1.__ctz_) & (~__storage_type(0) >> (__clz - __dn)); | ||||||
|             if ((*__first2.__seg_ & __m) != (*__first1.__seg_ & __m)) |             if ((*__first2.__seg_ & __m) != (*__first1.__seg_ & __m)) | ||||||
| @@ -1057,12 +1074,14 @@ private: | |||||||
|     unsigned          __ctz_; |     unsigned          __ctz_; | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY __bit_iterator() {} |     _LIBCPP_INLINE_VISIBILITY __bit_iterator() _NOEXCEPT {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY __bit_iterator(const __bit_iterator<_C, false>& __it) |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     __bit_iterator(const __bit_iterator<_C, false>& __it) _NOEXCEPT | ||||||
|         : __seg_(__it.__seg_), __ctz_(__it.__ctz_) {} |         : __seg_(__it.__seg_), __ctz_(__it.__ctz_) {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY reference operator*() const {return reference(__seg_, __storage_type(1) << __ctz_);} |     _LIBCPP_INLINE_VISIBILITY reference operator*() const _NOEXCEPT | ||||||
|  |         {return reference(__seg_, __storage_type(1) << __ctz_);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY __bit_iterator& operator++() |     _LIBCPP_INLINE_VISIBILITY __bit_iterator& operator++() | ||||||
|     { |     { | ||||||
| @@ -1162,7 +1181,8 @@ public: | |||||||
|  |  | ||||||
| private: | private: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __bit_iterator(__storage_pointer __s, unsigned __ctz) : __seg_(__s), __ctz_(__ctz) {} |     __bit_iterator(__storage_pointer __s, unsigned __ctz) _NOEXCEPT | ||||||
|  |         : __seg_(__s), __ctz_(__ctz) {} | ||||||
|  |  | ||||||
| #if defined(__clang__) | #if defined(__clang__) | ||||||
|     friend typename _C::__self; |     friend typename _C::__self; | ||||||
|   | |||||||
| @@ -13,13 +13,6 @@ | |||||||
|  |  | ||||||
| #pragma GCC system_header | #pragma GCC system_header | ||||||
|  |  | ||||||
| #ifdef __MINGW32__ |  | ||||||
| #include <yvals.h> |  | ||||||
| #undef _STD |  | ||||||
| #undef _C2 |  | ||||||
| #define _LIBCPP_VISIBILITY_TAG 0 |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #define _LIBCPP_VERSION 1000 | #define _LIBCPP_VERSION 1000 | ||||||
|  |  | ||||||
| #define _LIBCPP_ABI_VERSION 1 | #define _LIBCPP_ABI_VERSION 1 | ||||||
| @@ -54,10 +47,10 @@ | |||||||
| # endif  // _BYTE_ORDER == _LITTLE_ENDIAN | # endif  // _BYTE_ORDER == _LITTLE_ENDIAN | ||||||
| #endif  // __FreeBSD__ | #endif  // __FreeBSD__ | ||||||
|  |  | ||||||
| #if !defined(_LIBCPP_LITTLE_ENDIAN) && (defined(__i386__) || defined(__x86_64__)) | #ifdef _WIN32 | ||||||
| #  define _LIBCPP_LITTLE_ENDIAN 1 | #  define _LIBCPP_LITTLE_ENDIAN 1 | ||||||
| #  define _LIBCPP_BIG_ENDIAN    0 | #  define _LIBCPP_BIG_ENDIAN    0 | ||||||
| #endif | #endif  // _WIN32 | ||||||
|  |  | ||||||
| #if !defined(_LIBCPP_LITTLE_ENDIAN) || !defined(_LIBCPP_BIG_ENDIAN) | #if !defined(_LIBCPP_LITTLE_ENDIAN) || !defined(_LIBCPP_BIG_ENDIAN) | ||||||
| # include <endian.h> | # include <endian.h> | ||||||
| @@ -98,8 +91,9 @@ | |||||||
|  |  | ||||||
| #if defined(__clang__) | #if defined(__clang__) | ||||||
|  |  | ||||||
| #define _LIBCPP_HAS_NO_ADVANCED_SFINAE | #if !__has_feature(cxx_alias_templates) | ||||||
| #define _LIBCPP_HAS_NO_TEMPLATE_ALIASES | #define _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #ifndef __GXX_EXPERIMENTAL_CXX0X__ | #ifndef __GXX_EXPERIMENTAL_CXX0X__ | ||||||
| #ifdef __linux__ | #ifdef __linux__ | ||||||
| @@ -110,7 +104,7 @@ typedef __char32_t char32_t; | |||||||
| #endif | #endif | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if !(__has_feature(cxx_exceptions)) || defined(__MINGW32__) | #if !(__has_feature(cxx_exceptions)) | ||||||
| #define _LIBCPP_NO_EXCEPTIONS | #define _LIBCPP_NO_EXCEPTIONS | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| @@ -122,8 +116,10 @@ typedef __char32_t char32_t; | |||||||
| #define _LIBCPP_HAS_NO_DECLTYPE | #define _LIBCPP_HAS_NO_DECLTYPE | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if !(__has_feature(cxx_attributes)) | #if __has_feature(cxx_attributes) | ||||||
| #define _LIBCPP_HAS_NO_ATTRIBUTES | #  define _ATTRIBUTE(x) [[x]] | ||||||
|  | #else | ||||||
|  | #  define _ATTRIBUTE(x) __attribute__ ((x)) | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #define _LIBCPP_HAS_NO_DEFAULTED_FUNCTIONS | #define _LIBCPP_HAS_NO_DEFAULTED_FUNCTIONS | ||||||
| @@ -152,6 +148,10 @@ typedef __char32_t char32_t; | |||||||
| #define _LIBCPP_HAS_NO_AUTO_TYPE | #define _LIBCPP_HAS_NO_AUTO_TYPE | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #if !(__has_feature(cxx_access_control_sfinae)) || !__has_feature(cxx_trailing_return) | ||||||
|  | #define _LIBCPP_HAS_NO_ADVANCED_SFINAE | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #if !(__has_feature(cxx_variadic_templates)) | #if !(__has_feature(cxx_variadic_templates)) | ||||||
| #define _LIBCPP_HAS_NO_VARIADICS | #define _LIBCPP_HAS_NO_VARIADICS | ||||||
| #endif | #endif | ||||||
| @@ -160,10 +160,19 @@ typedef __char32_t char32_t; | |||||||
| #define _LIBCPP_HAS_NO_TRAILING_RETURN | #define _LIBCPP_HAS_NO_TRAILING_RETURN | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | // Objective-C++ features (opt-in) | ||||||
|  | #if __has_feature(objc_arc) | ||||||
|  | #define _LIBCPP_HAS_OBJC_ARC | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #if __has_feature(objc_arc_weak) | ||||||
|  | #define _LIBCPP_HAS_OBJC_ARC_WEAK | ||||||
|  | #endif | ||||||
|  |  | ||||||
| // Inline namespaces are available in Clang regardless of C++ dialect. | // Inline namespaces are available in Clang regardless of C++ dialect. | ||||||
| #define _LIBCPP_BEGIN_NAMESPACE_STD namespace std {inline namespace _LIBCPP_NAMESPACE { | #define _LIBCPP_BEGIN_NAMESPACE_STD namespace std {inline namespace _LIBCPP_NAMESPACE { | ||||||
| #define _LIBCPP_END_NAMESPACE_STD  } } | #define _LIBCPP_END_NAMESPACE_STD  } } | ||||||
| #define _STD std::_LIBCPP_NAMESPACE | #define _VSTD std::_LIBCPP_NAMESPACE | ||||||
|  |  | ||||||
| namespace std { | namespace std { | ||||||
|   inline namespace _LIBCPP_NAMESPACE { |   inline namespace _LIBCPP_NAMESPACE { | ||||||
| @@ -174,10 +183,24 @@ namespace std { | |||||||
| #define _LIBCPP_HAS_NO_CONSTEXPR | #define _LIBCPP_HAS_NO_CONSTEXPR | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #if (__has_feature(cxx_noexcept)) | ||||||
|  | #  define _NOEXCEPT noexcept | ||||||
|  | #  define _NOEXCEPT_(x) noexcept(x) | ||||||
|  | #else | ||||||
|  | #  define _NOEXCEPT throw() | ||||||
|  | #  define _NOEXCEPT_(x) | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #if __has_feature(underlying_type) | ||||||
|  | #  define _LIBCXX_UNDERLYING_TYPE(T) __underlying_type(T) | ||||||
|  | #endif | ||||||
|  |  | ||||||
| // end defined(__clang__) | // end defined(__clang__) | ||||||
|  |  | ||||||
| #elif defined(__GNUC__) | #elif defined(__GNUC__) | ||||||
|  |  | ||||||
|  | #define _ATTRIBUTE(x) __attribute__((x)) | ||||||
|  |  | ||||||
| #if !__EXCEPTIONS | #if !__EXCEPTIONS | ||||||
| #define _LIBCPP_NO_EXCEPTIONS | #define _LIBCPP_NO_EXCEPTIONS | ||||||
| #endif | #endif | ||||||
| @@ -185,6 +208,9 @@ namespace std { | |||||||
| #define _LIBCPP_HAS_NO_TEMPLATE_ALIASES | #define _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||||
| #define _LIBCPP_HAS_NO_CONSTEXPR | #define _LIBCPP_HAS_NO_CONSTEXPR | ||||||
|  |  | ||||||
|  | #define _NOEXCEPT throw() | ||||||
|  | #define _NOEXCEPT_(x) | ||||||
|  |  | ||||||
| #ifndef __GXX_EXPERIMENTAL_CXX0X__ | #ifndef __GXX_EXPERIMENTAL_CXX0X__ | ||||||
|  |  | ||||||
| #define _LIBCPP_HAS_NO_ADVANCED_SFINAE | #define _LIBCPP_HAS_NO_ADVANCED_SFINAE | ||||||
| @@ -228,7 +254,7 @@ namespace std { | |||||||
|  |  | ||||||
| #define _LIBCPP_BEGIN_NAMESPACE_STD namespace std { namespace _LIBCPP_NAMESPACE { | #define _LIBCPP_BEGIN_NAMESPACE_STD namespace std { namespace _LIBCPP_NAMESPACE { | ||||||
| #define _LIBCPP_END_NAMESPACE_STD  } } | #define _LIBCPP_END_NAMESPACE_STD  } } | ||||||
| #define _STD std::_LIBCPP_NAMESPACE | #define _VSTD std::_LIBCPP_NAMESPACE | ||||||
|  |  | ||||||
| namespace std { | namespace std { | ||||||
| namespace _LIBCPP_NAMESPACE { | namespace _LIBCPP_NAMESPACE { | ||||||
| @@ -266,4 +292,16 @@ template <unsigned> struct __static_assert_check {}; | |||||||
| #define __has_feature(__x) 0 | #define __has_feature(__x) 0 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #ifdef __APPLE__ | ||||||
|  | #define _LIBCPP_LOCALE__L_EXTENSIONS 1 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #ifdef __APPLE__ | ||||||
|  | #define _LIBCPP_STABLE_APPLE_ABI | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #ifdef __APPLE__ | ||||||
|  | #define _LIBCPP_WCTYPE_IS_MASK | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_CONFIG | #endif  // _LIBCPP_CONFIG | ||||||
|   | |||||||
| @@ -314,8 +314,8 @@ class __func<_F, _Alloc, _R()> | |||||||
| { | { | ||||||
|     __compressed_pair<_F, _Alloc> __f_; |     __compressed_pair<_F, _Alloc> __f_; | ||||||
| public: | public: | ||||||
|     explicit __func(_F __f) : __f_(_STD::move(__f)) {} |     explicit __func(_F __f) : __f_(_VSTD::move(__f)) {} | ||||||
|     explicit __func(_F __f, _Alloc __a) : __f_(_STD::move(__f), _STD::move(__a)) {} |     explicit __func(_F __f, _Alloc __a) : __f_(_VSTD::move(__f), _VSTD::move(__a)) {} | ||||||
|     virtual __base<_R()>* __clone() const; |     virtual __base<_R()>* __clone() const; | ||||||
|     virtual void __clone(__base<_R()>*) const; |     virtual void __clone(__base<_R()>*) const; | ||||||
|     virtual void destroy(); |     virtual void destroy(); | ||||||
| @@ -396,9 +396,9 @@ class __func<_F, _Alloc, _R(_A0)> | |||||||
| { | { | ||||||
|     __compressed_pair<_F, _Alloc> __f_; |     __compressed_pair<_F, _Alloc> __f_; | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY explicit __func(_F __f) : __f_(_STD::move(__f)) {} |     _LIBCPP_INLINE_VISIBILITY explicit __func(_F __f) : __f_(_VSTD::move(__f)) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY explicit __func(_F __f, _Alloc __a) |     _LIBCPP_INLINE_VISIBILITY explicit __func(_F __f, _Alloc __a) | ||||||
|         : __f_(_STD::move(__f), _STD::move(__a)) {} |         : __f_(_VSTD::move(__f), _VSTD::move(__a)) {} | ||||||
|     virtual __base<_R(_A0)>* __clone() const; |     virtual __base<_R(_A0)>* __clone() const; | ||||||
|     virtual void __clone(__base<_R(_A0)>*) const; |     virtual void __clone(__base<_R(_A0)>*) const; | ||||||
|     virtual void destroy(); |     virtual void destroy(); | ||||||
| @@ -479,9 +479,9 @@ class __func<_F, _Alloc, _R(_A0, _A1)> | |||||||
| { | { | ||||||
|     __compressed_pair<_F, _Alloc> __f_; |     __compressed_pair<_F, _Alloc> __f_; | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY explicit __func(_F __f) : __f_(_STD::move(__f)) {} |     _LIBCPP_INLINE_VISIBILITY explicit __func(_F __f) : __f_(_VSTD::move(__f)) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY explicit __func(_F __f, _Alloc __a) |     _LIBCPP_INLINE_VISIBILITY explicit __func(_F __f, _Alloc __a) | ||||||
|         : __f_(_STD::move(__f), _STD::move(__a)) {} |         : __f_(_VSTD::move(__f), _VSTD::move(__a)) {} | ||||||
|     virtual __base<_R(_A0, _A1)>* __clone() const; |     virtual __base<_R(_A0, _A1)>* __clone() const; | ||||||
|     virtual void __clone(__base<_R(_A0, _A1)>*) const; |     virtual void __clone(__base<_R(_A0, _A1)>*) const; | ||||||
|     virtual void destroy(); |     virtual void destroy(); | ||||||
| @@ -562,9 +562,9 @@ class __func<_F, _Alloc, _R(_A0, _A1, _A2)> | |||||||
| { | { | ||||||
|     __compressed_pair<_F, _Alloc> __f_; |     __compressed_pair<_F, _Alloc> __f_; | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY explicit __func(_F __f) : __f_(_STD::move(__f)) {} |     _LIBCPP_INLINE_VISIBILITY explicit __func(_F __f) : __f_(_VSTD::move(__f)) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY explicit __func(_F __f, _Alloc __a) |     _LIBCPP_INLINE_VISIBILITY explicit __func(_F __f, _Alloc __a) | ||||||
|         : __f_(_STD::move(__f), _STD::move(__a)) {} |         : __f_(_VSTD::move(__f), _VSTD::move(__a)) {} | ||||||
|     virtual __base<_R(_A0, _A1, _A2)>* __clone() const; |     virtual __base<_R(_A0, _A1, _A2)>* __clone() const; | ||||||
|     virtual void __clone(__base<_R(_A0, _A1, _A2)>*) const; |     virtual void __clone(__base<_R(_A0, _A1, _A2)>*) const; | ||||||
|     virtual void destroy(); |     virtual void destroy(); | ||||||
| @@ -831,7 +831,7 @@ typename enable_if | |||||||
| >::type | >::type | ||||||
| function<_R()>::operator=(_F __f) | function<_R()>::operator=(_F __f) | ||||||
| { | { | ||||||
|     function(_STD::move(__f)).swap(*this); |     function(_VSTD::move(__f)).swap(*this); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -878,7 +878,7 @@ function<_R()>::swap(function& __f) | |||||||
|         __f_ = (__base*)&__buf_; |         __f_ = (__base*)&__buf_; | ||||||
|     } |     } | ||||||
|     else |     else | ||||||
|         _STD::swap(__f_, __f.__f_); |         _VSTD::swap(__f_, __f.__f_); | ||||||
| } | } | ||||||
|  |  | ||||||
| template<class _R> | template<class _R> | ||||||
| @@ -1133,7 +1133,7 @@ typename enable_if | |||||||
| >::type | >::type | ||||||
| function<_R(_A0)>::operator=(_F __f) | function<_R(_A0)>::operator=(_F __f) | ||||||
| { | { | ||||||
|     function(_STD::move(__f)).swap(*this); |     function(_VSTD::move(__f)).swap(*this); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1180,7 +1180,7 @@ function<_R(_A0)>::swap(function& __f) | |||||||
|         __f_ = (__base*)&__buf_; |         __f_ = (__base*)&__buf_; | ||||||
|     } |     } | ||||||
|     else |     else | ||||||
|         _STD::swap(__f_, __f.__f_); |         _VSTD::swap(__f_, __f.__f_); | ||||||
| } | } | ||||||
|  |  | ||||||
| template<class _R, class _A0> | template<class _R, class _A0> | ||||||
| @@ -1435,7 +1435,7 @@ typename enable_if | |||||||
| >::type | >::type | ||||||
| function<_R(_A0, _A1)>::operator=(_F __f) | function<_R(_A0, _A1)>::operator=(_F __f) | ||||||
| { | { | ||||||
|     function(_STD::move(__f)).swap(*this); |     function(_VSTD::move(__f)).swap(*this); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1482,7 +1482,7 @@ function<_R(_A0, _A1)>::swap(function& __f) | |||||||
|         __f_ = (__base*)&__buf_; |         __f_ = (__base*)&__buf_; | ||||||
|     } |     } | ||||||
|     else |     else | ||||||
|         _STD::swap(__f_, __f.__f_); |         _VSTD::swap(__f_, __f.__f_); | ||||||
| } | } | ||||||
|  |  | ||||||
| template<class _R, class _A0, class _A1> | template<class _R, class _A0, class _A1> | ||||||
| @@ -1737,7 +1737,7 @@ typename enable_if | |||||||
| >::type | >::type | ||||||
| function<_R(_A0, _A1, _A2)>::operator=(_F __f) | function<_R(_A0, _A1, _A2)>::operator=(_F __f) | ||||||
| { | { | ||||||
|     function(_STD::move(__f)).swap(*this); |     function(_VSTD::move(__f)).swap(*this); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1784,7 +1784,7 @@ function<_R(_A0, _A1, _A2)>::swap(function& __f) | |||||||
|         __f_ = (__base*)&__buf_; |         __f_ = (__base*)&__buf_; | ||||||
|     } |     } | ||||||
|     else |     else | ||||||
|         _STD::swap(__f_, __f.__f_); |         _VSTD::swap(__f_, __f.__f_); | ||||||
| } | } | ||||||
|  |  | ||||||
| template<class _R, class _A0, class _A1, class _A2> | template<class _R, class _A0, class _A1, class _A2> | ||||||
| @@ -1909,7 +1909,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| typename __mu_return1<true, _Ti, _Uj...>::type | typename __mu_return1<true, _Ti, _Uj...>::type | ||||||
| __mu_expand(_Ti& __ti, tuple<_Uj...>&& __uj, __tuple_indices<_Indx...>) | __mu_expand(_Ti& __ti, tuple<_Uj...>&& __uj, __tuple_indices<_Indx...>) | ||||||
| { | { | ||||||
|     __ti(_STD::forward<typename tuple_element<_Indx, _Uj>::type>(get<_Indx>(__uj))...); |     __ti(_VSTD::forward<typename tuple_element<_Indx, _Uj>::type>(get<_Indx>(__uj))...); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Ti, class ..._Uj> | template <class _Ti, class ..._Uj> | ||||||
| @@ -1947,7 +1947,7 @@ __mu(_Ti&, _Uj& __uj) | |||||||
|     // compiler bug workaround |     // compiler bug workaround | ||||||
|     typename tuple_element<_Indx, _Uj>::type __t = get<_Indx>(__uj); |     typename tuple_element<_Indx, _Uj>::type __t = get<_Indx>(__uj); | ||||||
|     return __t; |     return __t; | ||||||
| //    return _STD::forward<typename tuple_element<_Indx, _Uj>::type>(get<_Indx>(__uj)); | //    return _VSTD::forward<typename tuple_element<_Indx, _Uj>::type>(get<_Indx>(__uj)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Ti, class _Uj> | template <class _Ti, class _Uj> | ||||||
| @@ -2051,8 +2051,8 @@ class __bind | |||||||
| public: | public: | ||||||
|     template <class _G, class ..._BA> |     template <class _G, class ..._BA> | ||||||
|       explicit __bind(_G&& __f, _BA&& ...__bound_args) |       explicit __bind(_G&& __f, _BA&& ...__bound_args) | ||||||
|         : __f_(_STD::forward<_G>(__f)), |         : __f_(_VSTD::forward<_G>(__f)), | ||||||
|           __bound_args_(_STD::forward<_BA>(__bound_args)...) {} |           __bound_args_(_VSTD::forward<_BA>(__bound_args)...) {} | ||||||
|  |  | ||||||
|     template <class ..._Args> |     template <class ..._Args> | ||||||
|         typename __bind_return<_F, tuple<_BoundArgs...>, tuple<_Args&&...> >::type |         typename __bind_return<_F, tuple<_BoundArgs...>, tuple<_Args&&...> >::type | ||||||
| @@ -2085,21 +2085,21 @@ public: | |||||||
|  |  | ||||||
|     template <class _G, class ..._BA> |     template <class _G, class ..._BA> | ||||||
|       explicit __bind_r(_G&& __f, _BA&& ...__bound_args) |       explicit __bind_r(_G&& __f, _BA&& ...__bound_args) | ||||||
|         : base(_STD::forward<_G>(__f), |         : base(_VSTD::forward<_G>(__f), | ||||||
|                _STD::forward<_BA>(__bound_args)...) {} |                _VSTD::forward<_BA>(__bound_args)...) {} | ||||||
|  |  | ||||||
|     template <class ..._Args> |     template <class ..._Args> | ||||||
|         result_type |         result_type | ||||||
|         operator()(_Args&& ...__args) |         operator()(_Args&& ...__args) | ||||||
|         { |         { | ||||||
|             return base::operator()(_STD::forward<_Args>(__args)...); |             return base::operator()(_VSTD::forward<_Args>(__args)...); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     template <class ..._Args> |     template <class ..._Args> | ||||||
|         result_type |         result_type | ||||||
|         operator()(_Args&& ...__args) const |         operator()(_Args&& ...__args) const | ||||||
|         { |         { | ||||||
|             return base::operator()(_STD::forward<_Args>(__args)...); |             return base::operator()(_VSTD::forward<_Args>(__args)...); | ||||||
|         } |         } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -2112,7 +2112,7 @@ __bind<typename decay<_F>::type, typename decay<_BoundArgs>::type...> | |||||||
| bind(_F&& __f, _BoundArgs&&... __bound_args) | bind(_F&& __f, _BoundArgs&&... __bound_args) | ||||||
| { | { | ||||||
|     typedef __bind<typename decay<_F>::type, typename decay<_BoundArgs>::type...> type; |     typedef __bind<typename decay<_F>::type, typename decay<_BoundArgs>::type...> type; | ||||||
|     return type(_STD::forward<_F>(__f), _STD::forward<_BoundArgs>(__bound_args)...); |     return type(_VSTD::forward<_F>(__f), _VSTD::forward<_BoundArgs>(__bound_args)...); | ||||||
| } | } | ||||||
|  |  | ||||||
| template<class _R, class _F, class ..._BoundArgs> | template<class _R, class _F, class ..._BoundArgs> | ||||||
| @@ -2121,7 +2121,7 @@ __bind_r<_R, typename decay<_F>::type, typename decay<_BoundArgs>::type...> | |||||||
| bind(_F&& __f, _BoundArgs&&... __bound_args) | bind(_F&& __f, _BoundArgs&&... __bound_args) | ||||||
| { | { | ||||||
|     typedef __bind_r<_R, typename decay<_F>::type, typename decay<_BoundArgs>::type...> type; |     typedef __bind_r<_R, typename decay<_F>::type, typename decay<_BoundArgs>::type...> type; | ||||||
|     return type(_STD::forward<_F>(__f), _STD::forward<_BoundArgs>(__bound_args)...); |     return type(_VSTD::forward<_F>(__f), _VSTD::forward<_BoundArgs>(__bound_args)...); | ||||||
| } | } | ||||||
| */ | */ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -281,167 +281,61 @@ struct __weak_result_type<_R (_C::*)(_A1, _A2, _A3...) const volatile> | |||||||
|  |  | ||||||
| // __invoke | // __invoke | ||||||
|  |  | ||||||
| // first bullet | // bullets 1 and 2 | ||||||
|  |  | ||||||
| template <class _R, class _T, class _T1, class ..._Param, class ..._Arg> | template <class _F, class _A0, class ..._Args> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| typename enable_if | auto | ||||||
| < | __invoke(_F&& __f, _A0&& __a0, _Args&& ...__args) | ||||||
|     sizeof...(_Param) == sizeof...(_Arg) && |     -> decltype((_VSTD::forward<_A0>(__a0).*__f)(_VSTD::forward<_Args>(__args)...)) | ||||||
|     is_base_of<_T, typename remove_reference<_T1>::type>::value, |  | ||||||
|     _R |  | ||||||
| >::type |  | ||||||
| __invoke(_R (_T::*__f)(_Param...), _T1&& __t1, _Arg&& ...__arg) |  | ||||||
| { | { | ||||||
|     return (_STD::forward<_T>(__t1).*__f)(_STD::forward<_Arg>(__arg)...); |     return (_VSTD::forward<_A0>(__a0).*__f)(_VSTD::forward<_Args>(__args)...); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _R, class _T, class _T1, class ..._Param, class ..._Arg> | template <class _F, class _A0, class ..._Args> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| typename enable_if | auto | ||||||
| < | __invoke(_F&& __f, _A0&& __a0, _Args&& ...__args) | ||||||
|     sizeof...(_Param) == sizeof...(_Arg) && |     -> decltype(((*_VSTD::forward<_A0>(__a0)).*__f)(_VSTD::forward<_Args>(__args)...)) | ||||||
|     is_base_of<_T, typename remove_reference<_T1>::type>::value, |  | ||||||
|     _R |  | ||||||
| >::type |  | ||||||
| __invoke(_R (_T::*__f)(_Param...) const, _T1&& __t1, _Arg&& ...__arg) |  | ||||||
| { | { | ||||||
|     return (_STD::forward<const _T>(__t1).*__f)(_STD::forward<_Arg>(__arg)...); |     return ((*_VSTD::forward<_A0>(__a0)).*__f)(_VSTD::forward<_Args>(__args)...); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _R, class _T, class _T1, class ..._Param, class ..._Arg> | // bullets 3 and 4 | ||||||
|  |  | ||||||
|  | template <class _F, class _A0> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| typename enable_if | auto | ||||||
| < | __invoke(_F&& __f, _A0&& __a0) | ||||||
|     sizeof...(_Param) == sizeof...(_Arg) && |     -> decltype(_VSTD::forward<_A0>(__a0).*__f) | ||||||
|     is_base_of<_T, typename remove_reference<_T1>::type>::value, |  | ||||||
|     _R |  | ||||||
| >::type |  | ||||||
| __invoke(_R (_T::*__f)(_Param...) volatile, _T1&& __t1, _Arg&& ...__arg) |  | ||||||
| { | { | ||||||
|     return (_STD::forward<volatile _T>(__t1).*__f)(_STD::forward<_Arg>(__arg)...); |     return _VSTD::forward<_A0>(__a0).*__f; | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _R, class _T, class _T1, class ..._Param, class ..._Arg> | template <class _F, class _A0> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| typename enable_if | auto | ||||||
| < | __invoke(_F&& __f, _A0&& __a0) | ||||||
|     sizeof...(_Param) == sizeof...(_Arg) && |     -> decltype((*_VSTD::forward<_A0>(__a0)).*__f) | ||||||
|     is_base_of<_T, typename remove_reference<_T1>::type>::value, |  | ||||||
|     _R |  | ||||||
| >::type |  | ||||||
| __invoke(_R (_T::*__f)(_Param...) const volatile, _T1&& __t1, _Arg&& ...__arg) |  | ||||||
| { | { | ||||||
|     return (_STD::forward<const volatile _T>(__t1).*__f)(_STD::forward<_Arg>(__arg)...); |     return (*_VSTD::forward<_A0>(__a0)).*__f; | ||||||
| } | } | ||||||
|  |  | ||||||
| // second bullet | // bullet 5 | ||||||
|  |  | ||||||
| template <class _R, class _T, class _T1, class ..._Param, class ..._Arg> | template <class _F, class ..._Args> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| typename enable_if | auto | ||||||
| < | __invoke(_F&& __f, _Args&& ...__args) | ||||||
|     sizeof...(_Param) == sizeof...(_Arg) && |     -> decltype(_VSTD::forward<_F>(__f)(_VSTD::forward<_Args>(__args)...)) | ||||||
|     !is_base_of<_T, typename remove_reference<_T1>::type>::value, |  | ||||||
|     _R |  | ||||||
| >::type |  | ||||||
| __invoke(_R (_T::*__f)(_Param...), _T1&& __t1, _Arg&& ...__arg) |  | ||||||
| { | { | ||||||
|     return ((*_STD::forward<_T1>(__t1)).*__f)(_STD::forward<_Arg>(__arg)...); |     return _VSTD::forward<_F>(__f)(_VSTD::forward<_Args>(__args)...); | ||||||
| } |  | ||||||
|  |  | ||||||
| template <class _R, class _T, class _T1, class ..._Param, class ..._Arg> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| typename enable_if |  | ||||||
| < |  | ||||||
|     sizeof...(_Param) == sizeof...(_Arg) && |  | ||||||
|     !is_base_of<_T, typename remove_reference<_T1>::type>::value, |  | ||||||
|     _R |  | ||||||
| >::type |  | ||||||
| __invoke(_R (_T::*__f)(_Param...) const, _T1&& __t1, _Arg&& ...__arg) |  | ||||||
| { |  | ||||||
|     return ((*_STD::forward<_T1>(__t1)).*__f)(_STD::forward<_Arg>(__arg)...); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| template <class _R, class _T, class _T1, class ..._Param, class ..._Arg> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| typename enable_if |  | ||||||
| < |  | ||||||
|     sizeof...(_Param) == sizeof...(_Arg) && |  | ||||||
|     !is_base_of<_T, typename remove_reference<_T1>::type>::value, |  | ||||||
|     _R |  | ||||||
| >::type |  | ||||||
| __invoke(_R (_T::*__f)(_Param...) volatile, _T1&& __t1, _Arg&& ...__arg) |  | ||||||
| { |  | ||||||
|     return ((*_STD::forward<_T1>(__t1)).*__f)(_STD::forward<_Arg>(__arg)...); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| template <class _R, class _T, class _T1, class ..._Param, class ..._Arg> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| typename enable_if |  | ||||||
| < |  | ||||||
|     sizeof...(_Param) == sizeof...(_Arg) && |  | ||||||
|     !is_base_of<_T, typename remove_reference<_T1>::type>::value, |  | ||||||
|     _R |  | ||||||
| >::type |  | ||||||
| __invoke(_R (_T::*__f)(_Param...) const volatile, _T1&& __t1, _Arg&& ...__arg) |  | ||||||
| { |  | ||||||
|     return ((*_STD::forward<_T1>(__t1)).*__f)(_STD::forward<_Arg>(__arg)...); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // third bullet |  | ||||||
|  |  | ||||||
| template <class _R, class _T, class _T1> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| typename enable_if |  | ||||||
| < |  | ||||||
|     is_base_of<_T, typename remove_reference<_T1>::type>::value, |  | ||||||
|     typename __apply_cv<_T1, _R>::type&& |  | ||||||
| >::type |  | ||||||
| __invoke(_R _T::* __f, _T1&& __t1) |  | ||||||
| { |  | ||||||
|     return _STD::forward<_T1>(__t1).*__f; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // forth bullet |  | ||||||
|  |  | ||||||
| template <class _T1, class _R, bool> |  | ||||||
| struct __4th_helper |  | ||||||
| { |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| template <class _T1, class _R> |  | ||||||
| struct __4th_helper<_T1, _R, true> |  | ||||||
| { |  | ||||||
|     typedef typename __apply_cv<decltype(*_STD::declval<_T1>()), _R>::type type; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| template <class _R, class _T, class _T1> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| typename __4th_helper<_T1, _R, |  | ||||||
|                       !is_base_of<_T, |  | ||||||
|                                   typename remove_reference<_T1>::type |  | ||||||
|                                  >::value |  | ||||||
|                      >::type&& |  | ||||||
| __invoke(_R _T::* __f, _T1&& __t1) |  | ||||||
| { |  | ||||||
|     return (*_STD::forward<_T1>(__t1)).*__f; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // fifth bullet |  | ||||||
|  |  | ||||||
| template <class _F, class ..._T> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| typename result_of<_F(_T...)>::type |  | ||||||
| __invoke(_F&& __f, _T&& ...__t) |  | ||||||
| { |  | ||||||
|     return _STD::forward<_F>(__f)(_STD::forward<_T>(__t)...); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, class ..._Args> | template <class _Tp, class ..._Args> | ||||||
| struct __invoke_return | struct __invoke_return | ||||||
| { | { | ||||||
|     typedef decltype(__invoke(_STD::declval<_Tp>(), _STD::declval<_Args>()...)) type; |     typedef decltype(__invoke(_VSTD::declval<_Tp>(), _VSTD::declval<_Args>()...)) type; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _Tp> | template <class _Tp> | ||||||
| @@ -456,22 +350,22 @@ private: | |||||||
|  |  | ||||||
| public: | public: | ||||||
|     // construct/copy/destroy |     // construct/copy/destroy | ||||||
|     _LIBCPP_INLINE_VISIBILITY reference_wrapper(type& __f) : __f_(&__f) {} |     _LIBCPP_INLINE_VISIBILITY reference_wrapper(type& __f) _NOEXCEPT : __f_(&__f) {} | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     private: reference_wrapper(type&&); public: // = delete; // do not bind to temps |     private: reference_wrapper(type&&); public: // = delete; // do not bind to temps | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|     // access |     // access | ||||||
|     _LIBCPP_INLINE_VISIBILITY operator type&    () const {return *__f_;} |     _LIBCPP_INLINE_VISIBILITY operator type&    () const _NOEXCEPT {return *__f_;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY          type& get() const {return *__f_;} |     _LIBCPP_INLINE_VISIBILITY          type& get() const _NOEXCEPT {return *__f_;} | ||||||
|  |  | ||||||
|     // invoke |     // invoke | ||||||
|     template <class... _ArgTypes> |     template <class... _ArgTypes> | ||||||
|        _LIBCPP_INLINE_VISIBILITY |        _LIBCPP_INLINE_VISIBILITY | ||||||
|        typename __invoke_return<type&, _ArgTypes...>::type |        typename __invoke_of<type&, _ArgTypes...>::type | ||||||
|           operator() (_ArgTypes&&... __args) const |           operator() (_ArgTypes&&... __args) const | ||||||
|           { |           { | ||||||
|               return __invoke(get(), _STD::forward<_ArgTypes>(__args)...); |               return __invoke(get(), _VSTD::forward<_ArgTypes>(__args)...); | ||||||
|           } |           } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -483,7 +377,7 @@ template <class _Tp> struct __is_reference_wrapper | |||||||
| template <class _Tp> | template <class _Tp> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| reference_wrapper<_Tp> | reference_wrapper<_Tp> | ||||||
| ref(_Tp& __t) | ref(_Tp& __t) _NOEXCEPT | ||||||
| { | { | ||||||
|     return reference_wrapper<_Tp>(__t); |     return reference_wrapper<_Tp>(__t); | ||||||
| } | } | ||||||
| @@ -491,7 +385,7 @@ ref(_Tp& __t) | |||||||
| template <class _Tp> | template <class _Tp> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| reference_wrapper<_Tp> | reference_wrapper<_Tp> | ||||||
| ref(reference_wrapper<_Tp> __t) | ref(reference_wrapper<_Tp> __t) _NOEXCEPT | ||||||
| { | { | ||||||
|     return ref(__t.get()); |     return ref(__t.get()); | ||||||
| } | } | ||||||
| @@ -499,7 +393,7 @@ ref(reference_wrapper<_Tp> __t) | |||||||
| template <class _Tp> | template <class _Tp> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| reference_wrapper<const _Tp> | reference_wrapper<const _Tp> | ||||||
| cref(const _Tp& __t) | cref(const _Tp& __t) _NOEXCEPT | ||||||
| { | { | ||||||
|     return reference_wrapper<const _Tp>(__t); |     return reference_wrapper<const _Tp>(__t); | ||||||
| } | } | ||||||
| @@ -507,7 +401,7 @@ cref(const _Tp& __t) | |||||||
| template <class _Tp> | template <class _Tp> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| reference_wrapper<const _Tp> | reference_wrapper<const _Tp> | ||||||
| cref(reference_wrapper<_Tp> __t) | cref(reference_wrapper<_Tp> __t) _NOEXCEPT | ||||||
| { | { | ||||||
|     return cref(__t.get()); |     return cref(__t.get()); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -842,7 +842,7 @@ struct __4th_helper | |||||||
| template <class _T1, class _R> | template <class _T1, class _R> | ||||||
| struct __4th_helper<_T1, _R, true> | struct __4th_helper<_T1, _R, true> | ||||||
| { | { | ||||||
|     typedef typename __apply_cv<decltype(*_STD::declval<_T1>()), _R>::type type; |     typedef typename __apply_cv<decltype(*_VSTD::declval<_T1>()), _R>::type type; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _R, class _T, class _T1> | template <class _R, class _T, class _T1> | ||||||
| @@ -959,13 +959,13 @@ struct __invoke_return | |||||||
| template <class _F> | template <class _F> | ||||||
| struct __invoke_return<_F, false> | struct __invoke_return<_F, false> | ||||||
| { | { | ||||||
|     typedef decltype(__invoke(_STD::declval<_F>())) type; |     typedef decltype(__invoke(_VSTD::declval<_F>())) type; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _Tp, class _A0> | template <class _Tp, class _A0> | ||||||
| struct __invoke_return0 | struct __invoke_return0 | ||||||
| { | { | ||||||
|     typedef decltype(__invoke(_STD::declval<_Tp>(), _STD::declval<_A0>())) type; |     typedef decltype(__invoke(_VSTD::declval<_Tp>(), _VSTD::declval<_A0>())) type; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _R, class _T, class _A0> | template <class _R, class _T, class _A0> | ||||||
| @@ -983,16 +983,16 @@ struct __invoke_return0<_R _T::*, _A0*> | |||||||
| template <class _Tp, class _A0, class _A1> | template <class _Tp, class _A0, class _A1> | ||||||
| struct __invoke_return1 | struct __invoke_return1 | ||||||
| { | { | ||||||
|     typedef decltype(__invoke(_STD::declval<_Tp>(), _STD::declval<_A0>(), |     typedef decltype(__invoke(_VSTD::declval<_Tp>(), _VSTD::declval<_A0>(), | ||||||
|                                                     _STD::declval<_A1>())) type; |                                                     _VSTD::declval<_A1>())) type; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _Tp, class _A0, class _A1, class _A2> | template <class _Tp, class _A0, class _A1, class _A2> | ||||||
| struct __invoke_return2 | struct __invoke_return2 | ||||||
| { | { | ||||||
|     typedef decltype(__invoke(_STD::declval<_Tp>(), _STD::declval<_A0>(), |     typedef decltype(__invoke(_VSTD::declval<_Tp>(), _VSTD::declval<_A0>(), | ||||||
|                                                     _STD::declval<_A1>(), |                                                     _VSTD::declval<_A1>(), | ||||||
|                                                     _STD::declval<_A2>())) type; |                                                     _VSTD::declval<_A2>())) type; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _Tp> | template <class _Tp> | ||||||
|   | |||||||
| @@ -23,7 +23,7 @@ | |||||||
| _LIBCPP_BEGIN_NAMESPACE_STD | _LIBCPP_BEGIN_NAMESPACE_STD | ||||||
|  |  | ||||||
| _LIBCPP_VISIBLE | _LIBCPP_VISIBLE | ||||||
| size_t __next_prime(size_t); | size_t __next_prime(size_t __n); | ||||||
|  |  | ||||||
| template <class _NodePtr> | template <class _NodePtr> | ||||||
| struct __hash_node_base | struct __hash_node_base | ||||||
| @@ -33,7 +33,7 @@ struct __hash_node_base | |||||||
|  |  | ||||||
|     _NodePtr    __next_; |     _NodePtr    __next_; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY __hash_node_base() : __next_(nullptr) {} |     _LIBCPP_INLINE_VISIBILITY __hash_node_base() _NOEXCEPT : __next_(nullptr) {} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _Tp, class _VoidPtr> | template <class _Tp, class _VoidPtr> | ||||||
| @@ -54,11 +54,12 @@ struct __hash_node | |||||||
|     value_type __value_; |     value_type __value_; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class, class, class, class> class __hash_table; | template <class _Tp, class _Hash, class _Equal, class _Alloc> class __hash_table; | ||||||
| template <class> class __hash_const_iterator; | template <class _ConstNodePtr> class __hash_const_iterator; | ||||||
| template <class> class __hash_map_iterator; | template <class _HashIterator> class __hash_map_iterator; | ||||||
| template <class> class __hash_map_const_iterator; | template <class _HashIterator> class __hash_map_const_iterator; | ||||||
| template <class, class, class, class, class> class _LIBCPP_VISIBLE unordered_map; | template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | ||||||
|  |     class _LIBCPP_VISIBLE unordered_map; | ||||||
|  |  | ||||||
| template <class _NodePtr> | template <class _NodePtr> | ||||||
| class _LIBCPP_VISIBLE __hash_iterator | class _LIBCPP_VISIBLE __hash_iterator | ||||||
| @@ -80,12 +81,12 @@ public: | |||||||
| #endif | #endif | ||||||
|                                                          pointer; |                                                          pointer; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY __hash_iterator() {} |     _LIBCPP_INLINE_VISIBILITY __hash_iterator() _NOEXCEPT {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|         reference operator*() const {return __node_->__value_;} |         reference operator*() const {return __node_->__value_;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|         pointer operator->() const {return _STD::addressof(__node_->__value_);} |         pointer operator->() const {return _VSTD::addressof(__node_->__value_);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __hash_iterator& operator++() |     __hash_iterator& operator++() | ||||||
| @@ -111,7 +112,7 @@ public: | |||||||
|  |  | ||||||
| private: | private: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __hash_iterator(__node_pointer __node) |     __hash_iterator(__node_pointer __node) _NOEXCEPT | ||||||
|         : __node_(__node) |         : __node_(__node) | ||||||
|         {} |         {} | ||||||
|  |  | ||||||
| @@ -154,16 +155,16 @@ public: | |||||||
|                                                       __non_const_node_pointer; |                                                       __non_const_node_pointer; | ||||||
|     typedef __hash_iterator<__non_const_node_pointer> __non_const_iterator; |     typedef __hash_iterator<__non_const_node_pointer> __non_const_iterator; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY __hash_const_iterator() {} |     _LIBCPP_INLINE_VISIBILITY __hash_const_iterator() _NOEXCEPT {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY  |     _LIBCPP_INLINE_VISIBILITY  | ||||||
|     __hash_const_iterator(const __non_const_iterator& __x) |     __hash_const_iterator(const __non_const_iterator& __x) _NOEXCEPT | ||||||
|         : __node_(__x.__node_) |         : __node_(__x.__node_) | ||||||
|         {} |         {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|         reference operator*() const {return __node_->__value_;} |         reference operator*() const {return __node_->__value_;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|         pointer operator->() const {return _STD::addressof(__node_->__value_);} |         pointer operator->() const {return _VSTD::addressof(__node_->__value_);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __hash_const_iterator& operator++() |     __hash_const_iterator& operator++() | ||||||
| @@ -189,7 +190,7 @@ public: | |||||||
|  |  | ||||||
| private: | private: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __hash_const_iterator(__node_pointer __node) |     __hash_const_iterator(__node_pointer __node) _NOEXCEPT | ||||||
|         : __node_(__node) |         : __node_(__node) | ||||||
|         {} |         {} | ||||||
|  |  | ||||||
| @@ -199,7 +200,7 @@ private: | |||||||
|     template <class, class, class, class, class> friend class _LIBCPP_VISIBLE unordered_multimap; |     template <class, class, class, class, class> friend class _LIBCPP_VISIBLE unordered_multimap; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class> class _LIBCPP_VISIBLE __hash_const_local_iterator; | template <class _ConstNodePtr> class _LIBCPP_VISIBLE __hash_const_local_iterator; | ||||||
|  |  | ||||||
| template <class _NodePtr> | template <class _NodePtr> | ||||||
| class _LIBCPP_VISIBLE __hash_local_iterator | class _LIBCPP_VISIBLE __hash_local_iterator | ||||||
| @@ -224,7 +225,7 @@ public: | |||||||
| #endif | #endif | ||||||
|                                                                 pointer; |                                                                 pointer; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY __hash_local_iterator() {} |     _LIBCPP_INLINE_VISIBILITY __hash_local_iterator() _NOEXCEPT {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|         reference operator*() const {return __node_->__value_;} |         reference operator*() const {return __node_->__value_;} | ||||||
| @@ -258,7 +259,7 @@ public: | |||||||
| private: | private: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __hash_local_iterator(__node_pointer __node, size_t __bucket, |     __hash_local_iterator(__node_pointer __node, size_t __bucket, | ||||||
|                           size_t __bucket_count) |                           size_t __bucket_count) _NOEXCEPT | ||||||
|         : __node_(__node), |         : __node_(__node), | ||||||
|           __bucket_(__bucket), |           __bucket_(__bucket), | ||||||
|           __bucket_count_(__bucket_count) |           __bucket_count_(__bucket_count) | ||||||
| @@ -308,9 +309,9 @@ public: | |||||||
| #endif | #endif | ||||||
|                                                        pointer; |                                                        pointer; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY __hash_const_local_iterator() {} |     _LIBCPP_INLINE_VISIBILITY __hash_const_local_iterator() _NOEXCEPT {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __hash_const_local_iterator(const __non_const_iterator& __x) |     __hash_const_local_iterator(const __non_const_iterator& __x) _NOEXCEPT | ||||||
|         : __node_(__x.__node_), |         : __node_(__x.__node_), | ||||||
|           __bucket_(__x.__bucket_), |           __bucket_(__x.__bucket_), | ||||||
|           __bucket_count_(__x.__bucket_count_) |           __bucket_count_(__x.__bucket_count_) | ||||||
| @@ -348,7 +349,7 @@ public: | |||||||
| private: | private: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __hash_const_local_iterator(__node_pointer __node, size_t __bucket, |     __hash_const_local_iterator(__node_pointer __node, size_t __bucket, | ||||||
|                                 size_t __bucket_count) |                                 size_t __bucket_count) _NOEXCEPT | ||||||
|         : __node_(__node), |         : __node_(__node), | ||||||
|           __bucket_(__bucket), |           __bucket_(__bucket), | ||||||
|           __bucket_count_(__bucket_count) |           __bucket_count_(__bucket_count) | ||||||
| @@ -374,37 +375,44 @@ public: | |||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __bucket_list_deallocator() |     __bucket_list_deallocator() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<allocator_type>::value) | ||||||
|         : __data_(0) {} |         : __data_(0) {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __bucket_list_deallocator(const allocator_type& __a, size_type __size) |     __bucket_list_deallocator(const allocator_type& __a, size_type __size) | ||||||
|  |         _NOEXCEPT_(is_nothrow_copy_constructible<allocator_type>::value) | ||||||
|         : __data_(__size, __a) {} |         : __data_(__size, __a) {} | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __bucket_list_deallocator(__bucket_list_deallocator&& __x) |     __bucket_list_deallocator(__bucket_list_deallocator&& __x) | ||||||
|         : __data_(_STD::move(__x.__data_)) |         _NOEXCEPT_(is_nothrow_move_constructible<allocator_type>::value) | ||||||
|  |         : __data_(_VSTD::move(__x.__data_)) | ||||||
|     { |     { | ||||||
|         __x.size() = 0; |         __x.size() = 0; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY size_type& size()       {return __data_.first();} |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     _LIBCPP_INLINE_VISIBILITY size_type  size() const {return __data_.first();} |     size_type& size() _NOEXCEPT {return __data_.first();} | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     _LIBCPP_INLINE_VISIBILITY allocator_type&       __alloc()       {return __data_.second();} |     size_type  size() const _NOEXCEPT {return __data_.first();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY const allocator_type& __alloc() const {return __data_.second();} |  | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void operator()(pointer __p) |     allocator_type& __alloc() _NOEXCEPT {return __data_.second();} | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     const allocator_type& __alloc() const _NOEXCEPT {return __data_.second();} | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     void operator()(pointer __p) _NOEXCEPT | ||||||
|     { |     { | ||||||
|         __alloc_traits::deallocate(__alloc(), __p, size()); |         __alloc_traits::deallocate(__alloc(), __p, size()); | ||||||
|     } |     } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class> class __hash_map_node_destructor; | template <class _Alloc> class __hash_map_node_destructor; | ||||||
|  |  | ||||||
| template <class _Alloc> | template <class _Alloc> | ||||||
| class __hash_node_destructor | class __hash_node_destructor | ||||||
| @@ -424,16 +432,17 @@ public: | |||||||
|     bool __value_constructed; |     bool __value_constructed; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __hash_node_destructor(allocator_type& __na) |     explicit __hash_node_destructor(allocator_type& __na, | ||||||
|  |                                     bool __constructed = false) _NOEXCEPT | ||||||
|         : __na_(__na), |         : __na_(__na), | ||||||
|           __value_constructed(false) |           __value_constructed(__constructed) | ||||||
|         {} |         {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void operator()(pointer __p) |     void operator()(pointer __p) _NOEXCEPT | ||||||
|     { |     { | ||||||
|         if (__value_constructed) |         if (__value_constructed) | ||||||
|             __alloc_traits::destroy(__na_, _STD::addressof(__p->__value_)); |             __alloc_traits::destroy(__na_, _VSTD::addressof(__p->__value_)); | ||||||
|         if (__p) |         if (__p) | ||||||
|             __alloc_traits::deallocate(__na_, __p, 1); |             __alloc_traits::deallocate(__na_, __p, 1); | ||||||
|     } |     } | ||||||
| @@ -495,21 +504,32 @@ private: | |||||||
|     __compressed_pair<float, key_equal>               __p3_; |     __compressed_pair<float, key_equal>               __p3_; | ||||||
|     // --- Member data end --- |     // --- Member data end --- | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY size_type& size()       {return __p2_.first();} |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     size_type& size() _NOEXCEPT {return __p2_.first();} | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY size_type  size() const {return __p2_.first();} |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     size_type  size() const _NOEXCEPT {return __p2_.first();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY       hasher& hash_function()       {return __p2_.second();} |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     _LIBCPP_INLINE_VISIBILITY const hasher& hash_function() const {return __p2_.second();} |     hasher& hash_function() _NOEXCEPT {return __p2_.second();} | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     const hasher& hash_function() const _NOEXCEPT {return __p2_.second();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY float& max_load_factor()       {return __p3_.first();} |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     _LIBCPP_INLINE_VISIBILITY float  max_load_factor() const {return __p3_.first();} |     float& max_load_factor() _NOEXCEPT {return __p3_.first();} | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     float  max_load_factor() const _NOEXCEPT {return __p3_.first();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY       key_equal& key_eq()       {return __p3_.second();} |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     _LIBCPP_INLINE_VISIBILITY const key_equal& key_eq() const {return __p3_.second();} |     key_equal& key_eq() _NOEXCEPT {return __p3_.second();} | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     const key_equal& key_eq() const _NOEXCEPT {return __p3_.second();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY __node_allocator&       __node_alloc()       {return __p1_.second();} |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     _LIBCPP_INLINE_VISIBILITY const __node_allocator& __node_alloc() const {return __p1_.second();} |     __node_allocator& __node_alloc() _NOEXCEPT {return __p1_.second();} | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     const __node_allocator& __node_alloc() const _NOEXCEPT | ||||||
|  |         {return __p1_.second();} | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     typedef __hash_iterator<__node_pointer>                   iterator; |     typedef __hash_iterator<__node_pointer>                   iterator; | ||||||
| @@ -517,7 +537,13 @@ public: | |||||||
|     typedef __hash_local_iterator<__node_pointer>             local_iterator; |     typedef __hash_local_iterator<__node_pointer>             local_iterator; | ||||||
|     typedef __hash_const_local_iterator<__node_const_pointer> const_local_iterator; |     typedef __hash_const_local_iterator<__node_const_pointer> const_local_iterator; | ||||||
|  |  | ||||||
|     __hash_table(); |     __hash_table() | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             is_nothrow_default_constructible<__bucket_list>::value && | ||||||
|  |             is_nothrow_default_constructible<__first_node>::value && | ||||||
|  |             is_nothrow_default_constructible<__node_allocator>::value && | ||||||
|  |             is_nothrow_default_constructible<hasher>::value && | ||||||
|  |             is_nothrow_default_constructible<key_equal>::value); | ||||||
|     __hash_table(const hasher& __hf, const key_equal& __eql); |     __hash_table(const hasher& __hf, const key_equal& __eql); | ||||||
|     __hash_table(const hasher& __hf, const key_equal& __eql, |     __hash_table(const hasher& __hf, const key_equal& __eql, | ||||||
|                  const allocator_type& __a); |                  const allocator_type& __a); | ||||||
| @@ -525,14 +551,25 @@ public: | |||||||
|     __hash_table(const __hash_table& __u); |     __hash_table(const __hash_table& __u); | ||||||
|     __hash_table(const __hash_table& __u, const allocator_type& __a); |     __hash_table(const __hash_table& __u, const allocator_type& __a); | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     __hash_table(__hash_table&& __u); |     __hash_table(__hash_table&& __u) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             is_nothrow_move_constructible<__bucket_list>::value && | ||||||
|  |             is_nothrow_move_constructible<__first_node>::value && | ||||||
|  |             is_nothrow_move_constructible<__node_allocator>::value && | ||||||
|  |             is_nothrow_move_constructible<hasher>::value && | ||||||
|  |             is_nothrow_move_constructible<key_equal>::value); | ||||||
|     __hash_table(__hash_table&& __u, const allocator_type& __a); |     __hash_table(__hash_table&& __u, const allocator_type& __a); | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     ~__hash_table(); |     ~__hash_table(); | ||||||
|  |  | ||||||
|     __hash_table& operator=(const __hash_table& __u); |     __hash_table& operator=(const __hash_table& __u); | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     __hash_table& operator=(__hash_table&& __u); |     __hash_table& operator=(__hash_table&& __u) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             __node_traits::propagate_on_container_move_assignment::value && | ||||||
|  |             is_nothrow_move_assignable<__node_allocator>::value && | ||||||
|  |             is_nothrow_move_assignable<hasher>::value && | ||||||
|  |             is_nothrow_move_assignable<key_equal>::value); | ||||||
| #endif | #endif | ||||||
|     template <class _InputIterator> |     template <class _InputIterator> | ||||||
|         void __assign_unique(_InputIterator __first, _InputIterator __last); |         void __assign_unique(_InputIterator __first, _InputIterator __last); | ||||||
| @@ -540,7 +577,7 @@ public: | |||||||
|         void __assign_multi(_InputIterator __first, _InputIterator __last); |         void __assign_multi(_InputIterator __first, _InputIterator __last); | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type max_size() const |     size_type max_size() const _NOEXCEPT | ||||||
|     { |     { | ||||||
|         return allocator_traits<__pointer_allocator>::max_size( |         return allocator_traits<__pointer_allocator>::max_size( | ||||||
|             __bucket_list_.get_deleter().__alloc()); |             __bucket_list_.get_deleter().__alloc()); | ||||||
| @@ -577,21 +614,21 @@ public: | |||||||
|     iterator __insert_multi(const_iterator __p, const value_type& __x); |     iterator __insert_multi(const_iterator __p, const value_type& __x); | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|     void clear(); |     void clear() _NOEXCEPT; | ||||||
|     void rehash(size_type __n); |     void rehash(size_type __n); | ||||||
|     _LIBCPP_INLINE_VISIBILITY void reserve(size_type __n) |     _LIBCPP_INLINE_VISIBILITY void reserve(size_type __n) | ||||||
|         {rehash(static_cast<size_type>(ceil(__n / max_load_factor())));} |         {rehash(static_cast<size_type>(ceil(__n / max_load_factor())));} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type bucket_count() const |     size_type bucket_count() const _NOEXCEPT | ||||||
|     { |     { | ||||||
|         return __bucket_list_.get_deleter().size(); |         return __bucket_list_.get_deleter().size(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     iterator       begin(); |     iterator       begin() _NOEXCEPT; | ||||||
|     iterator       end(); |     iterator       end() _NOEXCEPT; | ||||||
|     const_iterator begin() const; |     const_iterator begin() const _NOEXCEPT; | ||||||
|     const_iterator end() const; |     const_iterator end() const _NOEXCEPT; | ||||||
|  |  | ||||||
|     template <class _Key> |     template <class _Key> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -612,7 +649,7 @@ public: | |||||||
|         size_type __erase_unique(const _Key& __k); |         size_type __erase_unique(const _Key& __k); | ||||||
|     template <class _Key> |     template <class _Key> | ||||||
|         size_type __erase_multi(const _Key& __k); |         size_type __erase_multi(const _Key& __k); | ||||||
|     __node_holder remove(const_iterator __p); |     __node_holder remove(const_iterator __p) _NOEXCEPT; | ||||||
|  |  | ||||||
|     template <class _Key> |     template <class _Key> | ||||||
|         size_type __count_unique(const _Key& __k) const; |         size_type __count_unique(const _Key& __k) const; | ||||||
| @@ -633,19 +670,26 @@ public: | |||||||
|         pair<const_iterator, const_iterator> |         pair<const_iterator, const_iterator> | ||||||
|         __equal_range_multi(const _Key& __k) const; |         __equal_range_multi(const _Key& __k) const; | ||||||
|  |  | ||||||
|     void swap(__hash_table& __u); |     void swap(__hash_table& __u) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             (!allocator_traits<__pointer_allocator>::propagate_on_container_swap::value || | ||||||
|  |              __is_nothrow_swappable<__pointer_allocator>::value) && | ||||||
|  |             (!__node_traits::propagate_on_container_swap::value || | ||||||
|  |              __is_nothrow_swappable<__node_allocator>::value) && | ||||||
|  |             __is_nothrow_swappable<hasher>::value && | ||||||
|  |             __is_nothrow_swappable<key_equal>::value); | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type max_bucket_count() const |     size_type max_bucket_count() const _NOEXCEPT | ||||||
|         {return __bucket_list_.get_deleter().__alloc().max_size();} |         {return __bucket_list_.get_deleter().__alloc().max_size();} | ||||||
|     size_type bucket_size(size_type __n) const; |     size_type bucket_size(size_type __n) const; | ||||||
|     _LIBCPP_INLINE_VISIBILITY float load_factor() const |     _LIBCPP_INLINE_VISIBILITY float load_factor() const _NOEXCEPT | ||||||
|     { |     { | ||||||
|         size_type __bc = bucket_count(); |         size_type __bc = bucket_count(); | ||||||
|         return __bc != 0 ? (float)size() / __bc : 0.f; |         return __bc != 0 ? (float)size() / __bc : 0.f; | ||||||
|     } |     } | ||||||
|     _LIBCPP_INLINE_VISIBILITY void max_load_factor(float __mlf) |     _LIBCPP_INLINE_VISIBILITY void max_load_factor(float __mlf) _NOEXCEPT | ||||||
|         {max_load_factor() = _STD::max(__mlf, load_factor());} |         {max_load_factor() = _VSTD::max(__mlf, load_factor());} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY local_iterator       begin(size_type __n) |     _LIBCPP_INLINE_VISIBILITY local_iterator       begin(size_type __n) | ||||||
|         {return local_iterator(__bucket_list_[__n], __n, bucket_count());} |         {return local_iterator(__bucket_list_[__n], __n, bucket_count());} | ||||||
| @@ -678,25 +722,40 @@ private: | |||||||
|         void __copy_assign_alloc(const __hash_table& __u, false_type) {} |         void __copy_assign_alloc(const __hash_table& __u, false_type) {} | ||||||
|  |  | ||||||
|     void __move_assign(__hash_table& __u, false_type); |     void __move_assign(__hash_table& __u, false_type); | ||||||
|     void __move_assign(__hash_table& __u, true_type); |     void __move_assign(__hash_table& __u, true_type) | ||||||
|     _LIBCPP_INLINE_VISIBILITY void __move_assign_alloc(__hash_table& __u) |         _NOEXCEPT_( | ||||||
|  |             is_nothrow_move_assignable<__node_allocator>::value && | ||||||
|  |             is_nothrow_move_assignable<hasher>::value && | ||||||
|  |             is_nothrow_move_assignable<key_equal>::value); | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     void __move_assign_alloc(__hash_table& __u) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             !__node_traits::propagate_on_container_move_assignment::value || | ||||||
|  |             (is_nothrow_move_assignable<__pointer_allocator>::value && | ||||||
|  |              is_nothrow_move_assignable<__node_allocator>::value)) | ||||||
|         {__move_assign_alloc(__u, integral_constant<bool, |         {__move_assign_alloc(__u, integral_constant<bool, | ||||||
|              __node_traits::propagate_on_container_move_assignment::value>());} |              __node_traits::propagate_on_container_move_assignment::value>());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void __move_assign_alloc(__hash_table& __u, true_type) |     void __move_assign_alloc(__hash_table& __u, true_type) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             is_nothrow_move_assignable<__pointer_allocator>::value && | ||||||
|  |             is_nothrow_move_assignable<__node_allocator>::value) | ||||||
|     { |     { | ||||||
|         __bucket_list_.get_deleter().__alloc() = |         __bucket_list_.get_deleter().__alloc() = | ||||||
|                 _STD::move(__u.__bucket_list_.get_deleter().__alloc()); |                 _VSTD::move(__u.__bucket_list_.get_deleter().__alloc()); | ||||||
|         __node_alloc() = _STD::move(__u.__node_alloc()); |         __node_alloc() = _VSTD::move(__u.__node_alloc()); | ||||||
|     } |     } | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|         void __move_assign_alloc(__hash_table&, false_type) {} |         void __move_assign_alloc(__hash_table&, false_type) _NOEXCEPT {} | ||||||
|  |  | ||||||
|     template <class _A> |     template <class _A> | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     static |     static | ||||||
|     void |     void | ||||||
|     __swap_alloc(_A& __x, _A& __y) |     __swap_alloc(_A& __x, _A& __y) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             !allocator_traits<_A>::propagate_on_container_swap::value || | ||||||
|  |             __is_nothrow_swappable<_A>::value) | ||||||
|     { |     { | ||||||
|         __swap_alloc(__x, __y, |         __swap_alloc(__x, __y, | ||||||
|                      integral_constant<bool, |                      integral_constant<bool, | ||||||
| @@ -709,8 +768,9 @@ private: | |||||||
|     static |     static | ||||||
|     void |     void | ||||||
|     __swap_alloc(_A& __x, _A& __y, true_type) |     __swap_alloc(_A& __x, _A& __y, true_type) | ||||||
|  |         _NOEXCEPT_(__is_nothrow_swappable<_A>::value) | ||||||
|     { |     { | ||||||
|         using _STD::swap; |         using _VSTD::swap; | ||||||
|         swap(__x, __y); |         swap(__x, __y); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -718,15 +778,20 @@ private: | |||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     static |     static | ||||||
|     void |     void | ||||||
|     __swap_alloc(_A& __x, _A& __y, false_type) {} |     __swap_alloc(_A& __x, _A& __y, false_type) _NOEXCEPT {} | ||||||
|  |  | ||||||
|     void __deallocate(__node_pointer __np); |     void __deallocate(__node_pointer __np) _NOEXCEPT; | ||||||
|     __node_pointer __detach(); |     __node_pointer __detach() _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _Tp, class _Hash, class _Equal, class _Alloc> | template <class _Tp, class _Hash, class _Equal, class _Alloc> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::__hash_table() | __hash_table<_Tp, _Hash, _Equal, _Alloc>::__hash_table() | ||||||
|  |     _NOEXCEPT_( | ||||||
|  |         is_nothrow_default_constructible<__bucket_list>::value && | ||||||
|  |         is_nothrow_default_constructible<__first_node>::value && | ||||||
|  |         is_nothrow_default_constructible<hasher>::value && | ||||||
|  |         is_nothrow_default_constructible<key_equal>::value) | ||||||
|     : __p2_(0), |     : __p2_(0), | ||||||
|       __p3_(1.0f) |       __p3_(1.0f) | ||||||
| { | { | ||||||
| @@ -790,15 +855,20 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__hash_table(const __hash_table& __u, | |||||||
|  |  | ||||||
| template <class _Tp, class _Hash, class _Equal, class _Alloc> | template <class _Tp, class _Hash, class _Equal, class _Alloc> | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::__hash_table(__hash_table&& __u) | __hash_table<_Tp, _Hash, _Equal, _Alloc>::__hash_table(__hash_table&& __u) | ||||||
|     : __bucket_list_(_STD::move(__u.__bucket_list_)), |         _NOEXCEPT_( | ||||||
|       __p1_(_STD::move(__u.__p1_)), |             is_nothrow_move_constructible<__bucket_list>::value && | ||||||
|       __p2_(_STD::move(__u.__p2_)), |             is_nothrow_move_constructible<__first_node>::value && | ||||||
|       __p3_(_STD::move(__u.__p3_)) |             is_nothrow_move_constructible<hasher>::value && | ||||||
|  |             is_nothrow_move_constructible<key_equal>::value) | ||||||
|  |     : __bucket_list_(_VSTD::move(__u.__bucket_list_)), | ||||||
|  |       __p1_(_VSTD::move(__u.__p1_)), | ||||||
|  |       __p2_(_VSTD::move(__u.__p2_)), | ||||||
|  |       __p3_(_VSTD::move(__u.__p3_)) | ||||||
| { | { | ||||||
|     if (size() > 0) |     if (size() > 0) | ||||||
|     { |     { | ||||||
|         __bucket_list_[__p1_.first().__next_->__hash_ % bucket_count()] = |         __bucket_list_[__p1_.first().__next_->__hash_ % bucket_count()] = | ||||||
|             static_cast<__node_pointer>(_STD::addressof(__p1_.first())); |             static_cast<__node_pointer>(_VSTD::addressof(__p1_.first())); | ||||||
|         __u.__p1_.first().__next_ = nullptr; |         __u.__p1_.first().__next_ = nullptr; | ||||||
|         __u.size() = 0; |         __u.size() = 0; | ||||||
|     } |     } | ||||||
| @@ -809,8 +879,8 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__hash_table(__hash_table&& __u, | |||||||
|                                                        const allocator_type& __a) |                                                        const allocator_type& __a) | ||||||
|     : __bucket_list_(nullptr, __bucket_list_deleter(__pointer_allocator(__a), 0)), |     : __bucket_list_(nullptr, __bucket_list_deleter(__pointer_allocator(__a), 0)), | ||||||
|       __p1_(__node_allocator(__a)), |       __p1_(__node_allocator(__a)), | ||||||
|       __p2_(0, _STD::move(__u.hash_function())), |       __p2_(0, _VSTD::move(__u.hash_function())), | ||||||
|       __p3_(_STD::move(__u.__p3_)) |       __p3_(_VSTD::move(__u.__p3_)) | ||||||
| { | { | ||||||
|     if (__a == allocator_type(__u.__node_alloc())) |     if (__a == allocator_type(__u.__node_alloc())) | ||||||
|     { |     { | ||||||
| @@ -822,7 +892,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__hash_table(__hash_table&& __u, | |||||||
|             __p1_.first().__next_ = __u.__p1_.first().__next_; |             __p1_.first().__next_ = __u.__p1_.first().__next_; | ||||||
|             __u.__p1_.first().__next_ = nullptr; |             __u.__p1_.first().__next_ = nullptr; | ||||||
|             __bucket_list_[__p1_.first().__next_->__hash_ % bucket_count()] = |             __bucket_list_[__p1_.first().__next_->__hash_ % bucket_count()] = | ||||||
|                 static_cast<__node_pointer>(_STD::addressof(__p1_.first())); |                 static_cast<__node_pointer>(_VSTD::addressof(__p1_.first())); | ||||||
|             size() = __u.size(); |             size() = __u.size(); | ||||||
|             __u.size() = 0; |             __u.size() = 0; | ||||||
|         } |         } | ||||||
| @@ -870,12 +940,13 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::operator=(const __hash_table& __u) | |||||||
| template <class _Tp, class _Hash, class _Equal, class _Alloc> | template <class _Tp, class _Hash, class _Equal, class _Alloc> | ||||||
| void | void | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::__deallocate(__node_pointer __np) | __hash_table<_Tp, _Hash, _Equal, _Alloc>::__deallocate(__node_pointer __np) | ||||||
|  |     _NOEXCEPT | ||||||
| { | { | ||||||
|     __node_allocator& __na = __node_alloc(); |     __node_allocator& __na = __node_alloc(); | ||||||
|     while (__np != nullptr) |     while (__np != nullptr) | ||||||
|     { |     { | ||||||
|         __node_pointer __next = __np->__next_; |         __node_pointer __next = __np->__next_; | ||||||
|         __node_traits::destroy(__na, _STD::addressof(__np->__value_)); |         __node_traits::destroy(__na, _VSTD::addressof(__np->__value_)); | ||||||
|         __node_traits::deallocate(__na, __np, 1); |         __node_traits::deallocate(__na, __np, 1); | ||||||
|         __np = __next; |         __np = __next; | ||||||
|     } |     } | ||||||
| @@ -883,7 +954,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__deallocate(__node_pointer __np) | |||||||
|  |  | ||||||
| template <class _Tp, class _Hash, class _Equal, class _Alloc> | template <class _Tp, class _Hash, class _Equal, class _Alloc> | ||||||
| typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::__node_pointer | typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::__node_pointer | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::__detach() | __hash_table<_Tp, _Hash, _Equal, _Alloc>::__detach() _NOEXCEPT | ||||||
| { | { | ||||||
|     size_type __bc = bucket_count(); |     size_type __bc = bucket_count(); | ||||||
|     for (size_type __i = 0; __i < __bc; ++__i) |     for (size_type __i = 0; __i < __bc; ++__i) | ||||||
| @@ -900,6 +971,10 @@ template <class _Tp, class _Hash, class _Equal, class _Alloc> | |||||||
| void | void | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::__move_assign( | __hash_table<_Tp, _Hash, _Equal, _Alloc>::__move_assign( | ||||||
|         __hash_table& __u, true_type) |         __hash_table& __u, true_type) | ||||||
|  |     _NOEXCEPT_( | ||||||
|  |         is_nothrow_move_assignable<__node_allocator>::value && | ||||||
|  |         is_nothrow_move_assignable<hasher>::value && | ||||||
|  |         is_nothrow_move_assignable<key_equal>::value) | ||||||
| { | { | ||||||
|     clear(); |     clear(); | ||||||
|     __bucket_list_.reset(__u.__bucket_list_.release()); |     __bucket_list_.reset(__u.__bucket_list_.release()); | ||||||
| @@ -907,14 +982,14 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__move_assign( | |||||||
|     __u.__bucket_list_.get_deleter().size() = 0; |     __u.__bucket_list_.get_deleter().size() = 0; | ||||||
|     __move_assign_alloc(__u); |     __move_assign_alloc(__u); | ||||||
|     size() = __u.size(); |     size() = __u.size(); | ||||||
|     hash_function() = _STD::move(__u.hash_function()); |     hash_function() = _VSTD::move(__u.hash_function()); | ||||||
|     max_load_factor() = __u.max_load_factor(); |     max_load_factor() = __u.max_load_factor(); | ||||||
|     key_eq() = _STD::move(__u.key_eq()); |     key_eq() = _VSTD::move(__u.key_eq()); | ||||||
|     __p1_.first().__next_ = __u.__p1_.first().__next_; |     __p1_.first().__next_ = __u.__p1_.first().__next_; | ||||||
|     if (size() > 0) |     if (size() > 0) | ||||||
|     { |     { | ||||||
|         __bucket_list_[__p1_.first().__next_->__hash_ % bucket_count()] = |         __bucket_list_[__p1_.first().__next_->__hash_ % bucket_count()] = | ||||||
|             static_cast<__node_pointer>(_STD::addressof(__p1_.first())); |             static_cast<__node_pointer>(_VSTD::addressof(__p1_.first())); | ||||||
|         __u.__p1_.first().__next_ = nullptr; |         __u.__p1_.first().__next_ = nullptr; | ||||||
|         __u.size() = 0; |         __u.size() = 0; | ||||||
|     } |     } | ||||||
| @@ -929,8 +1004,8 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__move_assign( | |||||||
|         __move_assign(__u, true_type()); |         __move_assign(__u, true_type()); | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
|         hash_function() = _STD::move(__u.hash_function()); |         hash_function() = _VSTD::move(__u.hash_function()); | ||||||
|         key_eq() = _STD::move(__u.key_eq()); |         key_eq() = _VSTD::move(__u.key_eq()); | ||||||
|         max_load_factor() = __u.max_load_factor(); |         max_load_factor() = __u.max_load_factor(); | ||||||
|         if (bucket_count() != 0) |         if (bucket_count() != 0) | ||||||
|         { |         { | ||||||
| @@ -942,7 +1017,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__move_assign( | |||||||
|                 const_iterator __i = __u.begin(); |                 const_iterator __i = __u.begin(); | ||||||
|                 while (__cache != nullptr && __u.size() != 0) |                 while (__cache != nullptr && __u.size() != 0) | ||||||
|                 { |                 { | ||||||
|                     __cache->__value_ = _STD::move(__u.remove(__i++)->__value_); |                     __cache->__value_ = _VSTD::move(__u.remove(__i++)->__value_); | ||||||
|                     __node_pointer __next = __cache->__next_; |                     __node_pointer __next = __cache->__next_; | ||||||
|                     __node_insert_multi(__cache); |                     __node_insert_multi(__cache); | ||||||
|                     __cache = __next; |                     __cache = __next; | ||||||
| @@ -961,7 +1036,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__move_assign( | |||||||
|         while (__u.size() != 0) |         while (__u.size() != 0) | ||||||
|         { |         { | ||||||
|             __node_holder __h = |             __node_holder __h = | ||||||
|                     __construct_node(_STD::move(__u.remove(__i++)->__value_)); |                     __construct_node(_VSTD::move(__u.remove(__i++)->__value_)); | ||||||
|             __node_insert_multi(__h.get()); |             __node_insert_multi(__h.get()); | ||||||
|             __h.release(); |             __h.release(); | ||||||
|         } |         } | ||||||
| @@ -972,6 +1047,11 @@ template <class _Tp, class _Hash, class _Equal, class _Alloc> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>& | __hash_table<_Tp, _Hash, _Equal, _Alloc>& | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::operator=(__hash_table&& __u) | __hash_table<_Tp, _Hash, _Equal, _Alloc>::operator=(__hash_table&& __u) | ||||||
|  |     _NOEXCEPT_( | ||||||
|  |         __node_traits::propagate_on_container_move_assignment::value && | ||||||
|  |         is_nothrow_move_assignable<__node_allocator>::value && | ||||||
|  |         is_nothrow_move_assignable<hasher>::value && | ||||||
|  |         is_nothrow_move_assignable<key_equal>::value) | ||||||
| { | { | ||||||
|     __move_assign(__u, integral_constant<bool, |     __move_assign(__u, integral_constant<bool, | ||||||
|                   __node_traits::propagate_on_container_move_assignment::value>()); |                   __node_traits::propagate_on_container_move_assignment::value>()); | ||||||
| @@ -1051,7 +1131,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__assign_multi(_InputIterator __first, | |||||||
| template <class _Tp, class _Hash, class _Equal, class _Alloc> | template <class _Tp, class _Hash, class _Equal, class _Alloc> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator | typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::begin() | __hash_table<_Tp, _Hash, _Equal, _Alloc>::begin() _NOEXCEPT | ||||||
| { | { | ||||||
|     return iterator(__p1_.first().__next_); |     return iterator(__p1_.first().__next_); | ||||||
| } | } | ||||||
| @@ -1059,7 +1139,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::begin() | |||||||
| template <class _Tp, class _Hash, class _Equal, class _Alloc> | template <class _Tp, class _Hash, class _Equal, class _Alloc> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator | typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::end() | __hash_table<_Tp, _Hash, _Equal, _Alloc>::end() _NOEXCEPT | ||||||
| { | { | ||||||
|     return iterator(nullptr); |     return iterator(nullptr); | ||||||
| } | } | ||||||
| @@ -1067,7 +1147,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::end() | |||||||
| template <class _Tp, class _Hash, class _Equal, class _Alloc> | template <class _Tp, class _Hash, class _Equal, class _Alloc> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::const_iterator | typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::const_iterator | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::begin() const | __hash_table<_Tp, _Hash, _Equal, _Alloc>::begin() const _NOEXCEPT | ||||||
| { | { | ||||||
|     return const_iterator(__p1_.first().__next_); |     return const_iterator(__p1_.first().__next_); | ||||||
| } | } | ||||||
| @@ -1075,21 +1155,21 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::begin() const | |||||||
| template <class _Tp, class _Hash, class _Equal, class _Alloc> | template <class _Tp, class _Hash, class _Equal, class _Alloc> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::const_iterator | typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::const_iterator | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::end() const | __hash_table<_Tp, _Hash, _Equal, _Alloc>::end() const _NOEXCEPT | ||||||
| { | { | ||||||
|     return const_iterator(nullptr); |     return const_iterator(nullptr); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, class _Hash, class _Equal, class _Alloc> | template <class _Tp, class _Hash, class _Equal, class _Alloc> | ||||||
| void | void | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::clear() | __hash_table<_Tp, _Hash, _Equal, _Alloc>::clear() _NOEXCEPT | ||||||
| { | { | ||||||
|     if (size() > 0) |     if (size() > 0) | ||||||
|     { |     { | ||||||
|         __deallocate(__p1_.first().__next_); |         __deallocate(__p1_.first().__next_); | ||||||
|         __p1_.first().__next_ = nullptr; |         __p1_.first().__next_ = nullptr; | ||||||
|         size_type __bc = bucket_count(); |         size_type __bc = bucket_count(); | ||||||
|         for (size_type __i; __i < __bc; ++__i) |         for (size_type __i = 0; __i < __bc; ++__i) | ||||||
|             __bucket_list_[__i] = nullptr; |             __bucket_list_[__i] = nullptr; | ||||||
|         size() = 0; |         size() = 0; | ||||||
|     } |     } | ||||||
| @@ -1122,7 +1202,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__node_insert_unique(__node_pointer __ | |||||||
|     { |     { | ||||||
|         if (size()+1 > __bc * max_load_factor() || __bc == 0) |         if (size()+1 > __bc * max_load_factor() || __bc == 0) | ||||||
|         { |         { | ||||||
|             rehash(_STD::max<size_type>(2 * __bc + 1, |             rehash(_VSTD::max<size_type>(2 * __bc + 1, | ||||||
|                            size_type(ceil(float(size() + 1) / max_load_factor())))); |                            size_type(ceil(float(size() + 1) / max_load_factor())))); | ||||||
|             __bc = bucket_count(); |             __bc = bucket_count(); | ||||||
|             __chash = __nd->__hash_ % __bc; |             __chash = __nd->__hash_ % __bc; | ||||||
| @@ -1131,7 +1211,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__node_insert_unique(__node_pointer __ | |||||||
|         __node_pointer __pn = __bucket_list_[__chash]; |         __node_pointer __pn = __bucket_list_[__chash]; | ||||||
|         if (__pn == nullptr) |         if (__pn == nullptr) | ||||||
|         { |         { | ||||||
|             __pn = static_cast<__node_pointer>(_STD::addressof(__p1_.first())); |             __pn = static_cast<__node_pointer>(_VSTD::addressof(__p1_.first())); | ||||||
|             __nd->__next_ = __pn->__next_; |             __nd->__next_ = __pn->__next_; | ||||||
|             __pn->__next_ = __nd; |             __pn->__next_ = __nd; | ||||||
|             // fix up __bucket_list_ |             // fix up __bucket_list_ | ||||||
| @@ -1161,7 +1241,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__node_insert_multi(__node_pointer __c | |||||||
|     size_type __bc = bucket_count(); |     size_type __bc = bucket_count(); | ||||||
|     if (size()+1 > __bc * max_load_factor() || __bc == 0) |     if (size()+1 > __bc * max_load_factor() || __bc == 0) | ||||||
|     { |     { | ||||||
|         rehash(_STD::max<size_type>(2 * __bc + 1, |         rehash(_VSTD::max<size_type>(2 * __bc + 1, | ||||||
|                        size_type(ceil(float(size() + 1) / max_load_factor())))); |                        size_type(ceil(float(size() + 1) / max_load_factor())))); | ||||||
|         __bc = bucket_count(); |         __bc = bucket_count(); | ||||||
|     } |     } | ||||||
| @@ -1169,7 +1249,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__node_insert_multi(__node_pointer __c | |||||||
|     __node_pointer __pn = __bucket_list_[__chash]; |     __node_pointer __pn = __bucket_list_[__chash]; | ||||||
|     if (__pn == nullptr) |     if (__pn == nullptr) | ||||||
|     { |     { | ||||||
|         __pn = static_cast<__node_pointer>(_STD::addressof(__p1_.first())); |         __pn = static_cast<__node_pointer>(_VSTD::addressof(__p1_.first())); | ||||||
|         __cp->__next_ = __pn->__next_; |         __cp->__next_ = __pn->__next_; | ||||||
|         __pn->__next_ = __cp; |         __pn->__next_ = __cp; | ||||||
|         // fix up __bucket_list_ |         // fix up __bucket_list_ | ||||||
| @@ -1222,7 +1302,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__node_insert_multi( | |||||||
|         size_type __bc = bucket_count(); |         size_type __bc = bucket_count(); | ||||||
|         if (size()+1 > __bc * max_load_factor() || __bc == 0) |         if (size()+1 > __bc * max_load_factor() || __bc == 0) | ||||||
|         { |         { | ||||||
|             rehash(_STD::max<size_type>(2 * __bc + 1, |             rehash(_VSTD::max<size_type>(2 * __bc + 1, | ||||||
|                            size_type(ceil(float(size() + 1) / max_load_factor())))); |                            size_type(ceil(float(size() + 1) / max_load_factor())))); | ||||||
|             __bc = bucket_count(); |             __bc = bucket_count(); | ||||||
|         } |         } | ||||||
| @@ -1266,7 +1346,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__insert_unique(const value_type& __x) | |||||||
|         __node_holder __h = __construct_node(__x, __hash); |         __node_holder __h = __construct_node(__x, __hash); | ||||||
|         if (size()+1 > __bc * max_load_factor() || __bc == 0) |         if (size()+1 > __bc * max_load_factor() || __bc == 0) | ||||||
|         { |         { | ||||||
|             rehash(_STD::max<size_type>(2 * __bc + 1, |             rehash(_VSTD::max<size_type>(2 * __bc + 1, | ||||||
|                            size_type(ceil(float(size() + 1) / max_load_factor())))); |                            size_type(ceil(float(size() + 1) / max_load_factor())))); | ||||||
|             __bc = bucket_count(); |             __bc = bucket_count(); | ||||||
|             __chash = __hash % __bc; |             __chash = __hash % __bc; | ||||||
| @@ -1275,7 +1355,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__insert_unique(const value_type& __x) | |||||||
|         __node_pointer __pn = __bucket_list_[__chash]; |         __node_pointer __pn = __bucket_list_[__chash]; | ||||||
|         if (__pn == nullptr) |         if (__pn == nullptr) | ||||||
|         { |         { | ||||||
|             __pn = static_cast<__node_pointer>(_STD::addressof(__p1_.first())); |             __pn = static_cast<__node_pointer>(_VSTD::addressof(__p1_.first())); | ||||||
|             __h->__next_ = __pn->__next_; |             __h->__next_ = __pn->__next_; | ||||||
|             __pn->__next_ = __h.get(); |             __pn->__next_ = __h.get(); | ||||||
|             // fix up __bucket_list_ |             // fix up __bucket_list_ | ||||||
| @@ -1305,7 +1385,7 @@ template <class... _Args> | |||||||
| pair<typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator, bool> | pair<typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator, bool> | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::__emplace_unique(_Args&&... __args) | __hash_table<_Tp, _Hash, _Equal, _Alloc>::__emplace_unique(_Args&&... __args) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_Args>(__args)...); |     __node_holder __h = __construct_node(_VSTD::forward<_Args>(__args)...); | ||||||
|     pair<iterator, bool> __r = __node_insert_unique(__h.get()); |     pair<iterator, bool> __r = __node_insert_unique(__h.get()); | ||||||
|     if (__r.second) |     if (__r.second) | ||||||
|         __h.release(); |         __h.release(); | ||||||
| @@ -1317,7 +1397,7 @@ template <class... _Args> | |||||||
| typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator | typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::__emplace_multi(_Args&&... __args) | __hash_table<_Tp, _Hash, _Equal, _Alloc>::__emplace_multi(_Args&&... __args) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_Args>(__args)...); |     __node_holder __h = __construct_node(_VSTD::forward<_Args>(__args)...); | ||||||
|     iterator __r = __node_insert_multi(__h.get()); |     iterator __r = __node_insert_multi(__h.get()); | ||||||
|     __h.release(); |     __h.release(); | ||||||
|     return __r; |     return __r; | ||||||
| @@ -1329,7 +1409,7 @@ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator | |||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::__emplace_hint_multi( | __hash_table<_Tp, _Hash, _Equal, _Alloc>::__emplace_hint_multi( | ||||||
|         const_iterator __p, _Args&&... __args) |         const_iterator __p, _Args&&... __args) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_Args>(__args)...); |     __node_holder __h = __construct_node(_VSTD::forward<_Args>(__args)...); | ||||||
|     iterator __r = __node_insert_multi(__p, __h.get()); |     iterator __r = __node_insert_multi(__p, __h.get()); | ||||||
|     __h.release(); |     __h.release(); | ||||||
|     return __r; |     return __r; | ||||||
| @@ -1342,7 +1422,7 @@ template <class _P> | |||||||
| pair<typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator, bool> | pair<typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator, bool> | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::__insert_unique(_P&& __x) | __hash_table<_Tp, _Hash, _Equal, _Alloc>::__insert_unique(_P&& __x) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_P>(__x)); |     __node_holder __h = __construct_node(_VSTD::forward<_P>(__x)); | ||||||
|     pair<iterator, bool> __r = __node_insert_unique(__h.get()); |     pair<iterator, bool> __r = __node_insert_unique(__h.get()); | ||||||
|     if (__r.second) |     if (__r.second) | ||||||
|         __h.release(); |         __h.release(); | ||||||
| @@ -1358,7 +1438,7 @@ template <class _P> | |||||||
| typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator | typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::__insert_multi(_P&& __x) | __hash_table<_Tp, _Hash, _Equal, _Alloc>::__insert_multi(_P&& __x) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_P>(__x)); |     __node_holder __h = __construct_node(_VSTD::forward<_P>(__x)); | ||||||
|     iterator __r = __node_insert_multi(__h.get()); |     iterator __r = __node_insert_multi(__h.get()); | ||||||
|     __h.release(); |     __h.release(); | ||||||
|     return __r; |     return __r; | ||||||
| @@ -1370,7 +1450,7 @@ typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::iterator | |||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::__insert_multi(const_iterator __p, | __hash_table<_Tp, _Hash, _Equal, _Alloc>::__insert_multi(const_iterator __p, | ||||||
|                                                          _P&& __x) |                                                          _P&& __x) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_P>(__x)); |     __node_holder __h = __construct_node(_VSTD::forward<_P>(__x)); | ||||||
|     iterator __r = __node_insert_multi(__p, __h.get()); |     iterator __r = __node_insert_multi(__p, __h.get()); | ||||||
|     __h.release(); |     __h.release(); | ||||||
|     return __r; |     return __r; | ||||||
| @@ -1405,13 +1485,13 @@ template <class _Tp, class _Hash, class _Equal, class _Alloc> | |||||||
| void | void | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::rehash(size_type __n) | __hash_table<_Tp, _Hash, _Equal, _Alloc>::rehash(size_type __n) | ||||||
| { | { | ||||||
|     __n = __next_prime(_STD::max<size_type>(__n, size() > 0)); |     __n = __next_prime(_VSTD::max<size_type>(__n, size() > 0)); | ||||||
|     size_type __bc = bucket_count(); |     size_type __bc = bucket_count(); | ||||||
|     if (__n > __bc) |     if (__n > __bc) | ||||||
|         __rehash(__n); |         __rehash(__n); | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
|         __n = _STD::max<size_type> |         __n = _VSTD::max<size_type> | ||||||
|               ( |               ( | ||||||
|                   __n, |                   __n, | ||||||
|                   __next_prime(size_t(ceil(float(size()) / max_load_factor()))) |                   __next_prime(size_t(ceil(float(size()) / max_load_factor()))) | ||||||
| @@ -1433,7 +1513,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__rehash(size_type __nbc) | |||||||
|     { |     { | ||||||
|         for (size_type __i = 0; __i < __nbc; ++__i) |         for (size_type __i = 0; __i < __nbc; ++__i) | ||||||
|             __bucket_list_[__i] = nullptr; |             __bucket_list_[__i] = nullptr; | ||||||
|         __node_pointer __pp(static_cast<__node_pointer>(_STD::addressof(__p1_.first()))); |         __node_pointer __pp(static_cast<__node_pointer>(_VSTD::addressof(__p1_.first()))); | ||||||
|         __node_pointer __cp = __pp->__next_; |         __node_pointer __cp = __pp->__next_; | ||||||
|         if (__cp != nullptr) |         if (__cp != nullptr) | ||||||
|         { |         { | ||||||
| @@ -1533,7 +1613,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__construct_node(_Args&& ...__args) | |||||||
| { | { | ||||||
|     __node_allocator& __na = __node_alloc(); |     __node_allocator& __na = __node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_), _STD::forward<_Args>(__args)...); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_), _VSTD::forward<_Args>(__args)...); | ||||||
|     __h.get_deleter().__value_constructed = true; |     __h.get_deleter().__value_constructed = true; | ||||||
|     __h->__hash_ = hash_function()(__h->__value_); |     __h->__hash_ = hash_function()(__h->__value_); | ||||||
|     __h->__next_ = nullptr; |     __h->__next_ = nullptr; | ||||||
| @@ -1549,11 +1629,11 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__construct_node(value_type&& __v, | |||||||
| { | { | ||||||
|     __node_allocator& __na = __node_alloc(); |     __node_allocator& __na = __node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_), _STD::move(__v)); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_), _VSTD::move(__v)); | ||||||
|     __h.get_deleter().__value_constructed = true; |     __h.get_deleter().__value_constructed = true; | ||||||
|     __h->__hash_ = __hash; |     __h->__hash_ = __hash; | ||||||
|     __h->__next_ = nullptr; |     __h->__next_ = nullptr; | ||||||
|     return _STD::move(__h); |     return _VSTD::move(__h); | ||||||
| } | } | ||||||
|  |  | ||||||
| #else  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #else  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -1564,11 +1644,11 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__construct_node(const value_type& __v | |||||||
| { | { | ||||||
|     __node_allocator& __na = __node_alloc(); |     __node_allocator& __na = __node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_), __v); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_), __v); | ||||||
|     __h.get_deleter().__value_constructed = true; |     __h.get_deleter().__value_constructed = true; | ||||||
|     __h->__hash_ = hash_function()(__h->__value_); |     __h->__hash_ = hash_function()(__h->__value_); | ||||||
|     __h->__next_ = nullptr; |     __h->__next_ = nullptr; | ||||||
|     return _STD::move(__h); |     return _VSTD::move(__h); | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -1580,11 +1660,11 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__construct_node(const value_type& __v | |||||||
| { | { | ||||||
|     __node_allocator& __na = __node_alloc(); |     __node_allocator& __na = __node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_), __v); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_), __v); | ||||||
|     __h.get_deleter().__value_constructed = true; |     __h.get_deleter().__value_constructed = true; | ||||||
|     __h->__hash_ = __hash; |     __h->__hash_ = __hash; | ||||||
|     __h->__next_ = nullptr; |     __h->__next_ = nullptr; | ||||||
|     return _STD::move(__h); |     return _VSTD::move(__h); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, class _Hash, class _Equal, class _Alloc> | template <class _Tp, class _Hash, class _Equal, class _Alloc> | ||||||
| @@ -1645,7 +1725,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__erase_multi(const _Key& __k) | |||||||
|  |  | ||||||
| template <class _Tp, class _Hash, class _Equal, class _Alloc> | template <class _Tp, class _Hash, class _Equal, class _Alloc> | ||||||
| typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::__node_holder | typename __hash_table<_Tp, _Hash, _Equal, _Alloc>::__node_holder | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::remove(const_iterator __p) | __hash_table<_Tp, _Hash, _Equal, _Alloc>::remove(const_iterator __p) _NOEXCEPT | ||||||
| { | { | ||||||
|     // current node |     // current node | ||||||
|     __node_pointer __cn = const_cast<__node_pointer>(__p.__node_); |     __node_pointer __cn = const_cast<__node_pointer>(__p.__node_); | ||||||
| @@ -1658,7 +1738,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::remove(const_iterator __p) | |||||||
|     // Fix up __bucket_list_ |     // Fix up __bucket_list_ | ||||||
|         // if __pn is not in same bucket (before begin is not in same bucket) && |         // if __pn is not in same bucket (before begin is not in same bucket) && | ||||||
|         //    if __cn->__next_ is not in same bucket (nullptr is not in same bucket) |         //    if __cn->__next_ is not in same bucket (nullptr is not in same bucket) | ||||||
|     if (__pn == _STD::addressof(__p1_.first()) || __pn->__hash_ % __bc != __chash) |     if (__pn == _VSTD::addressof(__p1_.first()) || __pn->__hash_ % __bc != __chash) | ||||||
|     { |     { | ||||||
|         if (__cn->__next_ == nullptr || __cn->__next_->__hash_ % __bc != __chash) |         if (__cn->__next_ == nullptr || __cn->__next_->__hash_ % __bc != __chash) | ||||||
|             __bucket_list_[__chash] = nullptr; |             __bucket_list_[__chash] = nullptr; | ||||||
| @@ -1674,7 +1754,7 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::remove(const_iterator __p) | |||||||
|     __pn->__next_ = __cn->__next_; |     __pn->__next_ = __cn->__next_; | ||||||
|     __cn->__next_ = nullptr; |     __cn->__next_ = nullptr; | ||||||
|     --size(); |     --size(); | ||||||
|     return __node_holder(__cn, _D(__node_alloc())); |     return __node_holder(__cn, _D(__node_alloc(), true)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, class _Hash, class _Equal, class _Alloc> | template <class _Tp, class _Hash, class _Equal, class _Alloc> | ||||||
| @@ -1776,25 +1856,32 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::__equal_range_multi( | |||||||
| template <class _Tp, class _Hash, class _Equal, class _Alloc> | template <class _Tp, class _Hash, class _Equal, class _Alloc> | ||||||
| void | void | ||||||
| __hash_table<_Tp, _Hash, _Equal, _Alloc>::swap(__hash_table& __u) | __hash_table<_Tp, _Hash, _Equal, _Alloc>::swap(__hash_table& __u) | ||||||
|  |     _NOEXCEPT_( | ||||||
|  |         (!allocator_traits<__pointer_allocator>::propagate_on_container_swap::value || | ||||||
|  |          __is_nothrow_swappable<__pointer_allocator>::value) && | ||||||
|  |         (!__node_traits::propagate_on_container_swap::value || | ||||||
|  |          __is_nothrow_swappable<__node_allocator>::value) && | ||||||
|  |         __is_nothrow_swappable<hasher>::value && | ||||||
|  |         __is_nothrow_swappable<key_equal>::value) | ||||||
| { | { | ||||||
|     { |     { | ||||||
|     __node_pointer_pointer __npp = __bucket_list_.release(); |     __node_pointer_pointer __npp = __bucket_list_.release(); | ||||||
|     __bucket_list_.reset(__u.__bucket_list_.release()); |     __bucket_list_.reset(__u.__bucket_list_.release()); | ||||||
|     __u.__bucket_list_.reset(__npp); |     __u.__bucket_list_.reset(__npp); | ||||||
|     } |     } | ||||||
|     _STD::swap(__bucket_list_.get_deleter().size(), __u.__bucket_list_.get_deleter().size()); |     _VSTD::swap(__bucket_list_.get_deleter().size(), __u.__bucket_list_.get_deleter().size()); | ||||||
|     __swap_alloc(__bucket_list_.get_deleter().__alloc(), |     __swap_alloc(__bucket_list_.get_deleter().__alloc(), | ||||||
|              __u.__bucket_list_.get_deleter().__alloc()); |              __u.__bucket_list_.get_deleter().__alloc()); | ||||||
|     __swap_alloc(__node_alloc(), __u.__node_alloc()); |     __swap_alloc(__node_alloc(), __u.__node_alloc()); | ||||||
|     _STD::swap(__p1_.first().__next_, __u.__p1_.first().__next_); |     _VSTD::swap(__p1_.first().__next_, __u.__p1_.first().__next_); | ||||||
|     __p2_.swap(__u.__p2_); |     __p2_.swap(__u.__p2_); | ||||||
|     __p3_.swap(__u.__p3_); |     __p3_.swap(__u.__p3_); | ||||||
|     if (size() > 0) |     if (size() > 0) | ||||||
|         __bucket_list_[__p1_.first().__next_->__hash_ % bucket_count()] = |         __bucket_list_[__p1_.first().__next_->__hash_ % bucket_count()] = | ||||||
|             static_cast<__node_pointer>(_STD::addressof(__p1_.first())); |             static_cast<__node_pointer>(_VSTD::addressof(__p1_.first())); | ||||||
|     if (__u.size() > 0) |     if (__u.size() > 0) | ||||||
|         __u.__bucket_list_[__u.__p1_.first().__next_->__hash_ % __u.bucket_count()] = |         __u.__bucket_list_[__u.__p1_.first().__next_->__hash_ % __u.bucket_count()] = | ||||||
|             static_cast<__node_pointer>(_STD::addressof(__u.__p1_.first())); |             static_cast<__node_pointer>(_VSTD::addressof(__u.__p1_.first())); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, class _Hash, class _Equal, class _Alloc> | template <class _Tp, class _Hash, class _Equal, class _Alloc> | ||||||
| @@ -1814,6 +1901,16 @@ __hash_table<_Tp, _Hash, _Equal, _Alloc>::bucket_size(size_type __n) const | |||||||
|     return __r; |     return __r; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | template <class _Tp, class _Hash, class _Equal, class _Alloc> | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | void | ||||||
|  | swap(__hash_table<_Tp, _Hash, _Equal, _Alloc>& __x, | ||||||
|  |      __hash_table<_Tp, _Hash, _Equal, _Alloc>& __y) | ||||||
|  |     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||||
|  | { | ||||||
|  |     __x.swap(__y); | ||||||
|  | } | ||||||
|  |  | ||||||
| _LIBCPP_END_NAMESPACE_STD | _LIBCPP_END_NAMESPACE_STD | ||||||
|  |  | ||||||
| #endif  // _LIBCPP__HASH_TABLE | #endif  // _LIBCPP__HASH_TABLE | ||||||
|   | |||||||
							
								
								
									
										111
									
								
								include/__locale
									
									
									
									
									
								
							
							
						
						
									
										111
									
								
								include/__locale
									
									
									
									
									
								
							| @@ -19,21 +19,7 @@ | |||||||
| #include <cstdint> | #include <cstdint> | ||||||
| #include <cctype> | #include <cctype> | ||||||
| #include <locale.h> | #include <locale.h> | ||||||
| #ifdef __MINGW32__ |  | ||||||
| typedef _locale_t locale_t; |  | ||||||
|  |  | ||||||
| #include <xlocinfo.h> |  | ||||||
| #define LC_COLLATE_MASK _M_COLLATE |  | ||||||
| #define LC_CTYPE_MASK _M_CTYPE |  | ||||||
| #define LC_MONETARY_MASK _M_MONETARY |  | ||||||
| #define LC_NUMERIC_MASK _M_NUMERIC |  | ||||||
| #define LC_TIME_MASK _M_TIME |  | ||||||
| #define LC_MESSAGES_MASK _M_MESSAGES |  | ||||||
| #define LC_ALL_MASK _M_ALL |  | ||||||
|  |  | ||||||
| #else |  | ||||||
| #include <xlocale.h> | #include <xlocale.h> | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #pragma GCC system_header | #pragma GCC system_header | ||||||
|  |  | ||||||
| @@ -41,7 +27,7 @@ _LIBCPP_BEGIN_NAMESPACE_STD | |||||||
|  |  | ||||||
| class locale; | class locale; | ||||||
|  |  | ||||||
| template <class _Facet> bool has_facet(const locale&) throw(); | template <class _Facet> bool has_facet(const locale&) _NOEXCEPT; | ||||||
| template <class _Facet> const _Facet& use_facet(const locale&); | template <class _Facet> const _Facet& use_facet(const locale&); | ||||||
|  |  | ||||||
| class _LIBCPP_VISIBLE locale | class _LIBCPP_VISIBLE locale | ||||||
| @@ -63,8 +49,8 @@ public: | |||||||
|         all = collate | ctype | monetary | numeric | time | messages; |         all = collate | ctype | monetary | numeric | time | messages; | ||||||
|  |  | ||||||
|     // construct/copy/destroy: |     // construct/copy/destroy: | ||||||
|     locale() throw(); |     locale()  _NOEXCEPT; | ||||||
|     locale(const locale&) throw(); |     locale(const locale&)  _NOEXCEPT; | ||||||
|     explicit locale(const char*); |     explicit locale(const char*); | ||||||
|     explicit locale(const string&); |     explicit locale(const string&); | ||||||
|     locale(const locale&, const char*, category); |     locale(const locale&, const char*, category); | ||||||
| @@ -73,9 +59,9 @@ public: | |||||||
|         _LIBCPP_INLINE_VISIBILITY locale(const locale&, _Facet*); |         _LIBCPP_INLINE_VISIBILITY locale(const locale&, _Facet*); | ||||||
|     locale(const locale&, const locale&, category); |     locale(const locale&, const locale&, category); | ||||||
|  |  | ||||||
|     ~locale() throw(); |     ~locale(); | ||||||
|  |  | ||||||
|     const locale& operator=(const locale&) throw(); |     const locale& operator=(const locale&)  _NOEXCEPT; | ||||||
|  |  | ||||||
|     template <class _Facet> locale combine(const locale&) const; |     template <class _Facet> locale combine(const locale&) const; | ||||||
|  |  | ||||||
| @@ -100,7 +86,7 @@ private: | |||||||
|     bool has_facet(id&) const; |     bool has_facet(id&) const; | ||||||
|     const facet* use_facet(id&) const; |     const facet* use_facet(id&) const; | ||||||
|  |  | ||||||
|     template <class _Facet> friend bool has_facet(const locale&) throw(); |     template <class _Facet> friend bool has_facet(const locale&)  _NOEXCEPT; | ||||||
|     template <class _Facet> friend const _Facet& use_facet(const locale&); |     template <class _Facet> friend const _Facet& use_facet(const locale&); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -117,7 +103,7 @@ protected: | |||||||
| //    facet(const facet&) = delete;     // effectively done in __shared_count | //    facet(const facet&) = delete;     // effectively done in __shared_count | ||||||
| //    void operator=(const facet&) = delete; | //    void operator=(const facet&) = delete; | ||||||
| private: | private: | ||||||
|     virtual void __on_zero_shared(); |     virtual void __on_zero_shared() _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class _LIBCPP_VISIBLE locale::id | class _LIBCPP_VISIBLE locale::id | ||||||
| @@ -151,16 +137,16 @@ locale | |||||||
| locale::combine(const locale& __other) const | locale::combine(const locale& __other) const | ||||||
| { | { | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (!_STD::has_facet<_Facet>(__other)) |     if (!_VSTD::has_facet<_Facet>(__other)) | ||||||
|         throw runtime_error("locale::combine: locale missing facet"); |         throw runtime_error("locale::combine: locale missing facet"); | ||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|     return locale(*this, &const_cast<_Facet&>(_STD::use_facet<_Facet>(__other))); |     return locale(*this, &const_cast<_Facet&>(_VSTD::use_facet<_Facet>(__other))); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Facet> | template <class _Facet> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| has_facet(const locale& __l) throw() | has_facet(const locale& __l)  _NOEXCEPT | ||||||
| { | { | ||||||
|     return __l.has_facet(_Facet::id); |     return __l.has_facet(_Facet::id); | ||||||
| } | } | ||||||
| @@ -306,7 +292,7 @@ bool | |||||||
| locale::operator()(const basic_string<_CharT, _Traits, _Allocator>& __x, | locale::operator()(const basic_string<_CharT, _Traits, _Allocator>& __x, | ||||||
|                    const basic_string<_CharT, _Traits, _Allocator>& __y) const |                    const basic_string<_CharT, _Traits, _Allocator>& __y) const | ||||||
| { | { | ||||||
|     return _STD::use_facet<_STD::collate<_CharT> >(*this).compare( |     return _VSTD::use_facet<_VSTD::collate<_CharT> >(*this).compare( | ||||||
|                                        __x.data(), __x.data() + __x.size(), |                                        __x.data(), __x.data() + __x.size(), | ||||||
|                                        __y.data(), __y.data() + __y.size()) < 0; |                                        __y.data(), __y.data() + __y.size()) < 0; | ||||||
| } | } | ||||||
| @@ -316,7 +302,11 @@ locale::operator()(const basic_string<_CharT, _Traits, _Allocator>& __x, | |||||||
| class _LIBCPP_VISIBLE ctype_base | class _LIBCPP_VISIBLE ctype_base | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     typedef std::uint32_t mask; | #ifdef __GLIBC__ | ||||||
|  |     typedef unsigned short mask; | ||||||
|  | #else | ||||||
|  |     typedef __uint32_t mask; | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #if __APPLE__ | #if __APPLE__ | ||||||
|     static const mask space  = _CTYPE_S; |     static const mask space  = _CTYPE_S; | ||||||
| @@ -329,17 +319,6 @@ public: | |||||||
|     static const mask punct  = _CTYPE_P; |     static const mask punct  = _CTYPE_P; | ||||||
|     static const mask xdigit = _CTYPE_X; |     static const mask xdigit = _CTYPE_X; | ||||||
|     static const mask blank  = _CTYPE_B; |     static const mask blank  = _CTYPE_B; | ||||||
| #elif defined(__MINGW32__) |  | ||||||
|     static const mask space  = _SPACE; |  | ||||||
|     static const mask print  = (_BLANK|_PUNCT|_ALPHA|_DIGIT); |  | ||||||
|     static const mask cntrl  = _CONTROL; |  | ||||||
|     static const mask upper  = _UPPER; |  | ||||||
|     static const mask lower  = _LOWER; |  | ||||||
|     static const mask alpha  = _ALPHA; |  | ||||||
|     static const mask digit  = _DIGIT; |  | ||||||
|     static const mask punct  = _PUNCT; |  | ||||||
|     static const mask xdigit = _HEX; |  | ||||||
|     static const mask blank  = _BLANK; |  | ||||||
| #else  // __APPLE__ | #else  // __APPLE__ | ||||||
|     static const mask space  = _ISspace; |     static const mask space  = _ISspace; | ||||||
|     static const mask print  = _ISprint; |     static const mask print  = _ISprint; | ||||||
| @@ -476,7 +455,7 @@ public: | |||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     bool is(mask __m, char_type __c) const |     bool is(mask __m, char_type __c) const | ||||||
|     { |     { | ||||||
|         return isascii(__c) ? (__tab_ ? __tab_[__c] & __m : _isctype(__c, __m)) : false; |         return isascii(__c) ? __tab_[__c] & __m : false; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
| @@ -560,8 +539,12 @@ public: | |||||||
| #else | #else | ||||||
|     static const size_t table_size = 256;  // FIXME: Don't hardcode this. |     static const size_t table_size = 256;  // FIXME: Don't hardcode this. | ||||||
| #endif | #endif | ||||||
|     _LIBCPP_ALWAYS_INLINE const mask* table() const throw() {return __tab_;} |     _LIBCPP_ALWAYS_INLINE const mask* table() const  _NOEXCEPT {return __tab_;} | ||||||
|     static const mask* classic_table() throw(); |     static const mask* classic_table()  _NOEXCEPT; | ||||||
|  | #ifndef _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |     static const int* __classic_upper_table() _NOEXCEPT; | ||||||
|  |     static const int* __classic_lower_table() _NOEXCEPT; | ||||||
|  | #endif | ||||||
|  |  | ||||||
| protected: | protected: | ||||||
|     ~ctype(); |     ~ctype(); | ||||||
| @@ -780,13 +763,13 @@ public: | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     int encoding() const throw() |     int encoding() const  _NOEXCEPT | ||||||
|     { |     { | ||||||
|         return do_encoding(); |         return do_encoding(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     bool always_noconv() const throw() |     bool always_noconv() const  _NOEXCEPT | ||||||
|     { |     { | ||||||
|         return do_always_noconv(); |         return do_always_noconv(); | ||||||
|     } |     } | ||||||
| @@ -798,7 +781,7 @@ public: | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     int max_length() const throw() |     int max_length() const  _NOEXCEPT | ||||||
|     { |     { | ||||||
|         return do_max_length(); |         return do_max_length(); | ||||||
|     } |     } | ||||||
| @@ -820,10 +803,10 @@ protected: | |||||||
|                          intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const; |                          intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const; | ||||||
|     virtual result do_unshift(state_type& __st, |     virtual result do_unshift(state_type& __st, | ||||||
|                               extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; |                               extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; | ||||||
|     virtual int do_encoding() const throw(); |     virtual int do_encoding() const  _NOEXCEPT; | ||||||
|     virtual bool do_always_noconv() const throw(); |     virtual bool do_always_noconv() const  _NOEXCEPT; | ||||||
|     virtual int do_length(state_type& __st, const extern_type* __frm, const extern_type* __end, size_t __mx) const; |     virtual int do_length(state_type& __st, const extern_type* __frm, const extern_type* __end, size_t __mx) const; | ||||||
|     virtual int do_max_length() const throw(); |     virtual int do_max_length() const  _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // template <> class codecvt<wchar_t, char, mbstate_t> | // template <> class codecvt<wchar_t, char, mbstate_t> | ||||||
| @@ -865,13 +848,13 @@ public: | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     int encoding() const throw() |     int encoding() const  _NOEXCEPT | ||||||
|     { |     { | ||||||
|         return do_encoding(); |         return do_encoding(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     bool always_noconv() const throw() |     bool always_noconv() const  _NOEXCEPT | ||||||
|     { |     { | ||||||
|         return do_always_noconv(); |         return do_always_noconv(); | ||||||
|     } |     } | ||||||
| @@ -883,7 +866,7 @@ public: | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     int max_length() const throw() |     int max_length() const  _NOEXCEPT | ||||||
|     { |     { | ||||||
|         return do_max_length(); |         return do_max_length(); | ||||||
|     } |     } | ||||||
| @@ -903,10 +886,10 @@ protected: | |||||||
|                          intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const; |                          intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const; | ||||||
|     virtual result do_unshift(state_type& __st, |     virtual result do_unshift(state_type& __st, | ||||||
|                               extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; |                               extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; | ||||||
|     virtual int do_encoding() const throw(); |     virtual int do_encoding() const  _NOEXCEPT; | ||||||
|     virtual bool do_always_noconv() const throw(); |     virtual bool do_always_noconv() const  _NOEXCEPT; | ||||||
|     virtual int do_length(state_type&, const extern_type* __frm, const extern_type* __end, size_t __mx) const; |     virtual int do_length(state_type&, const extern_type* __frm, const extern_type* __end, size_t __mx) const; | ||||||
|     virtual int do_max_length() const throw(); |     virtual int do_max_length() const  _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // template <> class codecvt<char16_t, char, mbstate_t> | // template <> class codecvt<char16_t, char, mbstate_t> | ||||||
| @@ -949,13 +932,13 @@ public: | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     int encoding() const throw() |     int encoding() const  _NOEXCEPT | ||||||
|     { |     { | ||||||
|         return do_encoding(); |         return do_encoding(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     bool always_noconv() const throw() |     bool always_noconv() const  _NOEXCEPT | ||||||
|     { |     { | ||||||
|         return do_always_noconv(); |         return do_always_noconv(); | ||||||
|     } |     } | ||||||
| @@ -967,7 +950,7 @@ public: | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     int max_length() const throw() |     int max_length() const  _NOEXCEPT | ||||||
|     { |     { | ||||||
|         return do_max_length(); |         return do_max_length(); | ||||||
|     } |     } | ||||||
| @@ -989,10 +972,10 @@ protected: | |||||||
|                          intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const; |                          intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const; | ||||||
|     virtual result do_unshift(state_type& __st, |     virtual result do_unshift(state_type& __st, | ||||||
|                               extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; |                               extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; | ||||||
|     virtual int do_encoding() const throw(); |     virtual int do_encoding() const  _NOEXCEPT; | ||||||
|     virtual bool do_always_noconv() const throw(); |     virtual bool do_always_noconv() const  _NOEXCEPT; | ||||||
|     virtual int do_length(state_type&, const extern_type* __frm, const extern_type* __end, size_t __mx) const; |     virtual int do_length(state_type&, const extern_type* __frm, const extern_type* __end, size_t __mx) const; | ||||||
|     virtual int do_max_length() const throw(); |     virtual int do_max_length() const  _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // template <> class codecvt<char32_t, char, mbstate_t> | // template <> class codecvt<char32_t, char, mbstate_t> | ||||||
| @@ -1035,13 +1018,13 @@ public: | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     int encoding() const throw() |     int encoding() const  _NOEXCEPT | ||||||
|     { |     { | ||||||
|         return do_encoding(); |         return do_encoding(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     bool always_noconv() const throw() |     bool always_noconv() const  _NOEXCEPT | ||||||
|     { |     { | ||||||
|         return do_always_noconv(); |         return do_always_noconv(); | ||||||
|     } |     } | ||||||
| @@ -1053,7 +1036,7 @@ public: | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     int max_length() const throw() |     int max_length() const  _NOEXCEPT | ||||||
|     { |     { | ||||||
|         return do_max_length(); |         return do_max_length(); | ||||||
|     } |     } | ||||||
| @@ -1075,10 +1058,10 @@ protected: | |||||||
|                          intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const; |                          intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const; | ||||||
|     virtual result do_unshift(state_type& __st, |     virtual result do_unshift(state_type& __st, | ||||||
|                               extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; |                               extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; | ||||||
|     virtual int do_encoding() const throw(); |     virtual int do_encoding() const  _NOEXCEPT; | ||||||
|     virtual bool do_always_noconv() const throw(); |     virtual bool do_always_noconv() const  _NOEXCEPT; | ||||||
|     virtual int do_length(state_type&, const extern_type* __frm, const extern_type* __end, size_t __mx) const; |     virtual int do_length(state_type&, const extern_type* __frm, const extern_type* __end, size_t __mx) const; | ||||||
|     virtual int do_max_length() const throw(); |     virtual int do_max_length() const  _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // template <class _InternT, class _ExternT, class _StateT> class codecvt_byname | // template <class _InternT, class _ExternT, class _StateT> class codecvt_byname | ||||||
|   | |||||||
| @@ -14,43 +14,15 @@ | |||||||
| #include <__config> | #include <__config> | ||||||
| #include <chrono> | #include <chrono> | ||||||
| #include <system_error> | #include <system_error> | ||||||
| #ifdef __MINGW32__ |  | ||||||
| typedef unsigned pthread_t; |  | ||||||
| typedef unsigned pthread_mutex_t; |  | ||||||
| typedef unsigned pthread_mutexattr_t; |  | ||||||
| typedef unsigned pthread_cond_t; |  | ||||||
| typedef unsigned pthread_key_t; |  | ||||||
| #define PTHREAD_MUTEX_INITIALIZER 0 |  | ||||||
| #define PTHREAD_COND_INITIALIZER 0 |  | ||||||
| #define PTHREAD_MUTEX_RECURSIVE 0 |  | ||||||
| #define pthread_mutex_init(a,b) (*(a) = 0, -1) |  | ||||||
| #define pthread_mutex_destroy(a) (-1) |  | ||||||
| #define pthread_mutex_lock(a) (-1) |  | ||||||
| #define pthread_mutex_trylock(a) (-1) |  | ||||||
| #define pthread_mutex_unlock(a) (-1) |  | ||||||
| #define pthread_mutexattr_settype(a,b) (*(a) = (b), -1) |  | ||||||
| #define pthread_mutexattr_init(a) (*(a) = 0, -1) |  | ||||||
| #define pthread_mutexattr_destroy(a) (-1) |  | ||||||
| #define pthread_self() (-1) |  | ||||||
| #define pthread_equal(a,b) (0) |  | ||||||
| #define pthread_getspecific(a) ((void*)0) |  | ||||||
| #define pthread_cond_destroy(a) (-1) |  | ||||||
| #define pthread_cond_signal(a) (-1) |  | ||||||
| #define pthread_cond_broadcast(a) (-1) |  | ||||||
| #define pthread_cond_wait(a,b) (-1) |  | ||||||
| #define pthread_cond_timedwait(a,b,c) (-1) |  | ||||||
| #define sched_yield() (-1) |  | ||||||
| #else |  | ||||||
| #include <pthread.h> | #include <pthread.h> | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #pragma GCC system_header | #pragma GCC system_header | ||||||
|  |  | ||||||
| #ifdef _LIBCPP_SHARED_LOCK | #ifdef _LIBCPP_SHARED_LOCK | ||||||
|  |  | ||||||
| namespace ting { | namespace ting { | ||||||
| template <class> class shared_lock; | template <class _Mutex> class shared_lock; | ||||||
| template <class> class upgrade_lock; | template <class _Mutex> class upgrade_lock; | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_SHARED_LOCK | #endif  // _LIBCPP_SHARED_LOCK | ||||||
| @@ -218,8 +190,8 @@ public: | |||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(unique_lock& __u) |     void swap(unique_lock& __u) | ||||||
|     { |     { | ||||||
|         _STD::swap(__m_, __u.__m_); |         _VSTD::swap(__m_, __u.__m_); | ||||||
|         _STD::swap(__owns_, __u.__owns_); |         _VSTD::swap(__owns_, __u.__owns_); | ||||||
|     } |     } | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     mutex_type* release() |     mutex_type* release() | ||||||
| @@ -457,7 +429,7 @@ condition_variable::wait_for(unique_lock<mutex>& __lk, | |||||||
|                              _Predicate __pred) |                              _Predicate __pred) | ||||||
| { | { | ||||||
|     return wait_until(__lk, chrono::steady_clock::now() + __d, |     return wait_until(__lk, chrono::steady_clock::now() + __d, | ||||||
|                       _STD::move(__pred)); |                       _VSTD::move(__pred)); | ||||||
| } | } | ||||||
|  |  | ||||||
| _LIBCPP_END_NAMESPACE_STD | _LIBCPP_END_NAMESPACE_STD | ||||||
|   | |||||||
| @@ -47,29 +47,36 @@ public: | |||||||
|     typedef typename add_lvalue_reference<allocator_type>::type __alloc_ref; |     typedef typename add_lvalue_reference<allocator_type>::type __alloc_ref; | ||||||
|     typedef typename add_lvalue_reference<allocator_type>::type __alloc_const_ref; |     typedef typename add_lvalue_reference<allocator_type>::type __alloc_const_ref; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY __alloc_rr&           __alloc()         {return __end_cap_.second();} |     _LIBCPP_INLINE_VISIBILITY __alloc_rr&           __alloc() _NOEXCEPT         {return __end_cap_.second();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY const __alloc_rr&     __alloc() const   {return __end_cap_.second();} |     _LIBCPP_INLINE_VISIBILITY const __alloc_rr&     __alloc() const _NOEXCEPT   {return __end_cap_.second();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY pointer&              __end_cap()       {return __end_cap_.first();} |     _LIBCPP_INLINE_VISIBILITY pointer&              __end_cap() _NOEXCEPT       {return __end_cap_.first();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY const pointer&        __end_cap() const {return __end_cap_.first();} |     _LIBCPP_INLINE_VISIBILITY const pointer&        __end_cap() const _NOEXCEPT {return __end_cap_.first();} | ||||||
|  |  | ||||||
|     __split_buffer(); |     __split_buffer() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<allocator_type>::value); | ||||||
|     explicit __split_buffer(__alloc_rr& __a); |     explicit __split_buffer(__alloc_rr& __a); | ||||||
|     explicit __split_buffer(const __alloc_rr& __a); |     explicit __split_buffer(const __alloc_rr& __a); | ||||||
|     __split_buffer(size_type __cap, size_type __start, __alloc_rr& __a); |     __split_buffer(size_type __cap, size_type __start, __alloc_rr& __a); | ||||||
|     ~__split_buffer(); |     ~__split_buffer(); | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     __split_buffer(__split_buffer&& __c); |     __split_buffer(__split_buffer&& __c) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_constructible<allocator_type>::value); | ||||||
|     __split_buffer(__split_buffer&& __c, const __alloc_rr& __a); |     __split_buffer(__split_buffer&& __c, const __alloc_rr& __a); | ||||||
|     __split_buffer& operator=(__split_buffer&& __c); |     __split_buffer& operator=(__split_buffer&& __c) | ||||||
|  |         _NOEXCEPT_((__alloc_traits::propagate_on_container_move_assignment::value && | ||||||
|  |                 is_nothrow_move_assignable<allocator_type>::value) || | ||||||
|  |                !__alloc_traits::propagate_on_container_move_assignment::value); | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY       iterator begin()       {return __begin_;} |     _LIBCPP_INLINE_VISIBILITY       iterator begin() _NOEXCEPT       {return __begin_;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator begin() const {return __begin_;} |     _LIBCPP_INLINE_VISIBILITY const_iterator begin() const _NOEXCEPT {return __begin_;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY       iterator end()         {return __end_;} |     _LIBCPP_INLINE_VISIBILITY       iterator end() _NOEXCEPT         {return __end_;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator end() const   {return __end_;} |     _LIBCPP_INLINE_VISIBILITY const_iterator end() const _NOEXCEPT   {return __end_;} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY void clear() {__destruct_at_end(__begin_);} |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     void clear() _NOEXCEPT | ||||||
|  |         {__destruct_at_end(__begin_);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY size_type size() const {return static_cast<size_type>(__end_ - __begin_);} |     _LIBCPP_INLINE_VISIBILITY size_type size() const {return static_cast<size_type>(__end_ - __begin_);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY bool empty()     const {return __end_ == __begin_;} |     _LIBCPP_INLINE_VISIBILITY bool empty()     const {return __end_ == __begin_;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY size_type capacity() const {return static_cast<size_type>(__end_cap() - __first_);} |     _LIBCPP_INLINE_VISIBILITY size_type capacity() const {return static_cast<size_type>(__end_cap() - __first_);} | ||||||
| @@ -82,7 +89,7 @@ public: | |||||||
|     _LIBCPP_INLINE_VISIBILITY const_reference back() const  {return *(__end_ - 1);} |     _LIBCPP_INLINE_VISIBILITY const_reference back() const  {return *(__end_ - 1);} | ||||||
|  |  | ||||||
|     void reserve(size_type __n); |     void reserve(size_type __n); | ||||||
|     void shrink_to_fit(); |     void shrink_to_fit() _NOEXCEPT; | ||||||
|     void push_front(const_reference __x); |     void push_front(const_reference __x); | ||||||
|     void push_back(const_reference __x); |     void push_back(const_reference __x); | ||||||
| #if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) | #if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) | ||||||
| @@ -120,40 +127,47 @@ public: | |||||||
|         void __destruct_at_begin(pointer __new_begin, false_type); |         void __destruct_at_begin(pointer __new_begin, false_type); | ||||||
|         void __destruct_at_begin(pointer __new_begin, true_type); |         void __destruct_at_begin(pointer __new_begin, true_type); | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY void __destruct_at_end(pointer __new_last) |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     void __destruct_at_end(pointer __new_last) _NOEXCEPT | ||||||
|         {__destruct_at_end(__new_last, is_trivially_destructible<value_type>());} |         {__destruct_at_end(__new_last, is_trivially_destructible<value_type>());} | ||||||
|         void __destruct_at_end(pointer __new_last, false_type); |         void __destruct_at_end(pointer __new_last, false_type) _NOEXCEPT; | ||||||
|         void __destruct_at_end(pointer __new_last, true_type); |         void __destruct_at_end(pointer __new_last, true_type) _NOEXCEPT; | ||||||
|  |  | ||||||
|     void swap(__split_buffer& __x); |     void swap(__split_buffer& __x) | ||||||
|  |         _NOEXCEPT_(!__alloc_traits::propagate_on_container_swap::value|| | ||||||
|  |                    __is_nothrow_swappable<__alloc_rr>::value); | ||||||
|  |  | ||||||
|     bool __invariants() const; |     bool __invariants() const; | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void __move_assign_alloc(const __split_buffer& __c, true_type) |     void __move_assign_alloc(const __split_buffer& __c, true_type) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_assignable<allocator_type>::value) | ||||||
|         { |         { | ||||||
|             __alloc() = _STD::move(__c.__alloc()); |             __alloc() = _VSTD::move(__c.__alloc()); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void __move_assign_alloc(const __split_buffer& __c, false_type) |     void __move_assign_alloc(const __split_buffer& __c, false_type) _NOEXCEPT | ||||||
|         {} |         {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     static void __swap_alloc(__alloc_rr& __x, __alloc_rr& __y) |     static void __swap_alloc(__alloc_rr& __x, __alloc_rr& __y) | ||||||
|  |         _NOEXCEPT_(!__alloc_traits::propagate_on_container_swap::value|| | ||||||
|  |                    __is_nothrow_swappable<__alloc_rr>::value) | ||||||
|         {__swap_alloc(__x, __y, integral_constant<bool, |         {__swap_alloc(__x, __y, integral_constant<bool, | ||||||
|                       __alloc_traits::propagate_on_container_swap::value>());} |                       __alloc_traits::propagate_on_container_swap::value>());} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     static void __swap_alloc(__alloc_rr& __x, __alloc_rr& __y, true_type) |     static void __swap_alloc(__alloc_rr& __x, __alloc_rr& __y, true_type) | ||||||
|  |         _NOEXCEPT_(__is_nothrow_swappable<__alloc_rr>::value) | ||||||
|         { |         { | ||||||
|             using _STD::swap; |             using _VSTD::swap; | ||||||
|             swap(__x, __y); |             swap(__x, __y); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     static void __swap_alloc(__alloc_rr& __x, __alloc_rr& __y, false_type) |     static void __swap_alloc(__alloc_rr& __x, __alloc_rr& __y, false_type) _NOEXCEPT | ||||||
|         {} |         {} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -194,7 +208,7 @@ __split_buffer<_Tp, _Allocator>::__construct_at_end(size_type __n) | |||||||
|     __alloc_rr& __a = this->__alloc(); |     __alloc_rr& __a = this->__alloc(); | ||||||
|     do |     do | ||||||
|     { |     { | ||||||
|         __alloc_traits::construct(__a, _STD::__to_raw_pointer(this->__end_), value_type()); |         __alloc_traits::construct(__a, _VSTD::__to_raw_pointer(this->__end_), value_type()); | ||||||
|         ++this->__end_; |         ++this->__end_; | ||||||
|         --__n; |         --__n; | ||||||
|     } while (__n > 0); |     } while (__n > 0); | ||||||
| @@ -213,7 +227,7 @@ __split_buffer<_Tp, _Allocator>::__construct_at_end(size_type __n, const_referen | |||||||
|     __alloc_rr& __a = this->__alloc(); |     __alloc_rr& __a = this->__alloc(); | ||||||
|     do |     do | ||||||
|     { |     { | ||||||
|         __alloc_traits::construct(__a, _STD::__to_raw_pointer(this->__end_), __x); |         __alloc_traits::construct(__a, _VSTD::__to_raw_pointer(this->__end_), __x); | ||||||
|         ++this->__end_; |         ++this->__end_; | ||||||
|         --__n; |         --__n; | ||||||
|     } while (__n > 0); |     } while (__n > 0); | ||||||
| @@ -235,14 +249,14 @@ __split_buffer<_Tp, _Allocator>::__construct_at_end(_InputIter __first, _InputIt | |||||||
|         if (__end_ == __end_cap()) |         if (__end_ == __end_cap()) | ||||||
|         { |         { | ||||||
|             size_type __old_cap = __end_cap() - __first_; |             size_type __old_cap = __end_cap() - __first_; | ||||||
|             size_type __new_cap = _STD::max<size_type>(2 * __old_cap, 8); |             size_type __new_cap = _VSTD::max<size_type>(2 * __old_cap, 8); | ||||||
|             __split_buffer __buf(__new_cap, 0, __a); |             __split_buffer __buf(__new_cap, 0, __a); | ||||||
|             for (pointer __p = __begin_; __p != __end_; ++__p, ++__buf.__end_) |             for (pointer __p = __begin_; __p != __end_; ++__p, ++__buf.__end_) | ||||||
|                 __alloc_traits::construct(__buf.__alloc(), |                 __alloc_traits::construct(__buf.__alloc(), | ||||||
|                         _STD::__to_raw_pointer(__buf.__end_), _STD::move(*__p)); |                         _VSTD::__to_raw_pointer(__buf.__end_), _VSTD::move(*__p)); | ||||||
|             swap(__buf); |             swap(__buf); | ||||||
|         } |         } | ||||||
|         __alloc_traits::construct(__a, _STD::__to_raw_pointer(this->__end_), *__first); |         __alloc_traits::construct(__a, _VSTD::__to_raw_pointer(this->__end_), *__first); | ||||||
|         ++this->__end_; |         ++this->__end_; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -259,7 +273,7 @@ __split_buffer<_Tp, _Allocator>::__construct_at_end(_ForwardIterator __first, _F | |||||||
|     __alloc_rr& __a = this->__alloc(); |     __alloc_rr& __a = this->__alloc(); | ||||||
|     for (; __first != __last; ++__first) |     for (; __first != __last; ++__first) | ||||||
|     { |     { | ||||||
|         __alloc_traits::construct(__a, _STD::__to_raw_pointer(this->__end_), *__first); |         __alloc_traits::construct(__a, _VSTD::__to_raw_pointer(this->__end_), *__first); | ||||||
|         ++this->__end_; |         ++this->__end_; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -284,7 +298,7 @@ __split_buffer<_Tp, _Allocator>::__destruct_at_begin(pointer __new_begin, true_t | |||||||
| template <class _Tp, class _Allocator> | template <class _Tp, class _Allocator> | ||||||
| _LIBCPP_INLINE_VISIBILITY inline | _LIBCPP_INLINE_VISIBILITY inline | ||||||
| void | void | ||||||
| __split_buffer<_Tp, _Allocator>::__destruct_at_end(pointer __new_last, false_type) | __split_buffer<_Tp, _Allocator>::__destruct_at_end(pointer __new_last, false_type) _NOEXCEPT | ||||||
| { | { | ||||||
|     while (__new_last < __end_) |     while (__new_last < __end_) | ||||||
|         __alloc_traits::destroy(__alloc(), --__end_); |         __alloc_traits::destroy(__alloc(), --__end_); | ||||||
| @@ -293,7 +307,7 @@ __split_buffer<_Tp, _Allocator>::__destruct_at_end(pointer __new_last, false_typ | |||||||
| template <class _Tp, class _Allocator> | template <class _Tp, class _Allocator> | ||||||
| _LIBCPP_INLINE_VISIBILITY inline | _LIBCPP_INLINE_VISIBILITY inline | ||||||
| void | void | ||||||
| __split_buffer<_Tp, _Allocator>::__destruct_at_end(pointer __new_last, true_type) | __split_buffer<_Tp, _Allocator>::__destruct_at_end(pointer __new_last, true_type) _NOEXCEPT | ||||||
| { | { | ||||||
|     __end_ = __new_last; |     __end_ = __new_last; | ||||||
| } | } | ||||||
| @@ -310,6 +324,7 @@ __split_buffer<_Tp, _Allocator>::__split_buffer(size_type __cap, size_type __sta | |||||||
| template <class _Tp, class _Allocator> | template <class _Tp, class _Allocator> | ||||||
| _LIBCPP_INLINE_VISIBILITY inline | _LIBCPP_INLINE_VISIBILITY inline | ||||||
| __split_buffer<_Tp, _Allocator>::__split_buffer() | __split_buffer<_Tp, _Allocator>::__split_buffer() | ||||||
|  |     _NOEXCEPT_(is_nothrow_default_constructible<allocator_type>::value) | ||||||
|     : __first_(0), __begin_(0), __end_(0), __end_cap_(0) |     : __first_(0), __begin_(0), __end_(0), __end_cap_(0) | ||||||
| { | { | ||||||
| } | } | ||||||
| @@ -340,10 +355,11 @@ __split_buffer<_Tp, _Allocator>::~__split_buffer() | |||||||
|  |  | ||||||
| template <class _Tp, class _Allocator> | template <class _Tp, class _Allocator> | ||||||
| __split_buffer<_Tp, _Allocator>::__split_buffer(__split_buffer&& __c) | __split_buffer<_Tp, _Allocator>::__split_buffer(__split_buffer&& __c) | ||||||
|     : __first_(_STD::move(__c.__first_)), |     _NOEXCEPT_(is_nothrow_move_constructible<allocator_type>::value) | ||||||
|       __begin_(_STD::move(__c.__begin_)), |     : __first_(_VSTD::move(__c.__first_)), | ||||||
|       __end_(_STD::move(__c.__end_)), |       __begin_(_VSTD::move(__c.__begin_)), | ||||||
|       __end_cap_(_STD::move(__c.__end_cap_)) |       __end_(_VSTD::move(__c.__end_)), | ||||||
|  |       __end_cap_(_VSTD::move(__c.__end_cap_)) | ||||||
| { | { | ||||||
|     __c.__first_ = nullptr; |     __c.__first_ = nullptr; | ||||||
|     __c.__begin_ = nullptr; |     __c.__begin_ = nullptr; | ||||||
| @@ -380,6 +396,9 @@ __split_buffer<_Tp, _Allocator>::__split_buffer(__split_buffer&& __c, const __al | |||||||
| template <class _Tp, class _Allocator> | template <class _Tp, class _Allocator> | ||||||
| __split_buffer<_Tp, _Allocator>& | __split_buffer<_Tp, _Allocator>& | ||||||
| __split_buffer<_Tp, _Allocator>::operator=(__split_buffer&& __c) | __split_buffer<_Tp, _Allocator>::operator=(__split_buffer&& __c) | ||||||
|  |     _NOEXCEPT_((__alloc_traits::propagate_on_container_move_assignment::value && | ||||||
|  |                 is_nothrow_move_assignable<allocator_type>::value) || | ||||||
|  |                !__alloc_traits::propagate_on_container_move_assignment::value) | ||||||
| { | { | ||||||
|     clear(); |     clear(); | ||||||
|     shrink_to_fit(); |     shrink_to_fit(); | ||||||
| @@ -399,11 +418,13 @@ __split_buffer<_Tp, _Allocator>::operator=(__split_buffer&& __c) | |||||||
| template <class _Tp, class _Allocator> | template <class _Tp, class _Allocator> | ||||||
| void | void | ||||||
| __split_buffer<_Tp, _Allocator>::swap(__split_buffer& __x) | __split_buffer<_Tp, _Allocator>::swap(__split_buffer& __x) | ||||||
|  |         _NOEXCEPT_(!__alloc_traits::propagate_on_container_swap::value|| | ||||||
|  |                    __is_nothrow_swappable<__alloc_rr>::value) | ||||||
| { | { | ||||||
|     _STD::swap(__first_, __x.__first_); |     _VSTD::swap(__first_, __x.__first_); | ||||||
|     _STD::swap(__begin_, __x.__begin_); |     _VSTD::swap(__begin_, __x.__begin_); | ||||||
|     _STD::swap(__end_, __x.__end_); |     _VSTD::swap(__end_, __x.__end_); | ||||||
|     _STD::swap(__end_cap(), __x.__end_cap()); |     _VSTD::swap(__end_cap(), __x.__end_cap()); | ||||||
|     __swap_alloc(__alloc(), __x.__alloc()); |     __swap_alloc(__alloc(), __x.__alloc()); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -416,16 +437,16 @@ __split_buffer<_Tp, _Allocator>::reserve(size_type __n) | |||||||
|         __split_buffer<value_type, __alloc_rr&> __t(__n, 0, __alloc()); |         __split_buffer<value_type, __alloc_rr&> __t(__n, 0, __alloc()); | ||||||
|         __t.__construct_at_end(move_iterator<pointer>(__begin_), |         __t.__construct_at_end(move_iterator<pointer>(__begin_), | ||||||
|                                move_iterator<pointer>(__end_)); |                                move_iterator<pointer>(__end_)); | ||||||
|         _STD::swap(__first_, __t.__first_); |         _VSTD::swap(__first_, __t.__first_); | ||||||
|         _STD::swap(__begin_, __t.__begin_); |         _VSTD::swap(__begin_, __t.__begin_); | ||||||
|         _STD::swap(__end_, __t.__end_); |         _VSTD::swap(__end_, __t.__end_); | ||||||
|         _STD::swap(__end_cap(), __t.__end_cap()); |         _VSTD::swap(__end_cap(), __t.__end_cap()); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, class _Allocator> | template <class _Tp, class _Allocator> | ||||||
| void | void | ||||||
| __split_buffer<_Tp, _Allocator>::shrink_to_fit() | __split_buffer<_Tp, _Allocator>::shrink_to_fit() _NOEXCEPT | ||||||
| { | { | ||||||
|     if (capacity() > size()) |     if (capacity() > size()) | ||||||
|     { |     { | ||||||
| @@ -437,10 +458,10 @@ __split_buffer<_Tp, _Allocator>::shrink_to_fit() | |||||||
|             __t.__construct_at_end(move_iterator<pointer>(__begin_), |             __t.__construct_at_end(move_iterator<pointer>(__begin_), | ||||||
|                                    move_iterator<pointer>(__end_)); |                                    move_iterator<pointer>(__end_)); | ||||||
|             __t.__end_ = __t.__begin_ + (__end_ - __begin_); |             __t.__end_ = __t.__begin_ + (__end_ - __begin_); | ||||||
|             _STD::swap(__first_, __t.__first_); |             _VSTD::swap(__first_, __t.__first_); | ||||||
|             _STD::swap(__begin_, __t.__begin_); |             _VSTD::swap(__begin_, __t.__begin_); | ||||||
|             _STD::swap(__end_, __t.__end_); |             _VSTD::swap(__end_, __t.__end_); | ||||||
|             _STD::swap(__end_cap(), __t.__end_cap()); |             _VSTD::swap(__end_cap(), __t.__end_cap()); | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|         } |         } | ||||||
|         catch (...) |         catch (...) | ||||||
| @@ -460,7 +481,7 @@ __split_buffer<_Tp, _Allocator>::push_front(const_reference __x) | |||||||
|         { |         { | ||||||
|             difference_type __d = __end_cap() - __end_; |             difference_type __d = __end_cap() - __end_; | ||||||
|             __d = (__d + 1) / 2; |             __d = (__d + 1) / 2; | ||||||
|             __begin_ = _STD::move_backward(__begin_, __end_, __end_ + __d); |             __begin_ = _VSTD::move_backward(__begin_, __end_, __end_ + __d); | ||||||
|             __end_ += __d; |             __end_ += __d; | ||||||
|         } |         } | ||||||
|         else |         else | ||||||
| @@ -469,13 +490,13 @@ __split_buffer<_Tp, _Allocator>::push_front(const_reference __x) | |||||||
|             __split_buffer<value_type, __alloc_rr&> __t(__c, (__c + 3) / 4, __alloc()); |             __split_buffer<value_type, __alloc_rr&> __t(__c, (__c + 3) / 4, __alloc()); | ||||||
|             __t.__construct_at_end(move_iterator<pointer>(__begin_), |             __t.__construct_at_end(move_iterator<pointer>(__begin_), | ||||||
|                                    move_iterator<pointer>(__end_)); |                                    move_iterator<pointer>(__end_)); | ||||||
|             _STD::swap(__first_, __t.__first_); |             _VSTD::swap(__first_, __t.__first_); | ||||||
|             _STD::swap(__begin_, __t.__begin_); |             _VSTD::swap(__begin_, __t.__begin_); | ||||||
|             _STD::swap(__end_, __t.__end_); |             _VSTD::swap(__end_, __t.__end_); | ||||||
|             _STD::swap(__end_cap(), __t.__end_cap()); |             _VSTD::swap(__end_cap(), __t.__end_cap()); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     __alloc_traits::construct(__alloc(), _STD::__to_raw_pointer(__begin_-1), __x); |     __alloc_traits::construct(__alloc(), _VSTD::__to_raw_pointer(__begin_-1), __x); | ||||||
|     --__begin_; |     --__begin_; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -491,7 +512,7 @@ __split_buffer<_Tp, _Allocator>::push_front(value_type&& __x) | |||||||
|         { |         { | ||||||
|             difference_type __d = __end_cap() - __end_; |             difference_type __d = __end_cap() - __end_; | ||||||
|             __d = (__d + 1) / 2; |             __d = (__d + 1) / 2; | ||||||
|             __begin_ = _STD::move_backward(__begin_, __end_, __end_ + __d); |             __begin_ = _VSTD::move_backward(__begin_, __end_, __end_ + __d); | ||||||
|             __end_ += __d; |             __end_ += __d; | ||||||
|         } |         } | ||||||
|         else |         else | ||||||
| @@ -500,14 +521,14 @@ __split_buffer<_Tp, _Allocator>::push_front(value_type&& __x) | |||||||
|             __split_buffer<value_type, __alloc_rr&> __t(__c, (__c + 3) / 4, __alloc()); |             __split_buffer<value_type, __alloc_rr&> __t(__c, (__c + 3) / 4, __alloc()); | ||||||
|             __t.__construct_at_end(move_iterator<pointer>(__begin_), |             __t.__construct_at_end(move_iterator<pointer>(__begin_), | ||||||
|                                    move_iterator<pointer>(__end_)); |                                    move_iterator<pointer>(__end_)); | ||||||
|             _STD::swap(__first_, __t.__first_); |             _VSTD::swap(__first_, __t.__first_); | ||||||
|             _STD::swap(__begin_, __t.__begin_); |             _VSTD::swap(__begin_, __t.__begin_); | ||||||
|             _STD::swap(__end_, __t.__end_); |             _VSTD::swap(__end_, __t.__end_); | ||||||
|             _STD::swap(__end_cap(), __t.__end_cap()); |             _VSTD::swap(__end_cap(), __t.__end_cap()); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     __alloc_traits::construct(__alloc(), _STD::__to_raw_pointer(__begin_-1), |     __alloc_traits::construct(__alloc(), _VSTD::__to_raw_pointer(__begin_-1), | ||||||
|             _STD::move(__x)); |             _VSTD::move(__x)); | ||||||
|     --__begin_; |     --__begin_; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -524,7 +545,7 @@ __split_buffer<_Tp, _Allocator>::push_back(const_reference __x) | |||||||
|         { |         { | ||||||
|             difference_type __d = __begin_ - __first_; |             difference_type __d = __begin_ - __first_; | ||||||
|             __d = (__d + 1) / 2; |             __d = (__d + 1) / 2; | ||||||
|             __end_ = _STD::move(__begin_, __end_, __begin_ - __d); |             __end_ = _VSTD::move(__begin_, __end_, __begin_ - __d); | ||||||
|             __begin_ -= __d; |             __begin_ -= __d; | ||||||
|         } |         } | ||||||
|         else |         else | ||||||
| @@ -533,13 +554,13 @@ __split_buffer<_Tp, _Allocator>::push_back(const_reference __x) | |||||||
|             __split_buffer<value_type, __alloc_rr&> __t(__c, __c / 4, __alloc()); |             __split_buffer<value_type, __alloc_rr&> __t(__c, __c / 4, __alloc()); | ||||||
|             __t.__construct_at_end(move_iterator<pointer>(__begin_), |             __t.__construct_at_end(move_iterator<pointer>(__begin_), | ||||||
|                                    move_iterator<pointer>(__end_)); |                                    move_iterator<pointer>(__end_)); | ||||||
|             _STD::swap(__first_, __t.__first_); |             _VSTD::swap(__first_, __t.__first_); | ||||||
|             _STD::swap(__begin_, __t.__begin_); |             _VSTD::swap(__begin_, __t.__begin_); | ||||||
|             _STD::swap(__end_, __t.__end_); |             _VSTD::swap(__end_, __t.__end_); | ||||||
|             _STD::swap(__end_cap(), __t.__end_cap()); |             _VSTD::swap(__end_cap(), __t.__end_cap()); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     __alloc_traits::construct(__alloc(), _STD::__to_raw_pointer(__end_), __x); |     __alloc_traits::construct(__alloc(), _VSTD::__to_raw_pointer(__end_), __x); | ||||||
|     ++__end_; |     ++__end_; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -555,7 +576,7 @@ __split_buffer<_Tp, _Allocator>::push_back(value_type&& __x) | |||||||
|         { |         { | ||||||
|             difference_type __d = __begin_ - __first_; |             difference_type __d = __begin_ - __first_; | ||||||
|             __d = (__d + 1) / 2; |             __d = (__d + 1) / 2; | ||||||
|             __end_ = _STD::move(__begin_, __end_, __begin_ - __d); |             __end_ = _VSTD::move(__begin_, __end_, __begin_ - __d); | ||||||
|             __begin_ -= __d; |             __begin_ -= __d; | ||||||
|         } |         } | ||||||
|         else |         else | ||||||
| @@ -564,14 +585,14 @@ __split_buffer<_Tp, _Allocator>::push_back(value_type&& __x) | |||||||
|             __split_buffer<value_type, __alloc_rr&> __t(__c, __c / 4, __alloc()); |             __split_buffer<value_type, __alloc_rr&> __t(__c, __c / 4, __alloc()); | ||||||
|             __t.__construct_at_end(move_iterator<pointer>(__begin_), |             __t.__construct_at_end(move_iterator<pointer>(__begin_), | ||||||
|                                    move_iterator<pointer>(__end_)); |                                    move_iterator<pointer>(__end_)); | ||||||
|             _STD::swap(__first_, __t.__first_); |             _VSTD::swap(__first_, __t.__first_); | ||||||
|             _STD::swap(__begin_, __t.__begin_); |             _VSTD::swap(__begin_, __t.__begin_); | ||||||
|             _STD::swap(__end_, __t.__end_); |             _VSTD::swap(__end_, __t.__end_); | ||||||
|             _STD::swap(__end_cap(), __t.__end_cap()); |             _VSTD::swap(__end_cap(), __t.__end_cap()); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     __alloc_traits::construct(__alloc(), _STD::__to_raw_pointer(__end_), |     __alloc_traits::construct(__alloc(), _VSTD::__to_raw_pointer(__end_), | ||||||
|             _STD::move(__x)); |             _VSTD::move(__x)); | ||||||
|     ++__end_; |     ++__end_; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -588,7 +609,7 @@ __split_buffer<_Tp, _Allocator>::emplace_back(_Args&&... __args) | |||||||
|         { |         { | ||||||
|             difference_type __d = __begin_ - __first_; |             difference_type __d = __begin_ - __first_; | ||||||
|             __d = (__d + 1) / 2; |             __d = (__d + 1) / 2; | ||||||
|             __end_ = _STD::move(__begin_, __end_, __begin_ - __d); |             __end_ = _VSTD::move(__begin_, __end_, __begin_ - __d); | ||||||
|             __begin_ -= __d; |             __begin_ -= __d; | ||||||
|         } |         } | ||||||
|         else |         else | ||||||
| @@ -597,14 +618,14 @@ __split_buffer<_Tp, _Allocator>::emplace_back(_Args&&... __args) | |||||||
|             __split_buffer<value_type, __alloc_rr&> __t(__c, __c / 4, __alloc()); |             __split_buffer<value_type, __alloc_rr&> __t(__c, __c / 4, __alloc()); | ||||||
|             __t.__construct_at_end(move_iterator<pointer>(__begin_), |             __t.__construct_at_end(move_iterator<pointer>(__begin_), | ||||||
|                                    move_iterator<pointer>(__end_)); |                                    move_iterator<pointer>(__end_)); | ||||||
|             _STD::swap(__first_, __t.__first_); |             _VSTD::swap(__first_, __t.__first_); | ||||||
|             _STD::swap(__begin_, __t.__begin_); |             _VSTD::swap(__begin_, __t.__begin_); | ||||||
|             _STD::swap(__end_, __t.__end_); |             _VSTD::swap(__end_, __t.__end_); | ||||||
|             _STD::swap(__end_cap(), __t.__end_cap()); |             _VSTD::swap(__end_cap(), __t.__end_cap()); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     __alloc_traits::construct(__alloc(), _STD::__to_raw_pointer(__end_), |     __alloc_traits::construct(__alloc(), _VSTD::__to_raw_pointer(__end_), | ||||||
|                               _STD::forward<_Args>(__args)...); |                               _VSTD::forward<_Args>(__args)...); | ||||||
|     ++__end_; |     ++__end_; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -612,6 +633,16 @@ __split_buffer<_Tp, _Allocator>::emplace_back(_Args&&... __args) | |||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|  | template <class _Tp, class _Allocator> | ||||||
|  | _LIBCPP_INLINE_VISIBILITY inline | ||||||
|  | void | ||||||
|  | swap(__split_buffer<_Tp, _Allocator>& __x, __split_buffer<_Tp, _Allocator>& __y) | ||||||
|  |         _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||||
|  | { | ||||||
|  |     __x.swap(__y); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
| _LIBCPP_END_NAMESPACE_STD | _LIBCPP_END_NAMESPACE_STD | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_SPLIT_BUFFER | #endif  // _LIBCPP_SPLIT_BUFFER | ||||||
|   | |||||||
| @@ -97,7 +97,7 @@ typename __stdinbuf<_CharT>::int_type | |||||||
| __stdinbuf<_CharT>::__getchar(bool __consume) | __stdinbuf<_CharT>::__getchar(bool __consume) | ||||||
| { | { | ||||||
|     char __extbuf[__limit]; |     char __extbuf[__limit]; | ||||||
|     int __nread = _STD::max(1, __encoding_); |     int __nread = _VSTD::max(1, __encoding_); | ||||||
|     for (int __i = 0; __i < __nread; ++__i) |     for (int __i = 0; __i < __nread; ++__i) | ||||||
|     { |     { | ||||||
|         char __c = getc(__file_); |         char __c = getc(__file_); | ||||||
| @@ -120,7 +120,7 @@ __stdinbuf<_CharT>::__getchar(bool __consume) | |||||||
|                                    &__1buf, &__1buf + 1, __inxt); |                                    &__1buf, &__1buf + 1, __inxt); | ||||||
|             switch (__r) |             switch (__r) | ||||||
|             { |             { | ||||||
|             case _STD::codecvt_base::ok: |             case _VSTD::codecvt_base::ok: | ||||||
|                 break; |                 break; | ||||||
|             case codecvt_base::partial: |             case codecvt_base::partial: | ||||||
|                 __st_ = __sv_st; |                 __st_ = __sv_st; | ||||||
| @@ -136,11 +136,11 @@ __stdinbuf<_CharT>::__getchar(bool __consume) | |||||||
|                 break; |                 break; | ||||||
|             case codecvt_base::error: |             case codecvt_base::error: | ||||||
|                 return traits_type::eof(); |                 return traits_type::eof(); | ||||||
|             case _STD::codecvt_base::noconv: |             case _VSTD::codecvt_base::noconv: | ||||||
|                 __1buf = static_cast<char_type>(__extbuf[0]); |                 __1buf = static_cast<char_type>(__extbuf[0]); | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|         } while (__r == _STD::codecvt_base::partial); |         } while (__r == _VSTD::codecvt_base::partial); | ||||||
|     } |     } | ||||||
|     if (!__consume) |     if (!__consume) | ||||||
|     { |     { | ||||||
| @@ -166,9 +166,9 @@ __stdinbuf<_CharT>::pbackfail(int_type __c) | |||||||
|     switch (__cv_->out(__st_, &__ci, &__ci + 1, __inxt, |     switch (__cv_->out(__st_, &__ci, &__ci + 1, __inxt, | ||||||
|                               __extbuf, __extbuf + sizeof(__extbuf), __enxt)) |                               __extbuf, __extbuf + sizeof(__extbuf), __enxt)) | ||||||
|     { |     { | ||||||
|     case _STD::codecvt_base::ok: |     case _VSTD::codecvt_base::ok: | ||||||
|         break; |         break; | ||||||
|     case _STD::codecvt_base::noconv: |     case _VSTD::codecvt_base::noconv: | ||||||
|         __extbuf[0] = static_cast<char>(__c); |         __extbuf[0] = static_cast<char>(__c); | ||||||
|         __enxt = __extbuf + 1; |         __enxt = __extbuf + 1; | ||||||
|         break; |         break; | ||||||
| @@ -288,12 +288,12 @@ __stdoutbuf<_CharT>::sync() | |||||||
|         __r = __cv_->unshift(__st_, __extbuf, |         __r = __cv_->unshift(__st_, __extbuf, | ||||||
|                                     __extbuf + sizeof(__extbuf), |                                     __extbuf + sizeof(__extbuf), | ||||||
|                                     __extbe); |                                     __extbe); | ||||||
|         if (__r == codecvt_base::error) |  | ||||||
|             return -1; |  | ||||||
|         size_t __nmemb = static_cast<size_t>(__extbe - __extbuf); |         size_t __nmemb = static_cast<size_t>(__extbe - __extbuf); | ||||||
|         if (fwrite(__extbuf, 1, __nmemb, __file_) != __nmemb) |         if (fwrite(__extbuf, 1, __nmemb, __file_) != __nmemb) | ||||||
|             return -1; |             return -1; | ||||||
|     } while (__r == codecvt_base::partial); |     } while (__r == codecvt_base::partial); | ||||||
|  |     if (__r == codecvt_base::error) | ||||||
|  |         return -1; | ||||||
|     if (fflush(__file_)) |     if (fflush(__file_)) | ||||||
|         return -1; |         return -1; | ||||||
|     return 0; |     return 0; | ||||||
|   | |||||||
							
								
								
									
										239
									
								
								include/__tree
									
									
									
									
									
								
							
							
						
						
									
										239
									
								
								include/__tree
									
									
									
									
									
								
							| @@ -21,13 +21,19 @@ | |||||||
|  |  | ||||||
| _LIBCPP_BEGIN_NAMESPACE_STD | _LIBCPP_BEGIN_NAMESPACE_STD | ||||||
|  |  | ||||||
| template <class, class, class> class __tree; | template <class _Tp, class _Compare, class _Allocator> class __tree; | ||||||
| template <class, class, class> class _LIBCPP_VISIBLE __tree_iterator; | template <class _Tp, class _NodePtr, class _DiffType> | ||||||
| template <class, class, class> class _LIBCPP_VISIBLE __tree_const_iterator; |     class _LIBCPP_VISIBLE __tree_iterator; | ||||||
| template <class, class, class, class> class _LIBCPP_VISIBLE map; | template <class _Tp, class _ConstNodePtr, class _DiffType> | ||||||
| template <class, class, class, class> class _LIBCPP_VISIBLE multimap; |     class _LIBCPP_VISIBLE __tree_const_iterator; | ||||||
| template <class, class, class> class _LIBCPP_VISIBLE set; | template <class _Key, class _Tp, class _Compare, class _Allocator> | ||||||
| template <class, class, class> class _LIBCPP_VISIBLE multiset; |     class _LIBCPP_VISIBLE map; | ||||||
|  | template <class _Key, class _Tp, class _Compare, class _Allocator> | ||||||
|  |     class _LIBCPP_VISIBLE multimap; | ||||||
|  | template <class _Key, class _Compare, class _Allocator> | ||||||
|  |     class _LIBCPP_VISIBLE set; | ||||||
|  | template <class _Key, class _Compare, class _Allocator> | ||||||
|  |     class _LIBCPP_VISIBLE multiset; | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  |  | ||||||
| @@ -55,7 +61,7 @@ __root, have a non-null __parent_ field. | |||||||
| template <class _NodePtr> | template <class _NodePtr> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| __tree_is_left_child(_NodePtr __x) | __tree_is_left_child(_NodePtr __x) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __x == __x->__parent_->__left_; |     return __x == __x->__parent_->__left_; | ||||||
| } | } | ||||||
| @@ -121,7 +127,7 @@ __tree_invariant(_NodePtr __root) | |||||||
| template <class _NodePtr> | template <class _NodePtr> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| _NodePtr | _NodePtr | ||||||
| __tree_min(_NodePtr __x) | __tree_min(_NodePtr __x) _NOEXCEPT | ||||||
| { | { | ||||||
|     while (__x->__left_ != nullptr) |     while (__x->__left_ != nullptr) | ||||||
|         __x = __x->__left_; |         __x = __x->__left_; | ||||||
| @@ -133,7 +139,7 @@ __tree_min(_NodePtr __x) | |||||||
| template <class _NodePtr> | template <class _NodePtr> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| _NodePtr | _NodePtr | ||||||
| __tree_max(_NodePtr __x) | __tree_max(_NodePtr __x) _NOEXCEPT | ||||||
| { | { | ||||||
|     while (__x->__right_ != nullptr) |     while (__x->__right_ != nullptr) | ||||||
|         __x = __x->__right_; |         __x = __x->__right_; | ||||||
| @@ -144,7 +150,7 @@ __tree_max(_NodePtr __x) | |||||||
| // Precondition:  __x != nullptr. | // Precondition:  __x != nullptr. | ||||||
| template <class _NodePtr> | template <class _NodePtr> | ||||||
| _NodePtr | _NodePtr | ||||||
| __tree_next(_NodePtr __x) | __tree_next(_NodePtr __x) _NOEXCEPT | ||||||
| { | { | ||||||
|     if (__x->__right_ != nullptr) |     if (__x->__right_ != nullptr) | ||||||
|         return __tree_min(__x->__right_); |         return __tree_min(__x->__right_); | ||||||
| @@ -157,7 +163,7 @@ __tree_next(_NodePtr __x) | |||||||
| // Precondition:  __x != nullptr. | // Precondition:  __x != nullptr. | ||||||
| template <class _NodePtr> | template <class _NodePtr> | ||||||
| _NodePtr | _NodePtr | ||||||
| __tree_prev(_NodePtr __x) | __tree_prev(_NodePtr __x) _NOEXCEPT | ||||||
| { | { | ||||||
|     if (__x->__left_ != nullptr) |     if (__x->__left_ != nullptr) | ||||||
|         return __tree_max(__x->__left_); |         return __tree_max(__x->__left_); | ||||||
| @@ -170,7 +176,7 @@ __tree_prev(_NodePtr __x) | |||||||
| // Precondition:  __x != nullptr. | // Precondition:  __x != nullptr. | ||||||
| template <class _NodePtr> | template <class _NodePtr> | ||||||
| _NodePtr | _NodePtr | ||||||
| __tree_leaf(_NodePtr __x) | __tree_leaf(_NodePtr __x) _NOEXCEPT | ||||||
| { | { | ||||||
|     while (true) |     while (true) | ||||||
|     { |     { | ||||||
| @@ -194,7 +200,7 @@ __tree_leaf(_NodePtr __x) | |||||||
| // Precondition:  __x->__right_ != nullptr | // Precondition:  __x->__right_ != nullptr | ||||||
| template <class _NodePtr> | template <class _NodePtr> | ||||||
| void | void | ||||||
| __tree_left_rotate(_NodePtr __x) | __tree_left_rotate(_NodePtr __x) _NOEXCEPT | ||||||
| { | { | ||||||
|     _NodePtr __y = __x->__right_; |     _NodePtr __y = __x->__right_; | ||||||
|     __x->__right_ = __y->__left_; |     __x->__right_ = __y->__left_; | ||||||
| @@ -214,7 +220,7 @@ __tree_left_rotate(_NodePtr __x) | |||||||
| // Precondition:  __x->__left_ != nullptr | // Precondition:  __x->__left_ != nullptr | ||||||
| template <class _NodePtr> | template <class _NodePtr> | ||||||
| void | void | ||||||
| __tree_right_rotate(_NodePtr __x) | __tree_right_rotate(_NodePtr __x) _NOEXCEPT | ||||||
| { | { | ||||||
|     _NodePtr __y = __x->__left_; |     _NodePtr __y = __x->__left_; | ||||||
|     __x->__left_ = __y->__right_; |     __x->__left_ = __y->__right_; | ||||||
| @@ -239,7 +245,7 @@ __tree_right_rotate(_NodePtr __x) | |||||||
| //                may be different than the value passed in as __root. | //                may be different than the value passed in as __root. | ||||||
| template <class _NodePtr> | template <class _NodePtr> | ||||||
| void | void | ||||||
| __tree_balance_after_insert(_NodePtr __root, _NodePtr __x) | __tree_balance_after_insert(_NodePtr __root, _NodePtr __x) _NOEXCEPT | ||||||
| { | { | ||||||
|     __x->__is_black_ = __x == __root; |     __x->__is_black_ = __x == __root; | ||||||
|     while (__x != __root && !__x->__parent_->__is_black_) |     while (__x != __root && !__x->__parent_->__is_black_) | ||||||
| @@ -309,7 +315,7 @@ __tree_balance_after_insert(_NodePtr __root, _NodePtr __x) | |||||||
| //                may be different than the value passed in as __root. | //                may be different than the value passed in as __root. | ||||||
| template <class _NodePtr> | template <class _NodePtr> | ||||||
| void | void | ||||||
| __tree_remove(_NodePtr __root, _NodePtr __z) | __tree_remove(_NodePtr __root, _NodePtr __z) _NOEXCEPT | ||||||
| { | { | ||||||
|     // __z will be removed from the tree.  Client still needs to destruct/deallocate it |     // __z will be removed from the tree.  Client still needs to destruct/deallocate it | ||||||
|     // __y is either __z, or if __z has two children, __tree_next(__z). |     // __y is either __z, or if __z has two children, __tree_next(__z). | ||||||
| @@ -494,7 +500,7 @@ __tree_remove(_NodePtr __root, _NodePtr __z) | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class> class __map_node_destructor; | template <class _Allocator> class __map_node_destructor; | ||||||
|  |  | ||||||
| template <class _Allocator> | template <class _Allocator> | ||||||
| class __tree_node_destructor | class __tree_node_destructor | ||||||
| @@ -514,16 +520,16 @@ public: | |||||||
|     bool __value_constructed; |     bool __value_constructed; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __tree_node_destructor(allocator_type& __na) |     explicit __tree_node_destructor(allocator_type& __na) _NOEXCEPT | ||||||
|         : __na_(__na), |         : __na_(__na), | ||||||
|           __value_constructed(false) |           __value_constructed(false) | ||||||
|         {} |         {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void operator()(pointer __p) |     void operator()(pointer __p) _NOEXCEPT | ||||||
|     { |     { | ||||||
|         if (__value_constructed) |         if (__value_constructed) | ||||||
|             __alloc_traits::destroy(__na_, _STD::addressof(__p->__value_)); |             __alloc_traits::destroy(__na_, _VSTD::addressof(__p->__value_)); | ||||||
|         if (__p) |         if (__p) | ||||||
|             __alloc_traits::deallocate(__na_, __p, 1); |             __alloc_traits::deallocate(__na_, __p, 1); | ||||||
|     } |     } | ||||||
| @@ -541,7 +547,7 @@ public: | |||||||
|     pointer __left_; |     pointer __left_; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __tree_end_node() : __left_() {} |     __tree_end_node() _NOEXCEPT : __left_() {} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _VoidPtr> | template <class _VoidPtr> | ||||||
| @@ -580,7 +586,8 @@ public: | |||||||
|     bool __is_black_; |     bool __is_black_; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __tree_node_base() : __right_(), __parent_(), __is_black_(false) {} |     __tree_node_base() _NOEXCEPT | ||||||
|  |         : __right_(), __parent_(), __is_black_(false) {} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _Tp, class _VoidPtr> | template <class _Tp, class _VoidPtr> | ||||||
| @@ -597,7 +604,7 @@ public: | |||||||
|     template <class ..._Args> |     template <class ..._Args> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         explicit __tree_node(_Args&& ...__args) |         explicit __tree_node(_Args&& ...__args) | ||||||
|             : __value_(_STD::forward<_Args>(__args)...) {} |             : __value_(_VSTD::forward<_Args>(__args)...) {} | ||||||
| #else  // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | #else  // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __tree_node(const value_type& __v) |     explicit __tree_node(const value_type& __v) | ||||||
| @@ -605,8 +612,8 @@ public: | |||||||
| #endif  // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | #endif  // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class> class __map_iterator; | template <class _TreeIterator> class __map_iterator; | ||||||
| template <class> class __map_const_iterator; | template <class _TreeIterator> class __map_const_iterator; | ||||||
|  |  | ||||||
| template <class _Tp, class _NodePtr, class _DiffType> | template <class _Tp, class _NodePtr, class _DiffType> | ||||||
| class _LIBCPP_VISIBLE __tree_iterator | class _LIBCPP_VISIBLE __tree_iterator | ||||||
| @@ -632,7 +639,7 @@ public: | |||||||
| #endif | #endif | ||||||
|                                        pointer; |                                        pointer; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY __tree_iterator() {} |     _LIBCPP_INLINE_VISIBILITY __tree_iterator() _NOEXCEPT {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY reference operator*() const {return __ptr_->__value_;} |     _LIBCPP_INLINE_VISIBILITY reference operator*() const {return __ptr_->__value_;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY pointer operator->() const {return &__ptr_->__value_;} |     _LIBCPP_INLINE_VISIBILITY pointer operator->() const {return &__ptr_->__value_;} | ||||||
| @@ -662,7 +669,7 @@ public: | |||||||
|  |  | ||||||
| private: | private: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __tree_iterator(__node_pointer __p) : __ptr_(__p) {} |     explicit __tree_iterator(__node_pointer __p) _NOEXCEPT : __ptr_(__p) {} | ||||||
|     template <class, class, class> friend class __tree; |     template <class, class, class> friend class __tree; | ||||||
|     template <class, class, class> friend class _LIBCPP_VISIBLE __tree_const_iterator; |     template <class, class, class> friend class _LIBCPP_VISIBLE __tree_const_iterator; | ||||||
|     template <class> friend class _LIBCPP_VISIBLE __map_iterator; |     template <class> friend class _LIBCPP_VISIBLE __map_iterator; | ||||||
| @@ -716,7 +723,8 @@ private: | |||||||
|                                                  __non_const_iterator; |                                                  __non_const_iterator; | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __tree_const_iterator(__non_const_iterator __p) : __ptr_(__p.__ptr_) {} |     __tree_const_iterator(__non_const_iterator __p) _NOEXCEPT | ||||||
|  |         : __ptr_(__p.__ptr_) {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY reference operator*() const {return __ptr_->__value_;} |     _LIBCPP_INLINE_VISIBILITY reference operator*() const {return __ptr_->__value_;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY pointer operator->() const {return &__ptr_->__value_;} |     _LIBCPP_INLINE_VISIBILITY pointer operator->() const {return &__ptr_->__value_;} | ||||||
| @@ -746,7 +754,8 @@ public: | |||||||
|  |  | ||||||
| private: | private: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __tree_const_iterator(__node_pointer __p) : __ptr_(__p) {} |     explicit __tree_const_iterator(__node_pointer __p) _NOEXCEPT | ||||||
|  |         : __ptr_(__p) {} | ||||||
|     template <class, class, class> friend class __tree; |     template <class, class, class> friend class __tree; | ||||||
|     template <class, class, class, class> friend class _LIBCPP_VISIBLE map; |     template <class, class, class, class> friend class _LIBCPP_VISIBLE map; | ||||||
|     template <class, class, class, class> friend class _LIBCPP_VISIBLE multimap; |     template <class, class, class, class> friend class _LIBCPP_VISIBLE multimap; | ||||||
| @@ -805,7 +814,7 @@ private: | |||||||
|  |  | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __node_pointer __end_node() |     __node_pointer __end_node() _NOEXCEPT | ||||||
|     { |     { | ||||||
|         return static_cast<__node_pointer> |         return static_cast<__node_pointer> | ||||||
|                ( |                ( | ||||||
| @@ -813,7 +822,7 @@ public: | |||||||
|                ); |                ); | ||||||
|     } |     } | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __node_const_pointer __end_node() const |     __node_const_pointer __end_node() const _NOEXCEPT | ||||||
|     { |     { | ||||||
|         return static_cast<__node_const_pointer> |         return static_cast<__node_const_pointer> | ||||||
|                ( |                ( | ||||||
| @@ -821,39 +830,45 @@ public: | |||||||
|                ); |                ); | ||||||
|     } |     } | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           __node_allocator& __node_alloc()       {return __pair1_.second();} |           __node_allocator& __node_alloc() _NOEXCEPT {return __pair1_.second();} | ||||||
| private: | private: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const __node_allocator& __node_alloc() const {return __pair1_.second();} |     const __node_allocator& __node_alloc() const _NOEXCEPT | ||||||
|  |         {return __pair1_.second();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           __node_pointer& __begin_node()         {return __begin_node_;} |           __node_pointer& __begin_node() _NOEXCEPT {return __begin_node_;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const __node_pointer& __begin_node()   const {return __begin_node_;} |     const __node_pointer& __begin_node() const _NOEXCEPT {return __begin_node_;} | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     allocator_type __alloc() const {return allocator_type(__node_alloc());} |     allocator_type __alloc() const _NOEXCEPT | ||||||
|  |         {return allocator_type(__node_alloc());} | ||||||
| private: | private: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           size_type& size()                      {return __pair3_.first();} |           size_type& size() _NOEXCEPT {return __pair3_.first();} | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const size_type& size()                const {return __pair3_.first();} |     const size_type& size() const _NOEXCEPT {return __pair3_.first();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           value_compare& value_comp()            {return __pair3_.second();} |           value_compare& value_comp() _NOEXCEPT {return __pair3_.second();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const value_compare& value_comp()      const {return __pair3_.second();} |     const value_compare& value_comp() const _NOEXCEPT | ||||||
|  |         {return __pair3_.second();} | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __node_pointer       __root() |     __node_pointer __root() _NOEXCEPT | ||||||
|         {return static_cast<__node_pointer>      (__end_node()->__left_);} |         {return static_cast<__node_pointer>      (__end_node()->__left_);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __node_const_pointer __root() const |     __node_const_pointer __root() const _NOEXCEPT | ||||||
|         {return static_cast<__node_const_pointer>(__end_node()->__left_);} |         {return static_cast<__node_const_pointer>(__end_node()->__left_);} | ||||||
|  |  | ||||||
|     typedef __tree_iterator<value_type, __node_pointer, difference_type>             iterator; |     typedef __tree_iterator<value_type, __node_pointer, difference_type>             iterator; | ||||||
|     typedef __tree_const_iterator<value_type, __node_const_pointer, difference_type> const_iterator; |     typedef __tree_const_iterator<value_type, __node_const_pointer, difference_type> const_iterator; | ||||||
|  |  | ||||||
|     explicit __tree(const value_compare& __comp); |     explicit __tree(const value_compare& __comp) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             is_nothrow_default_constructible<__node_allocator>::value && | ||||||
|  |             is_nothrow_copy_constructible<value_compare>::value); | ||||||
|     explicit __tree(const allocator_type& __a); |     explicit __tree(const allocator_type& __a); | ||||||
|     __tree(const value_compare& __comp, const allocator_type& __a); |     __tree(const value_compare& __comp, const allocator_type& __a); | ||||||
|     __tree(const __tree& __t); |     __tree(const __tree& __t); | ||||||
| @@ -863,28 +878,40 @@ public: | |||||||
|     template <class _InputIterator> |     template <class _InputIterator> | ||||||
|         void __assign_multi(_InputIterator __first, _InputIterator __last); |         void __assign_multi(_InputIterator __first, _InputIterator __last); | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     __tree(__tree&& __t); |     __tree(__tree&& __t) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             is_nothrow_move_constructible<__node_allocator>::value && | ||||||
|  |             is_nothrow_move_constructible<value_compare>::value); | ||||||
|     __tree(__tree&& __t, const allocator_type& __a); |     __tree(__tree&& __t, const allocator_type& __a); | ||||||
|     __tree& operator=(__tree&& __t); |     __tree& operator=(__tree&& __t) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             __node_traits::propagate_on_container_move_assignment::value && | ||||||
|  |             is_nothrow_move_assignable<value_compare>::value && | ||||||
|  |             is_nothrow_move_assignable<__node_allocator>::value); | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|     ~__tree(); |     ~__tree(); | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           iterator begin()       {return       iterator(__begin_node());} |           iterator begin()  _NOEXCEPT {return       iterator(__begin_node());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator begin() const {return const_iterator(__begin_node());} |     const_iterator begin() const _NOEXCEPT {return const_iterator(__begin_node());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           iterator end()         {return       iterator(__end_node());} |           iterator end() _NOEXCEPT {return       iterator(__end_node());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator end()   const {return const_iterator(__end_node());} |     const_iterator end() const _NOEXCEPT {return const_iterator(__end_node());} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type max_size() const {return __node_traits::max_size(__node_alloc());} |     size_type max_size() const _NOEXCEPT | ||||||
|  |         {return __node_traits::max_size(__node_alloc());} | ||||||
|  |  | ||||||
|     void clear(); |     void clear() _NOEXCEPT; | ||||||
|  |  | ||||||
|     void swap(__tree& __t); |     void swap(__tree& __t) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             __is_nothrow_swappable<value_compare>::value && | ||||||
|  |             (!__node_traits::propagate_on_container_swap::value || | ||||||
|  |              __is_nothrow_swappable<__node_allocator>::value)); | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
| @@ -995,7 +1022,7 @@ public: | |||||||
|     typedef __tree_node_destructor<__node_allocator> _D; |     typedef __tree_node_destructor<__node_allocator> _D; | ||||||
|     typedef unique_ptr<__node, _D> __node_holder; |     typedef unique_ptr<__node, _D> __node_holder; | ||||||
|  |  | ||||||
|     __node_holder remove(const_iterator __p); |     __node_holder remove(const_iterator __p) _NOEXCEPT; | ||||||
| private: | private: | ||||||
|     typename __node_base::pointer& |     typename __node_base::pointer& | ||||||
|         __find_leaf_low(typename __node_base::pointer& __parent, const value_type& __v); |         __find_leaf_low(typename __node_base::pointer& __parent, const value_type& __v); | ||||||
| @@ -1019,7 +1046,7 @@ private: | |||||||
|         __node_holder __construct_node(const value_type& __v); |         __node_holder __construct_node(const value_type& __v); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|     void destroy(__node_pointer __nd); |     void destroy(__node_pointer __nd) _NOEXCEPT; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void __copy_assign_alloc(const __tree& __t) |     void __copy_assign_alloc(const __tree& __t) | ||||||
| @@ -1033,31 +1060,42 @@ private: | |||||||
|     void __copy_assign_alloc(const __tree& __t, false_type) {} |     void __copy_assign_alloc(const __tree& __t, false_type) {} | ||||||
|  |  | ||||||
|     void __move_assign(__tree& __t, false_type); |     void __move_assign(__tree& __t, false_type); | ||||||
|     void __move_assign(__tree& __t, true_type); |     void __move_assign(__tree& __t, true_type) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_assignable<value_compare>::value && | ||||||
|  |                    is_nothrow_move_assignable<__node_allocator>::value); | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void __move_assign_alloc(__tree& __t) |     void __move_assign_alloc(__tree& __t) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             !__node_traits::propagate_on_container_move_assignment::value || | ||||||
|  |             is_nothrow_move_assignable<__node_allocator>::value) | ||||||
|         {__move_assign_alloc(__t, integral_constant<bool, |         {__move_assign_alloc(__t, integral_constant<bool, | ||||||
|              __node_traits::propagate_on_container_move_assignment::value>());} |              __node_traits::propagate_on_container_move_assignment::value>());} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void __move_assign_alloc(__tree& __t, true_type) |     void __move_assign_alloc(__tree& __t, true_type) | ||||||
|         {__node_alloc() = _STD::move(__t.__node_alloc());} |         _NOEXCEPT_(is_nothrow_move_assignable<__node_allocator>::value) | ||||||
|  |         {__node_alloc() = _VSTD::move(__t.__node_alloc());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void __move_assign_alloc(__tree& __t, false_type) {} |     void __move_assign_alloc(__tree& __t, false_type) _NOEXCEPT {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     static void __swap_alloc(__node_allocator& __x, __node_allocator& __y) |     static void __swap_alloc(__node_allocator& __x, __node_allocator& __y) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             !__node_traits::propagate_on_container_swap::value || | ||||||
|  |             __is_nothrow_swappable<__node_allocator>::value) | ||||||
|         {__swap_alloc(__x, __y, integral_constant<bool, |         {__swap_alloc(__x, __y, integral_constant<bool, | ||||||
|                       __node_traits::propagate_on_container_swap::value>());} |                       __node_traits::propagate_on_container_swap::value>());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     static void __swap_alloc(__node_allocator& __x, __node_allocator& __y, true_type) |     static void __swap_alloc(__node_allocator& __x, __node_allocator& __y, true_type) | ||||||
|  |         _NOEXCEPT_(__is_nothrow_swappable<__node_allocator>::value) | ||||||
|         { |         { | ||||||
|             using _STD::swap; |             using _VSTD::swap; | ||||||
|             swap(__x, __y); |             swap(__x, __y); | ||||||
|         } |         } | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     static void __swap_alloc(__node_allocator& __x, __node_allocator& __y, false_type) |     static void __swap_alloc(__node_allocator& __x, __node_allocator& __y, false_type) | ||||||
|  |         _NOEXCEPT | ||||||
|         {} |         {} | ||||||
|  |  | ||||||
|     __node_pointer __detach(); |     __node_pointer __detach(); | ||||||
| @@ -1066,6 +1104,9 @@ private: | |||||||
|  |  | ||||||
| template <class _Tp, class _Compare, class _Allocator> | template <class _Tp, class _Compare, class _Allocator> | ||||||
| __tree<_Tp, _Compare, _Allocator>::__tree(const value_compare& __comp) | __tree<_Tp, _Compare, _Allocator>::__tree(const value_compare& __comp) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             is_nothrow_default_constructible<__node_allocator>::value && | ||||||
|  |             is_nothrow_copy_constructible<value_compare>::value) | ||||||
|     : __pair3_(0, __comp) |     : __pair3_(0, __comp) | ||||||
| { | { | ||||||
|     __begin_node() = __end_node(); |     __begin_node() = __end_node(); | ||||||
| @@ -1240,9 +1281,12 @@ __tree<_Tp, _Compare, _Allocator>::__tree(const __tree& __t) | |||||||
|  |  | ||||||
| template <class _Tp, class _Compare, class _Allocator> | template <class _Tp, class _Compare, class _Allocator> | ||||||
| __tree<_Tp, _Compare, _Allocator>::__tree(__tree&& __t) | __tree<_Tp, _Compare, _Allocator>::__tree(__tree&& __t) | ||||||
|     : __begin_node_(_STD::move(__t.__begin_node_)), |     _NOEXCEPT_( | ||||||
|       __pair1_(_STD::move(__t.__pair1_)), |         is_nothrow_move_constructible<__node_allocator>::value && | ||||||
|       __pair3_(_STD::move(__t.__pair3_)) |         is_nothrow_move_constructible<value_compare>::value) | ||||||
|  |     : __begin_node_(_VSTD::move(__t.__begin_node_)), | ||||||
|  |       __pair1_(_VSTD::move(__t.__pair1_)), | ||||||
|  |       __pair3_(_VSTD::move(__t.__pair3_)) | ||||||
| { | { | ||||||
|     if (size() == 0) |     if (size() == 0) | ||||||
|         __begin_node() = __end_node(); |         __begin_node() = __end_node(); | ||||||
| @@ -1258,7 +1302,7 @@ __tree<_Tp, _Compare, _Allocator>::__tree(__tree&& __t) | |||||||
| template <class _Tp, class _Compare, class _Allocator> | template <class _Tp, class _Compare, class _Allocator> | ||||||
| __tree<_Tp, _Compare, _Allocator>::__tree(__tree&& __t, const allocator_type& __a) | __tree<_Tp, _Compare, _Allocator>::__tree(__tree&& __t, const allocator_type& __a) | ||||||
|     : __pair1_(__node_allocator(__a)), |     : __pair1_(__node_allocator(__a)), | ||||||
|       __pair3_(0, _STD::move(__t.value_comp())) |       __pair3_(0, _VSTD::move(__t.value_comp())) | ||||||
| { | { | ||||||
|     if (__a == __t.__alloc()) |     if (__a == __t.__alloc()) | ||||||
|     { |     { | ||||||
| @@ -1284,12 +1328,14 @@ __tree<_Tp, _Compare, _Allocator>::__tree(__tree&& __t, const allocator_type& __ | |||||||
| template <class _Tp, class _Compare, class _Allocator> | template <class _Tp, class _Compare, class _Allocator> | ||||||
| void | void | ||||||
| __tree<_Tp, _Compare, _Allocator>::__move_assign(__tree& __t, true_type) | __tree<_Tp, _Compare, _Allocator>::__move_assign(__tree& __t, true_type) | ||||||
|  |     _NOEXCEPT_(is_nothrow_move_assignable<value_compare>::value && | ||||||
|  |                is_nothrow_move_assignable<__node_allocator>::value) | ||||||
| { | { | ||||||
|     destroy(static_cast<__node_pointer>(__end_node()->__left_)); |     destroy(static_cast<__node_pointer>(__end_node()->__left_)); | ||||||
|     __begin_node_ = __t.__begin_node_; |     __begin_node_ = __t.__begin_node_; | ||||||
|     __pair1_.first() = __t.__pair1_.first(); |     __pair1_.first() = __t.__pair1_.first(); | ||||||
|     __move_assign_alloc(__t); |     __move_assign_alloc(__t); | ||||||
|     __pair3_ = _STD::move(__t.__pair3_); |     __pair3_ = _VSTD::move(__t.__pair3_); | ||||||
|     if (size() == 0) |     if (size() == 0) | ||||||
|         __begin_node() = __end_node(); |         __begin_node() = __end_node(); | ||||||
|     else |     else | ||||||
| @@ -1309,7 +1355,7 @@ __tree<_Tp, _Compare, _Allocator>::__move_assign(__tree& __t, false_type) | |||||||
|         __move_assign(__t, true_type()); |         __move_assign(__t, true_type()); | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
|         value_comp() = _STD::move(__t.value_comp()); |         value_comp() = _VSTD::move(__t.value_comp()); | ||||||
|         const_iterator __e = end(); |         const_iterator __e = end(); | ||||||
|         if (size() != 0) |         if (size() != 0) | ||||||
|         { |         { | ||||||
| @@ -1320,7 +1366,7 @@ __tree<_Tp, _Compare, _Allocator>::__move_assign(__tree& __t, false_type) | |||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|                 while (__cache != nullptr && __t.size() != 0) |                 while (__cache != nullptr && __t.size() != 0) | ||||||
|                 { |                 { | ||||||
|                     __cache->__value_ = _STD::move(__t.remove(__t.begin())->__value_); |                     __cache->__value_ = _VSTD::move(__t.remove(__t.begin())->__value_); | ||||||
|                     __node_pointer __next = __detach(__cache); |                     __node_pointer __next = __detach(__cache); | ||||||
|                     __node_insert_multi(__cache); |                     __node_insert_multi(__cache); | ||||||
|                     __cache = __next; |                     __cache = __next; | ||||||
| @@ -1343,13 +1389,18 @@ __tree<_Tp, _Compare, _Allocator>::__move_assign(__tree& __t, false_type) | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         while (__t.size() != 0) |         while (__t.size() != 0) | ||||||
|             __insert_multi(__e, _STD::move(__t.remove(__t.begin())->__value_)); |             __insert_multi(__e, _VSTD::move(__t.remove(__t.begin())->__value_)); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, class _Compare, class _Allocator> | template <class _Tp, class _Compare, class _Allocator> | ||||||
| __tree<_Tp, _Compare, _Allocator>& | __tree<_Tp, _Compare, _Allocator>& | ||||||
| __tree<_Tp, _Compare, _Allocator>::operator=(__tree&& __t) | __tree<_Tp, _Compare, _Allocator>::operator=(__tree&& __t) | ||||||
|  |     _NOEXCEPT_( | ||||||
|  |         __node_traits::propagate_on_container_move_assignment::value && | ||||||
|  |         is_nothrow_move_assignable<value_compare>::value && | ||||||
|  |         is_nothrow_move_assignable<__node_allocator>::value) | ||||||
|  |          | ||||||
| { | { | ||||||
|     __move_assign(__t, integral_constant<bool, |     __move_assign(__t, integral_constant<bool, | ||||||
|                   __node_traits::propagate_on_container_move_assignment::value>()); |                   __node_traits::propagate_on_container_move_assignment::value>()); | ||||||
| @@ -1366,14 +1417,14 @@ __tree<_Tp, _Compare, _Allocator>::~__tree() | |||||||
|  |  | ||||||
| template <class _Tp, class _Compare, class _Allocator> | template <class _Tp, class _Compare, class _Allocator> | ||||||
| void | void | ||||||
| __tree<_Tp, _Compare, _Allocator>::destroy(__node_pointer __nd) | __tree<_Tp, _Compare, _Allocator>::destroy(__node_pointer __nd) _NOEXCEPT | ||||||
| { | { | ||||||
|     if (__nd != nullptr) |     if (__nd != nullptr) | ||||||
|     { |     { | ||||||
|         destroy(static_cast<__node_pointer>(__nd->__left_)); |         destroy(static_cast<__node_pointer>(__nd->__left_)); | ||||||
|         destroy(static_cast<__node_pointer>(__nd->__right_)); |         destroy(static_cast<__node_pointer>(__nd->__right_)); | ||||||
|         __node_allocator& __na = __node_alloc(); |         __node_allocator& __na = __node_alloc(); | ||||||
|         __node_traits::destroy(__na, _STD::addressof(__nd->__value_)); |         __node_traits::destroy(__na, _VSTD::addressof(__nd->__value_)); | ||||||
|         __node_traits::deallocate(__na, __nd, 1); |         __node_traits::deallocate(__na, __nd, 1); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -1381,8 +1432,12 @@ __tree<_Tp, _Compare, _Allocator>::destroy(__node_pointer __nd) | |||||||
| template <class _Tp, class _Compare, class _Allocator> | template <class _Tp, class _Compare, class _Allocator> | ||||||
| void | void | ||||||
| __tree<_Tp, _Compare, _Allocator>::swap(__tree& __t) | __tree<_Tp, _Compare, _Allocator>::swap(__tree& __t) | ||||||
|  |     _NOEXCEPT_( | ||||||
|  |         __is_nothrow_swappable<value_compare>::value && | ||||||
|  |         (!__node_traits::propagate_on_container_swap::value || | ||||||
|  |          __is_nothrow_swappable<__node_allocator>::value)) | ||||||
| { | { | ||||||
|     using _STD::swap; |     using _VSTD::swap; | ||||||
|     swap(__begin_node_, __t.__begin_node_); |     swap(__begin_node_, __t.__begin_node_); | ||||||
|     swap(__pair1_.first(), __t.__pair1_.first()); |     swap(__pair1_.first(), __t.__pair1_.first()); | ||||||
|     __swap_alloc(__node_alloc(), __t.__node_alloc()); |     __swap_alloc(__node_alloc(), __t.__node_alloc()); | ||||||
| @@ -1399,7 +1454,7 @@ __tree<_Tp, _Compare, _Allocator>::swap(__tree& __t) | |||||||
|  |  | ||||||
| template <class _Tp, class _Compare, class _Allocator> | template <class _Tp, class _Compare, class _Allocator> | ||||||
| void | void | ||||||
| __tree<_Tp, _Compare, _Allocator>::clear() | __tree<_Tp, _Compare, _Allocator>::clear() _NOEXCEPT | ||||||
| { | { | ||||||
|     destroy(__root()); |     destroy(__root()); | ||||||
|     size() = 0; |     size() = 0; | ||||||
| @@ -1606,10 +1661,10 @@ __tree<_Tp, _Compare, _Allocator>::__find_equal(const_iterator __hint, | |||||||
|     else if (value_comp()(*__hint, __v))  // check after |     else if (value_comp()(*__hint, __v))  // check after | ||||||
|     { |     { | ||||||
|         // *__hint < __v |         // *__hint < __v | ||||||
|         const_iterator __next = _STD::next(__hint); |         const_iterator __next = _VSTD::next(__hint); | ||||||
|         if (__next == end() || value_comp()(__v, *__next)) |         if (__next == end() || value_comp()(__v, *__next)) | ||||||
|         { |         { | ||||||
|             // *__hint < __v < *_STD::next(__hint) |             // *__hint < __v < *_VSTD::next(__hint) | ||||||
|             if (__hint.__ptr_->__right_ == nullptr) |             if (__hint.__ptr_->__right_ == nullptr) | ||||||
|             { |             { | ||||||
|                 __parent = const_cast<__node_pointer&>(__hint.__ptr_); |                 __parent = const_cast<__node_pointer&>(__hint.__ptr_); | ||||||
| @@ -1655,7 +1710,7 @@ __tree<_Tp, _Compare, _Allocator>::__construct_node(_Args&& ...__args) | |||||||
| { | { | ||||||
|     __node_allocator& __na = __node_alloc(); |     __node_allocator& __na = __node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_), _STD::forward<_Args>(__args)...); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_), _VSTD::forward<_Args>(__args)...); | ||||||
|     __h.get_deleter().__value_constructed = true; |     __h.get_deleter().__value_constructed = true; | ||||||
|     return __h; |     return __h; | ||||||
| } | } | ||||||
| @@ -1665,7 +1720,7 @@ template <class... _Args> | |||||||
| pair<typename __tree<_Tp, _Compare, _Allocator>::iterator, bool> | pair<typename __tree<_Tp, _Compare, _Allocator>::iterator, bool> | ||||||
| __tree<_Tp, _Compare, _Allocator>::__emplace_unique(_Args&&... __args) | __tree<_Tp, _Compare, _Allocator>::__emplace_unique(_Args&&... __args) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_Args>(__args)...); |     __node_holder __h = __construct_node(_VSTD::forward<_Args>(__args)...); | ||||||
|     __node_base_pointer __parent; |     __node_base_pointer __parent; | ||||||
|     __node_base_pointer& __child = __find_equal(__parent, __h->__value_); |     __node_base_pointer& __child = __find_equal(__parent, __h->__value_); | ||||||
|     __node_pointer __r = static_cast<__node_pointer>(__child); |     __node_pointer __r = static_cast<__node_pointer>(__child); | ||||||
| @@ -1684,7 +1739,7 @@ template <class... _Args> | |||||||
| typename __tree<_Tp, _Compare, _Allocator>::iterator | typename __tree<_Tp, _Compare, _Allocator>::iterator | ||||||
| __tree<_Tp, _Compare, _Allocator>::__emplace_hint_unique(const_iterator __p, _Args&&... __args) | __tree<_Tp, _Compare, _Allocator>::__emplace_hint_unique(const_iterator __p, _Args&&... __args) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_Args>(__args)...); |     __node_holder __h = __construct_node(_VSTD::forward<_Args>(__args)...); | ||||||
|     __node_base_pointer __parent; |     __node_base_pointer __parent; | ||||||
|     __node_base_pointer& __child = __find_equal(__p, __parent, __h->__value_); |     __node_base_pointer& __child = __find_equal(__p, __parent, __h->__value_); | ||||||
|     __node_pointer __r = static_cast<__node_pointer>(__child); |     __node_pointer __r = static_cast<__node_pointer>(__child); | ||||||
| @@ -1701,7 +1756,7 @@ template <class... _Args> | |||||||
| typename __tree<_Tp, _Compare, _Allocator>::iterator | typename __tree<_Tp, _Compare, _Allocator>::iterator | ||||||
| __tree<_Tp, _Compare, _Allocator>::__emplace_multi(_Args&&... __args) | __tree<_Tp, _Compare, _Allocator>::__emplace_multi(_Args&&... __args) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_Args>(__args)...); |     __node_holder __h = __construct_node(_VSTD::forward<_Args>(__args)...); | ||||||
|     __node_base_pointer __parent; |     __node_base_pointer __parent; | ||||||
|     __node_base_pointer& __child = __find_leaf_high(__parent, __h->__value_); |     __node_base_pointer& __child = __find_leaf_high(__parent, __h->__value_); | ||||||
|     __insert_node_at(__parent, __child, __h.get()); |     __insert_node_at(__parent, __child, __h.get()); | ||||||
| @@ -1714,7 +1769,7 @@ typename __tree<_Tp, _Compare, _Allocator>::iterator | |||||||
| __tree<_Tp, _Compare, _Allocator>::__emplace_hint_multi(const_iterator __p, | __tree<_Tp, _Compare, _Allocator>::__emplace_hint_multi(const_iterator __p, | ||||||
|                                                         _Args&&... __args) |                                                         _Args&&... __args) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_Args>(__args)...); |     __node_holder __h = __construct_node(_VSTD::forward<_Args>(__args)...); | ||||||
|     __node_base_pointer __parent; |     __node_base_pointer __parent; | ||||||
|     __node_base_pointer& __child = __find_leaf(__p, __parent, __h->__value_); |     __node_base_pointer& __child = __find_leaf(__p, __parent, __h->__value_); | ||||||
|     __insert_node_at(__parent, __child, __h.get()); |     __insert_node_at(__parent, __child, __h.get()); | ||||||
| @@ -1728,7 +1783,7 @@ template <class _V> | |||||||
| pair<typename __tree<_Tp, _Compare, _Allocator>::iterator, bool> | pair<typename __tree<_Tp, _Compare, _Allocator>::iterator, bool> | ||||||
| __tree<_Tp, _Compare, _Allocator>::__insert_unique(_V&& __v) | __tree<_Tp, _Compare, _Allocator>::__insert_unique(_V&& __v) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_V>(__v)); |     __node_holder __h = __construct_node(_VSTD::forward<_V>(__v)); | ||||||
|     pair<iterator, bool> __r = __node_insert_unique(__h.get()); |     pair<iterator, bool> __r = __node_insert_unique(__h.get()); | ||||||
|     if (__r.second) |     if (__r.second) | ||||||
|         __h.release(); |         __h.release(); | ||||||
| @@ -1740,7 +1795,7 @@ template <class _V> | |||||||
| typename __tree<_Tp, _Compare, _Allocator>::iterator | typename __tree<_Tp, _Compare, _Allocator>::iterator | ||||||
| __tree<_Tp, _Compare, _Allocator>::__insert_unique(const_iterator __p, _V&& __v) | __tree<_Tp, _Compare, _Allocator>::__insert_unique(const_iterator __p, _V&& __v) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_V>(__v)); |     __node_holder __h = __construct_node(_VSTD::forward<_V>(__v)); | ||||||
|     iterator __r = __node_insert_unique(__p, __h.get()); |     iterator __r = __node_insert_unique(__p, __h.get()); | ||||||
|     if (__r.__ptr_ == __h.get()) |     if (__r.__ptr_ == __h.get()) | ||||||
|         __h.release(); |         __h.release(); | ||||||
| @@ -1752,7 +1807,7 @@ template <class _V> | |||||||
| typename __tree<_Tp, _Compare, _Allocator>::iterator | typename __tree<_Tp, _Compare, _Allocator>::iterator | ||||||
| __tree<_Tp, _Compare, _Allocator>::__insert_multi(_V&& __v) | __tree<_Tp, _Compare, _Allocator>::__insert_multi(_V&& __v) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_V>(__v)); |     __node_holder __h = __construct_node(_VSTD::forward<_V>(__v)); | ||||||
|     __node_base_pointer __parent; |     __node_base_pointer __parent; | ||||||
|     __node_base_pointer& __child = __find_leaf_high(__parent, __h->__value_); |     __node_base_pointer& __child = __find_leaf_high(__parent, __h->__value_); | ||||||
|     __insert_node_at(__parent, __child, __h.get()); |     __insert_node_at(__parent, __child, __h.get()); | ||||||
| @@ -1764,7 +1819,7 @@ template <class _V> | |||||||
| typename __tree<_Tp, _Compare, _Allocator>::iterator | typename __tree<_Tp, _Compare, _Allocator>::iterator | ||||||
| __tree<_Tp, _Compare, _Allocator>::__insert_multi(const_iterator __p, _V&& __v) | __tree<_Tp, _Compare, _Allocator>::__insert_multi(const_iterator __p, _V&& __v) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_V>(__v)); |     __node_holder __h = __construct_node(_VSTD::forward<_V>(__v)); | ||||||
|     __node_base_pointer __parent; |     __node_base_pointer __parent; | ||||||
|     __node_base_pointer& __child = __find_leaf(__p, __parent, __h->__value_); |     __node_base_pointer& __child = __find_leaf(__p, __parent, __h->__value_); | ||||||
|     __insert_node_at(__parent, __child, __h.get()); |     __insert_node_at(__parent, __child, __h.get()); | ||||||
| @@ -1779,9 +1834,9 @@ __tree<_Tp, _Compare, _Allocator>::__construct_node(const value_type& __v) | |||||||
| { | { | ||||||
|     __node_allocator& __na = __node_alloc(); |     __node_allocator& __na = __node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_), __v); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_), __v); | ||||||
|     __h.get_deleter().__value_constructed = true; |     __h.get_deleter().__value_constructed = true; | ||||||
|     return _STD::move(__h); |     return _VSTD::move(__h); | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -1907,7 +1962,7 @@ __tree<_Tp, _Compare, _Allocator>::erase(const_iterator __p) | |||||||
|         __begin_node() = __r.__ptr_; |         __begin_node() = __r.__ptr_; | ||||||
|     --size(); |     --size(); | ||||||
|     __node_allocator& __na = __node_alloc(); |     __node_allocator& __na = __node_alloc(); | ||||||
|     __node_traits::destroy(__na, const_cast<value_type*>(_STD::addressof(*__p))); |     __node_traits::destroy(__na, const_cast<value_type*>(_VSTD::addressof(*__p))); | ||||||
|     __tree_remove(__end_node()->__left_, |     __tree_remove(__end_node()->__left_, | ||||||
|                   static_cast<__node_base_pointer>(__np)); |                   static_cast<__node_base_pointer>(__np)); | ||||||
|     __node_traits::deallocate(__na, __np, 1); |     __node_traits::deallocate(__na, __np, 1); | ||||||
| @@ -2009,7 +2064,7 @@ __tree<_Tp, _Compare, _Allocator>::__count_multi(const _Key& __k) const | |||||||
|         else if (value_comp()(__rt->__value_, __k)) |         else if (value_comp()(__rt->__value_, __k)) | ||||||
|             __rt = static_cast<__node_const_pointer>(__rt->__right_); |             __rt = static_cast<__node_const_pointer>(__rt->__right_); | ||||||
|         else |         else | ||||||
|             return _STD::distance( |             return _VSTD::distance( | ||||||
|                 __lower_bound(__k, static_cast<__node_const_pointer>(__rt->__left_), __rt), |                 __lower_bound(__k, static_cast<__node_const_pointer>(__rt->__left_), __rt), | ||||||
|                 __upper_bound(__k, static_cast<__node_const_pointer>(__rt->__right_), __result) |                 __upper_bound(__k, static_cast<__node_const_pointer>(__rt->__right_), __result) | ||||||
|             ); |             ); | ||||||
| @@ -2205,7 +2260,7 @@ __tree<_Tp, _Compare, _Allocator>::__equal_range_multi(const _Key& __k) const | |||||||
|  |  | ||||||
| template <class _Tp, class _Compare, class _Allocator> | template <class _Tp, class _Compare, class _Allocator> | ||||||
| typename __tree<_Tp, _Compare, _Allocator>::__node_holder | typename __tree<_Tp, _Compare, _Allocator>::__node_holder | ||||||
| __tree<_Tp, _Compare, _Allocator>::remove(const_iterator __p) | __tree<_Tp, _Compare, _Allocator>::remove(const_iterator __p) _NOEXCEPT | ||||||
| { | { | ||||||
|     __node_pointer __np = const_cast<__node_pointer>(__p.__ptr_); |     __node_pointer __np = const_cast<__node_pointer>(__p.__ptr_); | ||||||
|     if (__begin_node() == __np) |     if (__begin_node() == __np) | ||||||
| @@ -2221,6 +2276,16 @@ __tree<_Tp, _Compare, _Allocator>::remove(const_iterator __p) | |||||||
|     return __node_holder(__np, _D(__node_alloc())); |     return __node_holder(__np, _D(__node_alloc())); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | template <class _Tp, class _Compare, class _Allocator> | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | void | ||||||
|  | swap(__tree<_Tp, _Compare, _Allocator>& __x, | ||||||
|  |      __tree<_Tp, _Compare, _Allocator>& __y) | ||||||
|  |     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||||
|  | { | ||||||
|  |     __x.swap(__y); | ||||||
|  | } | ||||||
|  |  | ||||||
| _LIBCPP_END_NAMESPACE_STD | _LIBCPP_END_NAMESPACE_STD | ||||||
|  |  | ||||||
| #endif  // _LIBCPP___TREE | #endif  // _LIBCPP___TREE | ||||||
|   | |||||||
| @@ -78,39 +78,39 @@ template <class _Tp, size_t _Size> struct __tuple_like<array<_Tp, _Size> > : tru | |||||||
|  |  | ||||||
| template <size_t _Ip, class ..._Tp> | template <size_t _Ip, class ..._Tp> | ||||||
| typename tuple_element<_Ip, tuple<_Tp...> >::type& | typename tuple_element<_Ip, tuple<_Tp...> >::type& | ||||||
| get(tuple<_Tp...>&); | get(tuple<_Tp...>&) _NOEXCEPT; | ||||||
|  |  | ||||||
| template <size_t _Ip, class ..._Tp> | template <size_t _Ip, class ..._Tp> | ||||||
| const typename tuple_element<_Ip, tuple<_Tp...> >::type& | const typename tuple_element<_Ip, tuple<_Tp...> >::type& | ||||||
| get(const tuple<_Tp...>&); | get(const tuple<_Tp...>&) _NOEXCEPT; | ||||||
|  |  | ||||||
| template <size_t _Ip, class ..._Tp> | template <size_t _Ip, class ..._Tp> | ||||||
| typename tuple_element<_Ip, tuple<_Tp...> >::type&& | typename tuple_element<_Ip, tuple<_Tp...> >::type&& | ||||||
| get(tuple<_Tp...>&&); | get(tuple<_Tp...>&&) _NOEXCEPT; | ||||||
|  |  | ||||||
| template <size_t _Ip, class _T1, class _T2> | template <size_t _Ip, class _T1, class _T2> | ||||||
| typename tuple_element<_Ip, pair<_T1, _T2> >::type& | typename tuple_element<_Ip, pair<_T1, _T2> >::type& | ||||||
| get(pair<_T1, _T2>&); | get(pair<_T1, _T2>&) _NOEXCEPT; | ||||||
|  |  | ||||||
| template <size_t _Ip, class _T1, class _T2> | template <size_t _Ip, class _T1, class _T2> | ||||||
| const typename tuple_element<_Ip, pair<_T1, _T2> >::type& | const typename tuple_element<_Ip, pair<_T1, _T2> >::type& | ||||||
| get(const pair<_T1, _T2>&); | get(const pair<_T1, _T2>&) _NOEXCEPT; | ||||||
|  |  | ||||||
| template <size_t _Ip, class _T1, class _T2> | template <size_t _Ip, class _T1, class _T2> | ||||||
| typename tuple_element<_Ip, pair<_T1, _T2> >::type&& | typename tuple_element<_Ip, pair<_T1, _T2> >::type&& | ||||||
| get(pair<_T1, _T2>&&); | get(pair<_T1, _T2>&&) _NOEXCEPT; | ||||||
|  |  | ||||||
| template <size_t _Ip, class _Tp, size_t _Size> | template <size_t _Ip, class _Tp, size_t _Size> | ||||||
| _Tp& | _Tp& | ||||||
| get(array<_Tp, _Size>&); | get(array<_Tp, _Size>&) _NOEXCEPT; | ||||||
|  |  | ||||||
| template <size_t _Ip, class _Tp, size_t _Size> | template <size_t _Ip, class _Tp, size_t _Size> | ||||||
| const _Tp& | const _Tp& | ||||||
| get(const array<_Tp, _Size>&); | get(const array<_Tp, _Size>&) _NOEXCEPT; | ||||||
|  |  | ||||||
| template <size_t _Ip, class _Tp, size_t _Size> | template <size_t _Ip, class _Tp, size_t _Size> | ||||||
| _Tp&& | _Tp&& | ||||||
| get(array<_Tp, _Size>&&); | get(array<_Tp, _Size>&&) _NOEXCEPT; | ||||||
|  |  | ||||||
| // __make_tuple_indices | // __make_tuple_indices | ||||||
|  |  | ||||||
| @@ -214,11 +214,7 @@ struct __tuple_convertible_imp : public false_type {}; | |||||||
| template <class _Tp0, class ..._Tp, class _Up0, class ..._Up> | template <class _Tp0, class ..._Tp, class _Up0, class ..._Up> | ||||||
| struct __tuple_convertible_imp<true, __tuple_types<_Tp0, _Tp...>, __tuple_types<_Up0, _Up...> > | struct __tuple_convertible_imp<true, __tuple_types<_Tp0, _Tp...>, __tuple_types<_Up0, _Up...> > | ||||||
|     : public integral_constant<bool, |     : public integral_constant<bool, | ||||||
| #if 1 // waiting on cwg 1170 |  | ||||||
|                                is_convertible<_Tp0, _Up0>::value && |  | ||||||
| #else |  | ||||||
|                                is_constructible<_Up0, _Tp0>::value && |                                is_constructible<_Up0, _Tp0>::value && | ||||||
| #endif |  | ||||||
|                                __tuple_convertible_imp<true, __tuple_types<_Tp...>, __tuple_types<_Up...> >::value> {}; |                                __tuple_convertible_imp<true, __tuple_types<_Tp...>, __tuple_types<_Up...> >::value> {}; | ||||||
|  |  | ||||||
| template <> | template <> | ||||||
|   | |||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										119
									
								
								include/array
									
									
									
									
									
								
							
							
						
						
									
										119
									
								
								include/array
									
									
									
									
									
								
							| @@ -34,28 +34,28 @@ struct array | |||||||
|  |  | ||||||
|     // No explicit construct/copy/destroy for aggregate type |     // No explicit construct/copy/destroy for aggregate type | ||||||
|     void fill(const T& u); |     void fill(const T& u); | ||||||
|     void swap(array& a); |     void swap(array& a) noexcept(noexcept(swap(declval<T&>(), declval<T&>()))); | ||||||
|  |  | ||||||
|     // iterators: |     // iterators: | ||||||
|     iterator begin(); |     iterator begin() noexcept; | ||||||
|     const_iterator begin() const; |     const_iterator begin() const noexcept; | ||||||
|     iterator end(); |     iterator end() noexcept; | ||||||
|     const_iterator end() const; |     const_iterator end() const noexcept; | ||||||
|  |  | ||||||
|     reverse_iterator rbegin(); |     reverse_iterator rbegin() noexcept; | ||||||
|     const_reverse_iterator rbegin() const; |     const_reverse_iterator rbegin() const noexcept; | ||||||
|     reverse_iterator rend(); |     reverse_iterator rend() noexcept; | ||||||
|     const_reverse_iterator rend() const; |     const_reverse_iterator rend() const noexcept; | ||||||
|  |  | ||||||
|     const_iterator cbegin() const; |     const_iterator cbegin() const noexcept; | ||||||
|     const_iterator cend() const; |     const_iterator cend() const noexcept; | ||||||
|     const_reverse_iterator crbegin() const; |     const_reverse_iterator crbegin() const noexcept; | ||||||
|     const_reverse_iterator crend() const; |     const_reverse_iterator crend() const noexcept; | ||||||
|  |  | ||||||
|     // capacity: |     // capacity: | ||||||
|     constexpr size_type size() const; |     constexpr size_type size() const noexcept; | ||||||
|     constexpr size_type max_size() const; |     constexpr size_type max_size() const noexcept; | ||||||
|     bool empty() const; |     bool empty() const noexcept; | ||||||
|  |  | ||||||
|     // element access: |     // element access: | ||||||
|     reference operator[](size_type n); |     reference operator[](size_type n); | ||||||
| @@ -68,8 +68,8 @@ struct array | |||||||
|     reference back(); |     reference back(); | ||||||
|     const_reference back() const; |     const_reference back() const; | ||||||
|  |  | ||||||
|     T* data(); |     T* data() noexcept; | ||||||
|     const T* data() const; |     const T* data() const noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class T, size_t N> | template <class T, size_t N> | ||||||
| @@ -86,15 +86,15 @@ template <class T, size_t N> | |||||||
|   bool operator>=(const array<T,N>& x, const array<T,N>& y); |   bool operator>=(const array<T,N>& x, const array<T,N>& y); | ||||||
|  |  | ||||||
| template <class T, size_t N > | template <class T, size_t N > | ||||||
|   void swap(array<T,N>& x, array<T,N>& y); |   void swap(array<T,N>& x, array<T,N>& y) noexcept(noexcept(x.swap(y))); | ||||||
|  |  | ||||||
| template <class T> class tuple_size; | template <class T> class tuple_size; | ||||||
| template <int I, class T> class tuple_element; | template <int I, class T> class tuple_element; | ||||||
| template <class T, size_t N> struct tuple_size<array<T, N>>; | template <class T, size_t N> struct tuple_size<array<T, N>>; | ||||||
| template <int I, class T, size_t N> struct tuple_element<I, array<T, N>>; | template <int I, class T, size_t N> struct tuple_element<I, array<T, N>>; | ||||||
| template <int I, class T, size_t N> T& get(array<T, N>&); | template <int I, class T, size_t N> T& get(array<T, N>&) noexcept; | ||||||
| template <int I, class T, size_t N> const T& get(const array<T, N>&); | template <int I, class T, size_t N> const T& get(const array<T, N>&) noexcept; | ||||||
| template <int I, class T, size_t N> T&& get(array<T, N>&&); | template <int I, class T, size_t N> T&& get(array<T, N>&&) noexcept; | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
|  |  | ||||||
| @@ -136,30 +136,46 @@ struct _LIBCPP_VISIBLE array | |||||||
|  |  | ||||||
|     // No explicit construct/copy/destroy for aggregate type |     // No explicit construct/copy/destroy for aggregate type | ||||||
|     _LIBCPP_INLINE_VISIBILITY void fill(const value_type& __u) |     _LIBCPP_INLINE_VISIBILITY void fill(const value_type& __u) | ||||||
|         {_STD::fill_n(__elems_, _Size, __u);} |         {_VSTD::fill_n(__elems_, _Size, __u);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY void swap(array& __a) |     _LIBCPP_INLINE_VISIBILITY | ||||||
|         {_STD::swap_ranges(__elems_, __elems_ + _Size, __a.__elems_);} |     void swap(array& __a) _NOEXCEPT_(__is_nothrow_swappable<_Tp>::value) | ||||||
|  |         {_VSTD::swap_ranges(__elems_, __elems_ + _Size, __a.__elems_);} | ||||||
|  |  | ||||||
|     // iterators: |     // iterators: | ||||||
|     _LIBCPP_INLINE_VISIBILITY iterator begin()             {return iterator(__elems_);} |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator begin() const {return const_iterator(__elems_);} |     iterator begin() _NOEXCEPT {return iterator(__elems_);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY iterator end()               {return iterator(__elems_ + _Size);} |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator end() const   {return const_iterator(__elems_ + _Size);} |     const_iterator begin() const _NOEXCEPT {return const_iterator(__elems_);} | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     iterator end() _NOEXCEPT {return iterator(__elems_ + _Size);} | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     const_iterator end() const _NOEXCEPT {return const_iterator(__elems_ + _Size);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY reverse_iterator rbegin()             {return reverse_iterator(end());} |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     _LIBCPP_INLINE_VISIBILITY const_reverse_iterator rbegin() const {return const_reverse_iterator(end());} |     reverse_iterator rbegin() _NOEXCEPT {return reverse_iterator(end());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY reverse_iterator rend()               {return reverse_iterator(begin());} |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     _LIBCPP_INLINE_VISIBILITY const_reverse_iterator rend() const   {return const_reverse_iterator(begin());} |     const_reverse_iterator rbegin() const _NOEXCEPT {return const_reverse_iterator(end());} | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     reverse_iterator rend() _NOEXCEPT {return reverse_iterator(begin());} | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     const_reverse_iterator rend() const _NOEXCEPT {return const_reverse_iterator(begin());} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator cbegin() const          {return begin();} |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator cend() const            {return end();} |     const_iterator cbegin() const _NOEXCEPT {return begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY const_reverse_iterator crbegin() const {return rbegin();} |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     _LIBCPP_INLINE_VISIBILITY const_reverse_iterator crend() const   {return rend();} |     const_iterator cend() const _NOEXCEPT {return end();} | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     const_reverse_iterator crbegin() const _NOEXCEPT {return rbegin();} | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     const_reverse_iterator crend() const _NOEXCEPT {return rend();} | ||||||
|  |  | ||||||
|     // capacity: |     // capacity: | ||||||
|     _LIBCPP_INLINE_VISIBILITY /*constexpr*/ size_type size() const      {return _Size;} |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     _LIBCPP_INLINE_VISIBILITY /*constexpr*/ size_type max_size() const  {return _Size;} |     /*constexpr*/ size_type size() const _NOEXCEPT {return _Size;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY bool empty() const                    {return _Size == 0;} |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     /*constexpr*/ size_type max_size() const _NOEXCEPT {return _Size;} | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     bool empty() const _NOEXCEPT {return _Size == 0;} | ||||||
|  |  | ||||||
|     // element access: |     // element access: | ||||||
|     _LIBCPP_INLINE_VISIBILITY reference operator[](size_type __n)             {return __elems_[__n];} |     _LIBCPP_INLINE_VISIBILITY reference operator[](size_type __n)             {return __elems_[__n];} | ||||||
| @@ -172,8 +188,10 @@ struct _LIBCPP_VISIBLE array | |||||||
|     _LIBCPP_INLINE_VISIBILITY reference back()              {return __elems_[_Size > 0 ? _Size-1 : 0];} |     _LIBCPP_INLINE_VISIBILITY reference back()              {return __elems_[_Size > 0 ? _Size-1 : 0];} | ||||||
|     _LIBCPP_INLINE_VISIBILITY const_reference back() const  {return __elems_[_Size > 0 ? _Size-1 : 0];} |     _LIBCPP_INLINE_VISIBILITY const_reference back() const  {return __elems_[_Size > 0 ? _Size-1 : 0];} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY value_type* data()             {return __elems_;} |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     _LIBCPP_INLINE_VISIBILITY const value_type* data() const {return __elems_;} |     value_type* data() _NOEXCEPT {return __elems_;} | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     const value_type* data() const _NOEXCEPT {return __elems_;} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _Tp, size_t _Size> | template <class _Tp, size_t _Size> | ||||||
| @@ -207,7 +225,7 @@ _LIBCPP_INLINE_VISIBILITY inline | |||||||
| bool | bool | ||||||
| operator==(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) | operator==(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) | ||||||
| { | { | ||||||
|     return _STD::equal(__x.__elems_, __x.__elems_ + _Size, __y.__elems_); |     return _VSTD::equal(__x.__elems_, __x.__elems_ + _Size, __y.__elems_); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, size_t _Size> | template <class _Tp, size_t _Size> | ||||||
| @@ -223,7 +241,7 @@ _LIBCPP_INLINE_VISIBILITY inline | |||||||
| bool | bool | ||||||
| operator<(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) | operator<(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) | ||||||
| { | { | ||||||
|     return _STD::lexicographical_compare(__x.__elems_, __x.__elems_ + _Size, __y.__elems_, __y.__elems_ + _Size); |     return _VSTD::lexicographical_compare(__x.__elems_, __x.__elems_ + _Size, __y.__elems_, __y.__elems_ + _Size); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, size_t _Size> | template <class _Tp, size_t _Size> | ||||||
| @@ -252,8 +270,13 @@ operator>=(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) | |||||||
|  |  | ||||||
| template <class _Tp, size_t _Size> | template <class _Tp, size_t _Size> | ||||||
| _LIBCPP_INLINE_VISIBILITY inline | _LIBCPP_INLINE_VISIBILITY inline | ||||||
|  | typename enable_if | ||||||
|  | < | ||||||
|  |     __is_swappable<_Tp>::value, | ||||||
|     void |     void | ||||||
|  | >::type | ||||||
| swap(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) | swap(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) | ||||||
|  |                                   _NOEXCEPT_(__is_nothrow_swappable<_Tp>::value) | ||||||
| { | { | ||||||
|     __x.swap(__y); |     __x.swap(__y); | ||||||
| } | } | ||||||
| @@ -283,7 +306,7 @@ public: | |||||||
| template <size_t _Ip, class _Tp, size_t _Size> | template <size_t _Ip, class _Tp, size_t _Size> | ||||||
| _LIBCPP_INLINE_VISIBILITY inline | _LIBCPP_INLINE_VISIBILITY inline | ||||||
| _Tp& | _Tp& | ||||||
| get(array<_Tp, _Size>& __a) | get(array<_Tp, _Size>& __a) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __a[_Ip]; |     return __a[_Ip]; | ||||||
| } | } | ||||||
| @@ -291,7 +314,7 @@ get(array<_Tp, _Size>& __a) | |||||||
| template <size_t _Ip, class _Tp, size_t _Size> | template <size_t _Ip, class _Tp, size_t _Size> | ||||||
| _LIBCPP_INLINE_VISIBILITY inline | _LIBCPP_INLINE_VISIBILITY inline | ||||||
| const _Tp& | const _Tp& | ||||||
| get(const array<_Tp, _Size>& __a) | get(const array<_Tp, _Size>& __a) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __a[_Ip]; |     return __a[_Ip]; | ||||||
| } | } | ||||||
| @@ -301,9 +324,9 @@ get(const array<_Tp, _Size>& __a) | |||||||
| template <size_t _Ip, class _Tp, size_t _Size> | template <size_t _Ip, class _Tp, size_t _Size> | ||||||
| _LIBCPP_INLINE_VISIBILITY inline | _LIBCPP_INLINE_VISIBILITY inline | ||||||
| _Tp&& | _Tp&& | ||||||
| get(array<_Tp, _Size>&& __a) | get(array<_Tp, _Size>&& __a) _NOEXCEPT | ||||||
| { | { | ||||||
|     return _STD::move(__a[_Ip]); |     return _VSTD::move(__a[_Ip]); | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|   | |||||||
							
								
								
									
										325
									
								
								include/bitset
									
									
									
									
									
								
							
							
						
						
									
										325
									
								
								include/bitset
									
									
									
									
									
								
							| @@ -27,19 +27,19 @@ public: | |||||||
|     class reference |     class reference | ||||||
|     { |     { | ||||||
|         friend class bitset; |         friend class bitset; | ||||||
|         reference(); |         reference() noexcept; | ||||||
|     public: |     public: | ||||||
|         ~reference(); |         ~reference() noexcept; | ||||||
|         reference& operator=(bool x);           // for b[i] = x; |         reference& operator=(bool x) noexcept;           // for b[i] = x; | ||||||
|         reference& operator=(const reference&); // for b[i] = b[j]; |         reference& operator=(const reference&) noexcept; // for b[i] = b[j]; | ||||||
|         bool operator~() const;                 // flips the bit |         bool operator~() const noexcept;                 // flips the bit | ||||||
|         operator bool() const;                  // for x = b[i]; |         operator bool() const noexcept;                  // for x = b[i]; | ||||||
|         reference& flip();                      // for b[i].flip(); |         reference& flip() noexcept;                      // for b[i].flip(); | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     // 23.3.5.1 constructors: |     // 23.3.5.1 constructors: | ||||||
|     constexpr bitset(); |     constexpr bitset() noexcept; | ||||||
|     constexpr bitset(unsigned long long val); |     constexpr bitset(unsigned long long val) noexcept; | ||||||
|     template <class charT> |     template <class charT> | ||||||
|         explicit bitset(const charT* str, |         explicit bitset(const charT* str, | ||||||
|                         typename basic_string<charT>::size_type n = basic_string<charT>::npos, |                         typename basic_string<charT>::size_type n = basic_string<charT>::npos, | ||||||
| @@ -52,17 +52,17 @@ public: | |||||||
|                         charT zero = charT('0'), charT one = charT('1')); |                         charT zero = charT('0'), charT one = charT('1')); | ||||||
|  |  | ||||||
|     // 23.3.5.2 bitset operations: |     // 23.3.5.2 bitset operations: | ||||||
|     bitset& operator&=(const bitset& rhs); |     bitset& operator&=(const bitset& rhs) noexcept; | ||||||
|     bitset& operator|=(const bitset& rhs); |     bitset& operator|=(const bitset& rhs) noexcept; | ||||||
|     bitset& operator^=(const bitset& rhs); |     bitset& operator^=(const bitset& rhs) noexcept; | ||||||
|     bitset& operator<<=(size_t pos); |     bitset& operator<<=(size_t pos) noexcept; | ||||||
|     bitset& operator>>=(size_t pos); |     bitset& operator>>=(size_t pos) noexcept; | ||||||
|     bitset& set(); |     bitset& set() noexcept; | ||||||
|     bitset& set(size_t pos, bool val = true); |     bitset& set(size_t pos, bool val = true); | ||||||
|     bitset& reset(); |     bitset& reset() noexcept; | ||||||
|     bitset& reset(size_t pos); |     bitset& reset(size_t pos); | ||||||
|     bitset operator~() const; |     bitset operator~() const noexcept; | ||||||
|     bitset& flip(); |     bitset& flip() noexcept; | ||||||
|     bitset& flip(size_t pos); |     bitset& flip(size_t pos); | ||||||
|  |  | ||||||
|     // element access: |     // element access: | ||||||
| @@ -77,27 +77,27 @@ public: | |||||||
|     template <class charT> |     template <class charT> | ||||||
|         basic_string<charT, char_traits<charT>, allocator<charT> > to_string(charT zero = charT('0'), charT one = charT('1')) const; |         basic_string<charT, char_traits<charT>, allocator<charT> > to_string(charT zero = charT('0'), charT one = charT('1')) const; | ||||||
|     basic_string<char, char_traits<char>, allocator<char> > to_string(char zero = '0', char one = '1') const; |     basic_string<char, char_traits<char>, allocator<char> > to_string(char zero = '0', char one = '1') const; | ||||||
|     size_t count() const; |     size_t count() const noexcept; | ||||||
|     constexpr size_t size() const; |     constexpr size_t size() const noexcept; | ||||||
|     bool operator==(const bitset& rhs) const; |     bool operator==(const bitset& rhs) const noexcept; | ||||||
|     bool operator!=(const bitset& rhs) const; |     bool operator!=(const bitset& rhs) const noexcept; | ||||||
|     bool test(size_t pos) const; |     bool test(size_t pos) const; | ||||||
|     bool all() const; |     bool all() const noexcept; | ||||||
|     bool any() const; |     bool any() const noexcept; | ||||||
|     bool none() const; |     bool none() const noexcept; | ||||||
|     bitset operator<<(size_t pos) const; |     bitset operator<<(size_t pos) const noexcept; | ||||||
|     bitset operator>>(size_t pos) const; |     bitset operator>>(size_t pos) const noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // 23.3.5.3 bitset operators: | // 23.3.5.3 bitset operators: | ||||||
| template <size_t N> | template <size_t N> | ||||||
| bitset<N> operator&(const bitset<N>&, const bitset<N>&); | bitset<N> operator&(const bitset<N>&, const bitset<N>&) noexcept; | ||||||
|  |  | ||||||
| template <size_t N> | template <size_t N> | ||||||
| bitset<N> operator|(const bitset<N>&, const bitset<N>&); | bitset<N> operator|(const bitset<N>&, const bitset<N>&) noexcept; | ||||||
|  |  | ||||||
| template <size_t N> | template <size_t N> | ||||||
| bitset<N> operator^(const bitset<N>&, const bitset<N>&); | bitset<N> operator^(const bitset<N>&, const bitset<N>&) noexcept; | ||||||
|  |  | ||||||
| template <class charT, class traits, size_t N> | template <class charT, class traits, size_t N> | ||||||
| basic_istream<charT, traits>& | basic_istream<charT, traits>& | ||||||
| @@ -129,6 +129,15 @@ template <size_t N> struct hash<std::bitset<N>>; | |||||||
|  |  | ||||||
| _LIBCPP_BEGIN_NAMESPACE_STD | _LIBCPP_BEGIN_NAMESPACE_STD | ||||||
|  |  | ||||||
|  | template <size_t _N_words, size_t _Size> | ||||||
|  | class __bitset; | ||||||
|  |  | ||||||
|  | template <size_t _N_words, size_t _Size> | ||||||
|  | struct __has_storage_type<__bitset<_N_words, _Size> > | ||||||
|  | { | ||||||
|  |     static const bool value = true; | ||||||
|  | }; | ||||||
|  |  | ||||||
| template <size_t _N_words, size_t _Size> | template <size_t _N_words, size_t _Size> | ||||||
| class __bitset | class __bitset | ||||||
| { | { | ||||||
| @@ -155,34 +164,34 @@ protected: | |||||||
|     typedef __bit_iterator<__bitset, false>            iterator; |     typedef __bit_iterator<__bitset, false>            iterator; | ||||||
|     typedef __bit_iterator<__bitset, true>             const_iterator; |     typedef __bit_iterator<__bitset, true>             const_iterator; | ||||||
|  |  | ||||||
|     __bitset(); |     __bitset() _NOEXCEPT; | ||||||
|     explicit __bitset(unsigned long long __v); |     explicit __bitset(unsigned long long __v) _NOEXCEPT; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY reference __make_ref(size_t __pos) |     _LIBCPP_INLINE_VISIBILITY reference __make_ref(size_t __pos) _NOEXCEPT | ||||||
|         {return reference(__first_ + __pos / __bits_per_word, __storage_type(1) << __pos % __bits_per_word);} |         {return reference(__first_ + __pos / __bits_per_word, __storage_type(1) << __pos % __bits_per_word);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY const_reference __make_ref(size_t __pos) const |     _LIBCPP_INLINE_VISIBILITY const_reference __make_ref(size_t __pos) const _NOEXCEPT | ||||||
|         {return const_reference(__first_ + __pos / __bits_per_word, __storage_type(1) << __pos % __bits_per_word);} |         {return const_reference(__first_ + __pos / __bits_per_word, __storage_type(1) << __pos % __bits_per_word);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY iterator __make_iter(size_t __pos) |     _LIBCPP_INLINE_VISIBILITY iterator __make_iter(size_t __pos) _NOEXCEPT | ||||||
|         {return iterator(__first_ + __pos / __bits_per_word, __pos % __bits_per_word);} |         {return iterator(__first_ + __pos / __bits_per_word, __pos % __bits_per_word);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator __make_iter(size_t __pos) const |     _LIBCPP_INLINE_VISIBILITY const_iterator __make_iter(size_t __pos) const _NOEXCEPT | ||||||
|         {return const_iterator(__first_ + __pos / __bits_per_word, __pos % __bits_per_word);} |         {return const_iterator(__first_ + __pos / __bits_per_word, __pos % __bits_per_word);} | ||||||
|  |  | ||||||
|     void operator&=(const __bitset& __v); |     void operator&=(const __bitset& __v) _NOEXCEPT; | ||||||
|     void operator|=(const __bitset& __v); |     void operator|=(const __bitset& __v) _NOEXCEPT; | ||||||
|     void operator^=(const __bitset& __v); |     void operator^=(const __bitset& __v) _NOEXCEPT; | ||||||
|  |  | ||||||
|     void flip(); |     void flip() _NOEXCEPT; | ||||||
|     _LIBCPP_INLINE_VISIBILITY unsigned long to_ulong() const |     _LIBCPP_INLINE_VISIBILITY unsigned long to_ulong() const | ||||||
|         {return to_ulong(integral_constant<bool, _Size < sizeof(unsigned long) * CHAR_BIT>());} |         {return to_ulong(integral_constant<bool, _Size < sizeof(unsigned long) * CHAR_BIT>());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY unsigned long long to_ullong() const |     _LIBCPP_INLINE_VISIBILITY unsigned long long to_ullong() const | ||||||
|         {return to_ullong(integral_constant<bool, _Size < sizeof(unsigned long long) * CHAR_BIT>());} |         {return to_ullong(integral_constant<bool, _Size < sizeof(unsigned long long) * CHAR_BIT>());} | ||||||
|  |  | ||||||
|     bool all() const; |     bool all() const _NOEXCEPT; | ||||||
|     bool any() const; |     bool any() const _NOEXCEPT; | ||||||
|     size_t __hash_code() const; |     size_t __hash_code() const _NOEXCEPT; | ||||||
| private: | private: | ||||||
|     void __init(unsigned long long __v, false_type); |     void __init(unsigned long long __v, false_type) _NOEXCEPT; | ||||||
|     void __init(unsigned long long __v, true_type); |     void __init(unsigned long long __v, true_type) _NOEXCEPT; | ||||||
|     unsigned long to_ulong(false_type) const; |     unsigned long to_ulong(false_type) const; | ||||||
|     unsigned long to_ulong(true_type) const; |     unsigned long to_ulong(true_type) const; | ||||||
|     unsigned long long to_ullong(false_type) const; |     unsigned long long to_ullong(false_type) const; | ||||||
| @@ -193,9 +202,9 @@ private: | |||||||
|  |  | ||||||
| template <size_t _N_words, size_t _Size> | template <size_t _N_words, size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| __bitset<_N_words, _Size>::__bitset() | __bitset<_N_words, _Size>::__bitset() _NOEXCEPT | ||||||
| { | { | ||||||
|     _STD::fill_n(__first_, _N_words, __storage_type(0)); |     _VSTD::fill_n(__first_, _N_words, __storage_type(0)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <size_t _N_words, size_t _Size> | template <size_t _N_words, size_t _Size> | ||||||
| @@ -205,8 +214,8 @@ __bitset<_N_words, _Size>::__init(unsigned long long __v, false_type) | |||||||
|     __storage_type __t[sizeof(unsigned long long) / sizeof(__storage_type)]; |     __storage_type __t[sizeof(unsigned long long) / sizeof(__storage_type)]; | ||||||
|     for (size_t __i = 0; __i < sizeof(__t)/sizeof(__t[0]); ++__i, __v >>= __bits_per_word) |     for (size_t __i = 0; __i < sizeof(__t)/sizeof(__t[0]); ++__i, __v >>= __bits_per_word) | ||||||
|         __t[__i] = static_cast<__storage_type>(__v); |         __t[__i] = static_cast<__storage_type>(__v); | ||||||
|     _STD::copy(__t, __t + sizeof(__t)/sizeof(__t[0]), __first_); |     _VSTD::copy(__t, __t + sizeof(__t)/sizeof(__t[0]), __first_); | ||||||
|     _STD::fill(__first_ + sizeof(__t)/sizeof(__t[0]), __first_ + sizeof(__first_)/sizeof(__first_[0]), |     _VSTD::fill(__first_ + sizeof(__t)/sizeof(__t[0]), __first_ + sizeof(__first_)/sizeof(__first_[0]), | ||||||
|                __storage_type(0)); |                __storage_type(0)); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -216,12 +225,12 @@ void | |||||||
| __bitset<_N_words, _Size>::__init(unsigned long long __v, true_type) | __bitset<_N_words, _Size>::__init(unsigned long long __v, true_type) | ||||||
| { | { | ||||||
|     __first_[0] = __v; |     __first_[0] = __v; | ||||||
|     _STD::fill(__first_ + 1, __first_ + sizeof(__first_)/sizeof(__first_[0]), __storage_type(0)); |     _VSTD::fill(__first_ + 1, __first_ + sizeof(__first_)/sizeof(__first_[0]), __storage_type(0)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <size_t _N_words, size_t _Size> | template <size_t _N_words, size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| __bitset<_N_words, _Size>::__bitset(unsigned long long __v) | __bitset<_N_words, _Size>::__bitset(unsigned long long __v) _NOEXCEPT | ||||||
| { | { | ||||||
|     __init(__v, integral_constant<bool, sizeof(unsigned long long) == sizeof(__storage_type)>()); |     __init(__v, integral_constant<bool, sizeof(unsigned long long) == sizeof(__storage_type)>()); | ||||||
| } | } | ||||||
| @@ -229,7 +238,7 @@ __bitset<_N_words, _Size>::__bitset(unsigned long long __v) | |||||||
| template <size_t _N_words, size_t _Size> | template <size_t _N_words, size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| void | void | ||||||
| __bitset<_N_words, _Size>::operator&=(const __bitset& __v) | __bitset<_N_words, _Size>::operator&=(const __bitset& __v) _NOEXCEPT | ||||||
| { | { | ||||||
|     for (size_type __i = 0; __i < _N_words; ++__i) |     for (size_type __i = 0; __i < _N_words; ++__i) | ||||||
|         __first_[__i] &= __v.__first_[__i]; |         __first_[__i] &= __v.__first_[__i]; | ||||||
| @@ -238,7 +247,7 @@ __bitset<_N_words, _Size>::operator&=(const __bitset& __v) | |||||||
| template <size_t _N_words, size_t _Size> | template <size_t _N_words, size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| void | void | ||||||
| __bitset<_N_words, _Size>::operator|=(const __bitset& __v) | __bitset<_N_words, _Size>::operator|=(const __bitset& __v) _NOEXCEPT | ||||||
| { | { | ||||||
|     for (size_type __i = 0; __i < _N_words; ++__i) |     for (size_type __i = 0; __i < _N_words; ++__i) | ||||||
|         __first_[__i] |= __v.__first_[__i]; |         __first_[__i] |= __v.__first_[__i]; | ||||||
| @@ -247,7 +256,7 @@ __bitset<_N_words, _Size>::operator|=(const __bitset& __v) | |||||||
| template <size_t _N_words, size_t _Size> | template <size_t _N_words, size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| void | void | ||||||
| __bitset<_N_words, _Size>::operator^=(const __bitset& __v) | __bitset<_N_words, _Size>::operator^=(const __bitset& __v) _NOEXCEPT | ||||||
| { | { | ||||||
|     for (size_type __i = 0; __i < _N_words; ++__i) |     for (size_type __i = 0; __i < _N_words; ++__i) | ||||||
|         __first_[__i] ^= __v.__first_[__i]; |         __first_[__i] ^= __v.__first_[__i]; | ||||||
| @@ -255,7 +264,7 @@ __bitset<_N_words, _Size>::operator^=(const __bitset& __v) | |||||||
|  |  | ||||||
| template <size_t _N_words, size_t _Size> | template <size_t _N_words, size_t _Size> | ||||||
| void | void | ||||||
| __bitset<_N_words, _Size>::flip() | __bitset<_N_words, _Size>::flip() _NOEXCEPT | ||||||
| { | { | ||||||
|     // do middle whole words |     // do middle whole words | ||||||
|     size_type __n = _Size; |     size_type __n = _Size; | ||||||
| @@ -277,7 +286,7 @@ unsigned long | |||||||
| __bitset<_N_words, _Size>::to_ulong(false_type) const | __bitset<_N_words, _Size>::to_ulong(false_type) const | ||||||
| { | { | ||||||
|     const_iterator __e = __make_iter(_Size); |     const_iterator __e = __make_iter(_Size); | ||||||
|     const_iterator __i = _STD::find(__make_iter(sizeof(unsigned long) * CHAR_BIT), __e, true); |     const_iterator __i = _VSTD::find(__make_iter(sizeof(unsigned long) * CHAR_BIT), __e, true); | ||||||
|     if (__i != __e) |     if (__i != __e) | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|         throw overflow_error("bitset to_ulong overflow error"); |         throw overflow_error("bitset to_ulong overflow error"); | ||||||
| @@ -300,7 +309,7 @@ unsigned long long | |||||||
| __bitset<_N_words, _Size>::to_ullong(false_type) const | __bitset<_N_words, _Size>::to_ullong(false_type) const | ||||||
| { | { | ||||||
|     const_iterator __e = __make_iter(_Size); |     const_iterator __e = __make_iter(_Size); | ||||||
|     const_iterator __i = _STD::find(__make_iter(sizeof(unsigned long long) * CHAR_BIT), __e, true); |     const_iterator __i = _VSTD::find(__make_iter(sizeof(unsigned long long) * CHAR_BIT), __e, true); | ||||||
|     if (__i != __e) |     if (__i != __e) | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|         throw overflow_error("bitset to_ullong overflow error"); |         throw overflow_error("bitset to_ullong overflow error"); | ||||||
| @@ -338,7 +347,7 @@ __bitset<_N_words, _Size>::to_ullong(true_type, true_type) const | |||||||
|  |  | ||||||
| template <size_t _N_words, size_t _Size> | template <size_t _N_words, size_t _Size> | ||||||
| bool | bool | ||||||
| __bitset<_N_words, _Size>::all() const | __bitset<_N_words, _Size>::all() const _NOEXCEPT | ||||||
| { | { | ||||||
|     // do middle whole words |     // do middle whole words | ||||||
|     size_type __n = _Size; |     size_type __n = _Size; | ||||||
| @@ -358,7 +367,7 @@ __bitset<_N_words, _Size>::all() const | |||||||
|  |  | ||||||
| template <size_t _N_words, size_t _Size> | template <size_t _N_words, size_t _Size> | ||||||
| bool | bool | ||||||
| __bitset<_N_words, _Size>::any() const | __bitset<_N_words, _Size>::any() const _NOEXCEPT | ||||||
| { | { | ||||||
|     // do middle whole words |     // do middle whole words | ||||||
|     size_type __n = _Size; |     size_type __n = _Size; | ||||||
| @@ -379,7 +388,7 @@ __bitset<_N_words, _Size>::any() const | |||||||
| template <size_t _N_words, size_t _Size> | template <size_t _N_words, size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| size_t | size_t | ||||||
| __bitset<_N_words, _Size>::__hash_code() const | __bitset<_N_words, _Size>::__hash_code() const _NOEXCEPT | ||||||
| { | { | ||||||
|     size_t __h = 0; |     size_t __h = 0; | ||||||
|     for (size_type __i = 0; __i < _N_words; ++__i) |     for (size_type __i = 0; __i < _N_words; ++__i) | ||||||
| @@ -413,43 +422,43 @@ protected: | |||||||
|     typedef __bit_iterator<__bitset, false>            iterator; |     typedef __bit_iterator<__bitset, false>            iterator; | ||||||
|     typedef __bit_iterator<__bitset, true>             const_iterator; |     typedef __bit_iterator<__bitset, true>             const_iterator; | ||||||
|  |  | ||||||
|     __bitset(); |     __bitset() _NOEXCEPT; | ||||||
|     explicit __bitset(unsigned long long __v); |     explicit __bitset(unsigned long long __v) _NOEXCEPT; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY reference __make_ref(size_t __pos) |     _LIBCPP_INLINE_VISIBILITY reference __make_ref(size_t __pos) _NOEXCEPT | ||||||
|         {return reference(&__first_, __storage_type(1) << __pos);} |         {return reference(&__first_, __storage_type(1) << __pos);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY const_reference __make_ref(size_t __pos) const |     _LIBCPP_INLINE_VISIBILITY const_reference __make_ref(size_t __pos) const _NOEXCEPT | ||||||
|         {return const_reference(&__first_, __storage_type(1) << __pos);} |         {return const_reference(&__first_, __storage_type(1) << __pos);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY iterator __make_iter(size_t __pos) |     _LIBCPP_INLINE_VISIBILITY iterator __make_iter(size_t __pos) _NOEXCEPT | ||||||
|         {return iterator(&__first_ + __pos / __bits_per_word, __pos % __bits_per_word);} |         {return iterator(&__first_ + __pos / __bits_per_word, __pos % __bits_per_word);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator __make_iter(size_t __pos) const |     _LIBCPP_INLINE_VISIBILITY const_iterator __make_iter(size_t __pos) const _NOEXCEPT | ||||||
|         {return const_iterator(&__first_ + __pos / __bits_per_word, __pos % __bits_per_word);} |         {return const_iterator(&__first_ + __pos / __bits_per_word, __pos % __bits_per_word);} | ||||||
|  |  | ||||||
|     void operator&=(const __bitset& __v); |     void operator&=(const __bitset& __v) _NOEXCEPT; | ||||||
|     void operator|=(const __bitset& __v); |     void operator|=(const __bitset& __v) _NOEXCEPT; | ||||||
|     void operator^=(const __bitset& __v); |     void operator^=(const __bitset& __v) _NOEXCEPT; | ||||||
|  |  | ||||||
|     void flip(); |     void flip() _NOEXCEPT; | ||||||
|  |  | ||||||
|     unsigned long to_ulong() const; |     unsigned long to_ulong() const; | ||||||
|     unsigned long long to_ullong() const; |     unsigned long long to_ullong() const; | ||||||
|  |  | ||||||
|     bool all() const; |     bool all() const _NOEXCEPT; | ||||||
|     bool any() const; |     bool any() const _NOEXCEPT; | ||||||
|  |  | ||||||
|     size_t __hash_code() const; |     size_t __hash_code() const _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| __bitset<1, _Size>::__bitset() | __bitset<1, _Size>::__bitset() _NOEXCEPT | ||||||
|     : __first_(0) |     : __first_(0) | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| __bitset<1, _Size>::__bitset(unsigned long long __v) | __bitset<1, _Size>::__bitset(unsigned long long __v) _NOEXCEPT | ||||||
|     : __first_(static_cast<__storage_type>(__v)) |     : __first_(static_cast<__storage_type>(__v)) | ||||||
| { | { | ||||||
| } | } | ||||||
| @@ -457,7 +466,7 @@ __bitset<1, _Size>::__bitset(unsigned long long __v) | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| void | void | ||||||
| __bitset<1, _Size>::operator&=(const __bitset& __v) | __bitset<1, _Size>::operator&=(const __bitset& __v) _NOEXCEPT | ||||||
| { | { | ||||||
|     __first_ &= __v.__first_; |     __first_ &= __v.__first_; | ||||||
| } | } | ||||||
| @@ -465,7 +474,7 @@ __bitset<1, _Size>::operator&=(const __bitset& __v) | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| void | void | ||||||
| __bitset<1, _Size>::operator|=(const __bitset& __v) | __bitset<1, _Size>::operator|=(const __bitset& __v) _NOEXCEPT | ||||||
| { | { | ||||||
|     __first_ |= __v.__first_; |     __first_ |= __v.__first_; | ||||||
| } | } | ||||||
| @@ -473,7 +482,7 @@ __bitset<1, _Size>::operator|=(const __bitset& __v) | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| void | void | ||||||
| __bitset<1, _Size>::operator^=(const __bitset& __v) | __bitset<1, _Size>::operator^=(const __bitset& __v) _NOEXCEPT | ||||||
| { | { | ||||||
|     __first_ ^= __v.__first_; |     __first_ ^= __v.__first_; | ||||||
| } | } | ||||||
| @@ -481,7 +490,7 @@ __bitset<1, _Size>::operator^=(const __bitset& __v) | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| void | void | ||||||
| __bitset<1, _Size>::flip() | __bitset<1, _Size>::flip() _NOEXCEPT | ||||||
| { | { | ||||||
|     __storage_type __m = ~__storage_type(0) >> (__bits_per_word - _Size); |     __storage_type __m = ~__storage_type(0) >> (__bits_per_word - _Size); | ||||||
|     __first_ = ~__first_; |     __first_ = ~__first_; | ||||||
| @@ -507,7 +516,7 @@ __bitset<1, _Size>::to_ullong() const | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| __bitset<1, _Size>::all() const | __bitset<1, _Size>::all() const _NOEXCEPT | ||||||
| { | { | ||||||
|     __storage_type __m = ~__storage_type(0) >> (__bits_per_word - _Size); |     __storage_type __m = ~__storage_type(0) >> (__bits_per_word - _Size); | ||||||
|     return !(~__first_ & __m); |     return !(~__first_ & __m); | ||||||
| @@ -516,7 +525,7 @@ __bitset<1, _Size>::all() const | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| __bitset<1, _Size>::any() const | __bitset<1, _Size>::any() const _NOEXCEPT | ||||||
| { | { | ||||||
|     __storage_type __m = ~__storage_type(0) >> (__bits_per_word - _Size); |     __storage_type __m = ~__storage_type(0) >> (__bits_per_word - _Size); | ||||||
|     return __first_ & __m; |     return __first_ & __m; | ||||||
| @@ -525,7 +534,7 @@ __bitset<1, _Size>::any() const | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| size_t | size_t | ||||||
| __bitset<1, _Size>::__hash_code() const | __bitset<1, _Size>::__hash_code() const _NOEXCEPT | ||||||
| { | { | ||||||
|     return __first_; |     return __first_; | ||||||
| } | } | ||||||
| @@ -554,40 +563,40 @@ protected: | |||||||
|     typedef __bit_iterator<__bitset, false>            iterator; |     typedef __bit_iterator<__bitset, false>            iterator; | ||||||
|     typedef __bit_iterator<__bitset, true>             const_iterator; |     typedef __bit_iterator<__bitset, true>             const_iterator; | ||||||
|  |  | ||||||
|     __bitset(); |     __bitset() _NOEXCEPT; | ||||||
|     explicit __bitset(unsigned long long); |     explicit __bitset(unsigned long long) _NOEXCEPT; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY reference __make_ref(size_t) |     _LIBCPP_INLINE_VISIBILITY reference __make_ref(size_t) _NOEXCEPT | ||||||
|         {return reference(0, 1);} |         {return reference(0, 1);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY const_reference __make_ref(size_t) const |     _LIBCPP_INLINE_VISIBILITY const_reference __make_ref(size_t) const _NOEXCEPT | ||||||
|         {return const_reference(0, 1);} |         {return const_reference(0, 1);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY iterator __make_iter(size_t __pos) |     _LIBCPP_INLINE_VISIBILITY iterator __make_iter(size_t __pos) _NOEXCEPT | ||||||
|         {return iterator(0, 0);} |         {return iterator(0, 0);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator __make_iter(size_t __pos) const |     _LIBCPP_INLINE_VISIBILITY const_iterator __make_iter(size_t __pos) const _NOEXCEPT | ||||||
|         {return const_iterator(0, 0);} |         {return const_iterator(0, 0);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY void operator&=(const __bitset&) {} |     _LIBCPP_INLINE_VISIBILITY void operator&=(const __bitset&) _NOEXCEPT {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY void operator|=(const __bitset&) {} |     _LIBCPP_INLINE_VISIBILITY void operator|=(const __bitset&) _NOEXCEPT {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY void operator^=(const __bitset&) {} |     _LIBCPP_INLINE_VISIBILITY void operator^=(const __bitset&) _NOEXCEPT {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY void flip() {} |     _LIBCPP_INLINE_VISIBILITY void flip() _NOEXCEPT {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY unsigned long to_ulong() const {return 0;} |     _LIBCPP_INLINE_VISIBILITY unsigned long to_ulong() const {return 0;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY unsigned long long to_ullong() const {return 0;} |     _LIBCPP_INLINE_VISIBILITY unsigned long long to_ullong() const {return 0;} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY bool all() const {return true;} |     _LIBCPP_INLINE_VISIBILITY bool all() const _NOEXCEPT {return true;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY bool any() const {return false;} |     _LIBCPP_INLINE_VISIBILITY bool any() const _NOEXCEPT {return false;} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY size_t __hash_code() const {return 0;} |     _LIBCPP_INLINE_VISIBILITY size_t __hash_code() const _NOEXCEPT {return 0;} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| __bitset<0, 0>::__bitset() | __bitset<0, 0>::__bitset() _NOEXCEPT | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| __bitset<0, 0>::__bitset(unsigned long long) | __bitset<0, 0>::__bitset(unsigned long long) _NOEXCEPT | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -606,8 +615,8 @@ public: | |||||||
|     typedef typename base::const_reference const_reference; |     typedef typename base::const_reference const_reference; | ||||||
|  |  | ||||||
|     // 23.3.5.1 constructors: |     // 23.3.5.1 constructors: | ||||||
|     /*constexpr*/ _LIBCPP_INLINE_VISIBILITY bitset() {} |     /*constexpr*/ _LIBCPP_INLINE_VISIBILITY bitset() _NOEXCEPT {} | ||||||
|     /*constexpr*/ _LIBCPP_INLINE_VISIBILITY bitset(unsigned long long __v) : base(__v) {} |     /*constexpr*/ _LIBCPP_INLINE_VISIBILITY bitset(unsigned long long __v) _NOEXCEPT : base(__v) {} | ||||||
|     template<class _CharT> |     template<class _CharT> | ||||||
|         explicit bitset(const _CharT* __str, |         explicit bitset(const _CharT* __str, | ||||||
|                         typename basic_string<_CharT>::size_type __n = basic_string<_CharT>::npos, |                         typename basic_string<_CharT>::size_type __n = basic_string<_CharT>::npos, | ||||||
| @@ -620,17 +629,17 @@ public: | |||||||
|                         _CharT __zero = _CharT('0'), _CharT __one = _CharT('1')); |                         _CharT __zero = _CharT('0'), _CharT __one = _CharT('1')); | ||||||
|  |  | ||||||
|     // 23.3.5.2 bitset operations: |     // 23.3.5.2 bitset operations: | ||||||
|     bitset& operator&=(const bitset& __rhs); |     bitset& operator&=(const bitset& __rhs) _NOEXCEPT; | ||||||
|     bitset& operator|=(const bitset& __rhs); |     bitset& operator|=(const bitset& __rhs) _NOEXCEPT; | ||||||
|     bitset& operator^=(const bitset& __rhs); |     bitset& operator^=(const bitset& __rhs) _NOEXCEPT; | ||||||
|     bitset& operator<<=(size_t __pos); |     bitset& operator<<=(size_t __pos) _NOEXCEPT; | ||||||
|     bitset& operator>>=(size_t __pos); |     bitset& operator>>=(size_t __pos) _NOEXCEPT; | ||||||
|     bitset& set(); |     bitset& set() _NOEXCEPT; | ||||||
|     bitset& set(size_t __pos, bool __val = true); |     bitset& set(size_t __pos, bool __val = true); | ||||||
|     bitset& reset(); |     bitset& reset() _NOEXCEPT; | ||||||
|     bitset& reset(size_t __pos); |     bitset& reset(size_t __pos); | ||||||
|     bitset  operator~() const; |     bitset  operator~() const _NOEXCEPT; | ||||||
|     bitset& flip(); |     bitset& flip() _NOEXCEPT; | ||||||
|     bitset& flip(size_t __pos); |     bitset& flip(size_t __pos); | ||||||
|  |  | ||||||
|     // element access: |     // element access: | ||||||
| @@ -649,21 +658,21 @@ public: | |||||||
|                                                                                 _CharT __one = _CharT('1')) const; |                                                                                 _CharT __one = _CharT('1')) const; | ||||||
|     basic_string<char, char_traits<char>, allocator<char> > to_string(char __zero = '0', |     basic_string<char, char_traits<char>, allocator<char> > to_string(char __zero = '0', | ||||||
|                                                                       char __one = '1') const; |                                                                       char __one = '1') const; | ||||||
|     size_t count() const; |     size_t count() const _NOEXCEPT; | ||||||
|     /*constexpr*/ _LIBCPP_INLINE_VISIBILITY size_t size() const {return _Size;} |     /*constexpr*/ _LIBCPP_INLINE_VISIBILITY size_t size() const _NOEXCEPT {return _Size;} | ||||||
|     bool operator==(const bitset& __rhs) const; |     bool operator==(const bitset& __rhs) const _NOEXCEPT; | ||||||
|     bool operator!=(const bitset& __rhs) const; |     bool operator!=(const bitset& __rhs) const _NOEXCEPT; | ||||||
|     bool test(size_t __pos) const; |     bool test(size_t __pos) const; | ||||||
|     bool all() const; |     bool all() const _NOEXCEPT; | ||||||
|     bool any() const; |     bool any() const _NOEXCEPT; | ||||||
|     _LIBCPP_INLINE_VISIBILITY bool none() const {return !any();} |     _LIBCPP_INLINE_VISIBILITY bool none() const _NOEXCEPT {return !any();} | ||||||
|     bitset operator<<(size_t __pos) const; |     bitset operator<<(size_t __pos) const _NOEXCEPT; | ||||||
|     bitset operator>>(size_t __pos) const; |     bitset operator>>(size_t __pos) const _NOEXCEPT; | ||||||
|  |  | ||||||
| private: | private: | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t __hash_code() const {return base::__hash_code();} |     size_t __hash_code() const _NOEXCEPT {return base::__hash_code();} | ||||||
|  |  | ||||||
|     friend struct hash<bitset>; |     friend struct hash<bitset>; | ||||||
| }; | }; | ||||||
| @@ -674,7 +683,7 @@ bitset<_Size>::bitset(const _CharT* __str, | |||||||
|                       typename basic_string<_CharT>::size_type __n, |                       typename basic_string<_CharT>::size_type __n, | ||||||
|                       _CharT __zero, _CharT __one) |                       _CharT __zero, _CharT __one) | ||||||
| { | { | ||||||
|     size_t __rlen = _STD::min(__n, char_traits<_CharT>::length(__str)); |     size_t __rlen = _VSTD::min(__n, char_traits<_CharT>::length(__str)); | ||||||
|     for (size_t __i = 0; __i < __rlen; ++__i) |     for (size_t __i = 0; __i < __rlen; ++__i) | ||||||
|         if (__str[__i] != __zero && __str[__i] != __one) |         if (__str[__i] != __zero && __str[__i] != __one) | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
| @@ -682,7 +691,7 @@ bitset<_Size>::bitset(const _CharT* __str, | |||||||
| #else | #else | ||||||
|             assert(!"bitset string ctor has invalid argument"); |             assert(!"bitset string ctor has invalid argument"); | ||||||
| #endif | #endif | ||||||
|     size_t _M = _STD::min(__rlen, _Size); |     size_t _M = _VSTD::min(__rlen, _Size); | ||||||
|     size_t __i = 0; |     size_t __i = 0; | ||||||
|     for (; __i < _M; ++__i) |     for (; __i < _M; ++__i) | ||||||
|     { |     { | ||||||
| @@ -692,7 +701,7 @@ bitset<_Size>::bitset(const _CharT* __str, | |||||||
|         else |         else | ||||||
|             (*this)[__i] = true; |             (*this)[__i] = true; | ||||||
|     } |     } | ||||||
|     _STD::fill(base::__make_iter(__i), base::__make_iter(_Size), false); |     _VSTD::fill(base::__make_iter(__i), base::__make_iter(_Size), false); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| @@ -708,7 +717,7 @@ bitset<_Size>::bitset(const basic_string<_CharT,_Traits,_Allocator>& __str, | |||||||
| #else | #else | ||||||
|         assert(!"bitset string pos out of range"); |         assert(!"bitset string pos out of range"); | ||||||
| #endif | #endif | ||||||
|     size_t __rlen = _STD::min(__n, __str.size() - __pos); |     size_t __rlen = _VSTD::min(__n, __str.size() - __pos); | ||||||
|     for (size_t __i = __pos; __i < __pos + __rlen; ++__i) |     for (size_t __i = __pos; __i < __pos + __rlen; ++__i) | ||||||
|         if (!_Traits::eq(__str[__i], __zero) && !_Traits::eq(__str[__i], __one)) |         if (!_Traits::eq(__str[__i], __zero) && !_Traits::eq(__str[__i], __one)) | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
| @@ -716,7 +725,7 @@ bitset<_Size>::bitset(const basic_string<_CharT,_Traits,_Allocator>& __str, | |||||||
| #else | #else | ||||||
|             assert(!"bitset string ctor has invalid argument"); |             assert(!"bitset string ctor has invalid argument"); | ||||||
| #endif | #endif | ||||||
|     size_t _M = _STD::min(__rlen, _Size); |     size_t _M = _VSTD::min(__rlen, _Size); | ||||||
|     size_t __i = 0; |     size_t __i = 0; | ||||||
|     for (; __i < _M; ++__i) |     for (; __i < _M; ++__i) | ||||||
|     { |     { | ||||||
| @@ -726,13 +735,13 @@ bitset<_Size>::bitset(const basic_string<_CharT,_Traits,_Allocator>& __str, | |||||||
|         else |         else | ||||||
|             (*this)[__i] = true; |             (*this)[__i] = true; | ||||||
|     } |     } | ||||||
|     _STD::fill(base::__make_iter(__i), base::__make_iter(_Size), false); |     _VSTD::fill(base::__make_iter(__i), base::__make_iter(_Size), false); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bitset<_Size>& | bitset<_Size>& | ||||||
| bitset<_Size>::operator&=(const bitset& __rhs) | bitset<_Size>::operator&=(const bitset& __rhs) _NOEXCEPT | ||||||
| { | { | ||||||
|     base::operator&=(__rhs); |     base::operator&=(__rhs); | ||||||
|     return *this; |     return *this; | ||||||
| @@ -741,7 +750,7 @@ bitset<_Size>::operator&=(const bitset& __rhs) | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bitset<_Size>& | bitset<_Size>& | ||||||
| bitset<_Size>::operator|=(const bitset& __rhs) | bitset<_Size>::operator|=(const bitset& __rhs) _NOEXCEPT | ||||||
| { | { | ||||||
|     base::operator|=(__rhs); |     base::operator|=(__rhs); | ||||||
|     return *this; |     return *this; | ||||||
| @@ -750,7 +759,7 @@ bitset<_Size>::operator|=(const bitset& __rhs) | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bitset<_Size>& | bitset<_Size>& | ||||||
| bitset<_Size>::operator^=(const bitset& __rhs) | bitset<_Size>::operator^=(const bitset& __rhs) _NOEXCEPT | ||||||
| { | { | ||||||
|     base::operator^=(__rhs); |     base::operator^=(__rhs); | ||||||
|     return *this; |     return *this; | ||||||
| @@ -758,30 +767,30 @@ bitset<_Size>::operator^=(const bitset& __rhs) | |||||||
|  |  | ||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| bitset<_Size>& | bitset<_Size>& | ||||||
| bitset<_Size>::operator<<=(size_t __pos) | bitset<_Size>::operator<<=(size_t __pos) _NOEXCEPT | ||||||
| { | { | ||||||
|     __pos = _STD::min(__pos, _Size); |     __pos = _VSTD::min(__pos, _Size); | ||||||
|     _STD::copy_backward(base::__make_iter(0), base::__make_iter(_Size - __pos), base::__make_iter(_Size)); |     _VSTD::copy_backward(base::__make_iter(0), base::__make_iter(_Size - __pos), base::__make_iter(_Size)); | ||||||
|     _STD::fill_n(base::__make_iter(0), __pos, false); |     _VSTD::fill_n(base::__make_iter(0), __pos, false); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| bitset<_Size>& | bitset<_Size>& | ||||||
| bitset<_Size>::operator>>=(size_t __pos) | bitset<_Size>::operator>>=(size_t __pos) _NOEXCEPT | ||||||
| { | { | ||||||
|     __pos = _STD::min(__pos, _Size); |     __pos = _VSTD::min(__pos, _Size); | ||||||
|     _STD::copy(base::__make_iter(__pos), base::__make_iter(_Size), base::__make_iter(0)); |     _VSTD::copy(base::__make_iter(__pos), base::__make_iter(_Size), base::__make_iter(0)); | ||||||
|     _STD::fill_n(base::__make_iter(_Size - __pos), __pos, false); |     _VSTD::fill_n(base::__make_iter(_Size - __pos), __pos, false); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bitset<_Size>& | bitset<_Size>& | ||||||
| bitset<_Size>::set() | bitset<_Size>::set() _NOEXCEPT | ||||||
| { | { | ||||||
|     _STD::fill_n(base::__make_iter(0), _Size, true); |     _VSTD::fill_n(base::__make_iter(0), _Size, true); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -802,9 +811,9 @@ bitset<_Size>::set(size_t __pos, bool __val) | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bitset<_Size>& | bitset<_Size>& | ||||||
| bitset<_Size>::reset() | bitset<_Size>::reset() _NOEXCEPT | ||||||
| { | { | ||||||
|     _STD::fill_n(base::__make_iter(0), _Size, false); |     _VSTD::fill_n(base::__make_iter(0), _Size, false); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -825,7 +834,7 @@ bitset<_Size>::reset(size_t __pos) | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bitset<_Size> | bitset<_Size> | ||||||
| bitset<_Size>::operator~() const | bitset<_Size>::operator~() const _NOEXCEPT | ||||||
| { | { | ||||||
|     bitset __x(*this); |     bitset __x(*this); | ||||||
|     __x.flip(); |     __x.flip(); | ||||||
| @@ -835,7 +844,7 @@ bitset<_Size>::operator~() const | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bitset<_Size>& | bitset<_Size>& | ||||||
| bitset<_Size>::flip() | bitset<_Size>::flip() _NOEXCEPT | ||||||
| { | { | ||||||
|     base::flip(); |     base::flip(); | ||||||
|     return *this; |     return *this; | ||||||
| @@ -915,23 +924,23 @@ bitset<_Size>::to_string(char __zero, char __one) const | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| size_t | size_t | ||||||
| bitset<_Size>::count() const | bitset<_Size>::count() const _NOEXCEPT | ||||||
| { | { | ||||||
|     return static_cast<size_t>(_STD::count(base::__make_iter(0), base::__make_iter(_Size), true)); |     return static_cast<size_t>(_VSTD::count(base::__make_iter(0), base::__make_iter(_Size), true)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| bitset<_Size>::operator==(const bitset& __rhs) const | bitset<_Size>::operator==(const bitset& __rhs) const _NOEXCEPT | ||||||
| { | { | ||||||
|     return _STD::equal(base::__make_iter(0), base::__make_iter(_Size), __rhs.__make_iter(0)); |     return _VSTD::equal(base::__make_iter(0), base::__make_iter(_Size), __rhs.__make_iter(0)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| bitset<_Size>::operator!=(const bitset& __rhs) const | bitset<_Size>::operator!=(const bitset& __rhs) const _NOEXCEPT | ||||||
| { | { | ||||||
|     return !(*this == __rhs); |     return !(*this == __rhs); | ||||||
| } | } | ||||||
| @@ -952,7 +961,7 @@ bitset<_Size>::test(size_t __pos) const | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| bitset<_Size>::all() const | bitset<_Size>::all() const _NOEXCEPT | ||||||
| { | { | ||||||
|     return base::all(); |     return base::all(); | ||||||
| } | } | ||||||
| @@ -960,7 +969,7 @@ bitset<_Size>::all() const | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| bitset<_Size>::any() const | bitset<_Size>::any() const _NOEXCEPT | ||||||
| { | { | ||||||
|     return base::any(); |     return base::any(); | ||||||
| } | } | ||||||
| @@ -968,7 +977,7 @@ bitset<_Size>::any() const | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bitset<_Size> | bitset<_Size> | ||||||
| bitset<_Size>::operator<<(size_t __pos) const | bitset<_Size>::operator<<(size_t __pos) const _NOEXCEPT | ||||||
| { | { | ||||||
|     bitset __r = *this; |     bitset __r = *this; | ||||||
|     __r <<= __pos; |     __r <<= __pos; | ||||||
| @@ -978,7 +987,7 @@ bitset<_Size>::operator<<(size_t __pos) const | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bitset<_Size> | bitset<_Size> | ||||||
| bitset<_Size>::operator>>(size_t __pos) const | bitset<_Size>::operator>>(size_t __pos) const _NOEXCEPT | ||||||
| { | { | ||||||
|     bitset __r = *this; |     bitset __r = *this; | ||||||
|     __r >>= __pos; |     __r >>= __pos; | ||||||
| @@ -988,7 +997,7 @@ bitset<_Size>::operator>>(size_t __pos) const | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bitset<_Size> | bitset<_Size> | ||||||
| operator&(const bitset<_Size>& __x, const bitset<_Size>& __y) | operator&(const bitset<_Size>& __x, const bitset<_Size>& __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     bitset<_Size> __r = __x; |     bitset<_Size> __r = __x; | ||||||
|     __r &= __y; |     __r &= __y; | ||||||
| @@ -998,7 +1007,7 @@ operator&(const bitset<_Size>& __x, const bitset<_Size>& __y) | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bitset<_Size> | bitset<_Size> | ||||||
| operator|(const bitset<_Size>& __x, const bitset<_Size>& __y) | operator|(const bitset<_Size>& __x, const bitset<_Size>& __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     bitset<_Size> __r = __x; |     bitset<_Size> __r = __x; | ||||||
|     __r |= __y; |     __r |= __y; | ||||||
| @@ -1008,7 +1017,7 @@ operator|(const bitset<_Size>& __x, const bitset<_Size>& __y) | |||||||
| template <size_t _Size> | template <size_t _Size> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bitset<_Size> | bitset<_Size> | ||||||
| operator^(const bitset<_Size>& __x, const bitset<_Size>& __y) | operator^(const bitset<_Size>& __x, const bitset<_Size>& __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     bitset<_Size> __r = __x; |     bitset<_Size> __r = __x; | ||||||
|     __r ^= __y; |     __r ^= __y; | ||||||
| @@ -1020,10 +1029,18 @@ struct _LIBCPP_VISIBLE hash<bitset<_Size> > | |||||||
|     : public unary_function<bitset<_Size>, size_t> |     : public unary_function<bitset<_Size>, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(const bitset<_Size>& __bs) const |     size_t operator()(const bitset<_Size>& __bs) const _NOEXCEPT | ||||||
|         {return __bs.__hash_code();} |         {return __bs.__hash_code();} | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | template <class _CharT, class _Traits, size_t _Size> | ||||||
|  | basic_istream<_CharT, _Traits>& | ||||||
|  | operator>>(basic_istream<_CharT, _Traits>& __is, bitset<_Size>& __x); | ||||||
|  |  | ||||||
|  | template <class _CharT, class _Traits, size_t _Size> | ||||||
|  | basic_ostream<_CharT, _Traits>& | ||||||
|  | operator<<(basic_ostream<_CharT, _Traits>& __os, const bitset<_Size>& __x); | ||||||
|  |  | ||||||
| _LIBCPP_END_NAMESPACE_STD | _LIBCPP_END_NAMESPACE_STD | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_BITSET | #endif  // _LIBCPP_BITSET | ||||||
|   | |||||||
| @@ -225,9 +225,9 @@ public: | |||||||
|     typedef chrono::time_point<system_clock> time_point; |     typedef chrono::time_point<system_clock> time_point; | ||||||
|     static const bool is_steady =            false; |     static const bool is_steady =            false; | ||||||
|  |  | ||||||
|     static time_point now(); |     static time_point now() noexcept; | ||||||
|     static time_t     to_time_t  (const time_point& __t); |     static time_t     to_time_t  (const time_point& __t) noexcept; | ||||||
|     static time_point from_time_t(time_t __t); |     static time_point from_time_t(time_t __t) noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class steady_clock | class steady_clock | ||||||
| @@ -239,7 +239,7 @@ public: | |||||||
|     typedef chrono::time_point<steady_clock, duration>    time_point; |     typedef chrono::time_point<steady_clock, duration>    time_point; | ||||||
|     static const bool is_steady =                         true; |     static const bool is_steady =                         true; | ||||||
|  |  | ||||||
|     static time_point now(); |     static time_point now() noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| typedef steady_clock high_resolution_clock; | typedef steady_clock high_resolution_clock; | ||||||
| @@ -407,7 +407,7 @@ public: | |||||||
|                 (ratio_divide<_Period2, period>::type::den == 1 && |                 (ratio_divide<_Period2, period>::type::den == 1 && | ||||||
|                  !treat_as_floating_point<_Rep2>::value) |                  !treat_as_floating_point<_Rep2>::value) | ||||||
|             >::type* = 0) |             >::type* = 0) | ||||||
|                 : __rep_(_STD::chrono::duration_cast<duration>(__d).count()) {} |                 : __rep_(_VSTD::chrono::duration_cast<duration>(__d).count()) {} | ||||||
|  |  | ||||||
|     // observer |     // observer | ||||||
|  |  | ||||||
| @@ -726,7 +726,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| time_point<_Clock, _ToDuration> | time_point<_Clock, _ToDuration> | ||||||
| time_point_cast(const time_point<_Clock, _Duration>& __t) | time_point_cast(const time_point<_Clock, _Duration>& __t) | ||||||
| { | { | ||||||
|     return time_point<_Clock, _ToDuration>(_STD::chrono::duration_cast<_ToDuration>(__t.time_since_epoch())); |     return time_point<_Clock, _ToDuration>(_VSTD::chrono::duration_cast<_ToDuration>(__t.time_since_epoch())); | ||||||
| } | } | ||||||
|  |  | ||||||
| // time_point == | // time_point == | ||||||
| @@ -845,9 +845,9 @@ public: | |||||||
|     typedef chrono::time_point<system_clock> time_point; |     typedef chrono::time_point<system_clock> time_point; | ||||||
|     static const bool is_steady =            false; |     static const bool is_steady =            false; | ||||||
|  |  | ||||||
|     static time_point now(); |     static time_point now() _NOEXCEPT; | ||||||
|     static time_t     to_time_t  (const time_point& __t); |     static time_t     to_time_t  (const time_point& __t) _NOEXCEPT; | ||||||
|     static time_point from_time_t(time_t __t); |     static time_point from_time_t(time_t __t) _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class _LIBCPP_VISIBLE steady_clock | class _LIBCPP_VISIBLE steady_clock | ||||||
| @@ -859,7 +859,7 @@ public: | |||||||
|     typedef chrono::time_point<steady_clock, duration>    time_point; |     typedef chrono::time_point<steady_clock, duration>    time_point; | ||||||
|     static const bool is_steady =                         true; |     static const bool is_steady =                         true; | ||||||
|  |  | ||||||
|     static time_point now(); |     static time_point now() _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| typedef steady_clock high_resolution_clock; | typedef steady_clock high_resolution_clock; | ||||||
|   | |||||||
							
								
								
									
										674
									
								
								include/cmath
									
									
									
									
									
								
							
							
						
						
									
										674
									
								
								include/cmath
									
									
									
									
									
								
							| @@ -303,8 +303,340 @@ long double    truncl(long double x); | |||||||
|  |  | ||||||
| #pragma GCC system_header | #pragma GCC system_header | ||||||
|  |  | ||||||
|  | // signbit | ||||||
|  |  | ||||||
|  | #ifdef signbit | ||||||
|  |  | ||||||
|  | template <class _A1> | ||||||
|  | _LIBCPP_ALWAYS_INLINE | ||||||
|  | bool | ||||||
|  | __libcpp_signbit(_A1 __x) | ||||||
|  | { | ||||||
|  |     return signbit(__x); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #undef signbit | ||||||
|  |  | ||||||
|  | template <class _A1> | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | typename std::enable_if<std::is_floating_point<_A1>::value, bool>::type | ||||||
|  | signbit(_A1 __x) | ||||||
|  | { | ||||||
|  |     return __libcpp_signbit(__x); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif  // signbit | ||||||
|  |  | ||||||
|  | // fpclassify | ||||||
|  |  | ||||||
|  | #ifdef fpclassify | ||||||
|  |  | ||||||
|  | template <class _A1> | ||||||
|  | _LIBCPP_ALWAYS_INLINE | ||||||
|  | int | ||||||
|  | __libcpp_fpclassify(_A1 __x) | ||||||
|  | { | ||||||
|  |     return fpclassify(__x); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #undef fpclassify | ||||||
|  |  | ||||||
|  | template <class _A1> | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | typename std::enable_if<std::is_floating_point<_A1>::value, int>::type | ||||||
|  | fpclassify(_A1 __x) | ||||||
|  | { | ||||||
|  |     return __libcpp_fpclassify(__x); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif  // fpclassify | ||||||
|  |  | ||||||
|  | // isfinite | ||||||
|  |  | ||||||
|  | #ifdef isfinite | ||||||
|  |  | ||||||
|  | template <class _A1> | ||||||
|  | _LIBCPP_ALWAYS_INLINE | ||||||
|  | bool | ||||||
|  | __libcpp_isfinite(_A1 __x) | ||||||
|  | { | ||||||
|  |     return isfinite(__x); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #undef isfinite | ||||||
|  |  | ||||||
|  | template <class _A1> | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | typename std::enable_if<std::is_floating_point<_A1>::value, bool>::type | ||||||
|  | isfinite(_A1 __x) | ||||||
|  | { | ||||||
|  |     return __libcpp_isfinite(__x); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif  // isfinite | ||||||
|  |  | ||||||
|  | // isinf | ||||||
|  |  | ||||||
|  | #ifdef isinf | ||||||
|  |  | ||||||
|  | template <class _A1> | ||||||
|  | _LIBCPP_ALWAYS_INLINE | ||||||
|  | bool | ||||||
|  | __libcpp_isinf(_A1 __x) | ||||||
|  | { | ||||||
|  |     return isinf(__x); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #undef isinf | ||||||
|  |  | ||||||
|  | template <class _A1> | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | typename std::enable_if<std::is_floating_point<_A1>::value, bool>::type | ||||||
|  | isinf(_A1 __x) | ||||||
|  | { | ||||||
|  |     return __libcpp_isinf(__x); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif  // isinf | ||||||
|  |  | ||||||
|  | // isnan | ||||||
|  |  | ||||||
|  | #ifdef isnan | ||||||
|  |  | ||||||
|  | template <class _A1> | ||||||
|  | _LIBCPP_ALWAYS_INLINE | ||||||
|  | bool | ||||||
|  | __libcpp_isnan(_A1 __x) | ||||||
|  | { | ||||||
|  |     return isnan(__x); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #undef isnan | ||||||
|  |  | ||||||
|  | template <class _A1> | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | typename std::enable_if<std::is_floating_point<_A1>::value, bool>::type | ||||||
|  | isnan(_A1 __x) | ||||||
|  | { | ||||||
|  |     return __libcpp_isnan(__x); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif  // isnan | ||||||
|  |  | ||||||
|  | // isnormal | ||||||
|  |  | ||||||
|  | #ifdef isnormal | ||||||
|  |  | ||||||
|  | template <class _A1> | ||||||
|  | _LIBCPP_ALWAYS_INLINE | ||||||
|  | bool | ||||||
|  | __libcpp_isnormal(_A1 __x) | ||||||
|  | { | ||||||
|  |     return isnormal(__x); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #undef isnormal | ||||||
|  |  | ||||||
|  | template <class _A1> | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | typename std::enable_if<std::is_floating_point<_A1>::value, bool>::type | ||||||
|  | isnormal(_A1 __x) | ||||||
|  | { | ||||||
|  |     return __libcpp_isnormal(__x); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif  // isnormal | ||||||
|  |  | ||||||
|  | // isgreater | ||||||
|  |  | ||||||
|  | #ifdef isgreater | ||||||
|  |  | ||||||
|  | template <class _A1, class _A2> | ||||||
|  | _LIBCPP_ALWAYS_INLINE | ||||||
|  | bool | ||||||
|  | __libcpp_isgreater(_A1 __x, _A2 __y) | ||||||
|  | { | ||||||
|  |     return isgreater(__x, __y); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #undef isgreater | ||||||
|  |  | ||||||
|  | template <class _A1, class _A2> | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | typename std::enable_if | ||||||
|  | < | ||||||
|  |     std::is_floating_point<_A1>::value && | ||||||
|  |     std::is_floating_point<_A2>::value, | ||||||
|  |     bool | ||||||
|  | >::type | ||||||
|  | isgreater(_A1 __x, _A2 __y) | ||||||
|  | { | ||||||
|  |     return __libcpp_isgreater(__x, __y); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif  // isgreater | ||||||
|  |  | ||||||
|  | // isgreaterequal | ||||||
|  |  | ||||||
|  | #ifdef isgreaterequal | ||||||
|  |  | ||||||
|  | template <class _A1, class _A2> | ||||||
|  | _LIBCPP_ALWAYS_INLINE | ||||||
|  | bool | ||||||
|  | __libcpp_isgreaterequal(_A1 __x, _A2 __y) | ||||||
|  | { | ||||||
|  |     return isgreaterequal(__x, __y); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #undef isgreaterequal | ||||||
|  |  | ||||||
|  | template <class _A1, class _A2> | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | typename std::enable_if | ||||||
|  | < | ||||||
|  |     std::is_floating_point<_A1>::value && | ||||||
|  |     std::is_floating_point<_A2>::value, | ||||||
|  |     bool | ||||||
|  | >::type | ||||||
|  | isgreaterequal(_A1 __x, _A2 __y) | ||||||
|  | { | ||||||
|  |     return __libcpp_isgreaterequal(__x, __y); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif  // isgreaterequal | ||||||
|  |  | ||||||
|  | // isless | ||||||
|  |  | ||||||
|  | #ifdef isless | ||||||
|  |  | ||||||
|  | template <class _A1, class _A2> | ||||||
|  | _LIBCPP_ALWAYS_INLINE | ||||||
|  | bool | ||||||
|  | __libcpp_isless(_A1 __x, _A2 __y) | ||||||
|  | { | ||||||
|  |     return isless(__x, __y); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #undef isless | ||||||
|  |  | ||||||
|  | template <class _A1, class _A2> | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | typename std::enable_if | ||||||
|  | < | ||||||
|  |     std::is_floating_point<_A1>::value && | ||||||
|  |     std::is_floating_point<_A2>::value, | ||||||
|  |     bool | ||||||
|  | >::type | ||||||
|  | isless(_A1 __x, _A2 __y) | ||||||
|  | { | ||||||
|  |     return __libcpp_isless(__x, __y); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif  // isless | ||||||
|  |  | ||||||
|  | // islessequal | ||||||
|  |  | ||||||
|  | #ifdef islessequal | ||||||
|  |  | ||||||
|  | template <class _A1, class _A2> | ||||||
|  | _LIBCPP_ALWAYS_INLINE | ||||||
|  | bool | ||||||
|  | __libcpp_islessequal(_A1 __x, _A2 __y) | ||||||
|  | { | ||||||
|  |     return islessequal(__x, __y); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #undef islessequal | ||||||
|  |  | ||||||
|  | template <class _A1, class _A2> | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | typename std::enable_if | ||||||
|  | < | ||||||
|  |     std::is_floating_point<_A1>::value && | ||||||
|  |     std::is_floating_point<_A2>::value, | ||||||
|  |     bool | ||||||
|  | >::type | ||||||
|  | islessequal(_A1 __x, _A2 __y) | ||||||
|  | { | ||||||
|  |     return __libcpp_islessequal(__x, __y); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif  // islessequal | ||||||
|  |  | ||||||
|  | // islessgreater | ||||||
|  |  | ||||||
|  | #ifdef islessgreater | ||||||
|  |  | ||||||
|  | template <class _A1, class _A2> | ||||||
|  | _LIBCPP_ALWAYS_INLINE | ||||||
|  | bool | ||||||
|  | __libcpp_islessgreater(_A1 __x, _A2 __y) | ||||||
|  | { | ||||||
|  |     return islessgreater(__x, __y); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #undef islessgreater | ||||||
|  |  | ||||||
|  | template <class _A1, class _A2> | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | typename std::enable_if | ||||||
|  | < | ||||||
|  |     std::is_floating_point<_A1>::value && | ||||||
|  |     std::is_floating_point<_A2>::value, | ||||||
|  |     bool | ||||||
|  | >::type | ||||||
|  | islessgreater(_A1 __x, _A2 __y) | ||||||
|  | { | ||||||
|  |     return __libcpp_islessgreater(__x, __y); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif  // islessgreater | ||||||
|  |  | ||||||
|  | // isunordered | ||||||
|  |  | ||||||
|  | #ifdef isunordered | ||||||
|  |  | ||||||
|  | template <class _A1, class _A2> | ||||||
|  | _LIBCPP_ALWAYS_INLINE | ||||||
|  | bool | ||||||
|  | __libcpp_isunordered(_A1 __x, _A2 __y) | ||||||
|  | { | ||||||
|  |     return isunordered(__x, __y); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #undef isunordered | ||||||
|  |  | ||||||
|  | template <class _A1, class _A2> | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | typename std::enable_if | ||||||
|  | < | ||||||
|  |     std::is_floating_point<_A1>::value && | ||||||
|  |     std::is_floating_point<_A2>::value, | ||||||
|  |     bool | ||||||
|  | >::type | ||||||
|  | isunordered(_A1 __x, _A2 __y) | ||||||
|  | { | ||||||
|  |     return __libcpp_isunordered(__x, __y); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif  // isunordered | ||||||
|  |  | ||||||
| _LIBCPP_BEGIN_NAMESPACE_STD | _LIBCPP_BEGIN_NAMESPACE_STD | ||||||
|  |  | ||||||
|  | using ::signbit; | ||||||
|  | using ::fpclassify; | ||||||
|  | using ::isfinite; | ||||||
|  | using ::isinf; | ||||||
|  | using ::isnan; | ||||||
|  | using ::isnormal; | ||||||
|  | using ::isgreater; | ||||||
|  | using ::isgreaterequal; | ||||||
|  | using ::isless; | ||||||
|  | using ::islessequal; | ||||||
|  | using ::islessgreater; | ||||||
|  | using ::isunordered; | ||||||
|  | using ::isunordered; | ||||||
|  |  | ||||||
| using ::float_t; | using ::float_t; | ||||||
| using ::double_t; | using ::double_t; | ||||||
|  |  | ||||||
| @@ -629,348 +961,6 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| typename enable_if<is_integral<_A1>::value, double>::type | typename enable_if<is_integral<_A1>::value, double>::type | ||||||
| tanh(_A1 __x) {return tanh((double)__x);} | tanh(_A1 __x) {return tanh((double)__x);} | ||||||
|  |  | ||||||
| // signbit |  | ||||||
|  |  | ||||||
| #ifndef signbit |  | ||||||
| #error Implementation error: signbit not defined |  | ||||||
| #else |  | ||||||
|  |  | ||||||
| template <class _A1> |  | ||||||
| _LIBCPP_ALWAYS_INLINE |  | ||||||
| bool |  | ||||||
| __libcpp_signbit(_A1 __x) |  | ||||||
| { |  | ||||||
|     return signbit(__x); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #undef signbit |  | ||||||
|  |  | ||||||
| template <class _A1> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| typename enable_if<is_floating_point<_A1>::value, bool>::type |  | ||||||
| signbit(_A1 __x) |  | ||||||
| { |  | ||||||
|     return __libcpp_signbit(__x); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #endif  // signbit |  | ||||||
|  |  | ||||||
| // fpclassify |  | ||||||
|  |  | ||||||
| #ifndef fpclassify |  | ||||||
| #error Implementation error: fpclassify not defined |  | ||||||
| #else |  | ||||||
|  |  | ||||||
| template <class _A1> |  | ||||||
| _LIBCPP_ALWAYS_INLINE |  | ||||||
| int |  | ||||||
| __libcpp_fpclassify(_A1 __x) |  | ||||||
| { |  | ||||||
|     return fpclassify(__x); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #undef fpclassify |  | ||||||
|  |  | ||||||
| template <class _A1> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| typename enable_if<is_floating_point<_A1>::value, int>::type |  | ||||||
| fpclassify(_A1 __x) |  | ||||||
| { |  | ||||||
|     return __libcpp_fpclassify(__x); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #endif  // fpclassify |  | ||||||
|  |  | ||||||
| // isfinite |  | ||||||
|  |  | ||||||
| #ifndef isfinite |  | ||||||
| #error Implementation error: isfinite not defined |  | ||||||
| #else |  | ||||||
|  |  | ||||||
| template <class _A1> |  | ||||||
| _LIBCPP_ALWAYS_INLINE |  | ||||||
| bool |  | ||||||
| __libcpp_isfinite(_A1 __x) |  | ||||||
| { |  | ||||||
|     return isfinite(__x); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #undef isfinite |  | ||||||
|  |  | ||||||
| template <class _A1> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| typename enable_if<is_floating_point<_A1>::value, bool>::type |  | ||||||
| isfinite(_A1 __x) |  | ||||||
| { |  | ||||||
|     return __libcpp_isfinite(__x); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #endif  // isfinite |  | ||||||
|  |  | ||||||
| // isinf |  | ||||||
|  |  | ||||||
| #ifndef isinf |  | ||||||
| #error Implementation error: isinf not defined |  | ||||||
| #else |  | ||||||
|  |  | ||||||
| template <class _A1> |  | ||||||
| _LIBCPP_ALWAYS_INLINE |  | ||||||
| bool |  | ||||||
| __libcpp_isinf(_A1 __x) |  | ||||||
| { |  | ||||||
|     return isinf(__x); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #undef isinf |  | ||||||
|  |  | ||||||
| template <class _A1> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| typename enable_if<is_floating_point<_A1>::value, bool>::type |  | ||||||
| isinf(_A1 __x) |  | ||||||
| { |  | ||||||
|     return __libcpp_isinf(__x); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #endif  // isinf |  | ||||||
|  |  | ||||||
| // isnan |  | ||||||
|  |  | ||||||
| #ifndef isnan |  | ||||||
| #error Implementation error: isnan not defined |  | ||||||
| #else |  | ||||||
|  |  | ||||||
| template <class _A1> |  | ||||||
| _LIBCPP_ALWAYS_INLINE |  | ||||||
| bool |  | ||||||
| __libcpp_isnan(_A1 __x) |  | ||||||
| { |  | ||||||
|     return isnan(__x); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #undef isnan |  | ||||||
|  |  | ||||||
| template <class _A1> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| typename enable_if<is_floating_point<_A1>::value, bool>::type |  | ||||||
| isnan(_A1 __x) |  | ||||||
| { |  | ||||||
|     return __libcpp_isnan(__x); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #endif  // isnan |  | ||||||
|  |  | ||||||
| // isnormal |  | ||||||
|  |  | ||||||
| #ifndef isnormal |  | ||||||
| #error Implementation error: isnormal not defined |  | ||||||
| #else |  | ||||||
|  |  | ||||||
| template <class _A1> |  | ||||||
| _LIBCPP_ALWAYS_INLINE |  | ||||||
| bool |  | ||||||
| __libcpp_isnormal(_A1 __x) |  | ||||||
| { |  | ||||||
|     return isnormal(__x); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #undef isnormal |  | ||||||
|  |  | ||||||
| template <class _A1> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| typename enable_if<is_floating_point<_A1>::value, bool>::type |  | ||||||
| isnormal(_A1 __x) |  | ||||||
| { |  | ||||||
|     return __libcpp_isnormal(__x); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #endif  // isnormal |  | ||||||
|  |  | ||||||
| // isgreater |  | ||||||
|  |  | ||||||
| #ifndef isgreater |  | ||||||
| #error Implementation error: isgreater not defined |  | ||||||
| #else |  | ||||||
|  |  | ||||||
| template <class _A1, class _A2> |  | ||||||
| _LIBCPP_ALWAYS_INLINE |  | ||||||
| bool |  | ||||||
| __libcpp_isgreater(_A1 __x, _A2 __y) |  | ||||||
| { |  | ||||||
|     return isgreater(__x, __y); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #undef isgreater |  | ||||||
|  |  | ||||||
| template <class _A1, class _A2> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| typename enable_if |  | ||||||
| < |  | ||||||
|     is_floating_point<_A1>::value && |  | ||||||
|     is_floating_point<_A2>::value, |  | ||||||
|     bool |  | ||||||
| >::type |  | ||||||
| isgreater(_A1 __x, _A2 __y) |  | ||||||
| { |  | ||||||
|     return __libcpp_isgreater(__x, __y); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #endif  // isgreater |  | ||||||
|  |  | ||||||
| // isgreaterequal |  | ||||||
|  |  | ||||||
| #ifndef isgreaterequal |  | ||||||
| #error Implementation error: isgreaterequal not defined |  | ||||||
| #else |  | ||||||
|  |  | ||||||
| template <class _A1, class _A2> |  | ||||||
| _LIBCPP_ALWAYS_INLINE |  | ||||||
| bool |  | ||||||
| __libcpp_isgreaterequal(_A1 __x, _A2 __y) |  | ||||||
| { |  | ||||||
|     return isgreaterequal(__x, __y); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #undef isgreaterequal |  | ||||||
|  |  | ||||||
| template <class _A1, class _A2> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| typename enable_if |  | ||||||
| < |  | ||||||
|     is_floating_point<_A1>::value && |  | ||||||
|     is_floating_point<_A2>::value, |  | ||||||
|     bool |  | ||||||
| >::type |  | ||||||
| isgreaterequal(_A1 __x, _A2 __y) |  | ||||||
| { |  | ||||||
|     return __libcpp_isgreaterequal(__x, __y); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #endif  // isgreaterequal |  | ||||||
|  |  | ||||||
| // isless |  | ||||||
|  |  | ||||||
| #ifndef isless |  | ||||||
| #error Implementation error: isless not defined |  | ||||||
| #else |  | ||||||
|  |  | ||||||
| template <class _A1, class _A2> |  | ||||||
| _LIBCPP_ALWAYS_INLINE |  | ||||||
| bool |  | ||||||
| __libcpp_isless(_A1 __x, _A2 __y) |  | ||||||
| { |  | ||||||
|     return isless(__x, __y); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #undef isless |  | ||||||
|  |  | ||||||
| template <class _A1, class _A2> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| typename enable_if |  | ||||||
| < |  | ||||||
|     is_floating_point<_A1>::value && |  | ||||||
|     is_floating_point<_A2>::value, |  | ||||||
|     bool |  | ||||||
| >::type |  | ||||||
| isless(_A1 __x, _A2 __y) |  | ||||||
| { |  | ||||||
|     return __libcpp_isless(__x, __y); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #endif  // isless |  | ||||||
|  |  | ||||||
| // islessequal |  | ||||||
|  |  | ||||||
| #ifndef islessequal |  | ||||||
| #error Implementation error: islessequal not defined |  | ||||||
| #else |  | ||||||
|  |  | ||||||
| template <class _A1, class _A2> |  | ||||||
| _LIBCPP_ALWAYS_INLINE |  | ||||||
| bool |  | ||||||
| __libcpp_islessequal(_A1 __x, _A2 __y) |  | ||||||
| { |  | ||||||
|     return islessequal(__x, __y); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #undef islessequal |  | ||||||
|  |  | ||||||
| template <class _A1, class _A2> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| typename enable_if |  | ||||||
| < |  | ||||||
|     is_floating_point<_A1>::value && |  | ||||||
|     is_floating_point<_A2>::value, |  | ||||||
|     bool |  | ||||||
| >::type |  | ||||||
| islessequal(_A1 __x, _A2 __y) |  | ||||||
| { |  | ||||||
|     return __libcpp_islessequal(__x, __y); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #endif  // islessequal |  | ||||||
|  |  | ||||||
| // islessgreater |  | ||||||
|  |  | ||||||
| #ifndef islessgreater |  | ||||||
| #error Implementation error: islessgreater not defined |  | ||||||
| #else |  | ||||||
|  |  | ||||||
| template <class _A1, class _A2> |  | ||||||
| _LIBCPP_ALWAYS_INLINE |  | ||||||
| bool |  | ||||||
| __libcpp_islessgreater(_A1 __x, _A2 __y) |  | ||||||
| { |  | ||||||
|     return islessgreater(__x, __y); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #undef islessgreater |  | ||||||
|  |  | ||||||
| template <class _A1, class _A2> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| typename enable_if |  | ||||||
| < |  | ||||||
|     is_floating_point<_A1>::value && |  | ||||||
|     is_floating_point<_A2>::value, |  | ||||||
|     bool |  | ||||||
| >::type |  | ||||||
| islessgreater(_A1 __x, _A2 __y) |  | ||||||
| { |  | ||||||
|     return __libcpp_islessgreater(__x, __y); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #endif  // islessgreater |  | ||||||
|  |  | ||||||
| // isunordered |  | ||||||
|  |  | ||||||
| #ifndef isunordered |  | ||||||
| #error Implementation error: isunordered not defined |  | ||||||
| #else |  | ||||||
|  |  | ||||||
| template <class _A1, class _A2> |  | ||||||
| _LIBCPP_ALWAYS_INLINE |  | ||||||
| bool |  | ||||||
| __libcpp_isunordered(_A1 __x, _A2 __y) |  | ||||||
| { |  | ||||||
|     return isunordered(__x, __y); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #undef isunordered |  | ||||||
|  |  | ||||||
| template <class _A1, class _A2> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| typename enable_if |  | ||||||
| < |  | ||||||
|     is_floating_point<_A1>::value && |  | ||||||
|     is_floating_point<_A2>::value, |  | ||||||
|     bool |  | ||||||
| >::type |  | ||||||
| isunordered(_A1 __x, _A2 __y) |  | ||||||
| { |  | ||||||
|     return __libcpp_isunordered(__x, __y); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #endif  // isunordered |  | ||||||
|  |  | ||||||
| // acosh | // acosh | ||||||
|  |  | ||||||
| using ::acosh; | using ::acosh; | ||||||
|   | |||||||
| @@ -1173,7 +1173,7 @@ complex<typename __promote<_Tp, _Up>::type> | |||||||
| pow(const complex<_Tp>& __x, const complex<_Up>& __y) | pow(const complex<_Tp>& __x, const complex<_Up>& __y) | ||||||
| { | { | ||||||
|     typedef complex<typename __promote<_Tp, _Up>::type> result_type; |     typedef complex<typename __promote<_Tp, _Up>::type> result_type; | ||||||
|     return _STD::pow(result_type(__x), result_type(__y)); |     return _VSTD::pow(result_type(__x), result_type(__y)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template<class _Tp, class _Up> | template<class _Tp, class _Up> | ||||||
| @@ -1186,7 +1186,7 @@ typename enable_if | |||||||
| pow(const complex<_Tp>& __x, const _Up& __y) | pow(const complex<_Tp>& __x, const _Up& __y) | ||||||
| { | { | ||||||
|     typedef complex<typename __promote<_Tp, _Up>::type> result_type; |     typedef complex<typename __promote<_Tp, _Up>::type> result_type; | ||||||
|     return _STD::pow(result_type(__x), result_type(__y)); |     return _VSTD::pow(result_type(__x), result_type(__y)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template<class _Tp, class _Up> | template<class _Tp, class _Up> | ||||||
| @@ -1199,7 +1199,7 @@ typename enable_if | |||||||
| pow(const _Tp& __x, const complex<_Up>& __y) | pow(const _Tp& __x, const complex<_Up>& __y) | ||||||
| { | { | ||||||
|     typedef complex<typename __promote<_Tp, _Up>::type> result_type; |     typedef complex<typename __promote<_Tp, _Up>::type> result_type; | ||||||
|     return _STD::pow(result_type(__x), result_type(__y)); |     return _VSTD::pow(result_type(__x), result_type(__y)); | ||||||
| } | } | ||||||
|  |  | ||||||
| // asinh | // asinh | ||||||
|   | |||||||
| @@ -243,7 +243,7 @@ condition_variable_any::wait_for(_Lock& __lock, | |||||||
|                                  _Predicate __pred) |                                  _Predicate __pred) | ||||||
| { | { | ||||||
|     return wait_until(__lock, chrono::steady_clock::now() + __d, |     return wait_until(__lock, chrono::steady_clock::now() + __d, | ||||||
|                       _STD::move(__pred)); |                       _VSTD::move(__pred)); | ||||||
| } | } | ||||||
|  |  | ||||||
| _LIBCPP_VISIBLE | _LIBCPP_VISIBLE | ||||||
|   | |||||||
| @@ -82,14 +82,19 @@ struct _LIBCPP_VISIBLE nullptr_t | |||||||
|  |  | ||||||
| inline _LIBCPP_ALWAYS_INLINE nullptr_t __get_nullptr_t() {return nullptr_t(0);} | inline _LIBCPP_ALWAYS_INLINE nullptr_t __get_nullptr_t() {return nullptr_t(0);} | ||||||
|  |  | ||||||
| #define nullptr _STD::__get_nullptr_t() | #define nullptr _VSTD::__get_nullptr_t() | ||||||
|  |  | ||||||
| #else  // _LIBCPP_HAS_NO_NULLPTR |  | ||||||
|  |  | ||||||
| typedef decltype(nullptr) nullptr_t; |  | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_NULLPTR | #endif  // _LIBCPP_HAS_NO_NULLPTR | ||||||
|  |  | ||||||
| _LIBCPP_END_NAMESPACE_STD | _LIBCPP_END_NAMESPACE_STD | ||||||
|  |  | ||||||
|  | #ifndef _LIBCPP_HAS_NO_NULLPTR | ||||||
|  |  | ||||||
|  | namespace std | ||||||
|  | { | ||||||
|  |     typedef decltype(nullptr) nullptr_t; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif  // _LIBCPP_HAS_NO_NULLPTR | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_CSTDDEF | #endif  // _LIBCPP_CSTDDEF | ||||||
|   | |||||||
							
								
								
									
										434
									
								
								include/deque
									
									
									
									
									
								
							
							
						
						
									
										434
									
								
								include/deque
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -20,56 +20,56 @@ namespace std | |||||||
| class exception | class exception | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     exception() throw(); |     exception() noexcept; | ||||||
|     exception(const exception&) throw(); |     exception(const exception&) noexcept; | ||||||
|     exception& operator=(const exception&) throw(); |     exception& operator=(const exception&) noexcept; | ||||||
|     virtual ~exception() throw(); |     virtual ~exception() noexcept; | ||||||
|     virtual const char* what() const throw(); |     virtual const char* what() const noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class bad_exception | class bad_exception | ||||||
|     : public exception |     : public exception | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     bad_exception() throw(); |     bad_exception() noexcept; | ||||||
|     bad_exception(const bad_exception&) throw(); |     bad_exception(const bad_exception&) noexcept; | ||||||
|     bad_exception& operator=(const bad_exception&) throw(); |     bad_exception& operator=(const bad_exception&) noexcept; | ||||||
|     virtual ~bad_exception() throw(); |     virtual ~bad_exception() noexcept; | ||||||
|     virtual const char* what() const throw(); |     virtual const char* what() const noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| typedef void (*unexpected_handler)(); | typedef void (*unexpected_handler)(); | ||||||
| unexpected_handler set_unexpected(unexpected_handler  f ) throw(); | unexpected_handler set_unexpected(unexpected_handler  f ) noexcept; | ||||||
| unexpected_handler get_unexpected() throw(); | unexpected_handler get_unexpected() noexcept; | ||||||
| void unexpected [[noreturn]] (); | [[noreturn]] void unexpected(); | ||||||
|  |  | ||||||
| typedef void (*terminate_handler)(); | typedef void (*terminate_handler)(); | ||||||
| terminate_handler set_terminate(terminate_handler  f ) throw(); | terminate_handler set_terminate(terminate_handler  f ) noexcept; | ||||||
| terminate_handler get_terminate() throw(); | terminate_handler get_terminate() noexcept; | ||||||
| void terminate [[noreturn]] (); | [[noreturn]] void terminate() noexcept; | ||||||
|  |  | ||||||
| bool uncaught_exception() throw(); | bool uncaught_exception() noexcept; | ||||||
|  |  | ||||||
| typedef unspecified exception_ptr; | typedef unspecified exception_ptr; | ||||||
|  |  | ||||||
| exception_ptr current_exception(); | exception_ptr current_exception() noexcept; | ||||||
| void rethrow_exception [[noreturn]] (exception_ptr p); | void rethrow_exception [[noreturn]] (exception_ptr p); | ||||||
| template<class E> exception_ptr make_exception_ptr(E e); | template<class E> exception_ptr make_exception_ptr(E e) noexcept; | ||||||
|  |  | ||||||
| class nested_exception | class nested_exception | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     nested_exception() throw(); |     nested_exception() noexcept; | ||||||
|     nested_exception(const nested_exception&) throw() = default; |     nested_exception(const nested_exception&) noexcept = default; | ||||||
|     nested_exception& operator=(const nested_exception&) throw() = default; |     nested_exception& operator=(const nested_exception&) noexcept = default; | ||||||
|     virtual ~nested_exception() = default; |     virtual ~nested_exception() = default; | ||||||
|  |  | ||||||
|     // access functions |     // access functions | ||||||
|     void rethrow_nested [[noreturn]] () const; |     [[noreturn]] void rethrow_nested() const; | ||||||
|     exception_ptr nested_ptr() const; |     exception_ptr nested_ptr() const noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class T> void throw_with_nested [[noreturn]] (T&& t); | template <class T> [[noreturn]] void throw_with_nested(T&& t); | ||||||
| template <class E> void rethrow_if_nested(const E& e); | template <class E> void rethrow_if_nested(const E& e); | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
| @@ -88,65 +88,65 @@ namespace std  // purposefully not using versioning namespace | |||||||
| class _LIBCPP_EXCEPTION_ABI exception | class _LIBCPP_EXCEPTION_ABI exception | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY exception() throw() {} |     _LIBCPP_INLINE_VISIBILITY exception() _NOEXCEPT {} | ||||||
|     virtual ~exception() throw(); |     virtual ~exception() _NOEXCEPT; | ||||||
|     virtual const char* what() const throw(); |     virtual const char* what() const _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class _LIBCPP_EXCEPTION_ABI bad_exception | class _LIBCPP_EXCEPTION_ABI bad_exception | ||||||
|     : public exception |     : public exception | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY bad_exception() throw() {} |     _LIBCPP_INLINE_VISIBILITY bad_exception() _NOEXCEPT {} | ||||||
|     virtual ~bad_exception() throw(); |     virtual ~bad_exception() _NOEXCEPT; | ||||||
|     virtual const char* what() const throw(); |     virtual const char* what() const _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| typedef void (*unexpected_handler)(); | typedef void (*unexpected_handler)(); | ||||||
| _LIBCPP_VISIBLE unexpected_handler set_unexpected(unexpected_handler) throw(); | _LIBCPP_VISIBLE unexpected_handler set_unexpected(unexpected_handler) _NOEXCEPT; | ||||||
| _LIBCPP_VISIBLE unexpected_handler get_unexpected() throw(); | _LIBCPP_VISIBLE unexpected_handler get_unexpected() _NOEXCEPT; | ||||||
| _LIBCPP_VISIBLE void unexpected(); | _ATTRIBUTE(noreturn) _LIBCPP_VISIBLE void unexpected(); | ||||||
|  |  | ||||||
| typedef void (*terminate_handler)(); | typedef void (*terminate_handler)(); | ||||||
| _LIBCPP_VISIBLE terminate_handler set_terminate(terminate_handler) throw(); | _LIBCPP_VISIBLE terminate_handler set_terminate(terminate_handler) _NOEXCEPT; | ||||||
| _LIBCPP_VISIBLE terminate_handler get_terminate() throw(); | _LIBCPP_VISIBLE terminate_handler get_terminate() _NOEXCEPT; | ||||||
| _LIBCPP_VISIBLE void terminate() __attribute__((__noreturn__)); | _ATTRIBUTE(noreturn) _LIBCPP_VISIBLE void terminate() _NOEXCEPT; | ||||||
|  |  | ||||||
| _LIBCPP_VISIBLE bool uncaught_exception() throw(); | _LIBCPP_VISIBLE bool uncaught_exception() _NOEXCEPT; | ||||||
|  |  | ||||||
| class exception_ptr; | class exception_ptr; | ||||||
|  |  | ||||||
| exception_ptr current_exception(); | exception_ptr current_exception() _NOEXCEPT; | ||||||
| void rethrow_exception(exception_ptr);  // noreturn | _ATTRIBUTE(noreturn) void rethrow_exception(exception_ptr); | ||||||
|  |  | ||||||
| class _LIBCPP_VISIBLE exception_ptr | class _LIBCPP_VISIBLE exception_ptr | ||||||
| { | { | ||||||
|     void* __ptr_; |     void* __ptr_; | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY exception_ptr()  : __ptr_() {} |     _LIBCPP_INLINE_VISIBILITY exception_ptr() _NOEXCEPT : __ptr_() {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY exception_ptr(nullptr_t) : __ptr_() {} |     _LIBCPP_INLINE_VISIBILITY exception_ptr(nullptr_t) _NOEXCEPT : __ptr_() {} | ||||||
|     exception_ptr(const exception_ptr&); |     exception_ptr(const exception_ptr&) _NOEXCEPT; | ||||||
|     exception_ptr& operator=(const exception_ptr&); |     exception_ptr& operator=(const exception_ptr&) _NOEXCEPT; | ||||||
|     ~exception_ptr(); |     ~exception_ptr() _NOEXCEPT; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     // explicit |     // explicit | ||||||
|         operator bool() const {return __ptr_ != nullptr;} |         operator bool() const _NOEXCEPT {return __ptr_ != nullptr;} | ||||||
|  |  | ||||||
|     friend _LIBCPP_INLINE_VISIBILITY |     friend _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool operator==(const exception_ptr& __x, const exception_ptr& __y) |     bool operator==(const exception_ptr& __x, const exception_ptr& __y) _NOEXCEPT | ||||||
|         {return __x.__ptr_ == __y.__ptr_;} |         {return __x.__ptr_ == __y.__ptr_;} | ||||||
|     friend _LIBCPP_INLINE_VISIBILITY |     friend _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool operator!=(const exception_ptr& __x, const exception_ptr& __y) |     bool operator!=(const exception_ptr& __x, const exception_ptr& __y) _NOEXCEPT | ||||||
|         {return !(__x == __y);} |         {return !(__x == __y);} | ||||||
|  |  | ||||||
|     friend exception_ptr current_exception(); |     friend exception_ptr current_exception() _NOEXCEPT; | ||||||
|     friend void rethrow_exception(exception_ptr);  // noreturn |     _ATTRIBUTE(noreturn) friend void rethrow_exception(exception_ptr); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template<class _E> | template<class _E> | ||||||
| exception_ptr | exception_ptr | ||||||
| make_exception_ptr(_E __e) | make_exception_ptr(_E __e) _NOEXCEPT | ||||||
| { | { | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     try |     try | ||||||
| @@ -166,14 +166,14 @@ class _LIBCPP_EXCEPTION_ABI nested_exception | |||||||
| { | { | ||||||
|     exception_ptr __ptr_; |     exception_ptr __ptr_; | ||||||
| public: | public: | ||||||
|     nested_exception(); |     nested_exception() _NOEXCEPT; | ||||||
| //     nested_exception(const nested_exception&) throw() = default; | //     nested_exception(const nested_exception&) noexcept = default; | ||||||
| //     nested_exception& operator=(const nested_exception&) throw() = default; | //     nested_exception& operator=(const nested_exception&) noexcept = default; | ||||||
|     virtual ~nested_exception(); |     virtual ~nested_exception() _NOEXCEPT; | ||||||
|  |  | ||||||
|     // access functions |     // access functions | ||||||
|     void rethrow_nested /*[[noreturn]]*/ () const; |     _ATTRIBUTE(noreturn) void rethrow_nested() const; | ||||||
|     _LIBCPP_INLINE_VISIBILITY exception_ptr nested_ptr() const {return __ptr_;} |     _LIBCPP_INLINE_VISIBILITY exception_ptr nested_ptr() const _NOEXCEPT {return __ptr_;} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _Tp> | template <class _Tp> | ||||||
| @@ -185,9 +185,10 @@ struct __nested | |||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _Tp> | template <class _Tp> | ||||||
|  | _ATTRIBUTE(noreturn) | ||||||
| void | void | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| throw_with_nested /*[[noreturn]]*/ (_Tp&& __t, typename enable_if< | throw_with_nested(_Tp&& __t, typename enable_if< | ||||||
|                   is_class<typename remove_reference<_Tp>::type>::value && |                   is_class<typename remove_reference<_Tp>::type>::value && | ||||||
|                   !is_base_of<nested_exception, typename remove_reference<_Tp>::type>::value |                   !is_base_of<nested_exception, typename remove_reference<_Tp>::type>::value | ||||||
|                                     >::type* = 0) |                                     >::type* = 0) | ||||||
| @@ -198,14 +199,15 @@ throw_with_nested (_Tp& __t, typename enable_if< | |||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| { | { | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     throw __nested<typename remove_reference<_Tp>::type>(_STD::forward<_Tp>(__t)); |     throw __nested<typename remove_reference<_Tp>::type>(_VSTD::forward<_Tp>(__t)); | ||||||
| #endif | #endif | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp> | template <class _Tp> | ||||||
|  | _ATTRIBUTE(noreturn) | ||||||
| void | void | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| throw_with_nested /*[[noreturn]]*/ (_Tp&& __t, typename enable_if< | throw_with_nested(_Tp&& __t, typename enable_if< | ||||||
|                   !is_class<typename remove_reference<_Tp>::type>::value || |                   !is_class<typename remove_reference<_Tp>::type>::value || | ||||||
|                   is_base_of<nested_exception, typename remove_reference<_Tp>::type>::value |                   is_base_of<nested_exception, typename remove_reference<_Tp>::type>::value | ||||||
|                                     >::type* = 0) |                                     >::type* = 0) | ||||||
| @@ -216,7 +218,7 @@ throw_with_nested (_Tp& __t, typename enable_if< | |||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| { | { | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     throw _STD::forward<_Tp>(__t); |     throw _VSTD::forward<_Tp>(__t); | ||||||
| #endif | #endif | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -204,7 +204,9 @@ template <class Key, class T, class Hash, class Pred, class Alloc> | |||||||
| #include <functional> | #include <functional> | ||||||
| #include <stdexcept> | #include <stdexcept> | ||||||
|  |  | ||||||
|  | #if __DEPRECATED | ||||||
| #warning Use of the header <ext/hash_map> is deprecated.  Migrate to <unordered_map> | #warning Use of the header <ext/hash_map> is deprecated.  Migrate to <unordered_map> | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #pragma GCC system_header | #pragma GCC system_header | ||||||
|  |  | ||||||
| @@ -341,9 +343,9 @@ public: | |||||||
|     void operator()(pointer __p) |     void operator()(pointer __p) | ||||||
|     { |     { | ||||||
|         if (__second_constructed) |         if (__second_constructed) | ||||||
|             __alloc_traits::destroy(__na_, _STD::addressof(__p->__value_.second)); |             __alloc_traits::destroy(__na_, _VSTD::addressof(__p->__value_.second)); | ||||||
|         if (__first_constructed) |         if (__first_constructed) | ||||||
|             __alloc_traits::destroy(__na_, _STD::addressof(__p->__value_.first)); |             __alloc_traits::destroy(__na_, _VSTD::addressof(__p->__value_.first)); | ||||||
|         if (__p) |         if (__p) | ||||||
|             __alloc_traits::deallocate(__na_, __p, 1); |             __alloc_traits::deallocate(__na_, __p, 1); | ||||||
|     } |     } | ||||||
| @@ -666,11 +668,11 @@ hash_map<_Key, _Tp, _Hash, _Pred, _Alloc>::__construct_node(const key_type& __k) | |||||||
| { | { | ||||||
|     __node_allocator& __na = __table_.__node_alloc(); |     __node_allocator& __na = __table_.__node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.first), __k); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.first), __k); | ||||||
|     __h.get_deleter().__first_constructed = true; |     __h.get_deleter().__first_constructed = true; | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.second)); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.second)); | ||||||
|     __h.get_deleter().__second_constructed = true; |     __h.get_deleter().__second_constructed = true; | ||||||
|     return _STD::move(__h); |     return _VSTD::move(__h); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | ||||||
| @@ -963,9 +965,9 @@ operator==(const hash_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>& __x, | |||||||
|     { |     { | ||||||
|         _EqRng __xeq = __x.equal_range(__i->first); |         _EqRng __xeq = __x.equal_range(__i->first); | ||||||
|         _EqRng __yeq = __y.equal_range(__i->first); |         _EqRng __yeq = __y.equal_range(__i->first); | ||||||
|         if (_STD::distance(__xeq.first, __xeq.second) != |         if (_VSTD::distance(__xeq.first, __xeq.second) != | ||||||
|             _STD::distance(__yeq.first, __yeq.second) || |             _VSTD::distance(__yeq.first, __yeq.second) || | ||||||
|                   !_STD::is_permutation(__xeq.first, __xeq.second, __yeq.first)) |                   !_VSTD::is_permutation(__xeq.first, __xeq.second, __yeq.first)) | ||||||
|             return false; |             return false; | ||||||
|         __i = __xeq.second; |         __i = __xeq.second; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -197,7 +197,9 @@ template <class Value, class Hash, class Pred, class Alloc> | |||||||
| #include <__hash_table> | #include <__hash_table> | ||||||
| #include <functional> | #include <functional> | ||||||
|  |  | ||||||
|  | #if __DEPRECATED | ||||||
| #warning Use of the header <ext/hash_set> is deprecated.  Migrate to <unordered_set> | #warning Use of the header <ext/hash_set> is deprecated.  Migrate to <unordered_set> | ||||||
|  | #endif | ||||||
|  |  | ||||||
| namespace __gnu_cxx { | namespace __gnu_cxx { | ||||||
|  |  | ||||||
| @@ -627,9 +629,9 @@ operator==(const hash_multiset<_Value, _Hash, _Pred, _Alloc>& __x, | |||||||
|     { |     { | ||||||
|         _EqRng __xeq = __x.equal_range(*__i); |         _EqRng __xeq = __x.equal_range(*__i); | ||||||
|         _EqRng __yeq = __y.equal_range(*__i); |         _EqRng __yeq = __y.equal_range(*__i); | ||||||
|         if (_STD::distance(__xeq.first, __xeq.second) != |         if (_VSTD::distance(__xeq.first, __xeq.second) != | ||||||
|             _STD::distance(__yeq.first, __yeq.second) || |             _VSTD::distance(__yeq.first, __yeq.second) || | ||||||
|                   !_STD::is_permutation(__xeq.first, __xeq.second, __yeq.first)) |                   !_VSTD::is_permutation(__xeq.first, __xeq.second, __yeq.first)) | ||||||
|             return false; |             return false; | ||||||
|         __i = __xeq.second; |         __i = __xeq.second; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -34,7 +34,8 @@ public: | |||||||
|     typedef <details> iterator; |     typedef <details> iterator; | ||||||
|     typedef <details> const_iterator; |     typedef <details> const_iterator; | ||||||
|  |  | ||||||
|     forward_list(); |     forward_list() | ||||||
|  |         noexcept(is_nothrow_default_constructible<allocator_type>::value); | ||||||
|     explicit forward_list(const allocator_type& a); |     explicit forward_list(const allocator_type& a); | ||||||
|     explicit forward_list(size_type n); |     explicit forward_list(size_type n); | ||||||
|     forward_list(size_type n, const value_type& v); |     forward_list(size_type n, const value_type& v); | ||||||
| @@ -45,7 +46,8 @@ public: | |||||||
|         forward_list(InputIterator first, InputIterator last, const allocator_type& a); |         forward_list(InputIterator first, InputIterator last, const allocator_type& a); | ||||||
|     forward_list(const forward_list& x); |     forward_list(const forward_list& x); | ||||||
|     forward_list(const forward_list& x, const allocator_type& a); |     forward_list(const forward_list& x, const allocator_type& a); | ||||||
|     forward_list(forward_list&& x); |     forward_list(forward_list&& x) | ||||||
|  |         noexcept(is_nothrow_move_constructible<allocator_type>::value); | ||||||
|     forward_list(forward_list&& x, const allocator_type& a); |     forward_list(forward_list&& x, const allocator_type& a); | ||||||
|     forward_list(initializer_list<value_type> il); |     forward_list(initializer_list<value_type> il); | ||||||
|     forward_list(initializer_list<value_type> il, const allocator_type& a); |     forward_list(initializer_list<value_type> il, const allocator_type& a); | ||||||
| @@ -53,7 +55,10 @@ public: | |||||||
|     ~forward_list(); |     ~forward_list(); | ||||||
|  |  | ||||||
|     forward_list& operator=(const forward_list& x); |     forward_list& operator=(const forward_list& x); | ||||||
|     forward_list& operator=(forward_list&& x); |     forward_list& operator=(forward_list&& x) | ||||||
|  |         noexcept( | ||||||
|  |              allocator_type::propagate_on_container_move_assignment::value && | ||||||
|  |              is_nothrow_move_assignable<allocator_type>::value); | ||||||
|     forward_list& operator=(initializer_list<value_type> il); |     forward_list& operator=(initializer_list<value_type> il); | ||||||
|  |  | ||||||
|     template <class InputIterator> |     template <class InputIterator> | ||||||
| @@ -61,22 +66,22 @@ public: | |||||||
|     void assign(size_type n, const value_type& v); |     void assign(size_type n, const value_type& v); | ||||||
|     void assign(initializer_list<value_type> il); |     void assign(initializer_list<value_type> il); | ||||||
|  |  | ||||||
|     allocator_type get_allocator() const; |     allocator_type get_allocator() const noexcept; | ||||||
|  |  | ||||||
|     iterator       begin(); |     iterator       begin() noexcept; | ||||||
|     const_iterator begin() const; |     const_iterator begin() const noexcept; | ||||||
|     iterator       end(); |     iterator       end() noexcept; | ||||||
|     const_iterator end() const; |     const_iterator end() const noexcept; | ||||||
|  |  | ||||||
|     const_iterator cbegin() const; |     const_iterator cbegin() const noexcept; | ||||||
|     const_iterator cend() const; |     const_iterator cend() const noexcept; | ||||||
|  |  | ||||||
|     iterator       before_begin(); |     iterator       before_begin() noexcept; | ||||||
|     const_iterator before_begin() const; |     const_iterator before_begin() const noexcept; | ||||||
|     const_iterator cbefore_begin() const; |     const_iterator cbefore_begin() const noexcept; | ||||||
|  |  | ||||||
|     bool empty() const; |     bool empty() const noexcept; | ||||||
|     size_type max_size() const; |     size_type max_size() const noexcept; | ||||||
|  |  | ||||||
|     reference       front(); |     reference       front(); | ||||||
|     const_reference front() const; |     const_reference front() const; | ||||||
| @@ -100,11 +105,13 @@ public: | |||||||
|     iterator erase_after(const_iterator p); |     iterator erase_after(const_iterator p); | ||||||
|     iterator erase_after(const_iterator first, const_iterator last); |     iterator erase_after(const_iterator first, const_iterator last); | ||||||
|  |  | ||||||
|     void swap(forward_list& x); |     void swap(forward_list& x) | ||||||
|  |         noexcept(!allocator_type::propagate_on_container_swap::value || | ||||||
|  |                  __is_nothrow_swappable<allocator_type>::value); | ||||||
|  |  | ||||||
|     void resize(size_type n); |     void resize(size_type n); | ||||||
|     void resize(size_type n, const value_type& v); |     void resize(size_type n, const value_type& v); | ||||||
|     void clear(); |     void clear() noexcept; | ||||||
|  |  | ||||||
|     void splice_after(const_iterator p, forward_list& x); |     void splice_after(const_iterator p, forward_list& x); | ||||||
|     void splice_after(const_iterator p, forward_list&& x); |     void splice_after(const_iterator p, forward_list&& x); | ||||||
| @@ -124,7 +131,7 @@ public: | |||||||
|     template <class Compare> void merge(forward_list&& x, Compare comp); |     template <class Compare> void merge(forward_list&& x, Compare comp); | ||||||
|     void sort(); |     void sort(); | ||||||
|     template <class Compare> void sort(Compare comp); |     template <class Compare> void sort(Compare comp); | ||||||
|     void reverse(); |     void reverse() noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class T, class Allocator> | template <class T, class Allocator> | ||||||
| @@ -152,7 +159,8 @@ template <class T, class Allocator> | |||||||
|                     const forward_list<T, Allocator>& y); |                     const forward_list<T, Allocator>& y); | ||||||
|  |  | ||||||
| template <class T, class Allocator> | template <class T, class Allocator> | ||||||
|     void swap(forward_list<T, Allocator>& x, forward_list<T, Allocator>& y); |     void swap(forward_list<T, Allocator>& x, forward_list<T, Allocator>& y) | ||||||
|  |          noexcept(noexcept(x.swap(y))); | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
|  |  | ||||||
| @@ -170,7 +178,7 @@ template <class T, class Allocator> | |||||||
|  |  | ||||||
| _LIBCPP_BEGIN_NAMESPACE_STD | _LIBCPP_BEGIN_NAMESPACE_STD | ||||||
|  |  | ||||||
| template <class, class> struct __forward_list_node; | template <class _Tp, class _VoidPtr> struct __forward_list_node; | ||||||
|  |  | ||||||
| template <class _NodePtr> | template <class _NodePtr> | ||||||
| struct __forward_begin_node | struct __forward_begin_node | ||||||
| @@ -200,8 +208,8 @@ struct __forward_list_node | |||||||
|     value_type __value_; |     value_type __value_; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template<class, class> class forward_list; | template<class _Tp, class _Alloc> class forward_list; | ||||||
| template<class> class __forward_list_const_iterator; | template<class _NodeConstPtr> class __forward_list_const_iterator; | ||||||
|  |  | ||||||
| template <class _NodePtr> | template <class _NodePtr> | ||||||
| class _LIBCPP_VISIBLE __forward_list_iterator | class _LIBCPP_VISIBLE __forward_list_iterator | ||||||
| @@ -211,7 +219,7 @@ class _LIBCPP_VISIBLE __forward_list_iterator | |||||||
|     __node_pointer __ptr_; |     __node_pointer __ptr_; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __forward_list_iterator(__node_pointer __p) : __ptr_(__p) {} |     explicit __forward_list_iterator(__node_pointer __p) _NOEXCEPT : __ptr_(__p) {} | ||||||
|  |  | ||||||
|     template<class, class> friend class forward_list; |     template<class, class> friend class forward_list; | ||||||
|     template<class> friend class __forward_list_const_iterator; |     template<class> friend class __forward_list_const_iterator; | ||||||
| @@ -232,7 +240,7 @@ public: | |||||||
|                                                               pointer; |                                                               pointer; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __forward_list_iterator() : __ptr_(nullptr) {} |     __forward_list_iterator() _NOEXCEPT : __ptr_(nullptr) {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     reference operator*() const {return __ptr_->__value_;} |     reference operator*() const {return __ptr_->__value_;} | ||||||
| @@ -271,7 +279,7 @@ class _LIBCPP_VISIBLE __forward_list_const_iterator | |||||||
|     __node_const_pointer __ptr_; |     __node_const_pointer __ptr_; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __forward_list_const_iterator(__node_const_pointer __p) |     explicit __forward_list_const_iterator(__node_const_pointer __p) _NOEXCEPT | ||||||
|         : __ptr_(__p) {} |         : __ptr_(__p) {} | ||||||
|  |  | ||||||
|     typedef typename remove_const |     typedef typename remove_const | ||||||
| @@ -303,9 +311,9 @@ public: | |||||||
|                                                               pointer; |                                                               pointer; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __forward_list_const_iterator() : __ptr_(nullptr) {} |     __forward_list_const_iterator() _NOEXCEPT : __ptr_(nullptr) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __forward_list_const_iterator(__forward_list_iterator<__node_pointer> __p) |     __forward_list_const_iterator(__forward_list_iterator<__node_pointer> __p) _NOEXCEPT | ||||||
|         : __ptr_(__p.__ptr_) {} |         : __ptr_(__p.__ptr_) {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -361,41 +369,47 @@ protected: | |||||||
|     __compressed_pair<__begin_node, __node_allocator> __before_begin_; |     __compressed_pair<__begin_node, __node_allocator> __before_begin_; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __node_pointer        __before_begin() |     __node_pointer        __before_begin() _NOEXCEPT | ||||||
|         {return pointer_traits<__node_pointer>::pointer_to( |         {return pointer_traits<__node_pointer>::pointer_to( | ||||||
|                                 static_cast<__node&>(__before_begin_.first()));} |                                 static_cast<__node&>(__before_begin_.first()));} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __node_const_pointer  __before_begin() const |     __node_const_pointer  __before_begin() const _NOEXCEPT | ||||||
|         {return pointer_traits<__node_const_pointer>::pointer_to( |         {return pointer_traits<__node_const_pointer>::pointer_to( | ||||||
|                           static_cast<const __node&>(__before_begin_.first()));} |                           static_cast<const __node&>(__before_begin_.first()));} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           __node_allocator& __alloc()       {return __before_begin_.second();} |           __node_allocator& __alloc() _NOEXCEPT | ||||||
|  |             {return __before_begin_.second();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const __node_allocator& __alloc() const {return __before_begin_.second();} |     const __node_allocator& __alloc() const _NOEXCEPT | ||||||
|  |         {return __before_begin_.second();} | ||||||
|  |  | ||||||
|     typedef __forward_list_iterator<__node_pointer>             iterator; |     typedef __forward_list_iterator<__node_pointer>             iterator; | ||||||
|     typedef __forward_list_const_iterator<__node_const_pointer> const_iterator; |     typedef __forward_list_const_iterator<__node_const_pointer> const_iterator; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __forward_list_base() |     __forward_list_base() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<__node_allocator>::value) | ||||||
|         : __before_begin_(__begin_node()) {} |         : __before_begin_(__begin_node()) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __forward_list_base(const allocator_type& __a) |     __forward_list_base(const allocator_type& __a) | ||||||
|         : __before_begin_(__begin_node(), __node_allocator(__a)) {} |         : __before_begin_(__begin_node(), __node_allocator(__a)) {} | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     __forward_list_base(__forward_list_base&& __x); | public: | ||||||
|  |     __forward_list_base(__forward_list_base&& __x) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_constructible<__node_allocator>::value); | ||||||
|     __forward_list_base(__forward_list_base&& __x, const allocator_type& __a); |     __forward_list_base(__forward_list_base&& __x, const allocator_type& __a); | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     __forward_list_base(const __forward_list_base&); |     __forward_list_base(const __forward_list_base&); | ||||||
|     __forward_list_base& operator=(const __forward_list_base&); |     __forward_list_base& operator=(const __forward_list_base&); | ||||||
| protected: |  | ||||||
|  |  | ||||||
|  | public: | ||||||
|     ~__forward_list_base(); |     ~__forward_list_base(); | ||||||
|  |  | ||||||
|  | protected: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void __copy_assign_alloc(const __forward_list_base& __x) |     void __copy_assign_alloc(const __forward_list_base& __x) | ||||||
|         {__copy_assign_alloc(__x, integral_constant<bool, |         {__copy_assign_alloc(__x, integral_constant<bool, | ||||||
| @@ -403,11 +417,17 @@ protected: | |||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void __move_assign_alloc(__forward_list_base& __x) |     void __move_assign_alloc(__forward_list_base& __x) | ||||||
|  |         _NOEXCEPT_(!__node_traits::propagate_on_container_move_assignment::value || | ||||||
|  |                    is_nothrow_move_assignable<__node_allocator>::value) | ||||||
|         {__move_assign_alloc(__x, integral_constant<bool, |         {__move_assign_alloc(__x, integral_constant<bool, | ||||||
|               __node_traits::propagate_on_container_move_assignment::value>());} |               __node_traits::propagate_on_container_move_assignment::value>());} | ||||||
|  |  | ||||||
|     void swap(__forward_list_base& __x); | public: | ||||||
|     void clear(); |     void swap(__forward_list_base& __x) | ||||||
|  |         _NOEXCEPT_(!__node_traits::propagate_on_container_swap::value || | ||||||
|  |                    __is_nothrow_swappable<__node_allocator>::value); | ||||||
|  | protected: | ||||||
|  |     void clear() _NOEXCEPT; | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -421,24 +441,30 @@ private: | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void __move_assign_alloc(__forward_list_base& __x, false_type) {} |     void __move_assign_alloc(__forward_list_base& __x, false_type) _NOEXCEPT | ||||||
|  |         {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void __move_assign_alloc(__forward_list_base& __x, true_type) |     void __move_assign_alloc(__forward_list_base& __x, true_type) | ||||||
|         {__alloc() = _STD::move(__x.__alloc());} |         _NOEXCEPT_(is_nothrow_move_assignable<__node_allocator>::value) | ||||||
|  |         {__alloc() = _VSTD::move(__x.__alloc());} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     static void __swap_alloc(__node_allocator& __x, __node_allocator& __y) |     static void __swap_alloc(__node_allocator& __x, __node_allocator& __y) | ||||||
|  |         _NOEXCEPT_(!__node_traits::propagate_on_container_swap::value || | ||||||
|  |                    __is_nothrow_swappable<__node_allocator>::value) | ||||||
|         {__swap_alloc(__x, __y, integral_constant<bool, |         {__swap_alloc(__x, __y, integral_constant<bool, | ||||||
|                          __node_traits::propagate_on_container_swap::value>());} |                          __node_traits::propagate_on_container_swap::value>());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     static void __swap_alloc(__node_allocator& __x, __node_allocator& __y, |     static void __swap_alloc(__node_allocator& __x, __node_allocator& __y, | ||||||
|                                                                      false_type) |                                                                      false_type) | ||||||
|  |         _NOEXCEPT | ||||||
|         {} |         {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     static void __swap_alloc(__node_allocator& __x, __node_allocator& __y, |     static void __swap_alloc(__node_allocator& __x, __node_allocator& __y, | ||||||
|                                                                       true_type) |                                                                       true_type) | ||||||
|  |         _NOEXCEPT_(__is_nothrow_swappable<__node_allocator>::value) | ||||||
|         { |         { | ||||||
|             using _STD::swap; |             using _VSTD::swap; | ||||||
|             swap(__x, __y); |             swap(__x, __y); | ||||||
|         } |         } | ||||||
| }; | }; | ||||||
| @@ -448,7 +474,8 @@ private: | |||||||
| template <class _Tp, class _Alloc> | template <class _Tp, class _Alloc> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| __forward_list_base<_Tp, _Alloc>::__forward_list_base(__forward_list_base&& __x) | __forward_list_base<_Tp, _Alloc>::__forward_list_base(__forward_list_base&& __x) | ||||||
|     : __before_begin_(_STD::move(__x.__before_begin_)) |         _NOEXCEPT_(is_nothrow_move_constructible<__node_allocator>::value) | ||||||
|  |     : __before_begin_(_VSTD::move(__x.__before_begin_)) | ||||||
| { | { | ||||||
|     __x.__before_begin()->__next_ = nullptr; |     __x.__before_begin()->__next_ = nullptr; | ||||||
| } | } | ||||||
| @@ -478,21 +505,23 @@ template <class _Tp, class _Alloc> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| void | void | ||||||
| __forward_list_base<_Tp, _Alloc>::swap(__forward_list_base& __x) | __forward_list_base<_Tp, _Alloc>::swap(__forward_list_base& __x) | ||||||
|  |         _NOEXCEPT_(!__node_traits::propagate_on_container_swap::value || | ||||||
|  |                    __is_nothrow_swappable<__node_allocator>::value) | ||||||
| { | { | ||||||
|     __swap_alloc(__alloc(), __x.__alloc()); |     __swap_alloc(__alloc(), __x.__alloc()); | ||||||
|     using _STD::swap; |     using _VSTD::swap; | ||||||
|     swap(__before_begin()->__next_, __x.__before_begin()->__next_); |     swap(__before_begin()->__next_, __x.__before_begin()->__next_); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, class _Alloc> | template <class _Tp, class _Alloc> | ||||||
| void | void | ||||||
| __forward_list_base<_Tp, _Alloc>::clear() | __forward_list_base<_Tp, _Alloc>::clear() _NOEXCEPT | ||||||
| { | { | ||||||
|     __node_allocator& __a = __alloc(); |     __node_allocator& __a = __alloc(); | ||||||
|     for (__node_pointer __p = __before_begin()->__next_; __p != nullptr;) |     for (__node_pointer __p = __before_begin()->__next_; __p != nullptr;) | ||||||
|     { |     { | ||||||
|         __node_pointer __next = __p->__next_; |         __node_pointer __next = __p->__next_; | ||||||
|         __node_traits::destroy(__a, _STD::addressof(__p->__value_)); |         __node_traits::destroy(__a, _VSTD::addressof(__p->__value_)); | ||||||
|         __node_traits::deallocate(__a, __p, 1); |         __node_traits::deallocate(__a, __p, 1); | ||||||
|         __p = __next; |         __p = __next; | ||||||
|     } |     } | ||||||
| @@ -504,6 +533,11 @@ class _LIBCPP_VISIBLE forward_list | |||||||
|     : private __forward_list_base<_Tp, _Alloc> |     : private __forward_list_base<_Tp, _Alloc> | ||||||
| { | { | ||||||
|     typedef __forward_list_base<_Tp, _Alloc> base; |     typedef __forward_list_base<_Tp, _Alloc> base; | ||||||
|  |     typedef typename base::__node_allocator  __node_allocator; | ||||||
|  |     typedef typename base::__node            __node; | ||||||
|  |     typedef typename base::__node_traits     __node_traits; | ||||||
|  |     typedef typename base::__node_pointer    __node_pointer; | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     typedef _Tp    value_type; |     typedef _Tp    value_type; | ||||||
|     typedef _Alloc allocator_type; |     typedef _Alloc allocator_type; | ||||||
| @@ -518,7 +552,10 @@ public: | |||||||
|     typedef typename base::iterator       iterator; |     typedef typename base::iterator       iterator; | ||||||
|     typedef typename base::const_iterator const_iterator; |     typedef typename base::const_iterator const_iterator; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY forward_list() {} // = default; |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     forward_list() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<__node_allocator>::value) | ||||||
|  |         {} // = default; | ||||||
|     explicit forward_list(const allocator_type& __a); |     explicit forward_list(const allocator_type& __a); | ||||||
|     explicit forward_list(size_type __n); |     explicit forward_list(size_type __n); | ||||||
|     forward_list(size_type __n, const value_type& __v); |     forward_list(size_type __n, const value_type& __v); | ||||||
| @@ -538,7 +575,9 @@ public: | |||||||
|     forward_list(const forward_list& __x, const allocator_type& __a); |     forward_list(const forward_list& __x, const allocator_type& __a); | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     forward_list(forward_list&& __x) : base(_STD::move(__x)) {} |     forward_list(forward_list&& __x) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_constructible<base>::value) | ||||||
|  |         : base(_VSTD::move(__x)) {} | ||||||
|     forward_list(forward_list&& __x, const allocator_type& __a); |     forward_list(forward_list&& __x, const allocator_type& __a); | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     forward_list(initializer_list<value_type> __il); |     forward_list(initializer_list<value_type> __il); | ||||||
| @@ -548,7 +587,10 @@ public: | |||||||
|  |  | ||||||
|     forward_list& operator=(const forward_list& __x); |     forward_list& operator=(const forward_list& __x); | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     forward_list& operator=(forward_list&& __x); |     forward_list& operator=(forward_list&& __x) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |              __node_traits::propagate_on_container_move_assignment::value && | ||||||
|  |              is_nothrow_move_assignable<allocator_type>::value); | ||||||
| #endif | #endif | ||||||
|     forward_list& operator=(initializer_list<value_type> __il); |     forward_list& operator=(initializer_list<value_type> __il); | ||||||
|  |  | ||||||
| @@ -563,33 +605,45 @@ public: | |||||||
|     void assign(initializer_list<value_type> __il); |     void assign(initializer_list<value_type> __il); | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     allocator_type get_allocator() const {return allocator_type(base::__alloc());} |     allocator_type get_allocator() const _NOEXCEPT | ||||||
|  |         {return allocator_type(base::__alloc());} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator       begin()       {return       iterator(base::__before_begin()->__next_);} |     iterator       begin() _NOEXCEPT | ||||||
|  |         {return       iterator(base::__before_begin()->__next_);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator begin() const {return const_iterator(base::__before_begin()->__next_);} |     const_iterator begin() const _NOEXCEPT | ||||||
|  |         {return const_iterator(base::__before_begin()->__next_);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator       end()         {return       iterator(nullptr);} |     iterator       end() _NOEXCEPT | ||||||
|  |         {return       iterator(nullptr);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator end() const   {return const_iterator(nullptr);} |     const_iterator end() const _NOEXCEPT | ||||||
|  |         {return const_iterator(nullptr);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator cbegin() const {return const_iterator(base::__before_begin()->__next_);} |     const_iterator cbegin() const _NOEXCEPT | ||||||
|  |         {return const_iterator(base::__before_begin()->__next_);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator cend() const   {return const_iterator(nullptr);} |     const_iterator cend() const _NOEXCEPT | ||||||
|  |         {return const_iterator(nullptr);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator       before_begin()        {return       iterator(base::__before_begin());} |     iterator       before_begin() _NOEXCEPT | ||||||
|  |         {return       iterator(base::__before_begin());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator before_begin() const  {return const_iterator(base::__before_begin());} |     const_iterator before_begin() const _NOEXCEPT | ||||||
|  |         {return const_iterator(base::__before_begin());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator cbefore_begin() const {return const_iterator(base::__before_begin());} |     const_iterator cbefore_begin() const _NOEXCEPT | ||||||
|  |         {return const_iterator(base::__before_begin());} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool empty() const {return base::__before_begin()->__next_ == nullptr;} |     bool empty() const _NOEXCEPT | ||||||
|  |         {return base::__before_begin()->__next_ == nullptr;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type max_size() const {return numeric_limits<size_type>::max();} |     size_type max_size() const _NOEXCEPT | ||||||
|  |         {return numeric_limits<size_type>::max();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     reference       front()       {return base::__before_begin()->__next_->__value_;} |     reference       front()       {return base::__before_begin()->__next_->__value_;} | ||||||
| @@ -630,12 +684,15 @@ public: | |||||||
|     iterator erase_after(const_iterator __f, const_iterator __l); |     iterator erase_after(const_iterator __f, const_iterator __l); | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(forward_list& __x) {base::swap(__x);} |     void swap(forward_list& __x) | ||||||
|  |         _NOEXCEPT_(!__node_traits::propagate_on_container_swap::value || | ||||||
|  |                    __is_nothrow_swappable<__node_allocator>::value) | ||||||
|  |         {base::swap(__x);} | ||||||
|  |  | ||||||
|     void resize(size_type __n); |     void resize(size_type __n); | ||||||
|     void resize(size_type __n, const value_type& __v); |     void resize(size_type __n, const value_type& __v); | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void clear() {base::clear();} |     void clear() _NOEXCEPT {base::clear();} | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -661,7 +718,7 @@ public: | |||||||
|     template <class _Compare> |     template <class _Compare> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         void merge(forward_list&& __x, _Compare __comp) |         void merge(forward_list&& __x, _Compare __comp) | ||||||
|         {merge(__x, _STD::move(__comp));} |         {merge(__x, _VSTD::move(__comp));} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void merge(forward_list& __x) {merge(__x, __less<value_type>());} |     void merge(forward_list& __x) {merge(__x, __less<value_type>());} | ||||||
| @@ -669,16 +726,13 @@ public: | |||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void sort() {sort(__less<value_type>());} |     void sort() {sort(__less<value_type>());} | ||||||
|     template <class _Compare> void sort(_Compare __comp); |     template <class _Compare> void sort(_Compare __comp); | ||||||
|     void reverse(); |     void reverse() _NOEXCEPT; | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     typedef typename base::__node_allocator  __node_allocator; |  | ||||||
|     typedef typename base::__node            __node; |  | ||||||
|     typedef typename base::__node_traits     __node_traits; |  | ||||||
|     typedef typename base::__node_pointer    __node_pointer; |  | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     void __move_assign(forward_list& __x, true_type); |     void __move_assign(forward_list& __x, true_type) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_assignable<allocator_type>::value); | ||||||
|     void __move_assign(forward_list& __x, false_type); |     void __move_assign(forward_list& __x, false_type); | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
| @@ -712,7 +766,7 @@ forward_list<_Tp, _Alloc>::forward_list(size_type __n) | |||||||
|                                                              __p = __p->__next_) |                                                              __p = __p->__next_) | ||||||
|         { |         { | ||||||
|             __h.reset(__node_traits::allocate(__a, 1)); |             __h.reset(__node_traits::allocate(__a, 1)); | ||||||
|             __node_traits::construct(__a, _STD::addressof(__h->__value_)); |             __node_traits::construct(__a, _VSTD::addressof(__h->__value_)); | ||||||
|             __h->__next_ = nullptr; |             __h->__next_ = nullptr; | ||||||
|             __p->__next_ = __h.release(); |             __p->__next_ = __h.release(); | ||||||
|         } |         } | ||||||
| @@ -778,7 +832,7 @@ forward_list<_Tp, _Alloc>::forward_list(const forward_list& __x, | |||||||
| template <class _Tp, class _Alloc> | template <class _Tp, class _Alloc> | ||||||
| forward_list<_Tp, _Alloc>::forward_list(forward_list&& __x, | forward_list<_Tp, _Alloc>::forward_list(forward_list&& __x, | ||||||
|                                         const allocator_type& __a) |                                         const allocator_type& __a) | ||||||
|     : base(_STD::move(__x), __a) |     : base(_VSTD::move(__x), __a) | ||||||
| { | { | ||||||
|     if (base::__alloc() != __x.__alloc()) |     if (base::__alloc() != __x.__alloc()) | ||||||
|     { |     { | ||||||
| @@ -820,6 +874,7 @@ forward_list<_Tp, _Alloc>::operator=(const forward_list& __x) | |||||||
| template <class _Tp, class _Alloc> | template <class _Tp, class _Alloc> | ||||||
| void | void | ||||||
| forward_list<_Tp, _Alloc>::__move_assign(forward_list& __x, true_type) | forward_list<_Tp, _Alloc>::__move_assign(forward_list& __x, true_type) | ||||||
|  |     _NOEXCEPT_(is_nothrow_move_assignable<allocator_type>::value) | ||||||
| { | { | ||||||
|     clear(); |     clear(); | ||||||
|     base::__move_assign_alloc(__x); |     base::__move_assign_alloc(__x); | ||||||
| @@ -844,6 +899,9 @@ template <class _Tp, class _Alloc> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| forward_list<_Tp, _Alloc>& | forward_list<_Tp, _Alloc>& | ||||||
| forward_list<_Tp, _Alloc>::operator=(forward_list&& __x) | forward_list<_Tp, _Alloc>::operator=(forward_list&& __x) | ||||||
|  |     _NOEXCEPT_( | ||||||
|  |              __node_traits::propagate_on_container_move_assignment::value && | ||||||
|  |              is_nothrow_move_assignable<allocator_type>::value) | ||||||
| { | { | ||||||
|     __move_assign(__x, integral_constant<bool, |     __move_assign(__x, integral_constant<bool, | ||||||
|           __node_traits::propagate_on_container_move_assignment::value>()); |           __node_traits::propagate_on_container_move_assignment::value>()); | ||||||
| @@ -871,7 +929,7 @@ typename enable_if | |||||||
| forward_list<_Tp, _Alloc>::assign(_InputIterator __f, _InputIterator __l) | forward_list<_Tp, _Alloc>::assign(_InputIterator __f, _InputIterator __l) | ||||||
| { | { | ||||||
|     iterator __i = before_begin(); |     iterator __i = before_begin(); | ||||||
|     iterator __j = _STD::next(__i); |     iterator __j = _VSTD::next(__i); | ||||||
|     iterator __e = end(); |     iterator __e = end(); | ||||||
|     for (; __j != __e && __f != __l; ++__i, ++__j, ++__f) |     for (; __j != __e && __f != __l; ++__i, ++__j, ++__f) | ||||||
|         *__j = *__f; |         *__j = *__f; | ||||||
| @@ -886,7 +944,7 @@ void | |||||||
| forward_list<_Tp, _Alloc>::assign(size_type __n, const value_type& __v) | forward_list<_Tp, _Alloc>::assign(size_type __n, const value_type& __v) | ||||||
| { | { | ||||||
|     iterator __i = before_begin(); |     iterator __i = before_begin(); | ||||||
|     iterator __j = _STD::next(__i); |     iterator __j = _VSTD::next(__i); | ||||||
|     iterator __e = end(); |     iterator __e = end(); | ||||||
|     for (; __j != __e && __n > 0; --__n, ++__i, ++__j) |     for (; __j != __e && __n > 0; --__n, ++__i, ++__j) | ||||||
|         *__j = __v; |         *__j = __v; | ||||||
| @@ -915,8 +973,8 @@ forward_list<_Tp, _Alloc>::emplace_front(_Args&&... __args) | |||||||
|     __node_allocator& __a = base::__alloc(); |     __node_allocator& __a = base::__alloc(); | ||||||
|     typedef __allocator_destructor<__node_allocator> _D; |     typedef __allocator_destructor<__node_allocator> _D; | ||||||
|     unique_ptr<__node, _D> __h(__node_traits::allocate(__a, 1), _D(__a, 1)); |     unique_ptr<__node, _D> __h(__node_traits::allocate(__a, 1), _D(__a, 1)); | ||||||
|     __node_traits::construct(__a, _STD::addressof(__h->__value_), |     __node_traits::construct(__a, _VSTD::addressof(__h->__value_), | ||||||
|                                   _STD::forward<_Args>(__args)...); |                                   _VSTD::forward<_Args>(__args)...); | ||||||
|     __h->__next_ = base::__before_begin()->__next_; |     __h->__next_ = base::__before_begin()->__next_; | ||||||
|     base::__before_begin()->__next_ = __h.release(); |     base::__before_begin()->__next_ = __h.release(); | ||||||
| } | } | ||||||
| @@ -930,7 +988,7 @@ forward_list<_Tp, _Alloc>::push_front(value_type&& __v) | |||||||
|     __node_allocator& __a = base::__alloc(); |     __node_allocator& __a = base::__alloc(); | ||||||
|     typedef __allocator_destructor<__node_allocator> _D; |     typedef __allocator_destructor<__node_allocator> _D; | ||||||
|     unique_ptr<__node, _D> __h(__node_traits::allocate(__a, 1), _D(__a, 1)); |     unique_ptr<__node, _D> __h(__node_traits::allocate(__a, 1), _D(__a, 1)); | ||||||
|     __node_traits::construct(__a, _STD::addressof(__h->__value_), _STD::move(__v)); |     __node_traits::construct(__a, _VSTD::addressof(__h->__value_), _VSTD::move(__v)); | ||||||
|     __h->__next_ = base::__before_begin()->__next_; |     __h->__next_ = base::__before_begin()->__next_; | ||||||
|     base::__before_begin()->__next_ = __h.release(); |     base::__before_begin()->__next_ = __h.release(); | ||||||
| } | } | ||||||
| @@ -944,7 +1002,7 @@ forward_list<_Tp, _Alloc>::push_front(const value_type& __v) | |||||||
|     __node_allocator& __a = base::__alloc(); |     __node_allocator& __a = base::__alloc(); | ||||||
|     typedef __allocator_destructor<__node_allocator> _D; |     typedef __allocator_destructor<__node_allocator> _D; | ||||||
|     unique_ptr<__node, _D> __h(__node_traits::allocate(__a, 1), _D(__a, 1)); |     unique_ptr<__node, _D> __h(__node_traits::allocate(__a, 1), _D(__a, 1)); | ||||||
|     __node_traits::construct(__a, _STD::addressof(__h->__value_), __v); |     __node_traits::construct(__a, _VSTD::addressof(__h->__value_), __v); | ||||||
|     __h->__next_ = base::__before_begin()->__next_; |     __h->__next_ = base::__before_begin()->__next_; | ||||||
|     base::__before_begin()->__next_ = __h.release(); |     base::__before_begin()->__next_ = __h.release(); | ||||||
| } | } | ||||||
| @@ -956,7 +1014,7 @@ forward_list<_Tp, _Alloc>::pop_front() | |||||||
|     __node_allocator& __a = base::__alloc(); |     __node_allocator& __a = base::__alloc(); | ||||||
|     __node_pointer __p = base::__before_begin()->__next_; |     __node_pointer __p = base::__before_begin()->__next_; | ||||||
|     base::__before_begin()->__next_ = __p->__next_; |     base::__before_begin()->__next_ = __p->__next_; | ||||||
|     __node_traits::destroy(__a, _STD::addressof(__p->__value_)); |     __node_traits::destroy(__a, _VSTD::addressof(__p->__value_)); | ||||||
|     __node_traits::deallocate(__a, __p, 1); |     __node_traits::deallocate(__a, __p, 1); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -972,8 +1030,8 @@ forward_list<_Tp, _Alloc>::emplace_after(const_iterator __p, _Args&&... __args) | |||||||
|     __node_allocator& __a = base::__alloc(); |     __node_allocator& __a = base::__alloc(); | ||||||
|     typedef __allocator_destructor<__node_allocator> _D; |     typedef __allocator_destructor<__node_allocator> _D; | ||||||
|     unique_ptr<__node, _D> __h(__node_traits::allocate(__a, 1), _D(__a, 1)); |     unique_ptr<__node, _D> __h(__node_traits::allocate(__a, 1), _D(__a, 1)); | ||||||
|     __node_traits::construct(__a, _STD::addressof(__h->__value_), |     __node_traits::construct(__a, _VSTD::addressof(__h->__value_), | ||||||
|                                   _STD::forward<_Args>(__args)...); |                                   _VSTD::forward<_Args>(__args)...); | ||||||
|     __h->__next_ = __r->__next_; |     __h->__next_ = __r->__next_; | ||||||
|     __r->__next_ = __h.release(); |     __r->__next_ = __h.release(); | ||||||
|     return iterator(__r->__next_); |     return iterator(__r->__next_); | ||||||
| @@ -989,7 +1047,7 @@ forward_list<_Tp, _Alloc>::insert_after(const_iterator __p, value_type&& __v) | |||||||
|     __node_allocator& __a = base::__alloc(); |     __node_allocator& __a = base::__alloc(); | ||||||
|     typedef __allocator_destructor<__node_allocator> _D; |     typedef __allocator_destructor<__node_allocator> _D; | ||||||
|     unique_ptr<__node, _D> __h(__node_traits::allocate(__a, 1), _D(__a, 1)); |     unique_ptr<__node, _D> __h(__node_traits::allocate(__a, 1), _D(__a, 1)); | ||||||
|     __node_traits::construct(__a, _STD::addressof(__h->__value_), _STD::move(__v)); |     __node_traits::construct(__a, _VSTD::addressof(__h->__value_), _VSTD::move(__v)); | ||||||
|     __h->__next_ = __r->__next_; |     __h->__next_ = __r->__next_; | ||||||
|     __r->__next_ = __h.release(); |     __r->__next_ = __h.release(); | ||||||
|     return iterator(__r->__next_); |     return iterator(__r->__next_); | ||||||
| @@ -1005,7 +1063,7 @@ forward_list<_Tp, _Alloc>::insert_after(const_iterator __p, const value_type& __ | |||||||
|     __node_allocator& __a = base::__alloc(); |     __node_allocator& __a = base::__alloc(); | ||||||
|     typedef __allocator_destructor<__node_allocator> _D; |     typedef __allocator_destructor<__node_allocator> _D; | ||||||
|     unique_ptr<__node, _D> __h(__node_traits::allocate(__a, 1), _D(__a, 1)); |     unique_ptr<__node, _D> __h(__node_traits::allocate(__a, 1), _D(__a, 1)); | ||||||
|     __node_traits::construct(__a, _STD::addressof(__h->__value_), __v); |     __node_traits::construct(__a, _VSTD::addressof(__h->__value_), __v); | ||||||
|     __h->__next_ = __r->__next_; |     __h->__next_ = __r->__next_; | ||||||
|     __r->__next_ = __h.release(); |     __r->__next_ = __h.release(); | ||||||
|     return iterator(__r->__next_); |     return iterator(__r->__next_); | ||||||
| @@ -1022,7 +1080,7 @@ forward_list<_Tp, _Alloc>::insert_after(const_iterator __p, size_type __n, | |||||||
|         __node_allocator& __a = base::__alloc(); |         __node_allocator& __a = base::__alloc(); | ||||||
|         typedef __allocator_destructor<__node_allocator> _D; |         typedef __allocator_destructor<__node_allocator> _D; | ||||||
|         unique_ptr<__node, _D> __h(__node_traits::allocate(__a, 1), _D(__a, 1)); |         unique_ptr<__node, _D> __h(__node_traits::allocate(__a, 1), _D(__a, 1)); | ||||||
|         __node_traits::construct(__a, _STD::addressof(__h->__value_), __v); |         __node_traits::construct(__a, _VSTD::addressof(__h->__value_), __v); | ||||||
|         __node_pointer __first = __h.release(); |         __node_pointer __first = __h.release(); | ||||||
|         __node_pointer __last = __first; |         __node_pointer __last = __first; | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
| @@ -1032,7 +1090,7 @@ forward_list<_Tp, _Alloc>::insert_after(const_iterator __p, size_type __n, | |||||||
|             for (--__n; __n != 0; --__n, __last = __last->__next_) |             for (--__n; __n != 0; --__n, __last = __last->__next_) | ||||||
|             { |             { | ||||||
|                 __h.reset(__node_traits::allocate(__a, 1)); |                 __h.reset(__node_traits::allocate(__a, 1)); | ||||||
|                 __node_traits::construct(__a, _STD::addressof(__h->__value_), __v); |                 __node_traits::construct(__a, _VSTD::addressof(__h->__value_), __v); | ||||||
|                 __last->__next_ = __h.release(); |                 __last->__next_ = __h.release(); | ||||||
|             } |             } | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
| @@ -1042,7 +1100,7 @@ forward_list<_Tp, _Alloc>::insert_after(const_iterator __p, size_type __n, | |||||||
|             while (__first != nullptr) |             while (__first != nullptr) | ||||||
|             { |             { | ||||||
|                 __node_pointer __next = __first->__next_; |                 __node_pointer __next = __first->__next_; | ||||||
|                 __node_traits::destroy(__a, _STD::addressof(__first->__value_)); |                 __node_traits::destroy(__a, _VSTD::addressof(__first->__value_)); | ||||||
|                 __node_traits::deallocate(__a, __first, 1); |                 __node_traits::deallocate(__a, __first, 1); | ||||||
|                 __first = __next; |                 __first = __next; | ||||||
|             } |             } | ||||||
| @@ -1072,7 +1130,7 @@ forward_list<_Tp, _Alloc>::insert_after(const_iterator __p, | |||||||
|         __node_allocator& __a = base::__alloc(); |         __node_allocator& __a = base::__alloc(); | ||||||
|         typedef __allocator_destructor<__node_allocator> _D; |         typedef __allocator_destructor<__node_allocator> _D; | ||||||
|         unique_ptr<__node, _D> __h(__node_traits::allocate(__a, 1), _D(__a, 1)); |         unique_ptr<__node, _D> __h(__node_traits::allocate(__a, 1), _D(__a, 1)); | ||||||
|         __node_traits::construct(__a, _STD::addressof(__h->__value_), *__f); |         __node_traits::construct(__a, _VSTD::addressof(__h->__value_), *__f); | ||||||
|         __node_pointer __first = __h.release(); |         __node_pointer __first = __h.release(); | ||||||
|         __node_pointer __last = __first; |         __node_pointer __last = __first; | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
| @@ -1082,7 +1140,7 @@ forward_list<_Tp, _Alloc>::insert_after(const_iterator __p, | |||||||
|             for (++__f; __f != __l; ++__f, __last = __last->__next_) |             for (++__f; __f != __l; ++__f, __last = __last->__next_) | ||||||
|             { |             { | ||||||
|                 __h.reset(__node_traits::allocate(__a, 1)); |                 __h.reset(__node_traits::allocate(__a, 1)); | ||||||
|                 __node_traits::construct(__a, _STD::addressof(__h->__value_), *__f); |                 __node_traits::construct(__a, _VSTD::addressof(__h->__value_), *__f); | ||||||
|                 __last->__next_ = __h.release(); |                 __last->__next_ = __h.release(); | ||||||
|             } |             } | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
| @@ -1092,7 +1150,7 @@ forward_list<_Tp, _Alloc>::insert_after(const_iterator __p, | |||||||
|             while (__first != nullptr) |             while (__first != nullptr) | ||||||
|             { |             { | ||||||
|                 __node_pointer __next = __first->__next_; |                 __node_pointer __next = __first->__next_; | ||||||
|                 __node_traits::destroy(__a, _STD::addressof(__first->__value_)); |                 __node_traits::destroy(__a, _VSTD::addressof(__first->__value_)); | ||||||
|                 __node_traits::deallocate(__a, __first, 1); |                 __node_traits::deallocate(__a, __first, 1); | ||||||
|                 __first = __next; |                 __first = __next; | ||||||
|             } |             } | ||||||
| @@ -1114,7 +1172,7 @@ forward_list<_Tp, _Alloc>::erase_after(const_iterator __f) | |||||||
|     __node_pointer __n = __p->__next_; |     __node_pointer __n = __p->__next_; | ||||||
|     __p->__next_ = __n->__next_; |     __p->__next_ = __n->__next_; | ||||||
|     __node_allocator& __a = base::__alloc(); |     __node_allocator& __a = base::__alloc(); | ||||||
|     __node_traits::destroy(__a, _STD::addressof(__n->__value_)); |     __node_traits::destroy(__a, _VSTD::addressof(__n->__value_)); | ||||||
|     __node_traits::deallocate(__a, __n, 1); |     __node_traits::deallocate(__a, __n, 1); | ||||||
|     return iterator(__p->__next_); |     return iterator(__p->__next_); | ||||||
| } | } | ||||||
| @@ -1135,7 +1193,7 @@ forward_list<_Tp, _Alloc>::erase_after(const_iterator __f, const_iterator __l) | |||||||
|             do |             do | ||||||
|             { |             { | ||||||
|                 __p = __n->__next_; |                 __p = __n->__next_; | ||||||
|                 __node_traits::destroy(__a, _STD::addressof(__n->__value_)); |                 __node_traits::destroy(__a, _VSTD::addressof(__n->__value_)); | ||||||
|                 __node_traits::deallocate(__a, __n, 1); |                 __node_traits::deallocate(__a, __n, 1); | ||||||
|                 __n = __p; |                 __n = __p; | ||||||
|             } while (__n != __e); |             } while (__n != __e); | ||||||
| @@ -1168,7 +1226,7 @@ forward_list<_Tp, _Alloc>::resize(size_type __n) | |||||||
|                                                          __ptr = __ptr->__next_) |                                                          __ptr = __ptr->__next_) | ||||||
|             { |             { | ||||||
|                 __h.reset(__node_traits::allocate(__a, 1)); |                 __h.reset(__node_traits::allocate(__a, 1)); | ||||||
|                 __node_traits::construct(__a, _STD::addressof(__h->__value_)); |                 __node_traits::construct(__a, _VSTD::addressof(__h->__value_)); | ||||||
|                 __h->__next_ = nullptr; |                 __h->__next_ = nullptr; | ||||||
|                 __ptr->__next_ = __h.release(); |                 __ptr->__next_ = __h.release(); | ||||||
|             } |             } | ||||||
| @@ -1200,7 +1258,7 @@ forward_list<_Tp, _Alloc>::resize(size_type __n, const value_type& __v) | |||||||
|                                                          __ptr = __ptr->__next_) |                                                          __ptr = __ptr->__next_) | ||||||
|             { |             { | ||||||
|                 __h.reset(__node_traits::allocate(__a, 1)); |                 __h.reset(__node_traits::allocate(__a, 1)); | ||||||
|                 __node_traits::construct(__a, _STD::addressof(__h->__value_), __v); |                 __node_traits::construct(__a, _VSTD::addressof(__h->__value_), __v); | ||||||
|                 __h->__next_ = nullptr; |                 __h->__next_ = nullptr; | ||||||
|                 __ptr->__next_ = __h.release(); |                 __ptr->__next_ = __h.release(); | ||||||
|             } |             } | ||||||
| @@ -1235,7 +1293,7 @@ forward_list<_Tp, _Alloc>::splice_after(const_iterator __p, | |||||||
|                                         forward_list& __x, |                                         forward_list& __x, | ||||||
|                                         const_iterator __i) |                                         const_iterator __i) | ||||||
| { | { | ||||||
|     const_iterator __lm1 = _STD::next(__i); |     const_iterator __lm1 = _VSTD::next(__i); | ||||||
|     if (__p != __i && __p != __lm1) |     if (__p != __i && __p != __lm1) | ||||||
|     { |     { | ||||||
|         const_cast<__node_pointer>(__i.__ptr_)->__next_ = |         const_cast<__node_pointer>(__i.__ptr_)->__next_ = | ||||||
| @@ -1312,7 +1370,7 @@ forward_list<_Tp, _Alloc>::remove(const value_type& __v) | |||||||
|     { |     { | ||||||
|         if (__i.__ptr_->__next_->__value_ == __v) |         if (__i.__ptr_->__next_->__value_ == __v) | ||||||
|         { |         { | ||||||
|             iterator __j = _STD::next(__i, 2); |             iterator __j = _VSTD::next(__i, 2); | ||||||
|             for (; __j != __e && *__j == __v; ++__j) |             for (; __j != __e && *__j == __v; ++__j) | ||||||
|                 ; |                 ; | ||||||
|             erase_after(__i, __j); |             erase_after(__i, __j); | ||||||
| @@ -1335,7 +1393,7 @@ forward_list<_Tp, _Alloc>::remove_if(_Predicate __pred) | |||||||
|     { |     { | ||||||
|         if (__pred(__i.__ptr_->__next_->__value_)) |         if (__pred(__i.__ptr_->__next_->__value_)) | ||||||
|         { |         { | ||||||
|             iterator __j = _STD::next(__i, 2); |             iterator __j = _VSTD::next(__i, 2); | ||||||
|             for (; __j != __e && __pred(*__j); ++__j) |             for (; __j != __e && __pred(*__j); ++__j) | ||||||
|                 ; |                 ; | ||||||
|             erase_after(__i, __j); |             erase_after(__i, __j); | ||||||
| @@ -1355,7 +1413,7 @@ forward_list<_Tp, _Alloc>::unique(_BinaryPredicate __binary_pred) | |||||||
| { | { | ||||||
|     for (iterator __i = begin(), __e = end(); __i != __e;) |     for (iterator __i = begin(), __e = end(); __i != __e;) | ||||||
|     { |     { | ||||||
|         iterator __j = _STD::next(__i); |         iterator __j = _VSTD::next(__i); | ||||||
|         for (; __j != __e && __binary_pred(*__i, *__j); ++__j) |         for (; __j != __e && __binary_pred(*__i, *__j); ++__j) | ||||||
|             ; |             ; | ||||||
|         if (__i.__ptr_->__next_ != __j.__ptr_) |         if (__i.__ptr_->__next_ != __j.__ptr_) | ||||||
| @@ -1430,7 +1488,7 @@ void | |||||||
| forward_list<_Tp, _Alloc>::sort(_Compare __comp) | forward_list<_Tp, _Alloc>::sort(_Compare __comp) | ||||||
| { | { | ||||||
|     base::__before_begin()->__next_ = __sort(base::__before_begin()->__next_, |     base::__before_begin()->__next_ = __sort(base::__before_begin()->__next_, | ||||||
|                                        _STD::distance(begin(), end()), __comp); |                                        _VSTD::distance(begin(), end()), __comp); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, class _Alloc> | template <class _Tp, class _Alloc> | ||||||
| @@ -1456,7 +1514,7 @@ forward_list<_Tp, _Alloc>::__sort(__node_pointer __f1, difference_type __sz, | |||||||
|     } |     } | ||||||
|     difference_type __sz1 = __sz / 2; |     difference_type __sz1 = __sz / 2; | ||||||
|     difference_type __sz2 = __sz - __sz1; |     difference_type __sz2 = __sz - __sz1; | ||||||
|     __node_pointer __t = _STD::next(iterator(__f1), __sz1 - 1).__ptr_; |     __node_pointer __t = _VSTD::next(iterator(__f1), __sz1 - 1).__ptr_; | ||||||
|     __node_pointer __f2 = __t->__next_; |     __node_pointer __f2 = __t->__next_; | ||||||
|     __t->__next_ = nullptr; |     __t->__next_ = nullptr; | ||||||
|     return __merge(__sort(__f1, __sz1, __comp), |     return __merge(__sort(__f1, __sz1, __comp), | ||||||
| @@ -1465,7 +1523,7 @@ forward_list<_Tp, _Alloc>::__sort(__node_pointer __f1, difference_type __sz, | |||||||
|  |  | ||||||
| template <class _Tp, class _Alloc> | template <class _Tp, class _Alloc> | ||||||
| void | void | ||||||
| forward_list<_Tp, _Alloc>::reverse() | forward_list<_Tp, _Alloc>::reverse() _NOEXCEPT | ||||||
| { | { | ||||||
|     __node_pointer __p = base::__before_begin()->__next_; |     __node_pointer __p = base::__before_begin()->__next_; | ||||||
|     if (__p != nullptr) |     if (__p != nullptr) | ||||||
| @@ -1512,7 +1570,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| bool operator< (const forward_list<_Tp, _Alloc>& __x, | bool operator< (const forward_list<_Tp, _Alloc>& __x, | ||||||
|                 const forward_list<_Tp, _Alloc>& __y) |                 const forward_list<_Tp, _Alloc>& __y) | ||||||
| { | { | ||||||
|     return _STD::lexicographical_compare(__x.begin(), __x.end(), |     return _VSTD::lexicographical_compare(__x.begin(), __x.end(), | ||||||
|                                          __y.begin(), __y.end()); |                                          __y.begin(), __y.end()); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1544,6 +1602,7 @@ template <class _Tp, class _Alloc> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| void | void | ||||||
| swap(forward_list<_Tp, _Alloc>& __x, forward_list<_Tp, _Alloc>& __y) | swap(forward_list<_Tp, _Alloc>& __x, forward_list<_Tp, _Alloc>& __y) | ||||||
|  |     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||||
| { | { | ||||||
|     __x.swap(__y); |     __x.swap(__y); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -173,11 +173,6 @@ typedef basic_fstream<wchar_t> wfstream; | |||||||
|  |  | ||||||
| #pragma GCC system_header | #pragma GCC system_header | ||||||
|  |  | ||||||
| #ifdef _WIN32 |  | ||||||
| #define fseeko fseek |  | ||||||
| #define ftello ftell |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| _LIBCPP_BEGIN_NAMESPACE_STD | _LIBCPP_BEGIN_NAMESPACE_STD | ||||||
|  |  | ||||||
| template <class _CharT, class _Traits> | template <class _CharT, class _Traits> | ||||||
| @@ -367,9 +362,9 @@ basic_filebuf<_CharT, _Traits>::swap(basic_filebuf& __rhs) | |||||||
|     basic_streambuf<char_type, traits_type>::swap(__rhs); |     basic_streambuf<char_type, traits_type>::swap(__rhs); | ||||||
|     if (__extbuf_ != __extbuf_min_ && __rhs.__extbuf_ != __rhs.__extbuf_min_) |     if (__extbuf_ != __extbuf_min_ && __rhs.__extbuf_ != __rhs.__extbuf_min_) | ||||||
|     { |     { | ||||||
|         _STD::swap(__extbuf_, __rhs.__extbuf_); |         _VSTD::swap(__extbuf_, __rhs.__extbuf_); | ||||||
|         _STD::swap(__extbufnext_, __rhs.__extbufnext_); |         _VSTD::swap(__extbufnext_, __rhs.__extbufnext_); | ||||||
|         _STD::swap(__extbufend_, __rhs.__extbufend_); |         _VSTD::swap(__extbufend_, __rhs.__extbufend_); | ||||||
|     } |     } | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
| @@ -392,17 +387,17 @@ basic_filebuf<_CharT, _Traits>::swap(basic_filebuf& __rhs) | |||||||
|         __rhs.__extbufnext_ = __rhs.__extbuf_ + __ln; |         __rhs.__extbufnext_ = __rhs.__extbuf_ + __ln; | ||||||
|         __rhs.__extbufend_ = __rhs.__extbuf_ + __le; |         __rhs.__extbufend_ = __rhs.__extbuf_ + __le; | ||||||
|     } |     } | ||||||
|     _STD::swap(__ebs_, __rhs.__ebs_); |     _VSTD::swap(__ebs_, __rhs.__ebs_); | ||||||
|     _STD::swap(__intbuf_, __rhs.__intbuf_); |     _VSTD::swap(__intbuf_, __rhs.__intbuf_); | ||||||
|     _STD::swap(__ibs_, __rhs.__ibs_); |     _VSTD::swap(__ibs_, __rhs.__ibs_); | ||||||
|     _STD::swap(__file_, __rhs.__file_); |     _VSTD::swap(__file_, __rhs.__file_); | ||||||
|     _STD::swap(__cv_, __rhs.__cv_); |     _VSTD::swap(__cv_, __rhs.__cv_); | ||||||
|     _STD::swap(__st_, __rhs.__st_); |     _VSTD::swap(__st_, __rhs.__st_); | ||||||
|     _STD::swap(__om_, __rhs.__om_); |     _VSTD::swap(__om_, __rhs.__om_); | ||||||
|     _STD::swap(__cm_, __rhs.__cm_); |     _VSTD::swap(__cm_, __rhs.__cm_); | ||||||
|     _STD::swap(__owns_eb_, __rhs.__owns_eb_); |     _VSTD::swap(__owns_eb_, __rhs.__owns_eb_); | ||||||
|     _STD::swap(__owns_ib_, __rhs.__owns_ib_); |     _VSTD::swap(__owns_ib_, __rhs.__owns_ib_); | ||||||
|     _STD::swap(__always_noconv_, __rhs.__always_noconv_); |     _VSTD::swap(__always_noconv_, __rhs.__always_noconv_); | ||||||
|     if (this->eback() == (char_type*)__rhs.__extbuf_min_) |     if (this->eback() == (char_type*)__rhs.__extbuf_min_) | ||||||
|     { |     { | ||||||
|         ptrdiff_t __n = this->gptr() - this->eback(); |         ptrdiff_t __n = this->gptr() - this->eback(); | ||||||
| @@ -592,7 +587,7 @@ basic_filebuf<_CharT, _Traits>::underflow() | |||||||
|             memmove(__extbuf_, __extbufnext_, __extbufend_ - __extbufnext_); |             memmove(__extbuf_, __extbufnext_, __extbufend_ - __extbufnext_); | ||||||
|             __extbufnext_ = __extbuf_ + (__extbufend_ - __extbufnext_); |             __extbufnext_ = __extbuf_ + (__extbufend_ - __extbufnext_); | ||||||
|             __extbufend_ = __extbuf_ + (__extbuf_ == __extbuf_min_ ? sizeof(__extbuf_min_) : __ebs_); |             __extbufend_ = __extbuf_ + (__extbuf_ == __extbuf_min_ ? sizeof(__extbuf_min_) : __ebs_); | ||||||
|             size_t __nmemb = _STD::min(static_cast<size_t>(this->egptr() - this->eback() - __unget_sz), |             size_t __nmemb = _VSTD::min(static_cast<size_t>(this->egptr() - this->eback() - __unget_sz), | ||||||
|                                  static_cast<size_t>(__extbufend_ - __extbufnext_)); |                                  static_cast<size_t>(__extbufend_ - __extbufnext_)); | ||||||
|             codecvt_base::result __r; |             codecvt_base::result __r; | ||||||
|             state_type __svs = __st_; |             state_type __svs = __st_; | ||||||
| @@ -1024,8 +1019,8 @@ basic_ifstream<_CharT, _Traits>::basic_ifstream(const string& __s, ios_base::ope | |||||||
| template <class _CharT, class _Traits> | template <class _CharT, class _Traits> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| basic_ifstream<_CharT, _Traits>::basic_ifstream(basic_ifstream&& __rhs) | basic_ifstream<_CharT, _Traits>::basic_ifstream(basic_ifstream&& __rhs) | ||||||
|     : basic_istream<char_type, traits_type>(_STD::move(__rhs)), |     : basic_istream<char_type, traits_type>(_VSTD::move(__rhs)), | ||||||
|       __sb_(_STD::move(__rhs.__sb_)) |       __sb_(_VSTD::move(__rhs.__sb_)) | ||||||
| { | { | ||||||
|     this->set_rdbuf(&__sb_); |     this->set_rdbuf(&__sb_); | ||||||
| } | } | ||||||
| @@ -1035,8 +1030,8 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| basic_ifstream<_CharT, _Traits>& | basic_ifstream<_CharT, _Traits>& | ||||||
| basic_ifstream<_CharT, _Traits>::operator=(basic_ifstream&& __rhs) | basic_ifstream<_CharT, _Traits>::operator=(basic_ifstream&& __rhs) | ||||||
| { | { | ||||||
|     basic_istream<char_type, traits_type>::operator=(_STD::move(__rhs)); |     basic_istream<char_type, traits_type>::operator=(_VSTD::move(__rhs)); | ||||||
|     __sb_ = _STD::move(__rhs.__sb_); |     __sb_ = _VSTD::move(__rhs.__sb_); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1169,8 +1164,8 @@ basic_ofstream<_CharT, _Traits>::basic_ofstream(const string& __s, ios_base::ope | |||||||
| template <class _CharT, class _Traits> | template <class _CharT, class _Traits> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| basic_ofstream<_CharT, _Traits>::basic_ofstream(basic_ofstream&& __rhs) | basic_ofstream<_CharT, _Traits>::basic_ofstream(basic_ofstream&& __rhs) | ||||||
|     : basic_ostream<char_type, traits_type>(_STD::move(__rhs)), |     : basic_ostream<char_type, traits_type>(_VSTD::move(__rhs)), | ||||||
|       __sb_(_STD::move(__rhs.__sb_)) |       __sb_(_VSTD::move(__rhs.__sb_)) | ||||||
| { | { | ||||||
|     this->set_rdbuf(&__sb_); |     this->set_rdbuf(&__sb_); | ||||||
| } | } | ||||||
| @@ -1180,8 +1175,8 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| basic_ofstream<_CharT, _Traits>& | basic_ofstream<_CharT, _Traits>& | ||||||
| basic_ofstream<_CharT, _Traits>::operator=(basic_ofstream&& __rhs) | basic_ofstream<_CharT, _Traits>::operator=(basic_ofstream&& __rhs) | ||||||
| { | { | ||||||
|     basic_ostream<char_type, traits_type>::operator=(_STD::move(__rhs)); |     basic_ostream<char_type, traits_type>::operator=(_VSTD::move(__rhs)); | ||||||
|     __sb_ = _STD::move(__rhs.__sb_); |     __sb_ = _VSTD::move(__rhs.__sb_); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1314,8 +1309,8 @@ basic_fstream<_CharT, _Traits>::basic_fstream(const string& __s, ios_base::openm | |||||||
| template <class _CharT, class _Traits> | template <class _CharT, class _Traits> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| basic_fstream<_CharT, _Traits>::basic_fstream(basic_fstream&& __rhs) | basic_fstream<_CharT, _Traits>::basic_fstream(basic_fstream&& __rhs) | ||||||
|     : basic_iostream<char_type, traits_type>(_STD::move(__rhs)), |     : basic_iostream<char_type, traits_type>(_VSTD::move(__rhs)), | ||||||
|       __sb_(_STD::move(__rhs.__sb_)) |       __sb_(_VSTD::move(__rhs.__sb_)) | ||||||
| { | { | ||||||
|     this->set_rdbuf(&__sb_); |     this->set_rdbuf(&__sb_); | ||||||
| } | } | ||||||
| @@ -1325,8 +1320,8 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| basic_fstream<_CharT, _Traits>& | basic_fstream<_CharT, _Traits>& | ||||||
| basic_fstream<_CharT, _Traits>::operator=(basic_fstream&& __rhs) | basic_fstream<_CharT, _Traits>::operator=(basic_fstream&& __rhs) | ||||||
| { | { | ||||||
|     basic_iostream<char_type, traits_type>::operator=(_STD::move(__rhs)); |     basic_iostream<char_type, traits_type>::operator=(_VSTD::move(__rhs)); | ||||||
|     __sb_ = _STD::move(__rhs.__sb_); |     __sb_ = _VSTD::move(__rhs.__sb_); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -43,16 +43,16 @@ public: | |||||||
|     typedef see below result_type; // Not always defined |     typedef see below result_type; // Not always defined | ||||||
|  |  | ||||||
|     // construct/copy/destroy |     // construct/copy/destroy | ||||||
|     reference_wrapper(T&); |     reference_wrapper(T&) noexcept; | ||||||
|     reference_wrapper(T&&) = delete; // do not bind to temps |     reference_wrapper(T&&) = delete; // do not bind to temps | ||||||
|     reference_wrapper(const reference_wrapper<T>& x); |     reference_wrapper(const reference_wrapper<T>& x) noexcept; | ||||||
|  |  | ||||||
|     // assignment |     // assignment | ||||||
|     reference_wrapper& operator=(const reference_wrapper<T>& x); |     reference_wrapper& operator=(const reference_wrapper<T>& x) noexcept; | ||||||
|  |  | ||||||
|     // access |     // access | ||||||
|     operator T& () const; |     operator T& () const noexcept; | ||||||
|     T& get() const; |     T& get() const noexcept; | ||||||
|  |  | ||||||
|     // invoke |     // invoke | ||||||
|     template <class... ArgTypes> |     template <class... ArgTypes> | ||||||
| @@ -60,13 +60,13 @@ public: | |||||||
|           operator() (ArgTypes&&...) const; |           operator() (ArgTypes&&...) const; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class T> reference_wrapper<T> ref(T& t); | template <class T> reference_wrapper<T> ref(T& t) noexcept; | ||||||
| template <class T> void ref(const T&& t) = delete; | template <class T> void ref(const T&& t) = delete; | ||||||
| template <class T> reference_wrapper<T> ref(reference_wrapper<T>t); | template <class T> reference_wrapper<T> ref(reference_wrapper<T>t) noexcept; | ||||||
|  |  | ||||||
| template <class T> reference_wrapper<const T> cref(const T& t); | template <class T> reference_wrapper<const T> cref(const T& t) noexcept; | ||||||
| template <class T> void cref(const T&& t) = delete; | template <class T> void cref(const T&& t) = delete; | ||||||
| template <class T> reference_wrapper<const T> cref(reference_wrapper<T> t); | template <class T> reference_wrapper<const T> cref(reference_wrapper<T> t) noexcept; | ||||||
|  |  | ||||||
| template <class T> | template <class T> | ||||||
| struct plus : binary_function<T, T, T> | struct plus : binary_function<T, T, T> | ||||||
| @@ -365,16 +365,16 @@ public: | |||||||
|     typedef R result_type; |     typedef R result_type; | ||||||
|  |  | ||||||
|     // construct/copy/destroy: |     // construct/copy/destroy: | ||||||
|     function(); |     function() noexcept; | ||||||
|     function(nullptr_t); |     function(nullptr_t) noexcept; | ||||||
|     function(const function&); |     function(const function&); | ||||||
|     function(function&&); |     function(function&&) noexcept; | ||||||
|     template<class F> |     template<class F> | ||||||
|       function(F); |       function(F); | ||||||
|     template<Allocator Alloc> |     template<Allocator Alloc> | ||||||
|       function(allocator_arg_t, const Alloc&); |       function(allocator_arg_t, const Alloc&) noexcept; | ||||||
|     template<Allocator Alloc> |     template<Allocator Alloc> | ||||||
|       function(allocator_arg_t, const Alloc&, nullptr_t); |       function(allocator_arg_t, const Alloc&, nullptr_t) noexcept; | ||||||
|     template<Allocator Alloc> |     template<Allocator Alloc> | ||||||
|       function(allocator_arg_t, const Alloc&, const function&); |       function(allocator_arg_t, const Alloc&, const function&); | ||||||
|     template<Allocator Alloc> |     template<Allocator Alloc> | ||||||
| @@ -383,54 +383,48 @@ public: | |||||||
|       function(allocator_arg_t, const Alloc&, F); |       function(allocator_arg_t, const Alloc&, F); | ||||||
|  |  | ||||||
|     function& operator=(const function&); |     function& operator=(const function&); | ||||||
|     function& operator=(function&&); |     function& operator=(function&&) noexcept; | ||||||
|     function& operator=(nullptr_t); |     function& operator=(nullptr_t) noexcept; | ||||||
|     template<class F> |     template<class F> | ||||||
|       function& operator=(F&&); |       function& operator=(F&&); | ||||||
|     template<class F> |     template<class F> | ||||||
|       function& operator=(reference_wrapper<F>); |       function& operator=(reference_wrapper<F>) noexcept; | ||||||
|  |  | ||||||
|     ~function(); |     ~function(); | ||||||
|  |  | ||||||
|     // function modifiers: |     // function modifiers: | ||||||
|     void swap(function&); |     void swap(function&) noexcept; | ||||||
|     template<class F, class Alloc> |     template<class F, class Alloc> | ||||||
|       void assign(F&&, const Alloc&); |       void assign(F&&, const Alloc&); | ||||||
|  |  | ||||||
|     // function capacity: |     // function capacity: | ||||||
|     explicit operator bool() const; |     explicit operator bool() const noexcept; | ||||||
|  |  | ||||||
|     // deleted overloads close possible hole in the type system |  | ||||||
|     template<class R2, class... ArgTypes2> |  | ||||||
|       bool operator==(const function<R2(ArgTypes2...)>&) = delete; |  | ||||||
|     template<class R2, class... ArgTypes2> |  | ||||||
|       bool operator!=(const function<R2(ArgTypes2...)>&) = delete; |  | ||||||
|  |  | ||||||
|     // function invocation: |     // function invocation: | ||||||
|     R operator()(ArgTypes...) const; |     R operator()(ArgTypes...) const; | ||||||
|  |  | ||||||
|     // function target access: |     // function target access: | ||||||
|     const std::type_info& target_type() const; |     const std::type_info& target_type() const noexcept; | ||||||
|     template <typename T>       T* target(); |     template <typename T>       T* target() noexcept; | ||||||
|     template <typename T> const T* target() const; |     template <typename T> const T* target() const noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // Null pointer comparisons: | // Null pointer comparisons: | ||||||
| template <class R, class ... ArgTypes> | template <class R, class ... ArgTypes> | ||||||
|   bool operator==(const function<R(ArgTypes...)>&, nullptr_t); |   bool operator==(const function<R(ArgTypes...)>&, nullptr_t) noexcept; | ||||||
|  |  | ||||||
| template <class R, class ... ArgTypes> | template <class R, class ... ArgTypes> | ||||||
|   bool operator==(nullptr_t, const function<R(ArgTypes...)>&); |   bool operator==(nullptr_t, const function<R(ArgTypes...)>&) noexcept; | ||||||
|  |  | ||||||
| template <class R, class ... ArgTypes> | template <class R, class ... ArgTypes> | ||||||
|   bool operator!=(const function<R(ArgTypes...)>&, nullptr_t); |   bool operator!=(const function<R(ArgTypes...)>&, nullptr_t) noexcept; | ||||||
|  |  | ||||||
| template <class  R, class ... ArgTypes> | template <class  R, class ... ArgTypes> | ||||||
|   bool operator!=(nullptr_t, const function<R(ArgTypes...)>&); |   bool operator!=(nullptr_t, const function<R(ArgTypes...)>&) noexcept; | ||||||
|  |  | ||||||
| // specialized algorithms: | // specialized algorithms: | ||||||
| template <class  R, class ... ArgTypes> | template <class  R, class ... ArgTypes> | ||||||
|   void swap(function<R(ArgTypes...)>&, function<R(ArgTypes...)>&); |   void swap(function<R(ArgTypes...)>&, function<R(ArgTypes...)>&) noexcept; | ||||||
|  |  | ||||||
| template <class T> struct hash; | template <class T> struct hash; | ||||||
|  |  | ||||||
| @@ -890,7 +884,7 @@ public: | |||||||
|        typename __invoke_return<type, _ArgTypes...>::type |        typename __invoke_return<type, _ArgTypes...>::type | ||||||
|           operator() (_ArgTypes&&... __args) |           operator() (_ArgTypes&&... __args) | ||||||
|           { |           { | ||||||
|               return __invoke(__f_, _STD::forward<_ArgTypes>(__args)...); |               return __invoke(__f_, _VSTD::forward<_ArgTypes>(__args)...); | ||||||
|           } |           } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -980,12 +974,12 @@ public: | |||||||
|     _LIBCPP_INLINE_VISIBILITY virtual ~__base() {} |     _LIBCPP_INLINE_VISIBILITY virtual ~__base() {} | ||||||
|     virtual __base* __clone() const = 0; |     virtual __base* __clone() const = 0; | ||||||
|     virtual void __clone(__base*) const = 0; |     virtual void __clone(__base*) const = 0; | ||||||
|     virtual void destroy() = 0; |     virtual void destroy() _NOEXCEPT = 0; | ||||||
|     virtual void destroy_deallocate() = 0; |     virtual void destroy_deallocate() _NOEXCEPT = 0; | ||||||
|     virtual _R operator()(_ArgTypes&& ...) = 0; |     virtual _R operator()(_ArgTypes&& ...) = 0; | ||||||
| #ifndef _LIBCPP_NO_RTTI | #ifndef _LIBCPP_NO_RTTI | ||||||
|     virtual const void* target(const type_info&) const = 0; |     virtual const void* target(const type_info&) const _NOEXCEPT = 0; | ||||||
|     virtual const std::type_info& target_type() const = 0; |     virtual const std::type_info& target_type() const _NOEXCEPT = 0; | ||||||
| #endif  // _LIBCPP_NO_RTTI | #endif  // _LIBCPP_NO_RTTI | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -998,17 +992,17 @@ class __func<_F, _Alloc, _R(_ArgTypes...)> | |||||||
|     __compressed_pair<_F, _Alloc> __f_; |     __compressed_pair<_F, _Alloc> __f_; | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __func(_F __f) : __f_(_STD::move(__f)) {} |     explicit __func(_F __f) : __f_(_VSTD::move(__f)) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __func(_F __f, _Alloc __a) : __f_(_STD::move(__f), _STD::move(__a)) {} |     explicit __func(_F __f, _Alloc __a) : __f_(_VSTD::move(__f), _VSTD::move(__a)) {} | ||||||
|     virtual __base<_R(_ArgTypes...)>* __clone() const; |     virtual __base<_R(_ArgTypes...)>* __clone() const; | ||||||
|     virtual void __clone(__base<_R(_ArgTypes...)>*) const; |     virtual void __clone(__base<_R(_ArgTypes...)>*) const; | ||||||
|     virtual void destroy(); |     virtual void destroy() _NOEXCEPT; | ||||||
|     virtual void destroy_deallocate(); |     virtual void destroy_deallocate() _NOEXCEPT; | ||||||
|     virtual _R operator()(_ArgTypes&& ... __arg); |     virtual _R operator()(_ArgTypes&& ... __arg); | ||||||
| #ifndef _LIBCPP_NO_RTTI | #ifndef _LIBCPP_NO_RTTI | ||||||
|     virtual const void* target(const type_info&) const; |     virtual const void* target(const type_info&) const _NOEXCEPT; | ||||||
|     virtual const std::type_info& target_type() const; |     virtual const std::type_info& target_type() const _NOEXCEPT; | ||||||
| #endif  // _LIBCPP_NO_RTTI | #endif  // _LIBCPP_NO_RTTI | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -1033,14 +1027,14 @@ __func<_F, _Alloc, _R(_ArgTypes...)>::__clone(__base<_R(_ArgTypes...)>* __p) con | |||||||
|  |  | ||||||
| template<class _F, class _Alloc, class _R, class ..._ArgTypes> | template<class _F, class _Alloc, class _R, class ..._ArgTypes> | ||||||
| void | void | ||||||
| __func<_F, _Alloc, _R(_ArgTypes...)>::destroy() | __func<_F, _Alloc, _R(_ArgTypes...)>::destroy() _NOEXCEPT | ||||||
| { | { | ||||||
|     __f_.~__compressed_pair<_F, _Alloc>(); |     __f_.~__compressed_pair<_F, _Alloc>(); | ||||||
| } | } | ||||||
|  |  | ||||||
| template<class _F, class _Alloc, class _R, class ..._ArgTypes> | template<class _F, class _Alloc, class _R, class ..._ArgTypes> | ||||||
| void | void | ||||||
| __func<_F, _Alloc, _R(_ArgTypes...)>::destroy_deallocate() | __func<_F, _Alloc, _R(_ArgTypes...)>::destroy_deallocate() _NOEXCEPT | ||||||
| { | { | ||||||
|     typedef typename _Alloc::template rebind<__func>::other _A; |     typedef typename _Alloc::template rebind<__func>::other _A; | ||||||
|     _A __a(__f_.second()); |     _A __a(__f_.second()); | ||||||
| @@ -1052,14 +1046,14 @@ template<class _F, class _Alloc, class _R, class ..._ArgTypes> | |||||||
| _R | _R | ||||||
| __func<_F, _Alloc, _R(_ArgTypes...)>::operator()(_ArgTypes&& ... __arg) | __func<_F, _Alloc, _R(_ArgTypes...)>::operator()(_ArgTypes&& ... __arg) | ||||||
| { | { | ||||||
|     return __invoke(__f_.first(), _STD::forward<_ArgTypes>(__arg)...); |     return __invoke(__f_.first(), _VSTD::forward<_ArgTypes>(__arg)...); | ||||||
| } | } | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_NO_RTTI | #ifndef _LIBCPP_NO_RTTI | ||||||
|  |  | ||||||
| template<class _F, class _Alloc, class _R, class ..._ArgTypes> | template<class _F, class _Alloc, class _R, class ..._ArgTypes> | ||||||
| const void* | const void* | ||||||
| __func<_F, _Alloc, _R(_ArgTypes...)>::target(const type_info& __ti) const | __func<_F, _Alloc, _R(_ArgTypes...)>::target(const type_info& __ti) const _NOEXCEPT | ||||||
| { | { | ||||||
|     if (__ti == typeid(_F)) |     if (__ti == typeid(_F)) | ||||||
|         return &__f_.first(); |         return &__f_.first(); | ||||||
| @@ -1068,7 +1062,7 @@ __func<_F, _Alloc, _R(_ArgTypes...)>::target(const type_info& __ti) const | |||||||
|  |  | ||||||
| template<class _F, class _Alloc, class _R, class ..._ArgTypes> | template<class _F, class _Alloc, class _R, class ..._ArgTypes> | ||||||
| const std::type_info& | const std::type_info& | ||||||
| __func<_F, _Alloc, _R(_ArgTypes...)>::target_type() const | __func<_F, _Alloc, _R(_ArgTypes...)>::target_type() const _NOEXCEPT | ||||||
| { | { | ||||||
|     return typeid(_F); |     return typeid(_F); | ||||||
| } | } | ||||||
| @@ -1107,41 +1101,56 @@ class _LIBCPP_VISIBLE function<_R(_ArgTypes...)> | |||||||
|     template <class _R2, class ..._A> |     template <class _R2, class ..._A> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         static bool __not_null(const function<_R(_A...)>& __p) {return __p;} |         static bool __not_null(const function<_R(_A...)>& __p) {return __p;} | ||||||
|  |  | ||||||
|  |     template <class _F, bool = __invokable<_F&, _ArgTypes...>::value> | ||||||
|  |         struct __callable; | ||||||
|  |     template <class _F> | ||||||
|  |         struct __callable<_F, true> | ||||||
|  |         { | ||||||
|  |             static const bool value = | ||||||
|  |                 is_convertible<typename __invoke_of<_F&, _ArgTypes...>::type, | ||||||
|  |                                _R>::value; | ||||||
|  |         }; | ||||||
|  |     template <class _F> | ||||||
|  |         struct __callable<_F, false> | ||||||
|  |         { | ||||||
|  |             static const bool value = false; | ||||||
|  |         }; | ||||||
| public: | public: | ||||||
|     typedef _R result_type; |     typedef _R result_type; | ||||||
|  |  | ||||||
|     // construct/copy/destroy: |     // construct/copy/destroy: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     function() : __f_(0) {} |     function() _NOEXCEPT : __f_(0) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     function(nullptr_t) : __f_(0) {} |     function(nullptr_t) _NOEXCEPT : __f_(0) {} | ||||||
|     function(const function&); |     function(const function&); | ||||||
|     function(function&&); |     function(function&&) _NOEXCEPT; | ||||||
|     template<class _F> |     template<class _F> | ||||||
|       function(_F, |       function(_F, | ||||||
|                typename enable_if<!is_integral<_F>::value>::type* = 0); |                typename enable_if<__callable<_F>::value>::type* = 0); | ||||||
|  |  | ||||||
|     template<class _Alloc> |     template<class _Alloc> | ||||||
|       _LIBCPP_INLINE_VISIBILITY |       _LIBCPP_INLINE_VISIBILITY | ||||||
|       function(allocator_arg_t, const _Alloc&) : __f_(0) {} |       function(allocator_arg_t, const _Alloc&) _NOEXCEPT : __f_(0) {} | ||||||
|     template<class _Alloc> |     template<class _Alloc> | ||||||
|       _LIBCPP_INLINE_VISIBILITY |       _LIBCPP_INLINE_VISIBILITY | ||||||
|       function(allocator_arg_t, const _Alloc&, nullptr_t) : __f_(0) {} |       function(allocator_arg_t, const _Alloc&, nullptr_t) _NOEXCEPT : __f_(0) {} | ||||||
|     template<class _Alloc> |     template<class _Alloc> | ||||||
|       function(allocator_arg_t, const _Alloc&, const function&); |       function(allocator_arg_t, const _Alloc&, const function&); | ||||||
|     template<class _Alloc> |     template<class _Alloc> | ||||||
|       function(allocator_arg_t, const _Alloc&, function&&); |       function(allocator_arg_t, const _Alloc&, function&&); | ||||||
|     template<class _F, class _Alloc> |     template<class _F, class _Alloc> | ||||||
|       function(allocator_arg_t, const _Alloc& __a, _F __f, |       function(allocator_arg_t, const _Alloc& __a, _F __f, | ||||||
|                typename enable_if<!is_integral<_F>::value>::type* = 0); |                typename enable_if<__callable<_F>::value>::type* = 0); | ||||||
|  |  | ||||||
|     function& operator=(const function&); |     function& operator=(const function&); | ||||||
|     function& operator=(function&&); |     function& operator=(function&&) _NOEXCEPT; | ||||||
|     function& operator=(nullptr_t); |     function& operator=(nullptr_t) _NOEXCEPT; | ||||||
|     template<class _F> |     template<class _F> | ||||||
|       typename enable_if |       typename enable_if | ||||||
|       < |       < | ||||||
|         !is_integral<typename decay<_F>::type>::value, |         __callable<typename decay<_F>::type>::value, | ||||||
|         function& |         function& | ||||||
|       >::type |       >::type | ||||||
|       operator=(_F&&); |       operator=(_F&&); | ||||||
| @@ -1149,15 +1158,15 @@ public: | |||||||
|     ~function(); |     ~function(); | ||||||
|  |  | ||||||
|     // function modifiers: |     // function modifiers: | ||||||
|     void swap(function&); |     void swap(function&) _NOEXCEPT; | ||||||
|     template<class _F, class _Alloc> |     template<class _F, class _Alloc> | ||||||
|       _LIBCPP_INLINE_VISIBILITY |       _LIBCPP_INLINE_VISIBILITY | ||||||
|       void assign(_F&& __f, const _Alloc& __a) |       void assign(_F&& __f, const _Alloc& __a) | ||||||
|         {function(allocator_arg, __a, _STD::forward<_F>(__f)).swap(*this);} |         {function(allocator_arg, __a, _VSTD::forward<_F>(__f)).swap(*this);} | ||||||
|  |  | ||||||
|     // function capacity: |     // function capacity: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     /*explicit*/ operator bool() const {return __f_;} |     /*explicit*/ operator bool() const _NOEXCEPT {return __f_;} | ||||||
|  |  | ||||||
|     // deleted overloads close possible hole in the type system |     // deleted overloads close possible hole in the type system | ||||||
|     template<class _R2, class... _ArgTypes2> |     template<class _R2, class... _ArgTypes2> | ||||||
| @@ -1170,9 +1179,9 @@ public: | |||||||
|  |  | ||||||
| #ifndef _LIBCPP_NO_RTTI | #ifndef _LIBCPP_NO_RTTI | ||||||
|     // function target access: |     // function target access: | ||||||
|     const std::type_info& target_type() const; |     const std::type_info& target_type() const _NOEXCEPT; | ||||||
|     template <typename _T> _T* target(); |     template <typename _T> _T* target() _NOEXCEPT; | ||||||
|     template <typename _T> const _T* target() const; |     template <typename _T> const _T* target() const _NOEXCEPT; | ||||||
| #endif  // _LIBCPP_NO_RTTI | #endif  // _LIBCPP_NO_RTTI | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -1207,7 +1216,7 @@ function<_R(_ArgTypes...)>::function(allocator_arg_t, const _Alloc&, | |||||||
| } | } | ||||||
|  |  | ||||||
| template<class _R, class ..._ArgTypes> | template<class _R, class ..._ArgTypes> | ||||||
| function<_R(_ArgTypes...)>::function(function&& __f) | function<_R(_ArgTypes...)>::function(function&& __f) _NOEXCEPT | ||||||
| { | { | ||||||
|     if (__f.__f_ == 0) |     if (__f.__f_ == 0) | ||||||
|         __f_ = 0; |         __f_ = 0; | ||||||
| @@ -1245,16 +1254,16 @@ function<_R(_ArgTypes...)>::function(allocator_arg_t, const _Alloc&, | |||||||
| template<class _R, class ..._ArgTypes> | template<class _R, class ..._ArgTypes> | ||||||
| template <class _F> | template <class _F> | ||||||
| function<_R(_ArgTypes...)>::function(_F __f, | function<_R(_ArgTypes...)>::function(_F __f, | ||||||
|                                      typename enable_if<!is_integral<_F>::value>::type*) |                                      typename enable_if<__callable<_F>::value>::type*) | ||||||
|     : __f_(0) |     : __f_(0) | ||||||
| { | { | ||||||
|     if (__not_null(__f)) |     if (__not_null(__f)) | ||||||
|     { |     { | ||||||
|         typedef __function::__func<_F, allocator<_F>, _R(_ArgTypes...)> _FF; |         typedef __function::__func<_F, allocator<_F>, _R(_ArgTypes...)> _FF; | ||||||
|         if (sizeof(_FF) <= sizeof(__buf_)) |         if (sizeof(_FF) <= sizeof(__buf_) && is_nothrow_copy_constructible<_F>::value) | ||||||
|         { |         { | ||||||
|             __f_ = (__base*)&__buf_; |             __f_ = (__base*)&__buf_; | ||||||
|             ::new (__f_) _FF(_STD::move(__f)); |             ::new (__f_) _FF(_VSTD::move(__f)); | ||||||
|         } |         } | ||||||
|         else |         else | ||||||
|         { |         { | ||||||
| @@ -1262,7 +1271,7 @@ function<_R(_ArgTypes...)>::function(_F __f, | |||||||
|             _A __a; |             _A __a; | ||||||
|             typedef __allocator_destructor<_A> _D; |             typedef __allocator_destructor<_A> _D; | ||||||
|             unique_ptr<__base, _D> __hold(__a.allocate(1), _D(__a, 1)); |             unique_ptr<__base, _D> __hold(__a.allocate(1), _D(__a, 1)); | ||||||
|             ::new (__hold.get()) _FF(_STD::move(__f), allocator<_F>(__a)); |             ::new (__hold.get()) _FF(_VSTD::move(__f), allocator<_F>(__a)); | ||||||
|             __f_ = __hold.release(); |             __f_ = __hold.release(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -1271,17 +1280,17 @@ function<_R(_ArgTypes...)>::function(_F __f, | |||||||
| template<class _R, class ..._ArgTypes> | template<class _R, class ..._ArgTypes> | ||||||
| template <class _F, class _Alloc> | template <class _F, class _Alloc> | ||||||
| function<_R(_ArgTypes...)>::function(allocator_arg_t, const _Alloc& __a0, _F __f, | function<_R(_ArgTypes...)>::function(allocator_arg_t, const _Alloc& __a0, _F __f, | ||||||
|                                      typename enable_if<!is_integral<_F>::value>::type*) |                                      typename enable_if<__callable<_F>::value>::type*) | ||||||
|     : __f_(0) |     : __f_(0) | ||||||
| { | { | ||||||
|     typedef allocator_traits<_Alloc> __alloc_traits; |     typedef allocator_traits<_Alloc> __alloc_traits; | ||||||
|     if (__not_null(__f)) |     if (__not_null(__f)) | ||||||
|     { |     { | ||||||
|         typedef __function::__func<_F, _Alloc, _R(_ArgTypes...)> _FF; |         typedef __function::__func<_F, _Alloc, _R(_ArgTypes...)> _FF; | ||||||
|         if (sizeof(_FF) <= sizeof(__buf_)) |         if (sizeof(_FF) <= sizeof(__buf_) && is_nothrow_copy_constructible<_F>::value) | ||||||
|         { |         { | ||||||
|             __f_ = (__base*)&__buf_; |             __f_ = (__base*)&__buf_; | ||||||
|             ::new (__f_) _FF(_STD::move(__f)); |             ::new (__f_) _FF(_VSTD::move(__f)); | ||||||
|         } |         } | ||||||
|         else |         else | ||||||
|         { |         { | ||||||
| @@ -1295,7 +1304,7 @@ function<_R(_ArgTypes...)>::function(allocator_arg_t, const _Alloc& __a0, _F __f | |||||||
|             _A __a(__a0); |             _A __a(__a0); | ||||||
|             typedef __allocator_destructor<_A> _D; |             typedef __allocator_destructor<_A> _D; | ||||||
|             unique_ptr<__base, _D> __hold(__a.allocate(1), _D(__a, 1)); |             unique_ptr<__base, _D> __hold(__a.allocate(1), _D(__a, 1)); | ||||||
|             ::new (__hold.get()) _FF(_STD::move(__f), _Alloc(__a)); |             ::new (__hold.get()) _FF(_VSTD::move(__f), _Alloc(__a)); | ||||||
|             __f_ = __hold.release(); |             __f_ = __hold.release(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -1311,7 +1320,7 @@ function<_R(_ArgTypes...)>::operator=(const function& __f) | |||||||
|  |  | ||||||
| template<class _R, class ..._ArgTypes> | template<class _R, class ..._ArgTypes> | ||||||
| function<_R(_ArgTypes...)>& | function<_R(_ArgTypes...)>& | ||||||
| function<_R(_ArgTypes...)>::operator=(function&& __f) | function<_R(_ArgTypes...)>::operator=(function&& __f) _NOEXCEPT | ||||||
| { | { | ||||||
|     if (__f_ == (__base*)&__buf_) |     if (__f_ == (__base*)&__buf_) | ||||||
|         __f_->destroy(); |         __f_->destroy(); | ||||||
| @@ -1334,7 +1343,7 @@ function<_R(_ArgTypes...)>::operator=(function&& __f) | |||||||
|  |  | ||||||
| template<class _R, class ..._ArgTypes> | template<class _R, class ..._ArgTypes> | ||||||
| function<_R(_ArgTypes...)>& | function<_R(_ArgTypes...)>& | ||||||
| function<_R(_ArgTypes...)>::operator=(nullptr_t) | function<_R(_ArgTypes...)>::operator=(nullptr_t) _NOEXCEPT | ||||||
| { | { | ||||||
|     if (__f_ == (__base*)&__buf_) |     if (__f_ == (__base*)&__buf_) | ||||||
|         __f_->destroy(); |         __f_->destroy(); | ||||||
| @@ -1347,12 +1356,12 @@ template<class _R, class ..._ArgTypes> | |||||||
| template <class _F> | template <class _F> | ||||||
| typename enable_if | typename enable_if | ||||||
| < | < | ||||||
|     !is_integral<typename decay<_F>::type>::value, |     function<_R(_ArgTypes...)>::template __callable<typename decay<_F>::type>::value, | ||||||
|     function<_R(_ArgTypes...)>& |     function<_R(_ArgTypes...)>& | ||||||
| >::type | >::type | ||||||
| function<_R(_ArgTypes...)>::operator=(_F&& __f) | function<_R(_ArgTypes...)>::operator=(_F&& __f) | ||||||
| { | { | ||||||
|     function(_STD::forward<_F>(__f)).swap(*this); |     function(_VSTD::forward<_F>(__f)).swap(*this); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1367,7 +1376,7 @@ function<_R(_ArgTypes...)>::~function() | |||||||
|  |  | ||||||
| template<class _R, class ..._ArgTypes> | template<class _R, class ..._ArgTypes> | ||||||
| void | void | ||||||
| function<_R(_ArgTypes...)>::swap(function& __f) | function<_R(_ArgTypes...)>::swap(function& __f) _NOEXCEPT | ||||||
| { | { | ||||||
|     if (__f_ == (__base*)&__buf_ && __f.__f_ == (__base*)&__f.__buf_) |     if (__f_ == (__base*)&__buf_ && __f.__f_ == (__base*)&__f.__buf_) | ||||||
|     { |     { | ||||||
| @@ -1399,7 +1408,7 @@ function<_R(_ArgTypes...)>::swap(function& __f) | |||||||
|         __f_ = (__base*)&__buf_; |         __f_ = (__base*)&__buf_; | ||||||
|     } |     } | ||||||
|     else |     else | ||||||
|         _STD::swap(__f_, __f.__f_); |         _VSTD::swap(__f_, __f.__f_); | ||||||
| } | } | ||||||
|  |  | ||||||
| template<class _R, class ..._ArgTypes> | template<class _R, class ..._ArgTypes> | ||||||
| @@ -1410,14 +1419,14 @@ function<_R(_ArgTypes...)>::operator()(_ArgTypes... __arg) const | |||||||
|     if (__f_ == 0) |     if (__f_ == 0) | ||||||
|         throw bad_function_call(); |         throw bad_function_call(); | ||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|     return (*__f_)(_STD::forward<_ArgTypes>(__arg)...); |     return (*__f_)(_VSTD::forward<_ArgTypes>(__arg)...); | ||||||
| } | } | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_NO_RTTI | #ifndef _LIBCPP_NO_RTTI | ||||||
|  |  | ||||||
| template<class _R, class ..._ArgTypes> | template<class _R, class ..._ArgTypes> | ||||||
| const std::type_info& | const std::type_info& | ||||||
| function<_R(_ArgTypes...)>::target_type() const | function<_R(_ArgTypes...)>::target_type() const _NOEXCEPT | ||||||
| { | { | ||||||
|     if (__f_ == 0) |     if (__f_ == 0) | ||||||
|         return typeid(void); |         return typeid(void); | ||||||
| @@ -1427,7 +1436,7 @@ function<_R(_ArgTypes...)>::target_type() const | |||||||
| template<class _R, class ..._ArgTypes> | template<class _R, class ..._ArgTypes> | ||||||
| template <typename _T> | template <typename _T> | ||||||
| _T* | _T* | ||||||
| function<_R(_ArgTypes...)>::target() | function<_R(_ArgTypes...)>::target() _NOEXCEPT | ||||||
| { | { | ||||||
|     if (__f_ == 0) |     if (__f_ == 0) | ||||||
|         return (_T*)0; |         return (_T*)0; | ||||||
| @@ -1437,7 +1446,7 @@ function<_R(_ArgTypes...)>::target() | |||||||
| template<class _R, class ..._ArgTypes> | template<class _R, class ..._ArgTypes> | ||||||
| template <typename _T> | template <typename _T> | ||||||
| const _T* | const _T* | ||||||
| function<_R(_ArgTypes...)>::target() const | function<_R(_ArgTypes...)>::target() const _NOEXCEPT | ||||||
| { | { | ||||||
|     if (__f_ == 0) |     if (__f_ == 0) | ||||||
|         return (const _T*)0; |         return (const _T*)0; | ||||||
| @@ -1449,27 +1458,27 @@ function<_R(_ArgTypes...)>::target() const | |||||||
| template <class _R, class... _ArgTypes> | template <class _R, class... _ArgTypes> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator==(const function<_R(_ArgTypes...)>& __f, nullptr_t) {return !__f;} | operator==(const function<_R(_ArgTypes...)>& __f, nullptr_t) _NOEXCEPT {return !__f;} | ||||||
|  |  | ||||||
| template <class _R, class... _ArgTypes> | template <class _R, class... _ArgTypes> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator==(nullptr_t, const function<_R(_ArgTypes...)>& __f) {return !__f;} | operator==(nullptr_t, const function<_R(_ArgTypes...)>& __f) _NOEXCEPT {return !__f;} | ||||||
|  |  | ||||||
| template <class _R, class... _ArgTypes> | template <class _R, class... _ArgTypes> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator!=(const function<_R(_ArgTypes...)>& __f, nullptr_t) {return (bool)__f;} | operator!=(const function<_R(_ArgTypes...)>& __f, nullptr_t) _NOEXCEPT {return (bool)__f;} | ||||||
|  |  | ||||||
| template <class _R, class... _ArgTypes> | template <class _R, class... _ArgTypes> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator!=(nullptr_t, const function<_R(_ArgTypes...)>& __f) {return (bool)__f;} | operator!=(nullptr_t, const function<_R(_ArgTypes...)>& __f) _NOEXCEPT {return (bool)__f;} | ||||||
|  |  | ||||||
| template <class _R, class... _ArgTypes> | template <class _R, class... _ArgTypes> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| void | void | ||||||
| swap(function<_R(_ArgTypes...)>& __x, function<_R(_ArgTypes...)>& __y) | swap(function<_R(_ArgTypes...)>& __x, function<_R(_ArgTypes...)>& __y) _NOEXCEPT | ||||||
| {return __x.swap(__y);} | {return __x.swap(__y);} | ||||||
|  |  | ||||||
| template<class _Tp> struct __is_bind_expression : public false_type {}; | template<class _Tp> struct __is_bind_expression : public false_type {}; | ||||||
| @@ -1510,21 +1519,12 @@ __mu(reference_wrapper<_Tp> __t, _Uj&) | |||||||
|     return __t.get(); |     return __t.get(); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <bool _IsBindExpr, class _Ti, class ..._Uj> |  | ||||||
| struct __mu_return1 {}; |  | ||||||
|  |  | ||||||
| template <class _Ti, class ..._Uj> |  | ||||||
| struct __mu_return1<true, _Ti, _Uj...> |  | ||||||
| { |  | ||||||
|     typedef typename result_of<_Ti(_Uj...)>::type type; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| template <class _Ti, class ..._Uj, size_t ..._Indx> | template <class _Ti, class ..._Uj, size_t ..._Indx> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| typename __mu_return1<true, _Ti, _Uj...>::type | typename __invoke_of<_Ti&, _Uj...>::type | ||||||
| __mu_expand(_Ti& __ti, tuple<_Uj...>&& __uj, __tuple_indices<_Indx...>) | __mu_expand(_Ti& __ti, tuple<_Uj...>& __uj, __tuple_indices<_Indx...>) | ||||||
| { | { | ||||||
|     return __ti(_STD::forward<typename tuple_element<_Indx, _Uj>::type>(get<_Indx>(__uj))...); |     return __ti(_VSTD::forward<_Uj>(get<_Indx>(__uj))...); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Ti, class ..._Uj> | template <class _Ti, class ..._Uj> | ||||||
| @@ -1532,7 +1532,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| typename enable_if | typename enable_if | ||||||
| < | < | ||||||
|     is_bind_expression<_Ti>::value, |     is_bind_expression<_Ti>::value, | ||||||
|     typename __mu_return1<is_bind_expression<_Ti>::value, _Ti, _Uj...>::type |     typename __invoke_of<_Ti&, _Uj...>::type | ||||||
| >::type | >::type | ||||||
| __mu(_Ti& __ti, tuple<_Uj...>& __uj) | __mu(_Ti& __ti, tuple<_Uj...>& __uj) | ||||||
| { | { | ||||||
| @@ -1559,7 +1559,7 @@ typename enable_if | |||||||
| __mu(_Ti&, _Uj& __uj) | __mu(_Ti&, _Uj& __uj) | ||||||
| { | { | ||||||
|     const size_t _Indx = is_placeholder<_Ti>::value - 1; |     const size_t _Indx = is_placeholder<_Ti>::value - 1; | ||||||
|     return _STD::forward<typename tuple_element<_Indx, _Uj>::type>(get<_Indx>(__uj)); |     return _VSTD::forward<typename tuple_element<_Indx, _Uj>::type>(get<_Indx>(__uj)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Ti, class _Uj> | template <class _Ti, class _Uj> | ||||||
| @@ -1576,24 +1576,31 @@ __mu(_Ti& __ti, _Uj& __uj) | |||||||
|     return __ti; |     return __ti; | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Ti, bool IsBindEx, bool IsPh, class _TupleUj> | template <class _Ti, bool IsReferenceWrapper, bool IsBindEx, bool IsPh, | ||||||
|  |           class _TupleUj> | ||||||
| struct ____mu_return; | struct ____mu_return; | ||||||
|  |  | ||||||
| template <class _Ti, class ..._Uj> | template <class _Ti, class ..._Uj> | ||||||
| struct ____mu_return<_Ti, true, false, tuple<_Uj...> > | struct ____mu_return<_Ti, false, true, false, tuple<_Uj...> > | ||||||
| { | { | ||||||
|     typedef typename result_of<_Ti(_Uj...)>::type type; |     typedef typename __invoke_of<_Ti&, _Uj...>::type type; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _Ti, class _TupleUj> | template <class _Ti, class _TupleUj> | ||||||
| struct ____mu_return<_Ti, false, true, _TupleUj> | struct ____mu_return<_Ti, false, false, true, _TupleUj> | ||||||
| { | { | ||||||
|     typedef typename tuple_element<is_placeholder<_Ti>::value - 1, |     typedef typename tuple_element<is_placeholder<_Ti>::value - 1, | ||||||
|                                    _TupleUj>::type&& type; |                                    _TupleUj>::type&& type; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _Ti, class _TupleUj> | template <class _Ti, class _TupleUj> | ||||||
| struct ____mu_return<_Ti, false, false, _TupleUj> | struct ____mu_return<_Ti, true, false, false, _TupleUj> | ||||||
|  | { | ||||||
|  |     typedef typename _Ti::type& type; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | template <class _Ti, class _TupleUj> | ||||||
|  | struct ____mu_return<_Ti, false, false, false, _TupleUj> | ||||||
| { | { | ||||||
|     typedef _Ti& type; |     typedef _Ti& type; | ||||||
| }; | }; | ||||||
| @@ -1601,25 +1608,20 @@ struct ____mu_return<_Ti, false, false, _TupleUj> | |||||||
| template <class _Ti, class _TupleUj> | template <class _Ti, class _TupleUj> | ||||||
| struct __mu_return | struct __mu_return | ||||||
|     : public ____mu_return<_Ti, |     : public ____mu_return<_Ti, | ||||||
|  |                            __is_reference_wrapper<_Ti>::value, | ||||||
|                            is_bind_expression<_Ti>::value, |                            is_bind_expression<_Ti>::value, | ||||||
|                            0 < is_placeholder<_Ti>::value, |                            0 < is_placeholder<_Ti>::value, | ||||||
|                            _TupleUj> |                            _TupleUj> | ||||||
| { | { | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _Ti, class _TupleUj> |  | ||||||
| struct __mu_return<reference_wrapper<_Ti>, _TupleUj> |  | ||||||
| { |  | ||||||
|     typedef _Ti& type; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| template <class _F, class _BoundArgs, class _TupleUj> | template <class _F, class _BoundArgs, class _TupleUj> | ||||||
| struct __bind_return; | struct __bind_return; | ||||||
|  |  | ||||||
| template <class _F, class ..._BoundArgs, class _TupleUj> | template <class _F, class ..._BoundArgs, class _TupleUj> | ||||||
| struct __bind_return<_F, tuple<_BoundArgs...>, _TupleUj> | struct __bind_return<_F, tuple<_BoundArgs...>, _TupleUj> | ||||||
| { | { | ||||||
|     typedef typename __invoke_return |     typedef typename __invoke_of | ||||||
|     < |     < | ||||||
|         _F&, |         _F&, | ||||||
|         typename __mu_return |         typename __mu_return | ||||||
| @@ -1633,7 +1635,7 @@ struct __bind_return<_F, tuple<_BoundArgs...>, _TupleUj> | |||||||
| template <class _F, class ..._BoundArgs, class _TupleUj> | template <class _F, class ..._BoundArgs, class _TupleUj> | ||||||
| struct __bind_return<_F, const tuple<_BoundArgs...>, _TupleUj> | struct __bind_return<_F, const tuple<_BoundArgs...>, _TupleUj> | ||||||
| { | { | ||||||
|     typedef typename __invoke_return |     typedef typename __invoke_of | ||||||
|     < |     < | ||||||
|         _F&, |         _F&, | ||||||
|         typename __mu_return |         typename __mu_return | ||||||
| @@ -1655,41 +1657,67 @@ __apply_functor(_F& __f, _BoundArgs& __bound_args, __tuple_indices<_Indx...>, | |||||||
|  |  | ||||||
| template<class _F, class ..._BoundArgs> | template<class _F, class ..._BoundArgs> | ||||||
| class __bind | class __bind | ||||||
|     : public __weak_result_type<_F> |     : public __weak_result_type<typename decay<_F>::type> | ||||||
| { | { | ||||||
|     _F __f_; |     typedef typename decay<_F>::type _Fd; | ||||||
|     tuple<_BoundArgs...> __bound_args_; |     typedef tuple<typename decay<_BoundArgs>::type...> _Td; | ||||||
|  |     _Fd __f_; | ||||||
|  |     _Td __bound_args_; | ||||||
|  |  | ||||||
|     typedef typename __make_tuple_indices<sizeof...(_BoundArgs)>::type __indices; |     typedef typename __make_tuple_indices<sizeof...(_BoundArgs)>::type __indices; | ||||||
| public: | public: | ||||||
|  | #ifdef _LIBCPP_HAS_NO_DEFAULTED_FUNCTIONS | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     __bind(const __bind& __b) | ||||||
|  |         : __f_(__b.__f_), | ||||||
|  |           __bound_args_(__b.__bound_args_) {} | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     __bind& operator=(const __bind& __b) | ||||||
|  |     { | ||||||
|  |         __f_ = __b.__f_; | ||||||
|  |         __bound_args_ = __b.__bound_args_; | ||||||
|  |         return *this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __bind(__bind&& __b) |     __bind(__bind&& __b) | ||||||
|         : __f_(_STD::move(__b.__f_)), |         : __f_(_VSTD::move(__b.__f_)), | ||||||
|           __bound_args_(_STD::move(__b.__bound_args_)) {} |           __bound_args_(_VSTD::move(__b.__bound_args_)) {} | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     __bind& operator=(__bind&& __b) | ||||||
|  |     { | ||||||
|  |         __f_ = _VSTD::move(__b.__f_); | ||||||
|  |         __bound_args_ = _VSTD::move(__b.__bound_args_); | ||||||
|  |         return *this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | #endif  // _LIBCPP_HAS_NO_DEFAULTED_FUNCTIONS | ||||||
|  |  | ||||||
|     template <class _G, class ..._BA> |     template <class _G, class ..._BA> | ||||||
|       _LIBCPP_INLINE_VISIBILITY |       _LIBCPP_INLINE_VISIBILITY | ||||||
|       explicit __bind(_G&& __f, _BA&& ...__bound_args) |       explicit __bind(_G&& __f, _BA&& ...__bound_args) | ||||||
|         : __f_(_STD::forward<_G>(__f)), |         : __f_(_VSTD::forward<_G>(__f)), | ||||||
|           __bound_args_(_STD::forward<_BA>(__bound_args)...) {} |           __bound_args_(_VSTD::forward<_BA>(__bound_args)...) {} | ||||||
|  |  | ||||||
|     template <class ..._Args> |     template <class ..._Args> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         typename __bind_return<_F, tuple<_BoundArgs...>, tuple<_Args&&...> >::type |         typename __bind_return<_Fd, _Td, tuple<_Args&&...> >::type | ||||||
|         operator()(_Args&& ...__args) |         operator()(_Args&& ...__args) | ||||||
|         { |         { | ||||||
|             // compiler bug workaround |  | ||||||
|             return __apply_functor(__f_, __bound_args_, __indices(), |             return __apply_functor(__f_, __bound_args_, __indices(), | ||||||
|                                   tuple<_Args&&...>(_STD::forward<_Args>(__args)...)); |                                   tuple<_Args&&...>(_VSTD::forward<_Args>(__args)...)); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     template <class ..._Args> |     template <class ..._Args> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         typename __bind_return<_F, tuple<_BoundArgs...>, tuple<_Args&&...> >::type |         typename __bind_return<_Fd, _Td, tuple<_Args&&...> >::type | ||||||
|         operator()(_Args&& ...__args) const |         operator()(_Args&& ...__args) const | ||||||
|         { |         { | ||||||
|             return __apply_functor(__f_, __bound_args_, __indices(), |             return __apply_functor(__f_, __bound_args_, __indices(), | ||||||
|                                    tuple<_Args&&...>(_STD::forward<_Args>(__args)...)); |                                    tuple<_Args&&...>(_VSTD::forward<_Args>(__args)...)); | ||||||
|         } |         } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -1704,18 +1732,44 @@ class __bind_r | |||||||
| public: | public: | ||||||
|     typedef _R result_type; |     typedef _R result_type; | ||||||
|  |  | ||||||
|  | #ifdef _LIBCPP_HAS_NO_DEFAULTED_FUNCTIONS | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     __bind_r(const __bind_r& __b) | ||||||
|  |         : base(_VSTD::forward<const base&>(__b)) {} | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     __bind_r& operator=(const __bind_r& __b) | ||||||
|  |     { | ||||||
|  |         base::operator=(_VSTD::forward<const base&>(__b)); | ||||||
|  |         return *this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     __bind_r(__bind_r&& __b) | ||||||
|  |         : base(_VSTD::forward<base>(__b)) {} | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     __bind_r& operator=(__bind_r&& __b) | ||||||
|  |     { | ||||||
|  |         base::operator=(_VSTD::forward<base>(__b)); | ||||||
|  |         return *this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | #endif  // _LIBCPP_HAS_NO_DEFAULTED_FUNCTIONS | ||||||
|  |  | ||||||
|     template <class _G, class ..._BA> |     template <class _G, class ..._BA> | ||||||
|       _LIBCPP_INLINE_VISIBILITY |       _LIBCPP_INLINE_VISIBILITY | ||||||
|       explicit __bind_r(_G&& __f, _BA&& ...__bound_args) |       explicit __bind_r(_G&& __f, _BA&& ...__bound_args) | ||||||
|         : base(_STD::forward<_G>(__f), |         : base(_VSTD::forward<_G>(__f), | ||||||
|                _STD::forward<_BA>(__bound_args)...) {} |                _VSTD::forward<_BA>(__bound_args)...) {} | ||||||
|  |  | ||||||
|     template <class ..._Args> |     template <class ..._Args> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         result_type |         result_type | ||||||
|         operator()(_Args&& ...__args) |         operator()(_Args&& ...__args) | ||||||
|         { |         { | ||||||
|             return base::operator()(_STD::forward<_Args>(__args)...); |             return base::operator()(_VSTD::forward<_Args>(__args)...); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     template <class ..._Args> |     template <class ..._Args> | ||||||
| @@ -1723,7 +1777,7 @@ public: | |||||||
|         result_type |         result_type | ||||||
|         operator()(_Args&& ...__args) const |         operator()(_Args&& ...__args) const | ||||||
|         { |         { | ||||||
|             return base::operator()(_STD::forward<_Args>(__args)...); |             return base::operator()(_VSTD::forward<_Args>(__args)...); | ||||||
|         } |         } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -1732,20 +1786,20 @@ struct __is_bind_expression<__bind_r<_R, _F, _BoundArgs...> > : public true_type | |||||||
|  |  | ||||||
| template<class _F, class ..._BoundArgs> | template<class _F, class ..._BoundArgs> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| __bind<typename decay<_F>::type, typename decay<_BoundArgs>::type...> | __bind<_F, _BoundArgs...> | ||||||
| bind(_F&& __f, _BoundArgs&&... __bound_args) | bind(_F&& __f, _BoundArgs&&... __bound_args) | ||||||
| { | { | ||||||
|     typedef __bind<typename decay<_F>::type, typename decay<_BoundArgs>::type...> type; |     typedef __bind<_F, _BoundArgs...> type; | ||||||
|     return type(_STD::forward<_F>(__f), _STD::forward<_BoundArgs>(__bound_args)...); |     return type(_VSTD::forward<_F>(__f), _VSTD::forward<_BoundArgs>(__bound_args)...); | ||||||
| } | } | ||||||
|  |  | ||||||
| template<class _R, class _F, class ..._BoundArgs> | template<class _R, class _F, class ..._BoundArgs> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| __bind_r<_R, typename decay<_F>::type, typename decay<_BoundArgs>::type...> | __bind_r<_R, _F, _BoundArgs...> | ||||||
| bind(_F&& __f, _BoundArgs&&... __bound_args) | bind(_F&& __f, _BoundArgs&&... __bound_args) | ||||||
| { | { | ||||||
|     typedef __bind_r<_R, typename decay<_F>::type, typename decay<_BoundArgs>::type...> type; |     typedef __bind_r<_R, _F, _BoundArgs...> type; | ||||||
|     return type(_STD::forward<_F>(__f), _STD::forward<_BoundArgs>(__bound_args)...); |     return type(_VSTD::forward<_F>(__f), _VSTD::forward<_BoundArgs>(__bound_args)...); | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||||
| @@ -1755,7 +1809,7 @@ struct _LIBCPP_VISIBLE hash<bool> | |||||||
|     : public unary_function<bool, size_t> |     : public unary_function<bool, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(bool __v) const {return static_cast<size_t>(__v);} |     size_t operator()(bool __v) const _NOEXCEPT {return static_cast<size_t>(__v);} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <> | template <> | ||||||
| @@ -1763,7 +1817,7 @@ struct _LIBCPP_VISIBLE hash<char> | |||||||
|     : public unary_function<char, size_t> |     : public unary_function<char, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(char __v) const {return static_cast<size_t>(__v);} |     size_t operator()(char __v) const _NOEXCEPT {return static_cast<size_t>(__v);} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <> | template <> | ||||||
| @@ -1771,7 +1825,7 @@ struct _LIBCPP_VISIBLE hash<signed char> | |||||||
|     : public unary_function<signed char, size_t> |     : public unary_function<signed char, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(signed char __v) const {return static_cast<size_t>(__v);} |     size_t operator()(signed char __v) const _NOEXCEPT {return static_cast<size_t>(__v);} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <> | template <> | ||||||
| @@ -1779,7 +1833,7 @@ struct _LIBCPP_VISIBLE hash<unsigned char> | |||||||
|     : public unary_function<unsigned char, size_t> |     : public unary_function<unsigned char, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(unsigned char __v) const {return static_cast<size_t>(__v);} |     size_t operator()(unsigned char __v) const _NOEXCEPT {return static_cast<size_t>(__v);} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_UNICODE_CHARS | #ifndef _LIBCPP_HAS_NO_UNICODE_CHARS | ||||||
| @@ -1789,7 +1843,7 @@ struct _LIBCPP_VISIBLE hash<char16_t> | |||||||
|     : public unary_function<char16_t, size_t> |     : public unary_function<char16_t, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(char16_t __v) const {return static_cast<size_t>(__v);} |     size_t operator()(char16_t __v) const _NOEXCEPT {return static_cast<size_t>(__v);} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <> | template <> | ||||||
| @@ -1797,7 +1851,7 @@ struct _LIBCPP_VISIBLE hash<char32_t> | |||||||
|     : public unary_function<char32_t, size_t> |     : public unary_function<char32_t, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(char32_t __v) const {return static_cast<size_t>(__v);} |     size_t operator()(char32_t __v) const _NOEXCEPT {return static_cast<size_t>(__v);} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_UNICODE_CHARS | #endif  // _LIBCPP_HAS_NO_UNICODE_CHARS | ||||||
| @@ -1807,7 +1861,7 @@ struct _LIBCPP_VISIBLE hash<wchar_t> | |||||||
|     : public unary_function<wchar_t, size_t> |     : public unary_function<wchar_t, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(wchar_t __v) const {return static_cast<size_t>(__v);} |     size_t operator()(wchar_t __v) const _NOEXCEPT {return static_cast<size_t>(__v);} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <> | template <> | ||||||
| @@ -1815,7 +1869,7 @@ struct _LIBCPP_VISIBLE hash<short> | |||||||
|     : public unary_function<short, size_t> |     : public unary_function<short, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(short __v) const {return static_cast<size_t>(__v);} |     size_t operator()(short __v) const _NOEXCEPT {return static_cast<size_t>(__v);} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <> | template <> | ||||||
| @@ -1823,7 +1877,7 @@ struct _LIBCPP_VISIBLE hash<unsigned short> | |||||||
|     : public unary_function<unsigned short, size_t> |     : public unary_function<unsigned short, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(unsigned short __v) const {return static_cast<size_t>(__v);} |     size_t operator()(unsigned short __v) const _NOEXCEPT {return static_cast<size_t>(__v);} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <> | template <> | ||||||
| @@ -1831,7 +1885,7 @@ struct _LIBCPP_VISIBLE hash<int> | |||||||
|     : public unary_function<int, size_t> |     : public unary_function<int, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(int __v) const {return static_cast<size_t>(__v);} |     size_t operator()(int __v) const _NOEXCEPT {return static_cast<size_t>(__v);} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <> | template <> | ||||||
| @@ -1839,7 +1893,7 @@ struct _LIBCPP_VISIBLE hash<unsigned int> | |||||||
|     : public unary_function<unsigned int, size_t> |     : public unary_function<unsigned int, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(unsigned int __v) const {return static_cast<size_t>(__v);} |     size_t operator()(unsigned int __v) const _NOEXCEPT {return static_cast<size_t>(__v);} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <> | template <> | ||||||
| @@ -1847,7 +1901,7 @@ struct _LIBCPP_VISIBLE hash<long> | |||||||
|     : public unary_function<long, size_t> |     : public unary_function<long, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(long __v) const {return static_cast<size_t>(__v);} |     size_t operator()(long __v) const _NOEXCEPT {return static_cast<size_t>(__v);} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <> | template <> | ||||||
| @@ -1855,7 +1909,7 @@ struct _LIBCPP_VISIBLE hash<unsigned long> | |||||||
|     : public unary_function<unsigned long, size_t> |     : public unary_function<unsigned long, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(unsigned long __v) const {return static_cast<size_t>(__v);} |     size_t operator()(unsigned long __v) const _NOEXCEPT {return static_cast<size_t>(__v);} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <> | template <> | ||||||
| @@ -1863,7 +1917,7 @@ struct _LIBCPP_VISIBLE hash<long long> | |||||||
|     : public unary_function<long long, size_t> |     : public unary_function<long long, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(long long __v) const |     size_t operator()(long long __v) const _NOEXCEPT | ||||||
|     { |     { | ||||||
|         size_t __r = 0; |         size_t __r = 0; | ||||||
|         const size_t* const __p = reinterpret_cast<const size_t*>(&__v); |         const size_t* const __p = reinterpret_cast<const size_t*>(&__v); | ||||||
| @@ -1878,7 +1932,7 @@ struct _LIBCPP_VISIBLE hash<unsigned long long> | |||||||
|     : public unary_function<unsigned long long, size_t> |     : public unary_function<unsigned long long, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(unsigned long long __v) const |     size_t operator()(unsigned long long __v) const _NOEXCEPT | ||||||
|     { |     { | ||||||
|         size_t __r = 0; |         size_t __r = 0; | ||||||
|         const size_t* const __p = reinterpret_cast<const size_t*>(&__v); |         const size_t* const __p = reinterpret_cast<const size_t*>(&__v); | ||||||
| @@ -1893,7 +1947,7 @@ struct _LIBCPP_VISIBLE hash<float> | |||||||
|     : public unary_function<float, size_t> |     : public unary_function<float, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(float __v) const |     size_t operator()(float __v) const _NOEXCEPT | ||||||
|     { |     { | ||||||
|         if (__v == 0) |         if (__v == 0) | ||||||
|             return 0; |             return 0; | ||||||
| @@ -1907,7 +1961,7 @@ struct _LIBCPP_VISIBLE hash<double> | |||||||
|     : public unary_function<double, size_t> |     : public unary_function<double, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(double __v) const |     size_t operator()(double __v) const _NOEXCEPT | ||||||
|     { |     { | ||||||
|         if (__v == 0) |         if (__v == 0) | ||||||
|             return 0; |             return 0; | ||||||
| @@ -1924,7 +1978,7 @@ struct _LIBCPP_VISIBLE hash<long double> | |||||||
|     : public unary_function<long double, size_t> |     : public unary_function<long double, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(long double __v) const |     size_t operator()(long double __v) const _NOEXCEPT | ||||||
|     { |     { | ||||||
|         if (__v == 0) |         if (__v == 0) | ||||||
|             return 0; |             return 0; | ||||||
|   | |||||||
							
								
								
									
										368
									
								
								include/future
									
									
									
									
									
								
							
							
						
						
									
										368
									
								
								include/future
									
									
									
									
									
								
							| @@ -452,6 +452,8 @@ public: | |||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const error_code& code() const throw() {return __ec_;} |     const error_code& code() const throw() {return __ec_;} | ||||||
|  |  | ||||||
|  |     virtual ~future_error() _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class __assoc_sub_state | class __assoc_sub_state | ||||||
| @@ -463,7 +465,7 @@ protected: | |||||||
|     mutable condition_variable __cv_; |     mutable condition_variable __cv_; | ||||||
|     unsigned __state_; |     unsigned __state_; | ||||||
|  |  | ||||||
|     virtual void __on_zero_shared(); |     virtual void __on_zero_shared() _NOEXCEPT; | ||||||
|     void __sub_wait(unique_lock<mutex>& __lk); |     void __sub_wait(unique_lock<mutex>& __lk); | ||||||
| public: | public: | ||||||
|     enum |     enum | ||||||
| @@ -543,7 +545,7 @@ class __assoc_state | |||||||
| protected: | protected: | ||||||
|     _U __value_; |     _U __value_; | ||||||
|  |  | ||||||
|     virtual void __on_zero_shared(); |     virtual void __on_zero_shared() _NOEXCEPT; | ||||||
| public: | public: | ||||||
|  |  | ||||||
|     template <class _Arg> |     template <class _Arg> | ||||||
| @@ -566,7 +568,7 @@ public: | |||||||
|  |  | ||||||
| template <class _R> | template <class _R> | ||||||
| void | void | ||||||
| __assoc_state<_R>::__on_zero_shared() | __assoc_state<_R>::__on_zero_shared() _NOEXCEPT | ||||||
| { | { | ||||||
|     if (this->__state_ & base::__constructed) |     if (this->__state_ & base::__constructed) | ||||||
|         reinterpret_cast<_R*>(&__value_)->~_R(); |         reinterpret_cast<_R*>(&__value_)->~_R(); | ||||||
| @@ -583,9 +585,11 @@ __assoc_state<_R>::set_value(_Arg& __arg) | |||||||
| #endif | #endif | ||||||
| { | { | ||||||
|     unique_lock<mutex> __lk(this->__mut_); |     unique_lock<mutex> __lk(this->__mut_); | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (this->__has_value()) |     if (this->__has_value()) | ||||||
|         throw future_error(make_error_code(future_errc::promise_already_satisfied)); |         throw future_error(make_error_code(future_errc::promise_already_satisfied)); | ||||||
|     ::new(&__value_) _R(_STD::forward<_Arg>(__arg)); | #endif | ||||||
|  |     ::new(&__value_) _R(_VSTD::forward<_Arg>(__arg)); | ||||||
|     this->__state_ |= base::__constructed | base::ready; |     this->__state_ |= base::__constructed | base::ready; | ||||||
|     __lk.unlock(); |     __lk.unlock(); | ||||||
|     __cv_.notify_all(); |     __cv_.notify_all(); | ||||||
| @@ -601,9 +605,11 @@ __assoc_state<_R>::set_value_at_thread_exit(_Arg& __arg) | |||||||
| #endif | #endif | ||||||
| { | { | ||||||
|     unique_lock<mutex> __lk(this->__mut_); |     unique_lock<mutex> __lk(this->__mut_); | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (this->__has_value()) |     if (this->__has_value()) | ||||||
|         throw future_error(make_error_code(future_errc::promise_already_satisfied)); |         throw future_error(make_error_code(future_errc::promise_already_satisfied)); | ||||||
|     ::new(&__value_) _R(_STD::forward<_Arg>(__arg)); | #endif | ||||||
|  |     ::new(&__value_) _R(_VSTD::forward<_Arg>(__arg)); | ||||||
|     this->__state_ |= base::__constructed; |     this->__state_ |= base::__constructed; | ||||||
|     __thread_local_data()->__make_ready_at_thread_exit(this); |     __thread_local_data()->__make_ready_at_thread_exit(this); | ||||||
|     __lk.unlock(); |     __lk.unlock(); | ||||||
| @@ -617,7 +623,7 @@ __assoc_state<_R>::move() | |||||||
|     this->__sub_wait(__lk); |     this->__sub_wait(__lk); | ||||||
|     if (this->__exception_ != nullptr) |     if (this->__exception_ != nullptr) | ||||||
|         rethrow_exception(this->__exception_); |         rethrow_exception(this->__exception_); | ||||||
|     return _STD::move(*reinterpret_cast<_R*>(&__value_)); |     return _VSTD::move(*reinterpret_cast<_R*>(&__value_)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _R> | template <class _R> | ||||||
| @@ -640,7 +646,7 @@ class __assoc_state<_R&> | |||||||
| protected: | protected: | ||||||
|     _U __value_; |     _U __value_; | ||||||
|  |  | ||||||
|     virtual void __on_zero_shared(); |     virtual void __on_zero_shared() _NOEXCEPT; | ||||||
| public: | public: | ||||||
|  |  | ||||||
|     void set_value(_R& __arg); |     void set_value(_R& __arg); | ||||||
| @@ -651,7 +657,7 @@ public: | |||||||
|  |  | ||||||
| template <class _R> | template <class _R> | ||||||
| void | void | ||||||
| __assoc_state<_R&>::__on_zero_shared() | __assoc_state<_R&>::__on_zero_shared() _NOEXCEPT | ||||||
| { | { | ||||||
|     delete this; |     delete this; | ||||||
| } | } | ||||||
| @@ -661,8 +667,10 @@ void | |||||||
| __assoc_state<_R&>::set_value(_R& __arg) | __assoc_state<_R&>::set_value(_R& __arg) | ||||||
| { | { | ||||||
|     unique_lock<mutex> __lk(this->__mut_); |     unique_lock<mutex> __lk(this->__mut_); | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (this->__has_value()) |     if (this->__has_value()) | ||||||
|         throw future_error(make_error_code(future_errc::promise_already_satisfied)); |         throw future_error(make_error_code(future_errc::promise_already_satisfied)); | ||||||
|  | #endif | ||||||
|     __value_ = &__arg; |     __value_ = &__arg; | ||||||
|     this->__state_ |= base::__constructed | base::ready; |     this->__state_ |= base::__constructed | base::ready; | ||||||
|     __lk.unlock(); |     __lk.unlock(); | ||||||
| @@ -674,8 +682,10 @@ void | |||||||
| __assoc_state<_R&>::set_value_at_thread_exit(_R& __arg) | __assoc_state<_R&>::set_value_at_thread_exit(_R& __arg) | ||||||
| { | { | ||||||
|     unique_lock<mutex> __lk(this->__mut_); |     unique_lock<mutex> __lk(this->__mut_); | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (this->__has_value()) |     if (this->__has_value()) | ||||||
|         throw future_error(make_error_code(future_errc::promise_already_satisfied)); |         throw future_error(make_error_code(future_errc::promise_already_satisfied)); | ||||||
|  | #endif | ||||||
|     __value_ = &__arg; |     __value_ = &__arg; | ||||||
|     this->__state_ |= base::__constructed; |     this->__state_ |= base::__constructed; | ||||||
|     __thread_local_data()->__make_ready_at_thread_exit(this); |     __thread_local_data()->__make_ready_at_thread_exit(this); | ||||||
| @@ -700,7 +710,7 @@ class __assoc_state_alloc | |||||||
|     typedef __assoc_state<_R> base; |     typedef __assoc_state<_R> base; | ||||||
|     _Alloc __alloc_; |     _Alloc __alloc_; | ||||||
|  |  | ||||||
|     virtual void __on_zero_shared(); |     virtual void __on_zero_shared() _NOEXCEPT; | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __assoc_state_alloc(const _Alloc& __a) |     explicit __assoc_state_alloc(const _Alloc& __a) | ||||||
| @@ -709,7 +719,7 @@ public: | |||||||
|  |  | ||||||
| template <class _R, class _Alloc> | template <class _R, class _Alloc> | ||||||
| void | void | ||||||
| __assoc_state_alloc<_R, _Alloc>::__on_zero_shared() | __assoc_state_alloc<_R, _Alloc>::__on_zero_shared() _NOEXCEPT | ||||||
| { | { | ||||||
|     if (this->__state_ & base::__constructed) |     if (this->__state_ & base::__constructed) | ||||||
|         reinterpret_cast<_R*>(&this->__value_)->~_R(); |         reinterpret_cast<_R*>(&this->__value_)->~_R(); | ||||||
| @@ -725,7 +735,7 @@ class __assoc_state_alloc<_R&, _Alloc> | |||||||
|     typedef __assoc_state<_R&> base; |     typedef __assoc_state<_R&> base; | ||||||
|     _Alloc __alloc_; |     _Alloc __alloc_; | ||||||
|  |  | ||||||
|     virtual void __on_zero_shared(); |     virtual void __on_zero_shared() _NOEXCEPT; | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __assoc_state_alloc(const _Alloc& __a) |     explicit __assoc_state_alloc(const _Alloc& __a) | ||||||
| @@ -734,7 +744,7 @@ public: | |||||||
|  |  | ||||||
| template <class _R, class _Alloc> | template <class _R, class _Alloc> | ||||||
| void | void | ||||||
| __assoc_state_alloc<_R&, _Alloc>::__on_zero_shared() | __assoc_state_alloc<_R&, _Alloc>::__on_zero_shared() _NOEXCEPT | ||||||
| { | { | ||||||
|     typename _Alloc::template rebind<__assoc_state_alloc>::other __a(__alloc_); |     typename _Alloc::template rebind<__assoc_state_alloc>::other __a(__alloc_); | ||||||
|     this->~__assoc_state_alloc(); |     this->~__assoc_state_alloc(); | ||||||
| @@ -748,7 +758,7 @@ class __assoc_sub_state_alloc | |||||||
|     typedef __assoc_sub_state base; |     typedef __assoc_sub_state base; | ||||||
|     _Alloc __alloc_; |     _Alloc __alloc_; | ||||||
|  |  | ||||||
|     virtual void __on_zero_shared(); |     virtual void __on_zero_shared() _NOEXCEPT; | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __assoc_sub_state_alloc(const _Alloc& __a) |     explicit __assoc_sub_state_alloc(const _Alloc& __a) | ||||||
| @@ -757,7 +767,7 @@ public: | |||||||
|  |  | ||||||
| template <class _Alloc> | template <class _Alloc> | ||||||
| void | void | ||||||
| __assoc_sub_state_alloc<_Alloc>::__on_zero_shared() | __assoc_sub_state_alloc<_Alloc>::__on_zero_shared() _NOEXCEPT | ||||||
| { | { | ||||||
|     this->~base(); |     this->~base(); | ||||||
|     typename _Alloc::template rebind<__assoc_sub_state_alloc>::other __a(__alloc_); |     typename _Alloc::template rebind<__assoc_sub_state_alloc>::other __a(__alloc_); | ||||||
| @@ -786,7 +796,7 @@ public: | |||||||
| template <class _R, class _F> | template <class _R, class _F> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| __deferred_assoc_state<_R, _F>::__deferred_assoc_state(_F&& __f) | __deferred_assoc_state<_R, _F>::__deferred_assoc_state(_F&& __f) | ||||||
|     : __func_(_STD::forward<_F>(__f)) |     : __func_(_VSTD::forward<_F>(__f)) | ||||||
| { | { | ||||||
|     this->__set_deferred(); |     this->__set_deferred(); | ||||||
| } | } | ||||||
| @@ -832,7 +842,7 @@ public: | |||||||
| template <class _F> | template <class _F> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| __deferred_assoc_state<void, _F>::__deferred_assoc_state(_F&& __f) | __deferred_assoc_state<void, _F>::__deferred_assoc_state(_F&& __f) | ||||||
|     : __func_(_STD::forward<_F>(__f)) |     : __func_(_VSTD::forward<_F>(__f)) | ||||||
| { | { | ||||||
|     this->__set_deferred(); |     this->__set_deferred(); | ||||||
| } | } | ||||||
| @@ -858,9 +868,117 @@ __deferred_assoc_state<void, _F>::__execute() | |||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class> class promise; | template <class _R, class _F> | ||||||
| template <class> class shared_future; | class __async_assoc_state | ||||||
| template <class> class atomic_future; |     : public __assoc_state<_R> | ||||||
|  | { | ||||||
|  |     typedef __assoc_state<_R> base; | ||||||
|  |  | ||||||
|  |     _F __func_; | ||||||
|  |  | ||||||
|  |     virtual void __on_zero_shared() _NOEXCEPT; | ||||||
|  | public: | ||||||
|  | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     explicit __async_assoc_state(_F&& __f); | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |     virtual void __execute(); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|  | template <class _R, class _F> | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | __async_assoc_state<_R, _F>::__async_assoc_state(_F&& __f) | ||||||
|  |     : __func_(_VSTD::forward<_F>(__f)) | ||||||
|  | { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|  | template <class _R, class _F> | ||||||
|  | void | ||||||
|  | __async_assoc_state<_R, _F>::__execute() | ||||||
|  | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|  |     try | ||||||
|  |     { | ||||||
|  | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|  |         this->set_value(__func_()); | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|  |     } | ||||||
|  |     catch (...) | ||||||
|  |     { | ||||||
|  |         this->set_exception(current_exception()); | ||||||
|  |     } | ||||||
|  | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class _R, class _F> | ||||||
|  | void | ||||||
|  | __async_assoc_state<_R, _F>::__on_zero_shared() _NOEXCEPT | ||||||
|  | { | ||||||
|  |     this->wait(); | ||||||
|  |     base::__on_zero_shared(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class _F> | ||||||
|  | class __async_assoc_state<void, _F> | ||||||
|  |     : public __assoc_sub_state | ||||||
|  | { | ||||||
|  |     typedef __assoc_sub_state base; | ||||||
|  |  | ||||||
|  |     _F __func_; | ||||||
|  |  | ||||||
|  |     virtual void __on_zero_shared() _NOEXCEPT; | ||||||
|  | public: | ||||||
|  | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     explicit __async_assoc_state(_F&& __f); | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |     virtual void __execute(); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|  | template <class _F> | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | __async_assoc_state<void, _F>::__async_assoc_state(_F&& __f) | ||||||
|  |     : __func_(_VSTD::forward<_F>(__f)) | ||||||
|  | { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|  | template <class _F> | ||||||
|  | void | ||||||
|  | __async_assoc_state<void, _F>::__execute() | ||||||
|  | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|  |     try | ||||||
|  |     { | ||||||
|  | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|  |         __func_(); | ||||||
|  |         this->set_value(); | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|  |     } | ||||||
|  |     catch (...) | ||||||
|  |     { | ||||||
|  |         this->set_exception(current_exception()); | ||||||
|  |     } | ||||||
|  | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class _F> | ||||||
|  | void | ||||||
|  | __async_assoc_state<void, _F>::__on_zero_shared() _NOEXCEPT | ||||||
|  | { | ||||||
|  |     this->wait(); | ||||||
|  |     base::__on_zero_shared(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class _R> class promise; | ||||||
|  | template <class _R> class shared_future; | ||||||
|  |  | ||||||
| // future | // future | ||||||
|  |  | ||||||
| @@ -874,6 +992,14 @@ __make_deferred_assoc_state(_F&& __f); | |||||||
| __make_deferred_assoc_state(_F __f); | __make_deferred_assoc_state(_F __f); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | template <class _R, class _F> | ||||||
|  | future<_R> | ||||||
|  | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  | __make_async_assoc_state(_F&& __f); | ||||||
|  | #else | ||||||
|  | __make_async_assoc_state(_F __f); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| template <class _R> | template <class _R> | ||||||
| class _LIBCPP_VISIBLE future | class _LIBCPP_VISIBLE future | ||||||
| { | { | ||||||
| @@ -883,13 +1009,17 @@ class _LIBCPP_VISIBLE future | |||||||
|  |  | ||||||
|     template <class> friend class promise; |     template <class> friend class promise; | ||||||
|     template <class> friend class shared_future; |     template <class> friend class shared_future; | ||||||
|     template <class> friend class atomic_future; |  | ||||||
|  |  | ||||||
|     template <class _R1, class _F> |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     template <class _R1, class _F> | ||||||
|         friend future<_R1> __make_deferred_assoc_state(_F&& __f); |         friend future<_R1> __make_deferred_assoc_state(_F&& __f); | ||||||
|  |     template <class _R1, class _F> | ||||||
|  |         friend future<_R1> __make_async_assoc_state(_F&& __f); | ||||||
| #else | #else | ||||||
|  |     template <class _R1, class _F> | ||||||
|         friend future<_R1> __make_deferred_assoc_state(_F __f); |         friend future<_R1> __make_deferred_assoc_state(_F __f); | ||||||
|  |     template <class _R1, class _F> | ||||||
|  |         friend future<_R1> __make_async_assoc_state(_F __f); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| public: | public: | ||||||
| @@ -920,7 +1050,7 @@ public: | |||||||
|     _R get(); |     _R get(); | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(future& __rhs) {_STD::swap(__state_, __rhs.__state_);} |     void swap(future& __rhs) {_VSTD::swap(__state_, __rhs.__state_);} | ||||||
|  |  | ||||||
|     // functions to check state |     // functions to check state | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -944,8 +1074,10 @@ template <class _R> | |||||||
| future<_R>::future(__assoc_state<_R>* __state) | future<_R>::future(__assoc_state<_R>* __state) | ||||||
|     : __state_(__state) |     : __state_(__state) | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_->__has_future_attached()) |     if (__state_->__has_future_attached()) | ||||||
|         throw future_error(make_error_code(future_errc::future_already_retrieved)); |         throw future_error(make_error_code(future_errc::future_already_retrieved)); | ||||||
|  | #endif | ||||||
|     __state_->__add_shared(); |     __state_->__add_shared(); | ||||||
|     __state_->__set_future_attached(); |     __state_->__set_future_attached(); | ||||||
| } | } | ||||||
| @@ -981,13 +1113,17 @@ class _LIBCPP_VISIBLE future<_R&> | |||||||
|  |  | ||||||
|     template <class> friend class promise; |     template <class> friend class promise; | ||||||
|     template <class> friend class shared_future; |     template <class> friend class shared_future; | ||||||
|     template <class> friend class atomic_future; |  | ||||||
|  |  | ||||||
|     template <class _R1, class _F> |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     template <class _R1, class _F> | ||||||
|         friend future<_R1> __make_deferred_assoc_state(_F&& __f); |         friend future<_R1> __make_deferred_assoc_state(_F&& __f); | ||||||
|  |     template <class _R1, class _F> | ||||||
|  |         friend future<_R1> __make_async_assoc_state(_F&& __f); | ||||||
| #else | #else | ||||||
|  |     template <class _R1, class _F> | ||||||
|         friend future<_R1> __make_deferred_assoc_state(_F __f); |         friend future<_R1> __make_deferred_assoc_state(_F __f); | ||||||
|  |     template <class _R1, class _F> | ||||||
|  |         friend future<_R1> __make_async_assoc_state(_F __f); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| public: | public: | ||||||
| @@ -1018,7 +1154,7 @@ public: | |||||||
|     _R& get(); |     _R& get(); | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(future& __rhs) {_STD::swap(__state_, __rhs.__state_);} |     void swap(future& __rhs) {_VSTD::swap(__state_, __rhs.__state_);} | ||||||
|  |  | ||||||
|     // functions to check state |     // functions to check state | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -1042,8 +1178,10 @@ template <class _R> | |||||||
| future<_R&>::future(__assoc_state<_R&>* __state) | future<_R&>::future(__assoc_state<_R&>* __state) | ||||||
|     : __state_(__state) |     : __state_(__state) | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_->__has_future_attached()) |     if (__state_->__has_future_attached()) | ||||||
|         throw future_error(make_error_code(future_errc::future_already_retrieved)); |         throw future_error(make_error_code(future_errc::future_already_retrieved)); | ||||||
|  | #endif | ||||||
|     __state_->__add_shared(); |     __state_->__add_shared(); | ||||||
|     __state_->__set_future_attached(); |     __state_->__set_future_attached(); | ||||||
| } | } | ||||||
| @@ -1074,13 +1212,17 @@ class _LIBCPP_VISIBLE future<void> | |||||||
|  |  | ||||||
|     template <class> friend class promise; |     template <class> friend class promise; | ||||||
|     template <class> friend class shared_future; |     template <class> friend class shared_future; | ||||||
|     template <class> friend class atomic_future; |  | ||||||
|  |  | ||||||
|     template <class _R1, class _F> |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     template <class _R1, class _F> | ||||||
|         friend future<_R1> __make_deferred_assoc_state(_F&& __f); |         friend future<_R1> __make_deferred_assoc_state(_F&& __f); | ||||||
|  |     template <class _R1, class _F> | ||||||
|  |         friend future<_R1> __make_async_assoc_state(_F&& __f); | ||||||
| #else | #else | ||||||
|  |     template <class _R1, class _F> | ||||||
|         friend future<_R1> __make_deferred_assoc_state(_F __f); |         friend future<_R1> __make_deferred_assoc_state(_F __f); | ||||||
|  |     template <class _R1, class _F> | ||||||
|  |         friend future<_R1> __make_async_assoc_state(_F __f); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| public: | public: | ||||||
| @@ -1111,7 +1253,7 @@ public: | |||||||
|     void get(); |     void get(); | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(future& __rhs) {_STD::swap(__state_, __rhs.__state_);} |     void swap(future& __rhs) {_VSTD::swap(__state_, __rhs.__state_);} | ||||||
|  |  | ||||||
|     // functions to check state |     // functions to check state | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -1141,7 +1283,7 @@ swap(future<_R>& __x, future<_R>& __y) | |||||||
|  |  | ||||||
| // promise<R> | // promise<R> | ||||||
|  |  | ||||||
| template <class> class packaged_task; | template <class _Callable> class packaged_task; | ||||||
|  |  | ||||||
| template <class _R> | template <class _R> | ||||||
| class _LIBCPP_VISIBLE promise | class _LIBCPP_VISIBLE promise | ||||||
| @@ -1183,7 +1325,7 @@ private: | |||||||
| public: | public: | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(promise& __rhs) {_STD::swap(__state_, __rhs.__state_);} |     void swap(promise& __rhs) {_VSTD::swap(__state_, __rhs.__state_);} | ||||||
|  |  | ||||||
|     // retrieving the result |     // retrieving the result | ||||||
|     future<_R> get_future(); |     future<_R> get_future(); | ||||||
| @@ -1238,8 +1380,10 @@ template <class _R> | |||||||
| future<_R> | future<_R> | ||||||
| promise<_R>::get_future() | promise<_R>::get_future() | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_ == nullptr) |     if (__state_ == nullptr) | ||||||
|         throw future_error(make_error_code(future_errc::no_state)); |         throw future_error(make_error_code(future_errc::no_state)); | ||||||
|  | #endif | ||||||
|     return future<_R>(__state_); |     return future<_R>(__state_); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1247,8 +1391,10 @@ template <class _R> | |||||||
| void | void | ||||||
| promise<_R>::set_value(const _R& __r) | promise<_R>::set_value(const _R& __r) | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_ == nullptr) |     if (__state_ == nullptr) | ||||||
|         throw future_error(make_error_code(future_errc::no_state)); |         throw future_error(make_error_code(future_errc::no_state)); | ||||||
|  | #endif | ||||||
|     __state_->set_value(__r); |     __state_->set_value(__r); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1258,9 +1404,11 @@ template <class _R> | |||||||
| void | void | ||||||
| promise<_R>::set_value(_R&& __r) | promise<_R>::set_value(_R&& __r) | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_ == nullptr) |     if (__state_ == nullptr) | ||||||
|         throw future_error(make_error_code(future_errc::no_state)); |         throw future_error(make_error_code(future_errc::no_state)); | ||||||
|     __state_->set_value(_STD::move(__r)); | #endif | ||||||
|  |     __state_->set_value(_VSTD::move(__r)); | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -1269,8 +1417,10 @@ template <class _R> | |||||||
| void | void | ||||||
| promise<_R>::set_exception(exception_ptr __p) | promise<_R>::set_exception(exception_ptr __p) | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_ == nullptr) |     if (__state_ == nullptr) | ||||||
|         throw future_error(make_error_code(future_errc::no_state)); |         throw future_error(make_error_code(future_errc::no_state)); | ||||||
|  | #endif | ||||||
|     __state_->set_exception(__p); |     __state_->set_exception(__p); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1278,8 +1428,10 @@ template <class _R> | |||||||
| void | void | ||||||
| promise<_R>::set_value_at_thread_exit(const _R& __r) | promise<_R>::set_value_at_thread_exit(const _R& __r) | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_ == nullptr) |     if (__state_ == nullptr) | ||||||
|         throw future_error(make_error_code(future_errc::no_state)); |         throw future_error(make_error_code(future_errc::no_state)); | ||||||
|  | #endif | ||||||
|     __state_->set_value_at_thread_exit(__r); |     __state_->set_value_at_thread_exit(__r); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1289,9 +1441,11 @@ template <class _R> | |||||||
| void | void | ||||||
| promise<_R>::set_value_at_thread_exit(_R&& __r) | promise<_R>::set_value_at_thread_exit(_R&& __r) | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_ == nullptr) |     if (__state_ == nullptr) | ||||||
|         throw future_error(make_error_code(future_errc::no_state)); |         throw future_error(make_error_code(future_errc::no_state)); | ||||||
|     __state_->set_value_at_thread_exit(_STD::move(__r)); | #endif | ||||||
|  |     __state_->set_value_at_thread_exit(_VSTD::move(__r)); | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -1300,8 +1454,10 @@ template <class _R> | |||||||
| void | void | ||||||
| promise<_R>::set_exception_at_thread_exit(exception_ptr __p) | promise<_R>::set_exception_at_thread_exit(exception_ptr __p) | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_ == nullptr) |     if (__state_ == nullptr) | ||||||
|         throw future_error(make_error_code(future_errc::no_state)); |         throw future_error(make_error_code(future_errc::no_state)); | ||||||
|  | #endif | ||||||
|     __state_->set_exception_at_thread_exit(__p); |     __state_->set_exception_at_thread_exit(__p); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1348,7 +1504,7 @@ private: | |||||||
| public: | public: | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(promise& __rhs) {_STD::swap(__state_, __rhs.__state_);} |     void swap(promise& __rhs) {_VSTD::swap(__state_, __rhs.__state_);} | ||||||
|  |  | ||||||
|     // retrieving the result |     // retrieving the result | ||||||
|     future<_R&> get_future(); |     future<_R&> get_future(); | ||||||
| @@ -1397,8 +1553,10 @@ template <class _R> | |||||||
| future<_R&> | future<_R&> | ||||||
| promise<_R&>::get_future() | promise<_R&>::get_future() | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_ == nullptr) |     if (__state_ == nullptr) | ||||||
|         throw future_error(make_error_code(future_errc::no_state)); |         throw future_error(make_error_code(future_errc::no_state)); | ||||||
|  | #endif | ||||||
|     return future<_R&>(__state_); |     return future<_R&>(__state_); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1406,8 +1564,10 @@ template <class _R> | |||||||
| void | void | ||||||
| promise<_R&>::set_value(_R& __r) | promise<_R&>::set_value(_R& __r) | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_ == nullptr) |     if (__state_ == nullptr) | ||||||
|         throw future_error(make_error_code(future_errc::no_state)); |         throw future_error(make_error_code(future_errc::no_state)); | ||||||
|  | #endif | ||||||
|     __state_->set_value(__r); |     __state_->set_value(__r); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1415,8 +1575,10 @@ template <class _R> | |||||||
| void | void | ||||||
| promise<_R&>::set_exception(exception_ptr __p) | promise<_R&>::set_exception(exception_ptr __p) | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_ == nullptr) |     if (__state_ == nullptr) | ||||||
|         throw future_error(make_error_code(future_errc::no_state)); |         throw future_error(make_error_code(future_errc::no_state)); | ||||||
|  | #endif | ||||||
|     __state_->set_exception(__p); |     __state_->set_exception(__p); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1424,8 +1586,10 @@ template <class _R> | |||||||
| void | void | ||||||
| promise<_R&>::set_value_at_thread_exit(_R& __r) | promise<_R&>::set_value_at_thread_exit(_R& __r) | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_ == nullptr) |     if (__state_ == nullptr) | ||||||
|         throw future_error(make_error_code(future_errc::no_state)); |         throw future_error(make_error_code(future_errc::no_state)); | ||||||
|  | #endif | ||||||
|     __state_->set_value_at_thread_exit(__r); |     __state_->set_value_at_thread_exit(__r); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1433,8 +1597,10 @@ template <class _R> | |||||||
| void | void | ||||||
| promise<_R&>::set_exception_at_thread_exit(exception_ptr __p) | promise<_R&>::set_exception_at_thread_exit(exception_ptr __p) | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_ == nullptr) |     if (__state_ == nullptr) | ||||||
|         throw future_error(make_error_code(future_errc::no_state)); |         throw future_error(make_error_code(future_errc::no_state)); | ||||||
|  | #endif | ||||||
|     __state_->set_exception_at_thread_exit(__p); |     __state_->set_exception_at_thread_exit(__p); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1481,7 +1647,7 @@ private: | |||||||
| public: | public: | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(promise& __rhs) {_STD::swap(__state_, __rhs.__state_);} |     void swap(promise& __rhs) {_VSTD::swap(__state_, __rhs.__state_);} | ||||||
|  |  | ||||||
|     // retrieving the result |     // retrieving the result | ||||||
|     future<void> get_future(); |     future<void> get_future(); | ||||||
| @@ -1551,13 +1717,13 @@ public: | |||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __packaged_task_func(const _F& __f) : __f_(__f) {} |     explicit __packaged_task_func(const _F& __f) : __f_(__f) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __packaged_task_func(_F&& __f) : __f_(_STD::move(__f)) {} |     explicit __packaged_task_func(_F&& __f) : __f_(_VSTD::move(__f)) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __packaged_task_func(const _F& __f, const _Alloc& __a) |     __packaged_task_func(const _F& __f, const _Alloc& __a) | ||||||
|         : __f_(__f, __a) {} |         : __f_(__f, __a) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __packaged_task_func(_F&& __f, const _Alloc& __a) |     __packaged_task_func(_F&& __f, const _Alloc& __a) | ||||||
|         : __f_(_STD::move(__f), __a) {} |         : __f_(_VSTD::move(__f), __a) {} | ||||||
|     virtual void __move_to(__packaged_task_base<_R(_ArgTypes...)>*); |     virtual void __move_to(__packaged_task_base<_R(_ArgTypes...)>*); | ||||||
|     virtual void destroy(); |     virtual void destroy(); | ||||||
|     virtual void destroy_deallocate(); |     virtual void destroy_deallocate(); | ||||||
| @@ -1569,7 +1735,7 @@ void | |||||||
| __packaged_task_func<_F, _Alloc, _R(_ArgTypes...)>::__move_to( | __packaged_task_func<_F, _Alloc, _R(_ArgTypes...)>::__move_to( | ||||||
|                               __packaged_task_base<_R(_ArgTypes...)>* __p) |                               __packaged_task_base<_R(_ArgTypes...)>* __p) | ||||||
| { | { | ||||||
|     ::new (__p) __packaged_task_func(_STD::move(__f_.first()), _STD::move(__f_.second())); |     ::new (__p) __packaged_task_func(_VSTD::move(__f_.first()), _VSTD::move(__f_.second())); | ||||||
| } | } | ||||||
|  |  | ||||||
| template<class _F, class _Alloc, class _R, class ..._ArgTypes> | template<class _F, class _Alloc, class _R, class ..._ArgTypes> | ||||||
| @@ -1593,10 +1759,10 @@ template<class _F, class _Alloc, class _R, class ..._ArgTypes> | |||||||
| _R | _R | ||||||
| __packaged_task_func<_F, _Alloc, _R(_ArgTypes...)>::operator()(_ArgTypes&& ... __arg) | __packaged_task_func<_F, _Alloc, _R(_ArgTypes...)>::operator()(_ArgTypes&& ... __arg) | ||||||
| { | { | ||||||
|     return __invoke(__f_.first(), _STD::forward<_ArgTypes>(__arg)...); |     return __invoke(__f_.first(), _VSTD::forward<_ArgTypes>(__arg)...); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class> class __packaged_task_function; | template <class _Callable> class __packaged_task_function; | ||||||
|  |  | ||||||
| template<class _R, class ..._ArgTypes> | template<class _R, class ..._ArgTypes> | ||||||
| class __packaged_task_function<_R(_ArgTypes...)> | class __packaged_task_function<_R(_ArgTypes...)> | ||||||
| @@ -1656,7 +1822,7 @@ __packaged_task_function<_R(_ArgTypes...)>::__packaged_task_function(_F&& __f) | |||||||
|     if (sizeof(_FF) <= sizeof(__buf_)) |     if (sizeof(_FF) <= sizeof(__buf_)) | ||||||
|     { |     { | ||||||
|         __f_ = (__base*)&__buf_; |         __f_ = (__base*)&__buf_; | ||||||
|         ::new (__f_) _FF(_STD::forward<_F>(__f)); |         ::new (__f_) _FF(_VSTD::forward<_F>(__f)); | ||||||
|     } |     } | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
| @@ -1664,7 +1830,7 @@ __packaged_task_function<_R(_ArgTypes...)>::__packaged_task_function(_F&& __f) | |||||||
|         _A __a; |         _A __a; | ||||||
|         typedef __allocator_destructor<_A> _D; |         typedef __allocator_destructor<_A> _D; | ||||||
|         unique_ptr<__base, _D> __hold(__a.allocate(1), _D(__a, 1)); |         unique_ptr<__base, _D> __hold(__a.allocate(1), _D(__a, 1)); | ||||||
|         ::new (__hold.get()) _FF(_STD::forward<_F>(__f), allocator<_FR>(__a)); |         ::new (__hold.get()) _FF(_VSTD::forward<_F>(__f), allocator<_FR>(__a)); | ||||||
|         __f_ = __hold.release(); |         __f_ = __hold.release(); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -1681,7 +1847,7 @@ __packaged_task_function<_R(_ArgTypes...)>::__packaged_task_function( | |||||||
|     if (sizeof(_FF) <= sizeof(__buf_)) |     if (sizeof(_FF) <= sizeof(__buf_)) | ||||||
|     { |     { | ||||||
|         __f_ = (__base*)&__buf_; |         __f_ = (__base*)&__buf_; | ||||||
|         ::new (__f_) _FF(_STD::forward<_F>(__f)); |         ::new (__f_) _FF(_VSTD::forward<_F>(__f)); | ||||||
|     } |     } | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
| @@ -1695,7 +1861,7 @@ __packaged_task_function<_R(_ArgTypes...)>::__packaged_task_function( | |||||||
|         _A __a(__a0); |         _A __a(__a0); | ||||||
|         typedef __allocator_destructor<_A> _D; |         typedef __allocator_destructor<_A> _D; | ||||||
|         unique_ptr<__base, _D> __hold(__a.allocate(1), _D(__a, 1)); |         unique_ptr<__base, _D> __hold(__a.allocate(1), _D(__a, 1)); | ||||||
|         ::new (__hold.get()) _FF(_STD::forward<_F>(__f), _Alloc(__a)); |         ::new (__hold.get()) _FF(_VSTD::forward<_F>(__f), _Alloc(__a)); | ||||||
|         __f_ = __hold.release(); |         __f_ = __hold.release(); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -1766,7 +1932,7 @@ __packaged_task_function<_R(_ArgTypes...)>::swap(__packaged_task_function& __f) | |||||||
|         __f_ = (__base*)&__buf_; |         __f_ = (__base*)&__buf_; | ||||||
|     } |     } | ||||||
|     else |     else | ||||||
|         _STD::swap(__f_, __f.__f_); |         _VSTD::swap(__f_, __f.__f_); | ||||||
| } | } | ||||||
|  |  | ||||||
| template<class _R, class ..._ArgTypes> | template<class _R, class ..._ArgTypes> | ||||||
| @@ -1774,7 +1940,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| _R | _R | ||||||
| __packaged_task_function<_R(_ArgTypes...)>::operator()(_ArgTypes... __arg) const | __packaged_task_function<_R(_ArgTypes...)>::operator()(_ArgTypes... __arg) const | ||||||
| { | { | ||||||
|     return (*__f_)(_STD::forward<_ArgTypes>(__arg)...); |     return (*__f_)(_VSTD::forward<_ArgTypes>(__arg)...); | ||||||
| } | } | ||||||
|  |  | ||||||
| template<class _R, class ..._ArgTypes> | template<class _R, class ..._ArgTypes> | ||||||
| @@ -1793,11 +1959,11 @@ public: | |||||||
|     packaged_task() : __p_(nullptr) {} |     packaged_task() : __p_(nullptr) {} | ||||||
|     template <class _F> |     template <class _F> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         explicit packaged_task(_F&& __f) : __f_(_STD::forward<_F>(__f)) {} |         explicit packaged_task(_F&& __f) : __f_(_VSTD::forward<_F>(__f)) {} | ||||||
|     template <class _F, class _Allocator> |     template <class _F, class _Allocator> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         explicit packaged_task(allocator_arg_t, const _Allocator& __a, _F&& __f) |         explicit packaged_task(allocator_arg_t, const _Allocator& __a, _F&& __f) | ||||||
|              : __f_(allocator_arg, __a, _STD::forward<_F>(__f)), |              : __f_(allocator_arg, __a, _VSTD::forward<_F>(__f)), | ||||||
|                __p_(allocator_arg, __a) {} |                __p_(allocator_arg, __a) {} | ||||||
|     // ~packaged_task() = default; |     // ~packaged_task() = default; | ||||||
|  |  | ||||||
| @@ -1808,12 +1974,12 @@ public: | |||||||
|     // move support |     // move support | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     packaged_task(packaged_task&& __other) |     packaged_task(packaged_task&& __other) | ||||||
|         : __f_(_STD::move(__other.__f_)), __p_(_STD::move(__other.__p_)) {} |         : __f_(_VSTD::move(__other.__f_)), __p_(_VSTD::move(__other.__p_)) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     packaged_task& operator=(packaged_task&& __other) |     packaged_task& operator=(packaged_task&& __other) | ||||||
|     { |     { | ||||||
|         __f_ = _STD::move(__other.__f_); |         __f_ = _VSTD::move(__other.__f_); | ||||||
|         __p_ = _STD::move(__other.__p_); |         __p_ = _VSTD::move(__other.__p_); | ||||||
|         return *this; |         return *this; | ||||||
|     } |     } | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -1849,7 +2015,7 @@ packaged_task<_R(_ArgTypes...)>::operator()(_ArgTypes... __args) | |||||||
|     try |     try | ||||||
|     { |     { | ||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|         __p_.set_value(__f_(_STD::forward<_ArgTypes>(__args)...)); |         __p_.set_value(__f_(_VSTD::forward<_ArgTypes>(__args)...)); | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     } |     } | ||||||
|     catch (...) |     catch (...) | ||||||
| @@ -1871,7 +2037,7 @@ packaged_task<_R(_ArgTypes...)>::make_ready_at_thread_exit(_ArgTypes... __args) | |||||||
|     try |     try | ||||||
|     { |     { | ||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|         __p_.set_value_at_thread_exit(__f_(_STD::forward<_ArgTypes>(__args)...)); |         __p_.set_value_at_thread_exit(__f_(_VSTD::forward<_ArgTypes>(__args)...)); | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     } |     } | ||||||
|     catch (...) |     catch (...) | ||||||
| @@ -1908,11 +2074,11 @@ public: | |||||||
|     packaged_task() : __p_(nullptr) {} |     packaged_task() : __p_(nullptr) {} | ||||||
|     template <class _F> |     template <class _F> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         explicit packaged_task(_F&& __f) : __f_(_STD::forward<_F>(__f)) {} |         explicit packaged_task(_F&& __f) : __f_(_VSTD::forward<_F>(__f)) {} | ||||||
|     template <class _F, class _Allocator> |     template <class _F, class _Allocator> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         explicit packaged_task(allocator_arg_t, const _Allocator& __a, _F&& __f) |         explicit packaged_task(allocator_arg_t, const _Allocator& __a, _F&& __f) | ||||||
|              : __f_(allocator_arg, __a, _STD::forward<_F>(__f)), |              : __f_(allocator_arg, __a, _VSTD::forward<_F>(__f)), | ||||||
|                __p_(allocator_arg, __a) {} |                __p_(allocator_arg, __a) {} | ||||||
|     // ~packaged_task() = default; |     // ~packaged_task() = default; | ||||||
|  |  | ||||||
| @@ -1923,12 +2089,12 @@ public: | |||||||
|     // move support |     // move support | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     packaged_task(packaged_task&& __other) |     packaged_task(packaged_task&& __other) | ||||||
|         : __f_(_STD::move(__other.__f_)), __p_(_STD::move(__other.__p_)) {} |         : __f_(_VSTD::move(__other.__f_)), __p_(_VSTD::move(__other.__p_)) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     packaged_task& operator=(packaged_task&& __other) |     packaged_task& operator=(packaged_task&& __other) | ||||||
|     { |     { | ||||||
|         __f_ = _STD::move(__other.__f_); |         __f_ = _VSTD::move(__other.__f_); | ||||||
|         __p_ = _STD::move(__other.__p_); |         __p_ = _VSTD::move(__other.__p_); | ||||||
|         return *this; |         return *this; | ||||||
|     } |     } | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -1964,7 +2130,7 @@ packaged_task<void(_ArgTypes...)>::operator()(_ArgTypes... __args) | |||||||
|     try |     try | ||||||
|     { |     { | ||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|         __f_(_STD::forward<_ArgTypes>(__args)...); |         __f_(_VSTD::forward<_ArgTypes>(__args)...); | ||||||
|         __p_.set_value(); |         __p_.set_value(); | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     } |     } | ||||||
| @@ -1987,7 +2153,7 @@ packaged_task<void(_ArgTypes...)>::make_ready_at_thread_exit(_ArgTypes... __args | |||||||
|     try |     try | ||||||
|     { |     { | ||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|         __f_(_STD::forward<_ArgTypes>(__args)...); |         __f_(_VSTD::forward<_ArgTypes>(__args)...); | ||||||
|         __p_.set_value_at_thread_exit(); |         __p_.set_value_at_thread_exit(); | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     } |     } | ||||||
| @@ -2030,40 +2196,76 @@ __make_deferred_assoc_state(_F __f) | |||||||
| #endif | #endif | ||||||
| { | { | ||||||
|     unique_ptr<__deferred_assoc_state<_R, _F>, __release_shared_count> |     unique_ptr<__deferred_assoc_state<_R, _F>, __release_shared_count> | ||||||
|         __h(new __deferred_assoc_state<_R, _F>(_STD::forward<_F>(__f))); |         __h(new __deferred_assoc_state<_R, _F>(_VSTD::forward<_F>(__f))); | ||||||
|  |     return future<_R>(__h.get()); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class _R, class _F> | ||||||
|  | future<_R> | ||||||
|  | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  | __make_async_assoc_state(_F&& __f) | ||||||
|  | #else | ||||||
|  | __make_async_assoc_state(_F __f) | ||||||
|  | #endif | ||||||
|  | { | ||||||
|  |     unique_ptr<__async_assoc_state<_R, _F>, __release_shared_count> | ||||||
|  |         __h(new __async_assoc_state<_R, _F>(_VSTD::forward<_F>(__f))); | ||||||
|  |     _VSTD::thread(&__async_assoc_state<_R, _F>::__execute, __h.get()).detach(); | ||||||
|     return future<_R>(__h.get()); |     return future<_R>(__h.get()); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _F, class... _Args> | template <class _F, class... _Args> | ||||||
| future<typename result_of<_F(_Args...)>::type> | class __async_func | ||||||
|  | { | ||||||
|  |     tuple<_F, _Args...> __f_; | ||||||
|  |  | ||||||
|  | public: | ||||||
|  |     typedef typename __invoke_of<_F, _Args...>::type _R; | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     explicit __async_func(_F&& __f, _Args&&... __args) | ||||||
|  |         : __f_(_VSTD::move(__f), _VSTD::move(__args)...) {} | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     __async_func(__async_func&& __f) : __f_(_VSTD::move(__f.__f_)) {} | ||||||
|  |  | ||||||
|  |     _R operator()() | ||||||
|  |     { | ||||||
|  |         typedef typename __make_tuple_indices<1+sizeof...(_Args), 1>::type _Index; | ||||||
|  |         return __execute(_Index()); | ||||||
|  |     } | ||||||
|  | private: | ||||||
|  |     template <size_t ..._Indices> | ||||||
|  |     _R | ||||||
|  |     __execute(__tuple_indices<_Indices...>) | ||||||
|  |     { | ||||||
|  |         return __invoke(_VSTD::move(_VSTD::get<0>(__f_)), _VSTD::move(_VSTD::get<_Indices>(__f_))...); | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | template <class _F, class... _Args> | ||||||
|  | future<typename __invoke_of<typename decay<_F>::type, typename decay<_Args>::type...>::type> | ||||||
| async(launch __policy, _F&& __f, _Args&&... __args) | async(launch __policy, _F&& __f, _Args&&... __args) | ||||||
| { | { | ||||||
|     typedef typename result_of<_F(_Args...)>::type _R; |     typedef __async_func<typename decay<_F>::type, typename decay<_Args>::type...> _BF; | ||||||
|  |     typedef typename _BF::_R _R; | ||||||
|     future<_R> __r; |     future<_R> __r; | ||||||
|     if (__policy & launch::async) |     if (__policy & launch::async) | ||||||
|     { |         __r = _VSTD::__make_async_assoc_state<_R>(_BF(__decay_copy(_VSTD::forward<_F>(__f)), | ||||||
|         packaged_task<_R()> __pk(bind(_STD::forward<_F>(__f), |                                                      __decay_copy(_VSTD::forward<_Args>(__args))...)); | ||||||
|                                       _STD::forward<_Args>(__args)...)); |  | ||||||
|         __r = __pk.get_future(); |  | ||||||
|         thread(_STD::move(__pk)).detach(); |  | ||||||
|     } |  | ||||||
|     else if (__policy & launch::deferred) |     else if (__policy & launch::deferred) | ||||||
|         __r = _STD::__make_deferred_assoc_state<_R>(bind(_STD::forward<_F>(__f), |         __r = _VSTD::__make_deferred_assoc_state<_R>(_BF(__decay_copy(_VSTD::forward<_F>(__f)), | ||||||
|                                               _STD::forward<_Args>(__args)...)); |                                                         __decay_copy(_VSTD::forward<_Args>(__args))...)); | ||||||
|     return __r; |     return __r; | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _F, class... _Args> | template <class _F, class... _Args> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| typename enable_if | future<typename __invoke_of<typename decay<_F>::type, typename decay<_Args>::type...>::type> | ||||||
| < |  | ||||||
|     !is_same<typename decay<_F>::type, launch>::value, |  | ||||||
|     future<typename result_of<_F(_Args...)>::type> |  | ||||||
| >::type |  | ||||||
| async(_F&& __f, _Args&&... __args) | async(_F&& __f, _Args&&... __args) | ||||||
| { | { | ||||||
|     return async(launch::any, _STD::forward<_F>(__f), |     return _VSTD::async(launch::any, _VSTD::forward<_F>(__f), | ||||||
|                               _STD::forward<_Args>(__args)...); |                                     _VSTD::forward<_Args>(__args)...); | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||||
| @@ -2105,7 +2307,7 @@ public: | |||||||
|     const _R& get() const {return __state_->copy();} |     const _R& get() const {return __state_->copy();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(shared_future& __rhs) {_STD::swap(__state_, __rhs.__state_);} |     void swap(shared_future& __rhs) {_VSTD::swap(__state_, __rhs.__state_);} | ||||||
|  |  | ||||||
|     // functions to check state |     // functions to check state | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -2179,7 +2381,7 @@ public: | |||||||
|     _R& get() const {return __state_->copy();} |     _R& get() const {return __state_->copy();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(shared_future& __rhs) {_STD::swap(__state_, __rhs.__state_);} |     void swap(shared_future& __rhs) {_VSTD::swap(__state_, __rhs.__state_);} | ||||||
|  |  | ||||||
|     // functions to check state |     // functions to check state | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -2253,7 +2455,7 @@ public: | |||||||
|     void get() const {__state_->copy();} |     void get() const {__state_->copy();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(shared_future& __rhs) {_STD::swap(__state_, __rhs.__state_);} |     void swap(shared_future& __rhs) {_VSTD::swap(__state_, __rhs.__state_);} | ||||||
|  |  | ||||||
|     // functions to check state |     // functions to check state | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -2286,7 +2488,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| shared_future<_R> | shared_future<_R> | ||||||
| future<_R>::share() | future<_R>::share() | ||||||
| { | { | ||||||
|     return shared_future<_R>(_STD::move(*this)); |     return shared_future<_R>(_VSTD::move(*this)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _R> | template <class _R> | ||||||
| @@ -2294,7 +2496,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| shared_future<_R&> | shared_future<_R&> | ||||||
| future<_R&>::share() | future<_R&>::share() | ||||||
| { | { | ||||||
|     return shared_future<_R&>(_STD::move(*this)); |     return shared_future<_R&>(_VSTD::move(*this)); | ||||||
| } | } | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -2303,7 +2505,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| shared_future<void> | shared_future<void> | ||||||
| future<void>::share() | future<void>::share() | ||||||
| { | { | ||||||
|     return shared_future<void>(_STD::move(*this)); |     return shared_future<void>(_VSTD::move(*this)); | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|   | |||||||
| @@ -29,15 +29,15 @@ public: | |||||||
|     typedef const E* iterator; |     typedef const E* iterator; | ||||||
|     typedef const E* const_iterator; |     typedef const E* const_iterator; | ||||||
|  |  | ||||||
|     initializer_list(); |     initializer_list() noexcept; | ||||||
|  |  | ||||||
|     size_t   size()  const; |     size_t   size()  const noexcept; | ||||||
|     const E* begin() const; |     const E* begin() const noexcept; | ||||||
|     const E* end()   const; |     const E* end()   const noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template<class E> const E* begin(initializer_list<E> il); | template<class E> const E* begin(initializer_list<E> il) noexcept; | ||||||
| template<class E> const E* end(initializer_list<E> il); | template<class E> const E* end(initializer_list<E> il) noexcept; | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
|  |  | ||||||
| @@ -58,7 +58,7 @@ class _LIBCPP_VISIBLE initializer_list | |||||||
|     size_t    __size_; |     size_t    __size_; | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     initializer_list(const _E* __b, size_t __s) |     initializer_list(const _E* __b, size_t __s) _NOEXCEPT | ||||||
|         : __begin_(__b), |         : __begin_(__b), | ||||||
|           __size_(__s) |           __size_(__s) | ||||||
|         {} |         {} | ||||||
| @@ -71,17 +71,17 @@ public: | |||||||
|     typedef const _E* iterator; |     typedef const _E* iterator; | ||||||
|     typedef const _E* const_iterator; |     typedef const _E* const_iterator; | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE initializer_list() : __begin_(nullptr), __size_(0) {} |     _LIBCPP_ALWAYS_INLINE initializer_list() _NOEXCEPT : __begin_(nullptr), __size_(0) {} | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE size_t    size()  const {return __size_;} |     _LIBCPP_ALWAYS_INLINE size_t    size()  const _NOEXCEPT {return __size_;} | ||||||
|     _LIBCPP_ALWAYS_INLINE const _E* begin() const {return __begin_;} |     _LIBCPP_ALWAYS_INLINE const _E* begin() const _NOEXCEPT {return __begin_;} | ||||||
|     _LIBCPP_ALWAYS_INLINE const _E* end()   const {return __begin_ + __size_;} |     _LIBCPP_ALWAYS_INLINE const _E* end()   const _NOEXCEPT {return __begin_ + __size_;} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template<class _E> | template<class _E> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| const _E* | const _E* | ||||||
| begin(initializer_list<_E> __il) | begin(initializer_list<_E> __il) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __il.begin(); |     return __il.begin(); | ||||||
| } | } | ||||||
| @@ -89,7 +89,7 @@ begin(initializer_list<_E> __il) | |||||||
| template<class _E> | template<class _E> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| const _E* | const _E* | ||||||
| end(initializer_list<_E> __il) | end(initializer_list<_E> __il) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __il.end(); |     return __il.end(); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -266,8 +266,8 @@ public: | |||||||
|     enum seekdir {beg, cur, end}; |     enum seekdir {beg, cur, end}; | ||||||
|     typedef seekdir seek_dir; |     typedef seekdir seek_dir; | ||||||
|  |  | ||||||
|     typedef _STD::streamoff streamoff; |     typedef _VSTD::streamoff streamoff; | ||||||
|     typedef _STD::streampos streampos; |     typedef _VSTD::streampos streampos; | ||||||
|  |  | ||||||
|     class Init; |     class Init; | ||||||
|  |  | ||||||
| @@ -776,8 +776,8 @@ void | |||||||
| basic_ios<_CharT, _Traits>::swap(basic_ios& __rhs) | basic_ios<_CharT, _Traits>::swap(basic_ios& __rhs) | ||||||
| { | { | ||||||
|     ios_base::swap(__rhs); |     ios_base::swap(__rhs); | ||||||
|     _STD::swap(__tie_, __rhs.__tie_); |     _VSTD::swap(__tie_, __rhs.__tie_); | ||||||
|     _STD::swap(__fill_, __rhs.__fill_); |     _VSTD::swap(__fill_, __rhs.__fill_); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _CharT, class _Traits> | template <class _CharT, class _Traits> | ||||||
|   | |||||||
| @@ -20,6 +20,7 @@ namespace std | |||||||
| template<class charT> struct char_traits; | template<class charT> struct char_traits; | ||||||
| template<class T>     class allocator; | template<class T>     class allocator; | ||||||
|  |  | ||||||
|  | class ios_base; | ||||||
| template <class charT, class traits = char_traits<charT> > class basic_ios; | template <class charT, class traits = char_traits<charT> > class basic_ios; | ||||||
|  |  | ||||||
| template <class charT, class traits = char_traits<charT> > class basic_streambuf; | template <class charT, class traits = char_traits<charT> > class basic_streambuf; | ||||||
|   | |||||||
| @@ -177,11 +177,13 @@ public: | |||||||
|     virtual ~basic_istream(); |     virtual ~basic_istream(); | ||||||
| protected: | protected: | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     basic_istream(basic_istream&& __rhs); |     basic_istream(basic_istream&& __rhs); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|     // 27.7.1.1.2 Assign/swap: |     // 27.7.1.1.2 Assign/swap: | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     basic_istream& operator=(basic_istream&& __rhs); |     basic_istream& operator=(basic_istream&& __rhs); | ||||||
| #endif | #endif | ||||||
|     void swap(basic_istream& __rhs); |     void swap(basic_istream& __rhs); | ||||||
| @@ -321,7 +323,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| void | void | ||||||
| basic_istream<_CharT, _Traits>::swap(basic_istream& __rhs) | basic_istream<_CharT, _Traits>::swap(basic_istream& __rhs) | ||||||
| { | { | ||||||
|     _STD::swap(__gc_, __rhs.__gc_); |     _VSTD::swap(__gc_, __rhs.__gc_); | ||||||
|     basic_ios<char_type, traits_type>::swap(__rhs); |     basic_ios<char_type, traits_type>::swap(__rhs); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1273,7 +1275,7 @@ basic_istream<_CharT, _Traits>::readsome(char_type* __s, streamsize __n) | |||||||
|             case 0: |             case 0: | ||||||
|                 break; |                 break; | ||||||
|             default: |             default: | ||||||
|                 __c = _STD::min(__c, __n); |                 __c = _VSTD::min(__c, __n); | ||||||
|                 for (streamsize __k = 0; __k < __c; ++__k, ++__s, ++__i) |                 for (streamsize __k = 0; __k < __c; ++__k, ++__s, ++__i) | ||||||
|                     *__s = *__i; |                     *__s = *__i; | ||||||
|             } |             } | ||||||
| @@ -1504,11 +1506,13 @@ public: | |||||||
|     virtual ~basic_iostream(); |     virtual ~basic_iostream(); | ||||||
| protected: | protected: | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     basic_iostream(basic_iostream&& __rhs); |     basic_iostream(basic_iostream&& __rhs); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|     // assign/swap |     // assign/swap | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     basic_iostream& operator=(basic_iostream&& __rhs); |     basic_iostream& operator=(basic_iostream&& __rhs); | ||||||
| #endif | #endif | ||||||
|     void swap(basic_iostream& __rhs); |     void swap(basic_iostream& __rhs); | ||||||
| @@ -1527,7 +1531,7 @@ basic_iostream<_CharT, _Traits>::basic_iostream(basic_streambuf<char_type, trait | |||||||
| template <class _CharT, class _Traits> | template <class _CharT, class _Traits> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| basic_iostream<_CharT, _Traits>::basic_iostream(basic_iostream&& __rhs) | basic_iostream<_CharT, _Traits>::basic_iostream(basic_iostream&& __rhs) | ||||||
|     : basic_istream<_CharT, _Traits>(_STD::move(__rhs)) |     : basic_istream<_CharT, _Traits>(_VSTD::move(__rhs)) | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -488,7 +488,7 @@ next(_ForwardIter __x, | |||||||
|      typename iterator_traits<_ForwardIter>::difference_type __n = 1, |      typename iterator_traits<_ForwardIter>::difference_type __n = 1, | ||||||
|      typename enable_if<__is_forward_iterator<_ForwardIter>::value>::type* = 0) |      typename enable_if<__is_forward_iterator<_ForwardIter>::value>::type* = 0) | ||||||
| { | { | ||||||
|     _STD::advance(__x, __n); |     _VSTD::advance(__x, __n); | ||||||
|     return __x; |     return __x; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -499,7 +499,7 @@ prev(_BidiretionalIter __x, | |||||||
|      typename iterator_traits<_BidiretionalIter>::difference_type __n = 1, |      typename iterator_traits<_BidiretionalIter>::difference_type __n = 1, | ||||||
|      typename enable_if<__is_bidirectional_iterator<_BidiretionalIter>::value>::type* = 0) |      typename enable_if<__is_bidirectional_iterator<_BidiretionalIter>::value>::type* = 0) | ||||||
| { | { | ||||||
|     _STD::advance(__x, -__n); |     _VSTD::advance(__x, -__n); | ||||||
|     return __x; |     return __x; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -628,7 +628,7 @@ public: | |||||||
|         {container->push_back(__value); return *this;} |         {container->push_back(__value); return *this;} | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY back_insert_iterator& operator=(typename _Container::value_type&& __value) |     _LIBCPP_INLINE_VISIBILITY back_insert_iterator& operator=(typename _Container::value_type&& __value) | ||||||
|         {container->push_back(_STD::move(__value)); return *this;} |         {container->push_back(_VSTD::move(__value)); return *this;} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY back_insert_iterator& operator*()     {return *this;} |     _LIBCPP_INLINE_VISIBILITY back_insert_iterator& operator*()     {return *this;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY back_insert_iterator& operator++()    {return *this;} |     _LIBCPP_INLINE_VISIBILITY back_insert_iterator& operator++()    {return *this;} | ||||||
| @@ -661,7 +661,7 @@ public: | |||||||
|         {container->push_front(__value); return *this;} |         {container->push_front(__value); return *this;} | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY front_insert_iterator& operator=(typename _Container::value_type&& __value) |     _LIBCPP_INLINE_VISIBILITY front_insert_iterator& operator=(typename _Container::value_type&& __value) | ||||||
|         {container->push_front(_STD::move(__value)); return *this;} |         {container->push_front(_VSTD::move(__value)); return *this;} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY front_insert_iterator& operator*()     {return *this;} |     _LIBCPP_INLINE_VISIBILITY front_insert_iterator& operator*()     {return *this;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY front_insert_iterator& operator++()    {return *this;} |     _LIBCPP_INLINE_VISIBILITY front_insert_iterator& operator++()    {return *this;} | ||||||
| @@ -696,7 +696,7 @@ public: | |||||||
|         {iter = container->insert(iter, __value); ++iter; return *this;} |         {iter = container->insert(iter, __value); ++iter; return *this;} | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY insert_iterator& operator=(typename _Container::value_type&& __value) |     _LIBCPP_INLINE_VISIBILITY insert_iterator& operator=(typename _Container::value_type&& __value) | ||||||
|         {iter = container->insert(iter, _STD::move(__value)); ++iter; return *this;} |         {iter = container->insert(iter, _VSTD::move(__value)); ++iter; return *this;} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY insert_iterator& operator*()        {return *this;} |     _LIBCPP_INLINE_VISIBILITY insert_iterator& operator*()        {return *this;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY insert_iterator& operator++()       {return *this;} |     _LIBCPP_INLINE_VISIBILITY insert_iterator& operator++()       {return *this;} | ||||||
| @@ -1007,35 +1007,35 @@ template <class _Iter> class __wrap_iter; | |||||||
|  |  | ||||||
| template <class _Iter1, class _Iter2> | template <class _Iter1, class _Iter2> | ||||||
| bool | bool | ||||||
| operator==(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&); | operator==(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&) _NOEXCEPT; | ||||||
|  |  | ||||||
| template <class _Iter1, class _Iter2> | template <class _Iter1, class _Iter2> | ||||||
| bool | bool | ||||||
| operator<(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&); | operator<(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&) _NOEXCEPT; | ||||||
|  |  | ||||||
| template <class _Iter1, class _Iter2> | template <class _Iter1, class _Iter2> | ||||||
| bool | bool | ||||||
| operator!=(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&); | operator!=(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&) _NOEXCEPT; | ||||||
|  |  | ||||||
| template <class _Iter1, class _Iter2> | template <class _Iter1, class _Iter2> | ||||||
| bool | bool | ||||||
| operator>(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&); | operator>(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&) _NOEXCEPT; | ||||||
|  |  | ||||||
| template <class _Iter1, class _Iter2> | template <class _Iter1, class _Iter2> | ||||||
| bool | bool | ||||||
| operator>=(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&); | operator>=(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&) _NOEXCEPT; | ||||||
|  |  | ||||||
| template <class _Iter1, class _Iter2> | template <class _Iter1, class _Iter2> | ||||||
| bool | bool | ||||||
| operator<=(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&); | operator<=(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&) _NOEXCEPT; | ||||||
|  |  | ||||||
| template <class _Iter1, class _Iter2> | template <class _Iter1, class _Iter2> | ||||||
| typename __wrap_iter<_Iter1>::difference_type | typename __wrap_iter<_Iter1>::difference_type | ||||||
| operator-(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&); | operator-(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&) _NOEXCEPT; | ||||||
|  |  | ||||||
| template <class _Iter> | template <class _Iter> | ||||||
| __wrap_iter<_Iter> | __wrap_iter<_Iter> | ||||||
| operator+(typename __wrap_iter<_Iter>::difference_type, const __wrap_iter<_Iter>&); | operator+(typename __wrap_iter<_Iter>::difference_type, const __wrap_iter<_Iter>&) _NOEXCEPT; | ||||||
|  |  | ||||||
| template <class _I, class _O> _O copy(_I, _I, _O); | template <class _I, class _O> _O copy(_I, _I, _O); | ||||||
| template <class _B1, class _B2> _B2 copy_backward(_B1, _B1, _B2); | template <class _B1, class _B2> _B2 copy_backward(_B1, _B1, _B2); | ||||||
| @@ -1063,33 +1063,33 @@ public: | |||||||
| private: | private: | ||||||
|     iterator_type __i; |     iterator_type __i; | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY __wrap_iter() {} |     _LIBCPP_INLINE_VISIBILITY __wrap_iter() _NOEXCEPT {} | ||||||
|     template <class _Up> _LIBCPP_INLINE_VISIBILITY __wrap_iter(const __wrap_iter<_Up>& __u, |     template <class _Up> _LIBCPP_INLINE_VISIBILITY __wrap_iter(const __wrap_iter<_Up>& __u, | ||||||
|         typename enable_if<is_convertible<_Up, iterator_type>::value>::type* = 0) |         typename enable_if<is_convertible<_Up, iterator_type>::value>::type* = 0) _NOEXCEPT | ||||||
|         : __i(__u.base()) {} |         : __i(__u.base()) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY reference operator*() const {return *__i;} |     _LIBCPP_INLINE_VISIBILITY reference operator*() const _NOEXCEPT {return *__i;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY pointer  operator->() const {return &(operator*());} |     _LIBCPP_INLINE_VISIBILITY pointer  operator->() const _NOEXCEPT {return &(operator*());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY __wrap_iter& operator++() {++__i; return *this;} |     _LIBCPP_INLINE_VISIBILITY __wrap_iter& operator++() _NOEXCEPT {++__i; return *this;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY __wrap_iter  operator++(int) |     _LIBCPP_INLINE_VISIBILITY __wrap_iter  operator++(int) _NOEXCEPT | ||||||
|         {__wrap_iter __tmp(*this); ++__i; return __tmp;} |         {__wrap_iter __tmp(*this); ++__i; return __tmp;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY __wrap_iter& operator--() {--__i; return *this;} |     _LIBCPP_INLINE_VISIBILITY __wrap_iter& operator--() _NOEXCEPT {--__i; return *this;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY __wrap_iter  operator--(int) |     _LIBCPP_INLINE_VISIBILITY __wrap_iter  operator--(int) _NOEXCEPT | ||||||
|         {__wrap_iter __tmp(*this); --__i; return __tmp;} |         {__wrap_iter __tmp(*this); --__i; return __tmp;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY __wrap_iter  operator+ (difference_type __n) const |     _LIBCPP_INLINE_VISIBILITY __wrap_iter  operator+ (difference_type __n) const _NOEXCEPT | ||||||
|         {return __wrap_iter(__i + __n);} |         {return __wrap_iter(__i + __n);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY __wrap_iter& operator+=(difference_type __n) |     _LIBCPP_INLINE_VISIBILITY __wrap_iter& operator+=(difference_type __n) _NOEXCEPT | ||||||
|         {__i += __n; return *this;} |         {__i += __n; return *this;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY __wrap_iter  operator- (difference_type __n) const |     _LIBCPP_INLINE_VISIBILITY __wrap_iter  operator- (difference_type __n) const _NOEXCEPT | ||||||
|         {return __wrap_iter(__i - __n);} |         {return __wrap_iter(__i - __n);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY __wrap_iter& operator-=(difference_type __n) |     _LIBCPP_INLINE_VISIBILITY __wrap_iter& operator-=(difference_type __n) _NOEXCEPT | ||||||
|         {__i -= __n; return *this;} |         {__i -= __n; return *this;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY reference        operator[](difference_type __n) const |     _LIBCPP_INLINE_VISIBILITY reference        operator[](difference_type __n) const _NOEXCEPT | ||||||
|         {return __i[__n];} |         {return __i[__n];} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY iterator_type base() const {return __i;} |     _LIBCPP_INLINE_VISIBILITY iterator_type base() const _NOEXCEPT {return __i;} | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     _LIBCPP_INLINE_VISIBILITY __wrap_iter(iterator_type __x) : __i(__x) {} |     _LIBCPP_INLINE_VISIBILITY __wrap_iter(iterator_type __x) _NOEXCEPT : __i(__x) {} | ||||||
|  |  | ||||||
|     template <class _Up> friend class __wrap_iter; |     template <class _Up> friend class __wrap_iter; | ||||||
|     template <class _CharT, class _Traits, class _Alloc> friend class basic_string; |     template <class _CharT, class _Traits, class _Alloc> friend class basic_string; | ||||||
| @@ -1098,42 +1098,42 @@ private: | |||||||
|     template <class _Iter1, class _Iter2> |     template <class _Iter1, class _Iter2> | ||||||
|     friend |     friend | ||||||
|     bool |     bool | ||||||
|     operator==(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&); |     operator==(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&) _NOEXCEPT; | ||||||
|  |  | ||||||
|     template <class _Iter1, class _Iter2> |     template <class _Iter1, class _Iter2> | ||||||
|     friend |     friend | ||||||
|     bool |     bool | ||||||
|     operator<(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&); |     operator<(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&) _NOEXCEPT; | ||||||
|  |  | ||||||
|     template <class _Iter1, class _Iter2> |     template <class _Iter1, class _Iter2> | ||||||
|     friend |     friend | ||||||
|     bool |     bool | ||||||
|     operator!=(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&); |     operator!=(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&) _NOEXCEPT; | ||||||
|  |  | ||||||
|     template <class _Iter1, class _Iter2> |     template <class _Iter1, class _Iter2> | ||||||
|     friend |     friend | ||||||
|     bool |     bool | ||||||
|     operator>(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&); |     operator>(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&) _NOEXCEPT; | ||||||
|  |  | ||||||
|     template <class _Iter1, class _Iter2> |     template <class _Iter1, class _Iter2> | ||||||
|     friend |     friend | ||||||
|     bool |     bool | ||||||
|     operator>=(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&); |     operator>=(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&) _NOEXCEPT; | ||||||
|  |  | ||||||
|     template <class _Iter1, class _Iter2> |     template <class _Iter1, class _Iter2> | ||||||
|     friend |     friend | ||||||
|     bool |     bool | ||||||
|     operator<=(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&); |     operator<=(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&) _NOEXCEPT; | ||||||
|  |  | ||||||
|     template <class _Iter1, class _Iter2> |     template <class _Iter1, class _Iter2> | ||||||
|     friend |     friend | ||||||
|     typename __wrap_iter<_Iter1>::difference_type |     typename __wrap_iter<_Iter1>::difference_type | ||||||
|     operator-(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&); |     operator-(const __wrap_iter<_Iter1>&, const __wrap_iter<_Iter2>&) _NOEXCEPT; | ||||||
|  |  | ||||||
|     template <class _Iter1> |     template <class _Iter1> | ||||||
|     friend |     friend | ||||||
|     __wrap_iter<_Iter1> |     __wrap_iter<_Iter1> | ||||||
|     operator+(typename __wrap_iter<_Iter1>::difference_type, const __wrap_iter<_Iter1>&); |     operator+(typename __wrap_iter<_Iter1>::difference_type, const __wrap_iter<_Iter1>&) _NOEXCEPT; | ||||||
|  |  | ||||||
|     template <class _I, class _O> friend _O copy(_I, _I, _O); |     template <class _I, class _O> friend _O copy(_I, _I, _O); | ||||||
|     template <class _B1, class _B2> friend _B2 copy_backward(_B1, _B1, _B2); |     template <class _B1, class _B2> friend _B2 copy_backward(_B1, _B1, _B2); | ||||||
| @@ -1153,7 +1153,7 @@ private: | |||||||
| template <class _Iter1, class _Iter2> | template <class _Iter1, class _Iter2> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator==(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) | operator==(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __x.base() == __y.base(); |     return __x.base() == __y.base(); | ||||||
| } | } | ||||||
| @@ -1161,7 +1161,7 @@ operator==(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) | |||||||
| template <class _Iter1, class _Iter2> | template <class _Iter1, class _Iter2> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator<(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) | operator<(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __x.base() < __y.base(); |     return __x.base() < __y.base(); | ||||||
| } | } | ||||||
| @@ -1169,7 +1169,7 @@ operator<(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) | |||||||
| template <class _Iter1, class _Iter2> | template <class _Iter1, class _Iter2> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator!=(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) | operator!=(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __x.base() != __y.base(); |     return __x.base() != __y.base(); | ||||||
| } | } | ||||||
| @@ -1177,7 +1177,7 @@ operator!=(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) | |||||||
| template <class _Iter1, class _Iter2> | template <class _Iter1, class _Iter2> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator>(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) | operator>(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __x.base() > __y.base(); |     return __x.base() > __y.base(); | ||||||
| } | } | ||||||
| @@ -1185,7 +1185,7 @@ operator>(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) | |||||||
| template <class _Iter1, class _Iter2> | template <class _Iter1, class _Iter2> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator>=(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) | operator>=(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __x.base() >= __y.base(); |     return __x.base() >= __y.base(); | ||||||
| } | } | ||||||
| @@ -1193,7 +1193,7 @@ operator>=(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) | |||||||
| template <class _Iter1, class _Iter2> | template <class _Iter1, class _Iter2> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator<=(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) | operator<=(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __x.base() <= __y.base(); |     return __x.base() <= __y.base(); | ||||||
| } | } | ||||||
| @@ -1201,7 +1201,7 @@ operator<=(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) | |||||||
| template <class _Iter1, class _Iter2> | template <class _Iter1, class _Iter2> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| typename __wrap_iter<_Iter1>::difference_type | typename __wrap_iter<_Iter1>::difference_type | ||||||
| operator-(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) | operator-(const __wrap_iter<_Iter1>& __x, const __wrap_iter<_Iter2>& __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __x.base() - __y.base(); |     return __x.base() - __y.base(); | ||||||
| } | } | ||||||
| @@ -1210,7 +1210,7 @@ template <class _Iter> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| __wrap_iter<_Iter> | __wrap_iter<_Iter> | ||||||
| operator+(typename __wrap_iter<_Iter>::difference_type __n, | operator+(typename __wrap_iter<_Iter>::difference_type __n, | ||||||
|           const __wrap_iter<_Iter>& __x) |           const __wrap_iter<_Iter>& __x) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __wrap_iter<_Iter>(__x.base() + __n); |     return __wrap_iter<_Iter>(__x.base() + __n); | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										198
									
								
								include/limits
									
									
									
									
									
								
							
							
						
						
									
										198
									
								
								include/limits
									
									
									
									
									
								
							| @@ -22,9 +22,9 @@ class numeric_limits | |||||||
| { | { | ||||||
| public: | public: | ||||||
|     static const bool is_specialized = false; |     static const bool is_specialized = false; | ||||||
|     static T min() throw(); |     static T min() noexcept; | ||||||
|     static T max() throw(); |     static T max() noexcept; | ||||||
|     static T lowest() throw(); |     static T lowest() noexcept; | ||||||
|  |  | ||||||
|     static const int  digits = 0; |     static const int  digits = 0; | ||||||
|     static const int  digits10 = 0; |     static const int  digits10 = 0; | ||||||
| @@ -33,8 +33,8 @@ public: | |||||||
|     static const bool is_integer = false; |     static const bool is_integer = false; | ||||||
|     static const bool is_exact = false; |     static const bool is_exact = false; | ||||||
|     static const int  radix = 0; |     static const int  radix = 0; | ||||||
|     static T epsilon() throw(); |     static T epsilon() noexcept; | ||||||
|     static T round_error() throw(); |     static T round_error() noexcept; | ||||||
|  |  | ||||||
|     static const int  min_exponent = 0; |     static const int  min_exponent = 0; | ||||||
|     static const int  min_exponent10 = 0; |     static const int  min_exponent10 = 0; | ||||||
| @@ -46,10 +46,10 @@ public: | |||||||
|     static const bool has_signaling_NaN = false; |     static const bool has_signaling_NaN = false; | ||||||
|     static const float_denorm_style has_denorm = denorm_absent; |     static const float_denorm_style has_denorm = denorm_absent; | ||||||
|     static const bool has_denorm_loss = false; |     static const bool has_denorm_loss = false; | ||||||
|     static T infinity() throw(); |     static T infinity() noexcept; | ||||||
|     static T quiet_NaN() throw(); |     static T quiet_NaN() noexcept; | ||||||
|     static T signaling_NaN() throw(); |     static T signaling_NaN() noexcept; | ||||||
|     static T denorm_min() throw(); |     static T denorm_min() noexcept; | ||||||
|  |  | ||||||
|     static const bool is_iec559 = false; |     static const bool is_iec559 = false; | ||||||
|     static const bool is_bounded = false; |     static const bool is_bounded = false; | ||||||
| @@ -132,9 +132,9 @@ protected: | |||||||
|     typedef _Tp type; |     typedef _Tp type; | ||||||
|  |  | ||||||
|     static const bool is_specialized = false; |     static const bool is_specialized = false; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type min() throw() {return type();} |     _LIBCPP_INLINE_VISIBILITY static type min() _NOEXCEPT {return type();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type max() throw() {return type();} |     _LIBCPP_INLINE_VISIBILITY static type max() _NOEXCEPT {return type();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type lowest() throw() {return type();} |     _LIBCPP_INLINE_VISIBILITY static type lowest() _NOEXCEPT {return type();} | ||||||
|  |  | ||||||
|     static const int  digits = 0; |     static const int  digits = 0; | ||||||
|     static const int  digits10 = 0; |     static const int  digits10 = 0; | ||||||
| @@ -143,8 +143,8 @@ protected: | |||||||
|     static const bool is_integer = false; |     static const bool is_integer = false; | ||||||
|     static const bool is_exact = false; |     static const bool is_exact = false; | ||||||
|     static const int  radix = 0; |     static const int  radix = 0; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type epsilon() throw() {return type();} |     _LIBCPP_INLINE_VISIBILITY static type epsilon() _NOEXCEPT {return type();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type round_error() throw() {return type();} |     _LIBCPP_INLINE_VISIBILITY static type round_error() _NOEXCEPT {return type();} | ||||||
|  |  | ||||||
|     static const int  min_exponent = 0; |     static const int  min_exponent = 0; | ||||||
|     static const int  min_exponent10 = 0; |     static const int  min_exponent10 = 0; | ||||||
| @@ -156,10 +156,10 @@ protected: | |||||||
|     static const bool has_signaling_NaN = false; |     static const bool has_signaling_NaN = false; | ||||||
|     static const float_denorm_style has_denorm = denorm_absent; |     static const float_denorm_style has_denorm = denorm_absent; | ||||||
|     static const bool has_denorm_loss = false; |     static const bool has_denorm_loss = false; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type infinity() throw() {return type();} |     _LIBCPP_INLINE_VISIBILITY static type infinity() _NOEXCEPT {return type();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() throw() {return type();} |     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() _NOEXCEPT {return type();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() throw() {return type();} |     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() _NOEXCEPT {return type();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type denorm_min() throw() {return type();} |     _LIBCPP_INLINE_VISIBILITY static type denorm_min() _NOEXCEPT {return type();} | ||||||
|  |  | ||||||
|     static const bool is_iec559 = false; |     static const bool is_iec559 = false; | ||||||
|     static const bool is_bounded = false; |     static const bool is_bounded = false; | ||||||
| @@ -196,15 +196,15 @@ protected: | |||||||
|     static const int  max_digits10 = 0; |     static const int  max_digits10 = 0; | ||||||
|     static const type __min = __libcpp_compute_min<type, digits, is_signed>::value; |     static const type __min = __libcpp_compute_min<type, digits, is_signed>::value; | ||||||
|     static const type __max = is_signed ? type(type(~0) ^ __min) : type(~0); |     static const type __max = is_signed ? type(type(~0) ^ __min) : type(~0); | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type min() throw() {return __min;} |     _LIBCPP_INLINE_VISIBILITY static type min() _NOEXCEPT {return __min;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type max() throw() {return __max;} |     _LIBCPP_INLINE_VISIBILITY static type max() _NOEXCEPT {return __max;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type lowest() throw() {return min();} |     _LIBCPP_INLINE_VISIBILITY static type lowest() _NOEXCEPT {return min();} | ||||||
|  |  | ||||||
|     static const bool is_integer = true; |     static const bool is_integer = true; | ||||||
|     static const bool is_exact = true; |     static const bool is_exact = true; | ||||||
|     static const int  radix = 2; |     static const int  radix = 2; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type epsilon() throw() {return type(0);} |     _LIBCPP_INLINE_VISIBILITY static type epsilon() _NOEXCEPT {return type(0);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type round_error() throw() {return type(0);} |     _LIBCPP_INLINE_VISIBILITY static type round_error() _NOEXCEPT {return type(0);} | ||||||
|  |  | ||||||
|     static const int  min_exponent = 0; |     static const int  min_exponent = 0; | ||||||
|     static const int  min_exponent10 = 0; |     static const int  min_exponent10 = 0; | ||||||
| @@ -216,10 +216,10 @@ protected: | |||||||
|     static const bool has_signaling_NaN = false; |     static const bool has_signaling_NaN = false; | ||||||
|     static const float_denorm_style has_denorm = denorm_absent; |     static const float_denorm_style has_denorm = denorm_absent; | ||||||
|     static const bool has_denorm_loss = false; |     static const bool has_denorm_loss = false; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type infinity() throw() {return type(0);} |     _LIBCPP_INLINE_VISIBILITY static type infinity() _NOEXCEPT {return type(0);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() throw() {return type(0);} |     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() _NOEXCEPT {return type(0);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() throw() {return type(0);} |     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() _NOEXCEPT {return type(0);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type denorm_min() throw() {return type(0);} |     _LIBCPP_INLINE_VISIBILITY static type denorm_min() _NOEXCEPT {return type(0);} | ||||||
|  |  | ||||||
|     static const bool is_iec559 = false; |     static const bool is_iec559 = false; | ||||||
|     static const bool is_bounded = true; |     static const bool is_bounded = true; | ||||||
| @@ -248,15 +248,15 @@ protected: | |||||||
|     static const int  max_digits10 = 0; |     static const int  max_digits10 = 0; | ||||||
|     static const type __min = false; |     static const type __min = false; | ||||||
|     static const type __max = true; |     static const type __max = true; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type min() throw() {return __min;} |     _LIBCPP_INLINE_VISIBILITY static type min() _NOEXCEPT {return __min;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type max() throw() {return __max;} |     _LIBCPP_INLINE_VISIBILITY static type max() _NOEXCEPT {return __max;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type lowest() throw() {return min();} |     _LIBCPP_INLINE_VISIBILITY static type lowest() _NOEXCEPT {return min();} | ||||||
|  |  | ||||||
|     static const bool is_integer = true; |     static const bool is_integer = true; | ||||||
|     static const bool is_exact = true; |     static const bool is_exact = true; | ||||||
|     static const int  radix = 2; |     static const int  radix = 2; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type epsilon() throw() {return type(0);} |     _LIBCPP_INLINE_VISIBILITY static type epsilon() _NOEXCEPT {return type(0);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type round_error() throw() {return type(0);} |     _LIBCPP_INLINE_VISIBILITY static type round_error() _NOEXCEPT {return type(0);} | ||||||
|  |  | ||||||
|     static const int  min_exponent = 0; |     static const int  min_exponent = 0; | ||||||
|     static const int  min_exponent10 = 0; |     static const int  min_exponent10 = 0; | ||||||
| @@ -268,10 +268,10 @@ protected: | |||||||
|     static const bool has_signaling_NaN = false; |     static const bool has_signaling_NaN = false; | ||||||
|     static const float_denorm_style has_denorm = denorm_absent; |     static const float_denorm_style has_denorm = denorm_absent; | ||||||
|     static const bool has_denorm_loss = false; |     static const bool has_denorm_loss = false; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type infinity() throw() {return type(0);} |     _LIBCPP_INLINE_VISIBILITY static type infinity() _NOEXCEPT {return type(0);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() throw() {return type(0);} |     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() _NOEXCEPT {return type(0);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() throw() {return type(0);} |     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() _NOEXCEPT {return type(0);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type denorm_min() throw() {return type(0);} |     _LIBCPP_INLINE_VISIBILITY static type denorm_min() _NOEXCEPT {return type(0);} | ||||||
|  |  | ||||||
|     static const bool is_iec559 = false; |     static const bool is_iec559 = false; | ||||||
|     static const bool is_bounded = true; |     static const bool is_bounded = true; | ||||||
| @@ -294,15 +294,15 @@ protected: | |||||||
|     static const int  digits = __FLT_MANT_DIG__; |     static const int  digits = __FLT_MANT_DIG__; | ||||||
|     static const int  digits10 = __FLT_DIG__; |     static const int  digits10 = __FLT_DIG__; | ||||||
|     static const int  max_digits10 = 2+(digits * 30103)/100000; |     static const int  max_digits10 = 2+(digits * 30103)/100000; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type min() throw() {return __FLT_MIN__;} |     _LIBCPP_INLINE_VISIBILITY static type min() _NOEXCEPT {return __FLT_MIN__;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type max() throw() {return __FLT_MAX__;} |     _LIBCPP_INLINE_VISIBILITY static type max() _NOEXCEPT {return __FLT_MAX__;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type lowest() throw() {return -max();} |     _LIBCPP_INLINE_VISIBILITY static type lowest() _NOEXCEPT {return -max();} | ||||||
|  |  | ||||||
|     static const bool is_integer = false; |     static const bool is_integer = false; | ||||||
|     static const bool is_exact = false; |     static const bool is_exact = false; | ||||||
|     static const int  radix = __FLT_RADIX__; |     static const int  radix = __FLT_RADIX__; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type epsilon() throw() {return __FLT_EPSILON__;} |     _LIBCPP_INLINE_VISIBILITY static type epsilon() _NOEXCEPT {return __FLT_EPSILON__;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type round_error() throw() {return 0.5F;} |     _LIBCPP_INLINE_VISIBILITY static type round_error() _NOEXCEPT {return 0.5F;} | ||||||
|  |  | ||||||
|     static const int  min_exponent = __FLT_MIN_EXP__; |     static const int  min_exponent = __FLT_MIN_EXP__; | ||||||
|     static const int  min_exponent10 = __FLT_MIN_10_EXP__; |     static const int  min_exponent10 = __FLT_MIN_10_EXP__; | ||||||
| @@ -314,10 +314,10 @@ protected: | |||||||
|     static const bool has_signaling_NaN = true; |     static const bool has_signaling_NaN = true; | ||||||
|     static const float_denorm_style has_denorm = denorm_present; |     static const float_denorm_style has_denorm = denorm_present; | ||||||
|     static const bool has_denorm_loss = false; |     static const bool has_denorm_loss = false; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type infinity() throw() {return __builtin_huge_valf();} |     _LIBCPP_INLINE_VISIBILITY static type infinity() _NOEXCEPT {return __builtin_huge_valf();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() throw() {return __builtin_nanf("");} |     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() _NOEXCEPT {return __builtin_nanf("");} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() throw() {return __builtin_nansf("");} |     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() _NOEXCEPT {return __builtin_nansf("");} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type denorm_min() throw() {return __FLT_DENORM_MIN__;} |     _LIBCPP_INLINE_VISIBILITY static type denorm_min() _NOEXCEPT {return __FLT_DENORM_MIN__;} | ||||||
|  |  | ||||||
|     static const bool is_iec559 = true; |     static const bool is_iec559 = true; | ||||||
|     static const bool is_bounded = true; |     static const bool is_bounded = true; | ||||||
| @@ -340,15 +340,15 @@ protected: | |||||||
|     static const int  digits = __DBL_MANT_DIG__; |     static const int  digits = __DBL_MANT_DIG__; | ||||||
|     static const int  digits10 = __DBL_DIG__; |     static const int  digits10 = __DBL_DIG__; | ||||||
|     static const int  max_digits10 = 2+(digits * 30103)/100000; |     static const int  max_digits10 = 2+(digits * 30103)/100000; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type min() throw() {return __DBL_MIN__;} |     _LIBCPP_INLINE_VISIBILITY static type min() _NOEXCEPT {return __DBL_MIN__;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type max() throw() {return __DBL_MAX__;} |     _LIBCPP_INLINE_VISIBILITY static type max() _NOEXCEPT {return __DBL_MAX__;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type lowest() throw() {return -max();} |     _LIBCPP_INLINE_VISIBILITY static type lowest() _NOEXCEPT {return -max();} | ||||||
|  |  | ||||||
|     static const bool is_integer = false; |     static const bool is_integer = false; | ||||||
|     static const bool is_exact = false; |     static const bool is_exact = false; | ||||||
|     static const int  radix = __FLT_RADIX__; |     static const int  radix = __FLT_RADIX__; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type epsilon() throw() {return __DBL_EPSILON__;} |     _LIBCPP_INLINE_VISIBILITY static type epsilon() _NOEXCEPT {return __DBL_EPSILON__;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type round_error() throw() {return 0.5;} |     _LIBCPP_INLINE_VISIBILITY static type round_error() _NOEXCEPT {return 0.5;} | ||||||
|  |  | ||||||
|     static const int  min_exponent = __DBL_MIN_EXP__; |     static const int  min_exponent = __DBL_MIN_EXP__; | ||||||
|     static const int  min_exponent10 = __DBL_MIN_10_EXP__; |     static const int  min_exponent10 = __DBL_MIN_10_EXP__; | ||||||
| @@ -360,10 +360,10 @@ protected: | |||||||
|     static const bool has_signaling_NaN = true; |     static const bool has_signaling_NaN = true; | ||||||
|     static const float_denorm_style has_denorm = denorm_present; |     static const float_denorm_style has_denorm = denorm_present; | ||||||
|     static const bool has_denorm_loss = false; |     static const bool has_denorm_loss = false; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type infinity() throw() {return __builtin_huge_val();} |     _LIBCPP_INLINE_VISIBILITY static type infinity() _NOEXCEPT {return __builtin_huge_val();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() throw() {return __builtin_nan("");} |     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() _NOEXCEPT {return __builtin_nan("");} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() throw() {return __builtin_nans("");} |     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() _NOEXCEPT {return __builtin_nans("");} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type denorm_min() throw() {return __DBL_DENORM_MIN__;} |     _LIBCPP_INLINE_VISIBILITY static type denorm_min() _NOEXCEPT {return __DBL_DENORM_MIN__;} | ||||||
|  |  | ||||||
|     static const bool is_iec559 = true; |     static const bool is_iec559 = true; | ||||||
|     static const bool is_bounded = true; |     static const bool is_bounded = true; | ||||||
| @@ -386,15 +386,15 @@ protected: | |||||||
|     static const int  digits = __LDBL_MANT_DIG__; |     static const int  digits = __LDBL_MANT_DIG__; | ||||||
|     static const int  digits10 = __LDBL_DIG__; |     static const int  digits10 = __LDBL_DIG__; | ||||||
|     static const int  max_digits10 = 2+(digits * 30103)/100000; |     static const int  max_digits10 = 2+(digits * 30103)/100000; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type min() throw() {return __LDBL_MIN__;} |     _LIBCPP_INLINE_VISIBILITY static type min() _NOEXCEPT {return __LDBL_MIN__;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type max() throw() {return __LDBL_MAX__;} |     _LIBCPP_INLINE_VISIBILITY static type max() _NOEXCEPT {return __LDBL_MAX__;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type lowest() throw() {return -max();} |     _LIBCPP_INLINE_VISIBILITY static type lowest() _NOEXCEPT {return -max();} | ||||||
|  |  | ||||||
|     static const bool is_integer = false; |     static const bool is_integer = false; | ||||||
|     static const bool is_exact = false; |     static const bool is_exact = false; | ||||||
|     static const int  radix = __FLT_RADIX__; |     static const int  radix = __FLT_RADIX__; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type epsilon() throw() {return __LDBL_EPSILON__;} |     _LIBCPP_INLINE_VISIBILITY static type epsilon() _NOEXCEPT {return __LDBL_EPSILON__;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type round_error() throw() {return 0.5;} |     _LIBCPP_INLINE_VISIBILITY static type round_error() _NOEXCEPT {return 0.5;} | ||||||
|  |  | ||||||
|     static const int  min_exponent = __LDBL_MIN_EXP__; |     static const int  min_exponent = __LDBL_MIN_EXP__; | ||||||
|     static const int  min_exponent10 = __LDBL_MIN_10_EXP__; |     static const int  min_exponent10 = __LDBL_MIN_10_EXP__; | ||||||
| @@ -406,10 +406,10 @@ protected: | |||||||
|     static const bool has_signaling_NaN = true; |     static const bool has_signaling_NaN = true; | ||||||
|     static const float_denorm_style has_denorm = denorm_present; |     static const float_denorm_style has_denorm = denorm_present; | ||||||
|     static const bool has_denorm_loss = false; |     static const bool has_denorm_loss = false; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type infinity() throw() {return __builtin_huge_vall();} |     _LIBCPP_INLINE_VISIBILITY static type infinity() _NOEXCEPT {return __builtin_huge_vall();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() throw() {return __builtin_nanl("");} |     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() _NOEXCEPT {return __builtin_nanl("");} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() throw() {return __builtin_nansl("");} |     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() _NOEXCEPT {return __builtin_nansl("");} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type denorm_min() throw() {return __LDBL_DENORM_MIN__;} |     _LIBCPP_INLINE_VISIBILITY static type denorm_min() _NOEXCEPT {return __LDBL_DENORM_MIN__;} | ||||||
|  |  | ||||||
| #if (defined(__ppc__) || defined(__ppc64__)) | #if (defined(__ppc__) || defined(__ppc64__)) | ||||||
|     static const bool is_iec559 = false; |     static const bool is_iec559 = false; | ||||||
| @@ -432,9 +432,9 @@ class _LIBCPP_VISIBLE numeric_limits | |||||||
|     typedef typename __base::type type; |     typedef typename __base::type type; | ||||||
| public: | public: | ||||||
|     static const bool is_specialized = __base::is_specialized; |     static const bool is_specialized = __base::is_specialized; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type min() throw() {return __base::min();} |     _LIBCPP_INLINE_VISIBILITY static type min() _NOEXCEPT {return __base::min();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type max() throw() {return __base::max();} |     _LIBCPP_INLINE_VISIBILITY static type max() _NOEXCEPT {return __base::max();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type lowest() throw() {return __base::lowest();} |     _LIBCPP_INLINE_VISIBILITY static type lowest() _NOEXCEPT {return __base::lowest();} | ||||||
|  |  | ||||||
|     static const int  digits = __base::digits; |     static const int  digits = __base::digits; | ||||||
|     static const int  digits10 = __base::digits10; |     static const int  digits10 = __base::digits10; | ||||||
| @@ -443,8 +443,8 @@ public: | |||||||
|     static const bool is_integer = __base::is_integer; |     static const bool is_integer = __base::is_integer; | ||||||
|     static const bool is_exact = __base::is_exact; |     static const bool is_exact = __base::is_exact; | ||||||
|     static const int  radix = __base::radix; |     static const int  radix = __base::radix; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type epsilon() throw() {return __base::epsilon();} |     _LIBCPP_INLINE_VISIBILITY static type epsilon() _NOEXCEPT {return __base::epsilon();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type round_error() throw() {return __base::round_error();} |     _LIBCPP_INLINE_VISIBILITY static type round_error() _NOEXCEPT {return __base::round_error();} | ||||||
|  |  | ||||||
|     static const int  min_exponent = __base::min_exponent; |     static const int  min_exponent = __base::min_exponent; | ||||||
|     static const int  min_exponent10 = __base::min_exponent10; |     static const int  min_exponent10 = __base::min_exponent10; | ||||||
| @@ -456,10 +456,10 @@ public: | |||||||
|     static const bool has_signaling_NaN = __base::has_signaling_NaN; |     static const bool has_signaling_NaN = __base::has_signaling_NaN; | ||||||
|     static const float_denorm_style has_denorm = __base::has_denorm; |     static const float_denorm_style has_denorm = __base::has_denorm; | ||||||
|     static const bool has_denorm_loss = __base::has_denorm_loss; |     static const bool has_denorm_loss = __base::has_denorm_loss; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type infinity() throw() {return __base::infinity();} |     _LIBCPP_INLINE_VISIBILITY static type infinity() _NOEXCEPT {return __base::infinity();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() throw() {return __base::quiet_NaN();} |     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() _NOEXCEPT {return __base::quiet_NaN();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() throw() {return __base::signaling_NaN();} |     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() _NOEXCEPT {return __base::signaling_NaN();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type denorm_min() throw() {return __base::denorm_min();} |     _LIBCPP_INLINE_VISIBILITY static type denorm_min() _NOEXCEPT {return __base::denorm_min();} | ||||||
|  |  | ||||||
|     static const bool is_iec559 = __base::is_iec559; |     static const bool is_iec559 = __base::is_iec559; | ||||||
|     static const bool is_bounded = __base::is_bounded; |     static const bool is_bounded = __base::is_bounded; | ||||||
| @@ -478,9 +478,9 @@ class _LIBCPP_VISIBLE numeric_limits<const _Tp> | |||||||
|     typedef _Tp type; |     typedef _Tp type; | ||||||
| public: | public: | ||||||
|     static const bool is_specialized = __base::is_specialized; |     static const bool is_specialized = __base::is_specialized; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type min() throw() {return __base::min();} |     _LIBCPP_INLINE_VISIBILITY static type min() _NOEXCEPT {return __base::min();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type max() throw() {return __base::max();} |     _LIBCPP_INLINE_VISIBILITY static type max() _NOEXCEPT {return __base::max();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type lowest() throw() {return __base::lowest();} |     _LIBCPP_INLINE_VISIBILITY static type lowest() _NOEXCEPT {return __base::lowest();} | ||||||
|  |  | ||||||
|     static const int  digits = __base::digits; |     static const int  digits = __base::digits; | ||||||
|     static const int  digits10 = __base::digits10; |     static const int  digits10 = __base::digits10; | ||||||
| @@ -489,8 +489,8 @@ public: | |||||||
|     static const bool is_integer = __base::is_integer; |     static const bool is_integer = __base::is_integer; | ||||||
|     static const bool is_exact = __base::is_exact; |     static const bool is_exact = __base::is_exact; | ||||||
|     static const int  radix = __base::radix; |     static const int  radix = __base::radix; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type epsilon() throw() {return __base::epsilon();} |     _LIBCPP_INLINE_VISIBILITY static type epsilon() _NOEXCEPT {return __base::epsilon();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type round_error() throw() {return __base::round_error();} |     _LIBCPP_INLINE_VISIBILITY static type round_error() _NOEXCEPT {return __base::round_error();} | ||||||
|  |  | ||||||
|     static const int  min_exponent = __base::min_exponent; |     static const int  min_exponent = __base::min_exponent; | ||||||
|     static const int  min_exponent10 = __base::min_exponent10; |     static const int  min_exponent10 = __base::min_exponent10; | ||||||
| @@ -502,10 +502,10 @@ public: | |||||||
|     static const bool has_signaling_NaN = __base::has_signaling_NaN; |     static const bool has_signaling_NaN = __base::has_signaling_NaN; | ||||||
|     static const float_denorm_style has_denorm = __base::has_denorm; |     static const float_denorm_style has_denorm = __base::has_denorm; | ||||||
|     static const bool has_denorm_loss = __base::has_denorm_loss; |     static const bool has_denorm_loss = __base::has_denorm_loss; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type infinity() throw() {return __base::infinity();} |     _LIBCPP_INLINE_VISIBILITY static type infinity() _NOEXCEPT {return __base::infinity();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() throw() {return __base::quiet_NaN();} |     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() _NOEXCEPT {return __base::quiet_NaN();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() throw() {return __base::signaling_NaN();} |     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() _NOEXCEPT {return __base::signaling_NaN();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type denorm_min() throw() {return __base::denorm_min();} |     _LIBCPP_INLINE_VISIBILITY static type denorm_min() _NOEXCEPT {return __base::denorm_min();} | ||||||
|  |  | ||||||
|     static const bool is_iec559 = __base::is_iec559; |     static const bool is_iec559 = __base::is_iec559; | ||||||
|     static const bool is_bounded = __base::is_bounded; |     static const bool is_bounded = __base::is_bounded; | ||||||
| @@ -524,9 +524,9 @@ class _LIBCPP_VISIBLE numeric_limits<volatile _Tp> | |||||||
|     typedef _Tp type; |     typedef _Tp type; | ||||||
| public: | public: | ||||||
|     static const bool is_specialized = __base::is_specialized; |     static const bool is_specialized = __base::is_specialized; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type min() throw() {return __base::min();} |     _LIBCPP_INLINE_VISIBILITY static type min() _NOEXCEPT {return __base::min();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type max() throw() {return __base::max();} |     _LIBCPP_INLINE_VISIBILITY static type max() _NOEXCEPT {return __base::max();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type lowest() throw() {return __base::lowest();} |     _LIBCPP_INLINE_VISIBILITY static type lowest() _NOEXCEPT {return __base::lowest();} | ||||||
|  |  | ||||||
|     static const int  digits = __base::digits; |     static const int  digits = __base::digits; | ||||||
|     static const int  digits10 = __base::digits10; |     static const int  digits10 = __base::digits10; | ||||||
| @@ -535,8 +535,8 @@ public: | |||||||
|     static const bool is_integer = __base::is_integer; |     static const bool is_integer = __base::is_integer; | ||||||
|     static const bool is_exact = __base::is_exact; |     static const bool is_exact = __base::is_exact; | ||||||
|     static const int  radix = __base::radix; |     static const int  radix = __base::radix; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type epsilon() throw() {return __base::epsilon();} |     _LIBCPP_INLINE_VISIBILITY static type epsilon() _NOEXCEPT {return __base::epsilon();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type round_error() throw() {return __base::round_error();} |     _LIBCPP_INLINE_VISIBILITY static type round_error() _NOEXCEPT {return __base::round_error();} | ||||||
|  |  | ||||||
|     static const int  min_exponent = __base::min_exponent; |     static const int  min_exponent = __base::min_exponent; | ||||||
|     static const int  min_exponent10 = __base::min_exponent10; |     static const int  min_exponent10 = __base::min_exponent10; | ||||||
| @@ -548,10 +548,10 @@ public: | |||||||
|     static const bool has_signaling_NaN = __base::has_signaling_NaN; |     static const bool has_signaling_NaN = __base::has_signaling_NaN; | ||||||
|     static const float_denorm_style has_denorm = __base::has_denorm; |     static const float_denorm_style has_denorm = __base::has_denorm; | ||||||
|     static const bool has_denorm_loss = __base::has_denorm_loss; |     static const bool has_denorm_loss = __base::has_denorm_loss; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type infinity() throw() {return __base::infinity();} |     _LIBCPP_INLINE_VISIBILITY static type infinity() _NOEXCEPT {return __base::infinity();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() throw() {return __base::quiet_NaN();} |     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() _NOEXCEPT {return __base::quiet_NaN();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() throw() {return __base::signaling_NaN();} |     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() _NOEXCEPT {return __base::signaling_NaN();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type denorm_min() throw() {return __base::denorm_min();} |     _LIBCPP_INLINE_VISIBILITY static type denorm_min() _NOEXCEPT {return __base::denorm_min();} | ||||||
|  |  | ||||||
|     static const bool is_iec559 = __base::is_iec559; |     static const bool is_iec559 = __base::is_iec559; | ||||||
|     static const bool is_bounded = __base::is_bounded; |     static const bool is_bounded = __base::is_bounded; | ||||||
| @@ -570,9 +570,9 @@ class _LIBCPP_VISIBLE numeric_limits<const volatile _Tp> | |||||||
|     typedef _Tp type; |     typedef _Tp type; | ||||||
| public: | public: | ||||||
|     static const bool is_specialized = __base::is_specialized; |     static const bool is_specialized = __base::is_specialized; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type min() throw() {return __base::min();} |     _LIBCPP_INLINE_VISIBILITY static type min() _NOEXCEPT {return __base::min();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type max() throw() {return __base::max();} |     _LIBCPP_INLINE_VISIBILITY static type max() _NOEXCEPT {return __base::max();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type lowest() throw() {return __base::lowest();} |     _LIBCPP_INLINE_VISIBILITY static type lowest() _NOEXCEPT {return __base::lowest();} | ||||||
|  |  | ||||||
|     static const int  digits = __base::digits; |     static const int  digits = __base::digits; | ||||||
|     static const int  digits10 = __base::digits10; |     static const int  digits10 = __base::digits10; | ||||||
| @@ -581,8 +581,8 @@ public: | |||||||
|     static const bool is_integer = __base::is_integer; |     static const bool is_integer = __base::is_integer; | ||||||
|     static const bool is_exact = __base::is_exact; |     static const bool is_exact = __base::is_exact; | ||||||
|     static const int  radix = __base::radix; |     static const int  radix = __base::radix; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type epsilon() throw() {return __base::epsilon();} |     _LIBCPP_INLINE_VISIBILITY static type epsilon() _NOEXCEPT {return __base::epsilon();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type round_error() throw() {return __base::round_error();} |     _LIBCPP_INLINE_VISIBILITY static type round_error() _NOEXCEPT {return __base::round_error();} | ||||||
|  |  | ||||||
|     static const int  min_exponent = __base::min_exponent; |     static const int  min_exponent = __base::min_exponent; | ||||||
|     static const int  min_exponent10 = __base::min_exponent10; |     static const int  min_exponent10 = __base::min_exponent10; | ||||||
| @@ -594,10 +594,10 @@ public: | |||||||
|     static const bool has_signaling_NaN = __base::has_signaling_NaN; |     static const bool has_signaling_NaN = __base::has_signaling_NaN; | ||||||
|     static const float_denorm_style has_denorm = __base::has_denorm; |     static const float_denorm_style has_denorm = __base::has_denorm; | ||||||
|     static const bool has_denorm_loss = __base::has_denorm_loss; |     static const bool has_denorm_loss = __base::has_denorm_loss; | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type infinity() throw() {return __base::infinity();} |     _LIBCPP_INLINE_VISIBILITY static type infinity() _NOEXCEPT {return __base::infinity();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() throw() {return __base::quiet_NaN();} |     _LIBCPP_INLINE_VISIBILITY static type quiet_NaN() _NOEXCEPT {return __base::quiet_NaN();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() throw() {return __base::signaling_NaN();} |     _LIBCPP_INLINE_VISIBILITY static type signaling_NaN() _NOEXCEPT {return __base::signaling_NaN();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY static type denorm_min() throw() {return __base::denorm_min();} |     _LIBCPP_INLINE_VISIBILITY static type denorm_min() _NOEXCEPT {return __base::denorm_min();} | ||||||
|  |  | ||||||
|     static const bool is_iec559 = __base::is_iec559; |     static const bool is_iec559 = __base::is_iec559; | ||||||
|     static const bool is_bounded = __base::is_bounded; |     static const bool is_bounded = __base::is_bounded; | ||||||
|   | |||||||
							
								
								
									
										307
									
								
								include/list
									
									
									
									
									
								
							
							
						
						
									
										307
									
								
								include/list
									
									
									
									
									
								
							| @@ -36,7 +36,8 @@ public: | |||||||
|     typedef reverse_iterator<iterator> reverse_iterator; |     typedef reverse_iterator<iterator> reverse_iterator; | ||||||
|     typedef reverse_iterator<const_iterator> const_reverse_iterator; |     typedef reverse_iterator<const_iterator> const_reverse_iterator; | ||||||
|  |  | ||||||
|     list(); |     list() | ||||||
|  |         noexcept(is_nothrow_default_constructible<allocator_type>::value); | ||||||
|     explicit list(const allocator_type& a); |     explicit list(const allocator_type& a); | ||||||
|     explicit list(size_type n); |     explicit list(size_type n); | ||||||
|     list(size_type n, const value_type& value); |     list(size_type n, const value_type& value); | ||||||
| @@ -47,7 +48,8 @@ public: | |||||||
|         list(Iter first, Iter last, const allocator_type& a); |         list(Iter first, Iter last, const allocator_type& a); | ||||||
|     list(const list& x); |     list(const list& x); | ||||||
|     list(const list&, const allocator_type& a); |     list(const list&, const allocator_type& a); | ||||||
|     list(list&& x); |     list(list&& x) | ||||||
|  |         noexcept(is_nothrow_move_constructible<allocator_type>::value); | ||||||
|     list(list&&, const allocator_type& a); |     list(list&&, const allocator_type& a); | ||||||
|     list(initializer_list<value_type>); |     list(initializer_list<value_type>); | ||||||
|     list(initializer_list<value_type>, const allocator_type& a); |     list(initializer_list<value_type>, const allocator_type& a); | ||||||
| @@ -55,36 +57,39 @@ public: | |||||||
|     ~list(); |     ~list(); | ||||||
|  |  | ||||||
|     list& operator=(const list& x); |     list& operator=(const list& x); | ||||||
|     list& operator=(list&& x); |     list& operator=(list&& x) | ||||||
|  |         noexcept( | ||||||
|  |              allocator_type::propagate_on_container_move_assignment::value && | ||||||
|  |              is_nothrow_move_assignable<allocator_type>::value); | ||||||
|     list& operator=(initializer_list<value_type>); |     list& operator=(initializer_list<value_type>); | ||||||
|     template <class Iter> |     template <class Iter> | ||||||
|         void assign(Iter first, Iter last); |         void assign(Iter first, Iter last); | ||||||
|     void assign(size_type n, const value_type& t); |     void assign(size_type n, const value_type& t); | ||||||
|     void assign(initializer_list<value_type>); |     void assign(initializer_list<value_type>); | ||||||
|  |  | ||||||
|     allocator_type get_allocator() const; |     allocator_type get_allocator() const noexcept; | ||||||
|  |  | ||||||
|     iterator begin(); |     iterator begin() noexcept; | ||||||
|     const_iterator begin() const; |     const_iterator begin() const noexcept; | ||||||
|     iterator end(); |     iterator end() noexcept; | ||||||
|     const_iterator end() const; |     const_iterator end() const noexcept; | ||||||
|     reverse_iterator rbegin(); |     reverse_iterator rbegin() noexcept; | ||||||
|     const_reverse_iterator rbegin() const; |     const_reverse_iterator rbegin() const noexcept; | ||||||
|     reverse_iterator rend(); |     reverse_iterator rend() noexcept; | ||||||
|     const_reverse_iterator rend() const; |     const_reverse_iterator rend() const noexcept; | ||||||
|     const_iterator cbegin() const; |     const_iterator cbegin() const noexcept; | ||||||
|     const_iterator cend() const; |     const_iterator cend() const noexcept; | ||||||
|     const_reverse_iterator crbegin() const; |     const_reverse_iterator crbegin() const noexcept; | ||||||
|     const_reverse_iterator crend() const; |     const_reverse_iterator crend() const noexcept; | ||||||
|  |  | ||||||
|     reference front(); |     reference front(); | ||||||
|     const_reference front() const; |     const_reference front() const; | ||||||
|     reference back(); |     reference back(); | ||||||
|     const_reference back() const; |     const_reference back() const; | ||||||
|  |  | ||||||
|     bool empty() const; |     bool empty() const noexcept; | ||||||
|     size_type size() const; |     size_type size() const noexcept; | ||||||
|     size_type max_size() const; |     size_type max_size() const noexcept; | ||||||
|  |  | ||||||
|     template <class... Args> |     template <class... Args> | ||||||
|         void emplace_front(Args&&... args); |         void emplace_front(Args&&... args); | ||||||
| @@ -111,8 +116,10 @@ public: | |||||||
|     void resize(size_type sz); |     void resize(size_type sz); | ||||||
|     void resize(size_type sz, const value_type& c); |     void resize(size_type sz, const value_type& c); | ||||||
|  |  | ||||||
|     void swap(list<value_type,allocator_type>&); |     void swap(list&) | ||||||
|     void clear(); |         noexcept(!allocator_type::propagate_on_container_swap::value || | ||||||
|  |                  __is_nothrow_swappable<allocator_type>::value); | ||||||
|  |     void clear() noexcept; | ||||||
|  |  | ||||||
|     void splice(const_iterator position, list& x); |     void splice(const_iterator position, list& x); | ||||||
|     void splice(const_iterator position, list&& x); |     void splice(const_iterator position, list&& x); | ||||||
| @@ -137,7 +144,7 @@ public: | |||||||
|     void sort(); |     void sort(); | ||||||
|     template <class Compare> |     template <class Compare> | ||||||
|         void sort(Compare comp); |         void sort(Compare comp); | ||||||
|     void reverse(); |     void reverse() noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class T, class Alloc> | template <class T, class Alloc> | ||||||
| @@ -154,7 +161,8 @@ template <class T, class Alloc> | |||||||
|     bool operator<=(const list<T,Alloc>& x, const list<T,Alloc>& y); |     bool operator<=(const list<T,Alloc>& x, const list<T,Alloc>& y); | ||||||
|  |  | ||||||
| template <class T, class Alloc> | template <class T, class Alloc> | ||||||
|     void swap(list<T,Alloc>& x, list<T,Alloc>& y); |     void swap(list<T,Alloc>& x, list<T,Alloc>& y) | ||||||
|  |          noexcept(noexcept(x.swap(y))); | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
|  |  | ||||||
| @@ -172,7 +180,7 @@ template <class T, class Alloc> | |||||||
|  |  | ||||||
| _LIBCPP_BEGIN_NAMESPACE_STD | _LIBCPP_BEGIN_NAMESPACE_STD | ||||||
|  |  | ||||||
| template <class, class> struct __list_node; | template <class _Tp, class _VoidPtr> struct __list_node; | ||||||
|  |  | ||||||
| template <class _Tp, class _VoidPtr> | template <class _Tp, class _VoidPtr> | ||||||
| struct __list_node_base | struct __list_node_base | ||||||
| @@ -201,9 +209,9 @@ struct __list_node | |||||||
|     _Tp __value_; |     _Tp __value_; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class, class> class list; | template <class _Tp, class _Alloc> class list; | ||||||
| template <class, class> class __list_imp; | template <class _Tp, class _Alloc> class __list_imp; | ||||||
| template <class, class> class __list_const_iterator; | template <class _Tp, class _VoidPtr> class __list_const_iterator; | ||||||
|  |  | ||||||
| template <class _Tp, class _VoidPtr> | template <class _Tp, class _VoidPtr> | ||||||
| class _LIBCPP_VISIBLE __list_iterator | class _LIBCPP_VISIBLE __list_iterator | ||||||
| @@ -218,7 +226,7 @@ class _LIBCPP_VISIBLE __list_iterator | |||||||
|     __node_pointer __ptr_; |     __node_pointer __ptr_; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __list_iterator(__node_pointer __p) : __ptr_(__p) {} |     explicit __list_iterator(__node_pointer __p) _NOEXCEPT : __ptr_(__p) {} | ||||||
|  |  | ||||||
|     template<class, class> friend class list; |     template<class, class> friend class list; | ||||||
|     template<class, class> friend class __list_imp; |     template<class, class> friend class __list_imp; | ||||||
| @@ -237,7 +245,7 @@ public: | |||||||
|     typedef typename pointer_traits<pointer>::difference_type difference_type; |     typedef typename pointer_traits<pointer>::difference_type difference_type; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __list_iterator() {} |     __list_iterator() _NOEXCEPT {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     reference operator*() const {return __ptr_->__value_;} |     reference operator*() const {return __ptr_->__value_;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -274,7 +282,7 @@ class _LIBCPP_VISIBLE __list_const_iterator | |||||||
|     __node_pointer __ptr_; |     __node_pointer __ptr_; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __list_const_iterator(__node_pointer __p) : __ptr_(__p) {} |     explicit __list_const_iterator(__node_pointer __p) _NOEXCEPT : __ptr_(__p) {} | ||||||
|  |  | ||||||
|     template<class, class> friend class list; |     template<class, class> friend class list; | ||||||
|     template<class, class> friend class __list_imp; |     template<class, class> friend class __list_imp; | ||||||
| @@ -292,9 +300,10 @@ public: | |||||||
|     typedef typename pointer_traits<pointer>::difference_type difference_type; |     typedef typename pointer_traits<pointer>::difference_type difference_type; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __list_const_iterator() {} |     __list_const_iterator() _NOEXCEPT {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __list_const_iterator(__list_iterator<_Tp, _VoidPtr> __p) : __ptr_(__p.__ptr_) {} |     __list_const_iterator(__list_iterator<_Tp, _VoidPtr> __p) _NOEXCEPT | ||||||
|  |         : __ptr_(__p.__ptr_) {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     reference operator*() const {return __ptr_->__value_;} |     reference operator*() const {return __ptr_->__value_;} | ||||||
| @@ -352,33 +361,43 @@ protected: | |||||||
|     __compressed_pair<size_type, __node_allocator> __size_alloc_; |     __compressed_pair<size_type, __node_allocator> __size_alloc_; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           size_type& __sz()       {return __size_alloc_.first();} |           size_type& __sz() _NOEXCEPT {return __size_alloc_.first();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const size_type& __sz() const {return __size_alloc_.first();} |     const size_type& __sz() const _NOEXCEPT | ||||||
|  |         {return __size_alloc_.first();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           __node_allocator& __node_alloc()       {return __size_alloc_.second();} |           __node_allocator& __node_alloc() _NOEXCEPT | ||||||
|  |           {return __size_alloc_.second();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const __node_allocator& __node_alloc() const {return __size_alloc_.second();} |     const __node_allocator& __node_alloc() const _NOEXCEPT | ||||||
|  |         {return __size_alloc_.second();} | ||||||
|  |  | ||||||
|     static void __unlink_nodes(__node_base& __f, __node_base& __l); |     static void __unlink_nodes(__node_base& __f, __node_base& __l) _NOEXCEPT; | ||||||
|  |  | ||||||
|     __list_imp(); |     __list_imp() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<__node_allocator>::value); | ||||||
|     __list_imp(const allocator_type& __a); |     __list_imp(const allocator_type& __a); | ||||||
|     ~__list_imp(); |     ~__list_imp(); | ||||||
|     void clear(); |     void clear() _NOEXCEPT; | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool empty() const {return __sz() == 0;} |     bool empty() const _NOEXCEPT {return __sz() == 0;} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           iterator begin()       {return       iterator(__end_.__next_);} |           iterator begin() _NOEXCEPT | ||||||
|  |             {return       iterator(__end_.__next_);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator begin() const {return const_iterator(__end_.__next_);} |     const_iterator begin() const  _NOEXCEPT | ||||||
|  |         {return const_iterator(__end_.__next_);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           iterator end()       {return       iterator(static_cast<__node_pointer>      (&__end_));} |           iterator end() _NOEXCEPT | ||||||
|  |             {return       iterator(static_cast<__node_pointer>      (&__end_));} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator end() const {return const_iterator(static_cast<__node_const_pointer>(&__end_));} |     const_iterator end() const _NOEXCEPT | ||||||
|  |         {return const_iterator(static_cast<__node_const_pointer>(&__end_));} | ||||||
|  |  | ||||||
|     void swap(__list_imp& __c); |     void swap(__list_imp& __c) | ||||||
|  |         _NOEXCEPT_(!__node_alloc_traits::propagate_on_container_swap::value || | ||||||
|  |                    __is_nothrow_swappable<__node_allocator>::value); | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void __copy_assign_alloc(const __list_imp& __c) |     void __copy_assign_alloc(const __list_imp& __c) | ||||||
| @@ -387,22 +406,29 @@ protected: | |||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void __move_assign_alloc(__list_imp& __c) |     void __move_assign_alloc(__list_imp& __c) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             !__node_alloc_traits::propagate_on_container_move_assignment::value || | ||||||
|  |             is_nothrow_move_assignable<__node_allocator>::value) | ||||||
|         {__move_assign_alloc(__c, integral_constant<bool, |         {__move_assign_alloc(__c, integral_constant<bool, | ||||||
|                       __node_alloc_traits::propagate_on_container_move_assignment::value>());} |                       __node_alloc_traits::propagate_on_container_move_assignment::value>());} | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     static void __swap_alloc(__node_allocator& __x, __node_allocator& __y) |     static void __swap_alloc(__node_allocator& __x, __node_allocator& __y) | ||||||
|  |         _NOEXCEPT_(!__node_alloc_traits::propagate_on_container_swap::value || | ||||||
|  |                    __is_nothrow_swappable<__node_allocator>::value) | ||||||
|         {__swap_alloc(__x, __y, integral_constant<bool, |         {__swap_alloc(__x, __y, integral_constant<bool, | ||||||
|                       __node_alloc_traits::propagate_on_container_swap::value>());} |                       __node_alloc_traits::propagate_on_container_swap::value>());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     static void __swap_alloc(__node_allocator& __x, __node_allocator& __y, true_type) |     static void __swap_alloc(__node_allocator& __x, __node_allocator& __y, true_type) | ||||||
|  |         _NOEXCEPT_(__is_nothrow_swappable<__node_allocator>::value) | ||||||
|         { |         { | ||||||
|             using _STD::swap; |             using _VSTD::swap; | ||||||
|             swap(__x, __y); |             swap(__x, __y); | ||||||
|         } |         } | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     static void __swap_alloc(__node_allocator& __x, __node_allocator& __y, false_type) |     static void __swap_alloc(__node_allocator& __x, __node_allocator& __y, false_type) | ||||||
|  |         _NOEXCEPT | ||||||
|         {} |         {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -419,12 +445,14 @@ private: | |||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void __move_assign_alloc(const __list_imp& __c, true_type) |     void __move_assign_alloc(const __list_imp& __c, true_type) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_assignable<__node_allocator>::value) | ||||||
|         { |         { | ||||||
|             __node_alloc() = _STD::move(__c.__node_alloc()); |             __node_alloc() = _VSTD::move(__c.__node_alloc()); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void __move_assign_alloc(const __list_imp& __c, false_type) |     void __move_assign_alloc(const __list_imp& __c, false_type) | ||||||
|  |         _NOEXCEPT | ||||||
|         {} |         {} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -433,6 +461,7 @@ template <class _Tp, class _Alloc> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| void | void | ||||||
| __list_imp<_Tp, _Alloc>::__unlink_nodes(__node_base& __f, __node_base& __l) | __list_imp<_Tp, _Alloc>::__unlink_nodes(__node_base& __f, __node_base& __l) | ||||||
|  |     _NOEXCEPT | ||||||
| { | { | ||||||
|     __f.__prev_->__next_ = __l.__next_; |     __f.__prev_->__next_ = __l.__next_; | ||||||
|     __l.__next_->__prev_ = __f.__prev_; |     __l.__next_->__prev_ = __f.__prev_; | ||||||
| @@ -441,6 +470,7 @@ __list_imp<_Tp, _Alloc>::__unlink_nodes(__node_base& __f, __node_base& __l) | |||||||
| template <class _Tp, class _Alloc> | template <class _Tp, class _Alloc> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| __list_imp<_Tp, _Alloc>::__list_imp() | __list_imp<_Tp, _Alloc>::__list_imp() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<__node_allocator>::value) | ||||||
|     : __size_alloc_(0) |     : __size_alloc_(0) | ||||||
| { | { | ||||||
| } | } | ||||||
| @@ -460,7 +490,7 @@ __list_imp<_Tp, _Alloc>::~__list_imp() | |||||||
|  |  | ||||||
| template <class _Tp, class _Alloc> | template <class _Tp, class _Alloc> | ||||||
| void | void | ||||||
| __list_imp<_Tp, _Alloc>::clear() | __list_imp<_Tp, _Alloc>::clear() _NOEXCEPT | ||||||
| { | { | ||||||
|     if (!empty()) |     if (!empty()) | ||||||
|     { |     { | ||||||
| @@ -473,8 +503,8 @@ __list_imp<_Tp, _Alloc>::clear() | |||||||
|         { |         { | ||||||
|             __node& __n = *__f.__ptr_; |             __node& __n = *__f.__ptr_; | ||||||
|             ++__f; |             ++__f; | ||||||
|             __node_alloc_traits::destroy(__na, _STD::addressof(__n.__value_)); |             __node_alloc_traits::destroy(__na, _VSTD::addressof(__n.__value_)); | ||||||
|             __node_alloc_traits::deallocate(__na, _STD::addressof(__n), 1); |             __node_alloc_traits::deallocate(__na, _VSTD::addressof(__n), 1); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -482,8 +512,10 @@ __list_imp<_Tp, _Alloc>::clear() | |||||||
| template <class _Tp, class _Alloc> | template <class _Tp, class _Alloc> | ||||||
| void | void | ||||||
| __list_imp<_Tp, _Alloc>::swap(__list_imp& __c) | __list_imp<_Tp, _Alloc>::swap(__list_imp& __c) | ||||||
|  |         _NOEXCEPT_(!__node_alloc_traits::propagate_on_container_swap::value || | ||||||
|  |                    __is_nothrow_swappable<__node_allocator>::value) | ||||||
| { | { | ||||||
|     using _STD::swap; |     using _VSTD::swap; | ||||||
|     __swap_alloc(__node_alloc(), __c.__node_alloc()); |     __swap_alloc(__node_alloc(), __c.__node_alloc()); | ||||||
|     swap(__sz(), __c.__sz()); |     swap(__sz(), __c.__sz()); | ||||||
|     swap(__end_, __c.__end_); |     swap(__end_, __c.__end_); | ||||||
| @@ -523,11 +555,13 @@ public: | |||||||
|     typedef typename base::difference_type           difference_type; |     typedef typename base::difference_type           difference_type; | ||||||
|     typedef typename base::iterator                  iterator; |     typedef typename base::iterator                  iterator; | ||||||
|     typedef typename base::const_iterator            const_iterator; |     typedef typename base::const_iterator            const_iterator; | ||||||
|     typedef _STD::reverse_iterator<iterator>         reverse_iterator; |     typedef _VSTD::reverse_iterator<iterator>         reverse_iterator; | ||||||
|     typedef _STD::reverse_iterator<const_iterator>   const_reverse_iterator; |     typedef _VSTD::reverse_iterator<const_iterator>   const_reverse_iterator; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     list() {} |     list() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<__node_allocator>::value) | ||||||
|  |         {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     list(const allocator_type& __a) : base(__a) {} |     list(const allocator_type& __a) : base(__a) {} | ||||||
|     list(size_type __n); |     list(size_type __n); | ||||||
| @@ -546,9 +580,13 @@ public: | |||||||
|     list(initializer_list<value_type> __il); |     list(initializer_list<value_type> __il); | ||||||
|     list(initializer_list<value_type> __il, const allocator_type& __a); |     list(initializer_list<value_type> __il, const allocator_type& __a); | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     list(list&& __c); |     list(list&& __c) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_constructible<__node_allocator>::value); | ||||||
|     list(list&& __c, const allocator_type& __a); |     list(list&& __c, const allocator_type& __a); | ||||||
|     list& operator=(list&& __c); |     list& operator=(list&& __c) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             __node_alloc_traits::propagate_on_container_move_assignment::value && | ||||||
|  |             is_nothrow_move_assignable<__node_allocator>::value); | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     list& operator=(initializer_list<value_type> __il) |     list& operator=(initializer_list<value_type> __il) | ||||||
| @@ -562,40 +600,47 @@ public: | |||||||
|     void assign(initializer_list<value_type> __il) |     void assign(initializer_list<value_type> __il) | ||||||
|         {assign(__il.begin(), __il.end());} |         {assign(__il.begin(), __il.end());} | ||||||
|  |  | ||||||
|     allocator_type get_allocator() const; |     allocator_type get_allocator() const _NOEXCEPT; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type size() const     {return base::__sz();} |     size_type size() const _NOEXCEPT     {return base::__sz();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool empty() const         {return base::empty();} |     bool empty() const _NOEXCEPT         {return base::empty();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type max_size() const {return numeric_limits<difference_type>::max();} |     size_type max_size() const _NOEXCEPT | ||||||
|  |         {return numeric_limits<difference_type>::max();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           iterator begin()        {return base::begin();} |           iterator begin() _NOEXCEPT        {return base::begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator begin()  const {return base::begin();} |     const_iterator begin()  const _NOEXCEPT {return base::begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           iterator end()          {return base::end();} |           iterator end() _NOEXCEPT          {return base::end();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator end()    const {return base::end();} |     const_iterator end()    const _NOEXCEPT {return base::end();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator cbegin() const {return base::begin();} |     const_iterator cbegin() const _NOEXCEPT {return base::begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator cend()   const {return base::end();} |     const_iterator cend()   const _NOEXCEPT {return base::end();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           reverse_iterator rbegin()        {return       reverse_iterator(end());} |           reverse_iterator rbegin() _NOEXCEPT | ||||||
|  |             {return       reverse_iterator(end());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator rbegin()  const {return const_reverse_iterator(end());} |     const_reverse_iterator rbegin()  const _NOEXCEPT | ||||||
|  |         {return const_reverse_iterator(end());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           reverse_iterator rend()          {return       reverse_iterator(begin());} |           reverse_iterator rend() _NOEXCEPT | ||||||
|  |             {return       reverse_iterator(begin());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator rend()    const {return const_reverse_iterator(begin());} |     const_reverse_iterator rend()    const _NOEXCEPT | ||||||
|  |         {return const_reverse_iterator(begin());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator crbegin() const {return const_reverse_iterator(end());} |     const_reverse_iterator crbegin() const _NOEXCEPT | ||||||
|  |         {return const_reverse_iterator(end());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator crend()   const {return const_reverse_iterator(begin());} |     const_reverse_iterator crend()   const _NOEXCEPT | ||||||
|  |         {return const_reverse_iterator(begin());} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           reference front()        {return base::__end_.__next_->__value_;} |           reference front()        {return base::__end_.__next_->__value_;} | ||||||
| @@ -633,9 +678,12 @@ public: | |||||||
|         {return insert(__p, __il.begin(), __il.end());} |         {return insert(__p, __il.begin(), __il.end());} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(list& __c) {base::swap(__c);} |     void swap(list& __c) | ||||||
|  |         _NOEXCEPT_(!__node_alloc_traits::propagate_on_container_swap::value || | ||||||
|  |                    __is_nothrow_swappable<__node_allocator>::value) | ||||||
|  |         {base::swap(__c);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void clear() {base::clear();} |     void clear() _NOEXCEPT {base::clear();} | ||||||
|  |  | ||||||
|     void pop_front(); |     void pop_front(); | ||||||
|     void pop_back(); |     void pop_back(); | ||||||
| @@ -685,7 +733,7 @@ public: | |||||||
|     template <class _Comp> |     template <class _Comp> | ||||||
|         void sort(_Comp __comp); |         void sort(_Comp __comp); | ||||||
|  |  | ||||||
|     void reverse(); |     void reverse() _NOEXCEPT; | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     static void __link_nodes(__node& __p, __node& __f, __node& __l); |     static void __link_nodes(__node& __p, __node& __f, __node& __l); | ||||||
| @@ -693,7 +741,8 @@ private: | |||||||
|     template <class _Comp> |     template <class _Comp> | ||||||
|         static iterator __sort(iterator __f1, iterator __e2, size_type __n, _Comp& __comp); |         static iterator __sort(iterator __f1, iterator __e2, size_type __n, _Comp& __comp); | ||||||
|  |  | ||||||
|     void __move_assign(list& __c, true_type); |     void __move_assign(list& __c, true_type) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_assignable<__node_allocator>::value); | ||||||
|     void __move_assign(list& __c, false_type); |     void __move_assign(list& __c, false_type); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -714,8 +763,8 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| typename list<_Tp, _Alloc>::iterator | typename list<_Tp, _Alloc>::iterator | ||||||
| list<_Tp, _Alloc>::__iterator(size_type __n) | list<_Tp, _Alloc>::__iterator(size_type __n) | ||||||
| { | { | ||||||
|     return __n <= base::__sz() / 2 ? _STD::next(begin(), __n) |     return __n <= base::__sz() / 2 ? _VSTD::next(begin(), __n) | ||||||
|                                    : _STD::prev(end(), base::__sz() - __n); |                                    : _VSTD::prev(end(), base::__sz() - __n); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, class _Alloc> | template <class _Tp, class _Alloc> | ||||||
| @@ -816,7 +865,8 @@ list<_Tp, _Alloc>::operator=(const list& __c) | |||||||
| template <class _Tp, class _Alloc> | template <class _Tp, class _Alloc> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| list<_Tp, _Alloc>::list(list&& __c) | list<_Tp, _Alloc>::list(list&& __c) | ||||||
|     : base(allocator_type(_STD::move(__c.__node_alloc()))) |     _NOEXCEPT_(is_nothrow_move_constructible<__node_allocator>::value) | ||||||
|  |     : base(allocator_type(_VSTD::move(__c.__node_alloc()))) | ||||||
| { | { | ||||||
|     splice(end(), __c); |     splice(end(), __c); | ||||||
| } | } | ||||||
| @@ -839,6 +889,9 @@ template <class _Tp, class _Alloc> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| list<_Tp, _Alloc>& | list<_Tp, _Alloc>& | ||||||
| list<_Tp, _Alloc>::operator=(list&& __c) | list<_Tp, _Alloc>::operator=(list&& __c) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             __node_alloc_traits::propagate_on_container_move_assignment::value && | ||||||
|  |             is_nothrow_move_assignable<__node_allocator>::value) | ||||||
| { | { | ||||||
|     __move_assign(__c, integral_constant<bool, |     __move_assign(__c, integral_constant<bool, | ||||||
|           __node_alloc_traits::propagate_on_container_move_assignment::value>()); |           __node_alloc_traits::propagate_on_container_move_assignment::value>()); | ||||||
| @@ -861,6 +914,7 @@ list<_Tp, _Alloc>::__move_assign(list& __c, false_type) | |||||||
| template <class _Tp, class _Alloc> | template <class _Tp, class _Alloc> | ||||||
| void | void | ||||||
| list<_Tp, _Alloc>::__move_assign(list& __c, true_type) | list<_Tp, _Alloc>::__move_assign(list& __c, true_type) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_assignable<__node_allocator>::value) | ||||||
| { | { | ||||||
|     clear(); |     clear(); | ||||||
|     base::__move_assign_alloc(__c); |     base::__move_assign_alloc(__c); | ||||||
| @@ -902,7 +956,7 @@ list<_Tp, _Alloc>::assign(size_type __n, const value_type& __x) | |||||||
| template <class _Tp, class _Alloc> | template <class _Tp, class _Alloc> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| _Alloc | _Alloc | ||||||
| list<_Tp, _Alloc>::get_allocator() const | list<_Tp, _Alloc>::get_allocator() const _NOEXCEPT | ||||||
| { | { | ||||||
|     return allocator_type(base::__node_alloc()); |     return allocator_type(base::__node_alloc()); | ||||||
| } | } | ||||||
| @@ -915,7 +969,7 @@ list<_Tp, _Alloc>::insert(const_iterator __p, const value_type& __x) | |||||||
|     typedef __allocator_destructor<__node_allocator> _D; |     typedef __allocator_destructor<__node_allocator> _D; | ||||||
|     unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); |     unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); | ||||||
|     __hold->__prev_ = 0; |     __hold->__prev_ = 0; | ||||||
|     __node_alloc_traits::construct(__na, _STD::addressof(__hold->__value_), __x); |     __node_alloc_traits::construct(__na, _VSTD::addressof(__hold->__value_), __x); | ||||||
|     __link_nodes(const_cast<__node&>(*__p.__ptr_), *__hold, *__hold); |     __link_nodes(const_cast<__node&>(*__p.__ptr_), *__hold, *__hold); | ||||||
|     ++base::__sz(); |     ++base::__sz(); | ||||||
|     return iterator(__hold.release()); |     return iterator(__hold.release()); | ||||||
| @@ -933,7 +987,7 @@ list<_Tp, _Alloc>::insert(const_iterator __p, size_type __n, const value_type& _ | |||||||
|         typedef __allocator_destructor<__node_allocator> _D; |         typedef __allocator_destructor<__node_allocator> _D; | ||||||
|         unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); |         unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); | ||||||
|         __hold->__prev_ = 0; |         __hold->__prev_ = 0; | ||||||
|         __node_alloc_traits::construct(__na, _STD::addressof(__hold->__value_), __x); |         __node_alloc_traits::construct(__na, _VSTD::addressof(__hold->__value_), __x); | ||||||
|         ++__ds; |         ++__ds; | ||||||
|         __r = iterator(__hold.get()); |         __r = iterator(__hold.get()); | ||||||
|         __hold.release(); |         __hold.release(); | ||||||
| @@ -945,7 +999,7 @@ list<_Tp, _Alloc>::insert(const_iterator __p, size_type __n, const value_type& _ | |||||||
|             for (--__n; __n != 0; --__n, ++__e, ++__ds) |             for (--__n; __n != 0; --__n, ++__e, ++__ds) | ||||||
|             { |             { | ||||||
|                 __hold.reset(__node_alloc_traits::allocate(__na, 1)); |                 __hold.reset(__node_alloc_traits::allocate(__na, 1)); | ||||||
|                 __node_alloc_traits::construct(__na, _STD::addressof(__hold->__value_), __x); |                 __node_alloc_traits::construct(__na, _VSTD::addressof(__hold->__value_), __x); | ||||||
|                 __e.__ptr_->__next_ = __hold.get(); |                 __e.__ptr_->__next_ = __hold.get(); | ||||||
|                 __hold->__prev_ = __e.__ptr_; |                 __hold->__prev_ = __e.__ptr_; | ||||||
|                 __hold.release(); |                 __hold.release(); | ||||||
| @@ -956,7 +1010,7 @@ list<_Tp, _Alloc>::insert(const_iterator __p, size_type __n, const value_type& _ | |||||||
|         { |         { | ||||||
|             while (true) |             while (true) | ||||||
|             { |             { | ||||||
|                 __node_alloc_traits::destroy(__na, _STD::addressof(*__e)); |                 __node_alloc_traits::destroy(__na, _VSTD::addressof(*__e)); | ||||||
|                 __node_pointer __prev = __e.__ptr_->__prev_; |                 __node_pointer __prev = __e.__ptr_->__prev_; | ||||||
|                 __node_alloc_traits::deallocate(__na, __e.__ptr_, 1); |                 __node_alloc_traits::deallocate(__na, __e.__ptr_, 1); | ||||||
|                 if (__prev == 0) |                 if (__prev == 0) | ||||||
| @@ -986,7 +1040,7 @@ list<_Tp, _Alloc>::insert(const_iterator __p, _InpIter __f, _InpIter __l, | |||||||
|         typedef __allocator_destructor<__node_allocator> _D; |         typedef __allocator_destructor<__node_allocator> _D; | ||||||
|         unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); |         unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); | ||||||
|         __hold->__prev_ = 0; |         __hold->__prev_ = 0; | ||||||
|         __node_alloc_traits::construct(__na, _STD::addressof(__hold->__value_), *__f); |         __node_alloc_traits::construct(__na, _VSTD::addressof(__hold->__value_), *__f); | ||||||
|         ++__ds; |         ++__ds; | ||||||
|         __r = iterator(__hold.get()); |         __r = iterator(__hold.get()); | ||||||
|         __hold.release(); |         __hold.release(); | ||||||
| @@ -998,7 +1052,7 @@ list<_Tp, _Alloc>::insert(const_iterator __p, _InpIter __f, _InpIter __l, | |||||||
|             for (++__f; __f != __l; ++__f, ++__e, ++__ds) |             for (++__f; __f != __l; ++__f, ++__e, ++__ds) | ||||||
|             { |             { | ||||||
|                 __hold.reset(__node_alloc_traits::allocate(__na, 1)); |                 __hold.reset(__node_alloc_traits::allocate(__na, 1)); | ||||||
|                 __node_alloc_traits::construct(__na, _STD::addressof(__hold->__value_), *__f); |                 __node_alloc_traits::construct(__na, _VSTD::addressof(__hold->__value_), *__f); | ||||||
|                 __e.__ptr_->__next_ = __hold.get(); |                 __e.__ptr_->__next_ = __hold.get(); | ||||||
|                 __hold->__prev_ = __e.__ptr_; |                 __hold->__prev_ = __e.__ptr_; | ||||||
|                 __hold.release(); |                 __hold.release(); | ||||||
| @@ -1009,7 +1063,7 @@ list<_Tp, _Alloc>::insert(const_iterator __p, _InpIter __f, _InpIter __l, | |||||||
|         { |         { | ||||||
|             while (true) |             while (true) | ||||||
|             { |             { | ||||||
|                 __node_alloc_traits::destroy(__na, _STD::addressof(*__e)); |                 __node_alloc_traits::destroy(__na, _VSTD::addressof(*__e)); | ||||||
|                 __node_pointer __prev = __e.__ptr_->__prev_; |                 __node_pointer __prev = __e.__ptr_->__prev_; | ||||||
|                 __node_alloc_traits::deallocate(__na, __e.__ptr_, 1); |                 __node_alloc_traits::deallocate(__na, __e.__ptr_, 1); | ||||||
|                 if (__prev == 0) |                 if (__prev == 0) | ||||||
| @@ -1032,7 +1086,7 @@ list<_Tp, _Alloc>::push_front(const value_type& __x) | |||||||
|     __node_allocator& __na = base::__node_alloc(); |     __node_allocator& __na = base::__node_alloc(); | ||||||
|     typedef __allocator_destructor<__node_allocator> _D; |     typedef __allocator_destructor<__node_allocator> _D; | ||||||
|     unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); |     unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); | ||||||
|     __node_alloc_traits::construct(__na, _STD::addressof(__hold->__value_), __x); |     __node_alloc_traits::construct(__na, _VSTD::addressof(__hold->__value_), __x); | ||||||
|     __link_nodes(*base::__end_.__next_, *__hold, *__hold); |     __link_nodes(*base::__end_.__next_, *__hold, *__hold); | ||||||
|     ++base::__sz(); |     ++base::__sz(); | ||||||
|     __hold.release(); |     __hold.release(); | ||||||
| @@ -1045,7 +1099,7 @@ list<_Tp, _Alloc>::push_back(const value_type& __x) | |||||||
|     __node_allocator& __na = base::__node_alloc(); |     __node_allocator& __na = base::__node_alloc(); | ||||||
|     typedef __allocator_destructor<__node_allocator> _D; |     typedef __allocator_destructor<__node_allocator> _D; | ||||||
|     unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); |     unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); | ||||||
|     __node_alloc_traits::construct(__na, _STD::addressof(__hold->__value_), __x); |     __node_alloc_traits::construct(__na, _VSTD::addressof(__hold->__value_), __x); | ||||||
|     __link_nodes(static_cast<__node&>(base::__end_), *__hold, *__hold); |     __link_nodes(static_cast<__node&>(base::__end_), *__hold, *__hold); | ||||||
|     ++base::__sz(); |     ++base::__sz(); | ||||||
|     __hold.release(); |     __hold.release(); | ||||||
| @@ -1060,7 +1114,7 @@ list<_Tp, _Alloc>::push_front(value_type&& __x) | |||||||
|     __node_allocator& __na = base::__node_alloc(); |     __node_allocator& __na = base::__node_alloc(); | ||||||
|     typedef __allocator_destructor<__node_allocator> _D; |     typedef __allocator_destructor<__node_allocator> _D; | ||||||
|     unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); |     unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); | ||||||
|     __node_alloc_traits::construct(__na, _STD::addressof(__hold->__value_), _STD::move(__x)); |     __node_alloc_traits::construct(__na, _VSTD::addressof(__hold->__value_), _VSTD::move(__x)); | ||||||
|     __link_nodes(*base::__end_.__next_, *__hold, *__hold); |     __link_nodes(*base::__end_.__next_, *__hold, *__hold); | ||||||
|     ++base::__sz(); |     ++base::__sz(); | ||||||
|     __hold.release(); |     __hold.release(); | ||||||
| @@ -1073,7 +1127,7 @@ list<_Tp, _Alloc>::push_back(value_type&& __x) | |||||||
|     __node_allocator& __na = base::__node_alloc(); |     __node_allocator& __na = base::__node_alloc(); | ||||||
|     typedef __allocator_destructor<__node_allocator> _D; |     typedef __allocator_destructor<__node_allocator> _D; | ||||||
|     unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); |     unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); | ||||||
|     __node_alloc_traits::construct(__na, _STD::addressof(__hold->__value_), _STD::move(__x)); |     __node_alloc_traits::construct(__na, _VSTD::addressof(__hold->__value_), _VSTD::move(__x)); | ||||||
|     __link_nodes(static_cast<__node&>(base::__end_), *__hold, *__hold); |     __link_nodes(static_cast<__node&>(base::__end_), *__hold, *__hold); | ||||||
|     ++base::__sz(); |     ++base::__sz(); | ||||||
|     __hold.release(); |     __hold.release(); | ||||||
| @@ -1089,7 +1143,7 @@ list<_Tp, _Alloc>::emplace_front(_Args&&... __args) | |||||||
|     __node_allocator& __na = base::__node_alloc(); |     __node_allocator& __na = base::__node_alloc(); | ||||||
|     typedef __allocator_destructor<__node_allocator> _D; |     typedef __allocator_destructor<__node_allocator> _D; | ||||||
|     unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); |     unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); | ||||||
|     __node_alloc_traits::construct(__na, _STD::addressof(__hold->__value_), _STD::forward<_Args>(__args)...); |     __node_alloc_traits::construct(__na, _VSTD::addressof(__hold->__value_), _VSTD::forward<_Args>(__args)...); | ||||||
|     __link_nodes(*base::__end_.__next_, *__hold, *__hold); |     __link_nodes(*base::__end_.__next_, *__hold, *__hold); | ||||||
|     ++base::__sz(); |     ++base::__sz(); | ||||||
|     __hold.release(); |     __hold.release(); | ||||||
| @@ -1103,7 +1157,7 @@ list<_Tp, _Alloc>::emplace_back(_Args&&... __args) | |||||||
|     __node_allocator& __na = base::__node_alloc(); |     __node_allocator& __na = base::__node_alloc(); | ||||||
|     typedef __allocator_destructor<__node_allocator> _D; |     typedef __allocator_destructor<__node_allocator> _D; | ||||||
|     unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); |     unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); | ||||||
|     __node_alloc_traits::construct(__na, _STD::addressof(__hold->__value_), _STD::forward<_Args>(__args)...); |     __node_alloc_traits::construct(__na, _VSTD::addressof(__hold->__value_), _VSTD::forward<_Args>(__args)...); | ||||||
|     __link_nodes(static_cast<__node&>(base::__end_), *__hold, *__hold); |     __link_nodes(static_cast<__node&>(base::__end_), *__hold, *__hold); | ||||||
|     ++base::__sz(); |     ++base::__sz(); | ||||||
|     __hold.release(); |     __hold.release(); | ||||||
| @@ -1118,7 +1172,7 @@ list<_Tp, _Alloc>::emplace(const_iterator __p, _Args&&... __args) | |||||||
|     typedef __allocator_destructor<__node_allocator> _D; |     typedef __allocator_destructor<__node_allocator> _D; | ||||||
|     unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); |     unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); | ||||||
|     __hold->__prev_ = 0; |     __hold->__prev_ = 0; | ||||||
|     __node_alloc_traits::construct(__na, _STD::addressof(__hold->__value_), _STD::forward<_Args>(__args)...); |     __node_alloc_traits::construct(__na, _VSTD::addressof(__hold->__value_), _VSTD::forward<_Args>(__args)...); | ||||||
|     __link_nodes(const_cast<__node&>(*__p.__ptr_), *__hold, *__hold); |     __link_nodes(const_cast<__node&>(*__p.__ptr_), *__hold, *__hold); | ||||||
|     ++base::__sz(); |     ++base::__sz(); | ||||||
|     return iterator(__hold.release()); |     return iterator(__hold.release()); | ||||||
| @@ -1134,7 +1188,7 @@ list<_Tp, _Alloc>::insert(const_iterator __p, value_type&& __x) | |||||||
|     typedef __allocator_destructor<__node_allocator> _D; |     typedef __allocator_destructor<__node_allocator> _D; | ||||||
|     unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); |     unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); | ||||||
|     __hold->__prev_ = 0; |     __hold->__prev_ = 0; | ||||||
|     __node_alloc_traits::construct(__na, _STD::addressof(__hold->__value_), _STD::move(__x)); |     __node_alloc_traits::construct(__na, _VSTD::addressof(__hold->__value_), _VSTD::move(__x)); | ||||||
|     __link_nodes(const_cast<__node&>(*__p.__ptr_), *__hold, *__hold); |     __link_nodes(const_cast<__node&>(*__p.__ptr_), *__hold, *__hold); | ||||||
|     ++base::__sz(); |     ++base::__sz(); | ||||||
|     return iterator(__hold.release()); |     return iterator(__hold.release()); | ||||||
| @@ -1150,8 +1204,8 @@ list<_Tp, _Alloc>::pop_front() | |||||||
|     __node& __n = *base::__end_.__next_; |     __node& __n = *base::__end_.__next_; | ||||||
|     base::__unlink_nodes(__n, __n); |     base::__unlink_nodes(__n, __n); | ||||||
|     --base::__sz(); |     --base::__sz(); | ||||||
|     __node_alloc_traits::destroy(__na, _STD::addressof(__n.__value_)); |     __node_alloc_traits::destroy(__na, _VSTD::addressof(__n.__value_)); | ||||||
|     __node_alloc_traits::deallocate(__na, _STD::addressof(__n), 1); |     __node_alloc_traits::deallocate(__na, _VSTD::addressof(__n), 1); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, class _Alloc> | template <class _Tp, class _Alloc> | ||||||
| @@ -1162,8 +1216,8 @@ list<_Tp, _Alloc>::pop_back() | |||||||
|     __node& __n = *base::__end_.__prev_; |     __node& __n = *base::__end_.__prev_; | ||||||
|     base::__unlink_nodes(__n, __n); |     base::__unlink_nodes(__n, __n); | ||||||
|     --base::__sz(); |     --base::__sz(); | ||||||
|     __node_alloc_traits::destroy(__na, _STD::addressof(__n.__value_)); |     __node_alloc_traits::destroy(__na, _VSTD::addressof(__n.__value_)); | ||||||
|     __node_alloc_traits::deallocate(__na, _STD::addressof(__n), 1); |     __node_alloc_traits::deallocate(__na, _VSTD::addressof(__n), 1); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, class _Alloc> | template <class _Tp, class _Alloc> | ||||||
| @@ -1175,8 +1229,8 @@ list<_Tp, _Alloc>::erase(const_iterator __p) | |||||||
|     __node_pointer __r = __n.__next_; |     __node_pointer __r = __n.__next_; | ||||||
|     base::__unlink_nodes(__n, __n); |     base::__unlink_nodes(__n, __n); | ||||||
|     --base::__sz(); |     --base::__sz(); | ||||||
|     __node_alloc_traits::destroy(__na, _STD::addressof(__n.__value_)); |     __node_alloc_traits::destroy(__na, _VSTD::addressof(__n.__value_)); | ||||||
|     __node_alloc_traits::deallocate(__na, _STD::addressof(__n), 1); |     __node_alloc_traits::deallocate(__na, _VSTD::addressof(__n), 1); | ||||||
|     return iterator(__r); |     return iterator(__r); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1193,8 +1247,8 @@ list<_Tp, _Alloc>::erase(const_iterator __f, const_iterator __l) | |||||||
|             __node& __n = const_cast<__node&>(*__f.__ptr_); |             __node& __n = const_cast<__node&>(*__f.__ptr_); | ||||||
|             ++__f; |             ++__f; | ||||||
|             --base::__sz(); |             --base::__sz(); | ||||||
|             __node_alloc_traits::destroy(__na, _STD::addressof(__n.__value_)); |             __node_alloc_traits::destroy(__na, _VSTD::addressof(__n.__value_)); | ||||||
|             __node_alloc_traits::deallocate(__na, _STD::addressof(__n), 1); |             __node_alloc_traits::deallocate(__na, _VSTD::addressof(__n), 1); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     return iterator(const_cast<__node_pointer>(__l.__ptr_)); |     return iterator(const_cast<__node_pointer>(__l.__ptr_)); | ||||||
| @@ -1214,7 +1268,7 @@ list<_Tp, _Alloc>::resize(size_type __n) | |||||||
|         typedef __allocator_destructor<__node_allocator> _D; |         typedef __allocator_destructor<__node_allocator> _D; | ||||||
|         unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); |         unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); | ||||||
|         __hold->__prev_ = 0; |         __hold->__prev_ = 0; | ||||||
|         __node_alloc_traits::construct(__na, _STD::addressof(__hold->__value_)); |         __node_alloc_traits::construct(__na, _VSTD::addressof(__hold->__value_)); | ||||||
|         ++__ds; |         ++__ds; | ||||||
|         iterator __r = iterator(__hold.release()); |         iterator __r = iterator(__hold.release()); | ||||||
|         iterator __e = __r; |         iterator __e = __r; | ||||||
| @@ -1225,7 +1279,7 @@ list<_Tp, _Alloc>::resize(size_type __n) | |||||||
|             for (--__n; __n != 0; --__n, ++__e, ++__ds) |             for (--__n; __n != 0; --__n, ++__e, ++__ds) | ||||||
|             { |             { | ||||||
|                 __hold.reset(__node_alloc_traits::allocate(__na, 1)); |                 __hold.reset(__node_alloc_traits::allocate(__na, 1)); | ||||||
|                 __node_alloc_traits::construct(__na, _STD::addressof(__hold->__value_)); |                 __node_alloc_traits::construct(__na, _VSTD::addressof(__hold->__value_)); | ||||||
|                 __e.__ptr_->__next_ = __hold.get(); |                 __e.__ptr_->__next_ = __hold.get(); | ||||||
|                 __hold->__prev_ = __e.__ptr_; |                 __hold->__prev_ = __e.__ptr_; | ||||||
|                 __hold.release(); |                 __hold.release(); | ||||||
| @@ -1236,7 +1290,7 @@ list<_Tp, _Alloc>::resize(size_type __n) | |||||||
|         { |         { | ||||||
|             while (true) |             while (true) | ||||||
|             { |             { | ||||||
|                 __node_alloc_traits::destroy(__na, _STD::addressof(*__e)); |                 __node_alloc_traits::destroy(__na, _VSTD::addressof(*__e)); | ||||||
|                 __node_pointer __prev = __e.__ptr_->__prev_; |                 __node_pointer __prev = __e.__ptr_->__prev_; | ||||||
|                 __node_alloc_traits::deallocate(__na, __e.__ptr_, 1); |                 __node_alloc_traits::deallocate(__na, __e.__ptr_, 1); | ||||||
|                 if (__prev == 0) |                 if (__prev == 0) | ||||||
| @@ -1265,7 +1319,7 @@ list<_Tp, _Alloc>::resize(size_type __n, const value_type& __x) | |||||||
|         typedef __allocator_destructor<__node_allocator> _D; |         typedef __allocator_destructor<__node_allocator> _D; | ||||||
|         unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); |         unique_ptr<__node, _D> __hold(__node_alloc_traits::allocate(__na, 1), _D(__na, 1)); | ||||||
|         __hold->__prev_ = 0; |         __hold->__prev_ = 0; | ||||||
|         __node_alloc_traits::construct(__na, _STD::addressof(__hold->__value_), __x); |         __node_alloc_traits::construct(__na, _VSTD::addressof(__hold->__value_), __x); | ||||||
|         ++__ds; |         ++__ds; | ||||||
|         iterator __r = iterator(__hold.release()); |         iterator __r = iterator(__hold.release()); | ||||||
|         iterator __e = __r; |         iterator __e = __r; | ||||||
| @@ -1276,7 +1330,7 @@ list<_Tp, _Alloc>::resize(size_type __n, const value_type& __x) | |||||||
|             for (--__n; __n != 0; --__n, ++__e, ++__ds) |             for (--__n; __n != 0; --__n, ++__e, ++__ds) | ||||||
|             { |             { | ||||||
|                 __hold.reset(__node_alloc_traits::allocate(__na, 1)); |                 __hold.reset(__node_alloc_traits::allocate(__na, 1)); | ||||||
|                 __node_alloc_traits::construct(__na, _STD::addressof(__hold->__value_), __x); |                 __node_alloc_traits::construct(__na, _VSTD::addressof(__hold->__value_), __x); | ||||||
|                 __e.__ptr_->__next_ = __hold.get(); |                 __e.__ptr_->__next_ = __hold.get(); | ||||||
|                 __hold->__prev_ = __e.__ptr_; |                 __hold->__prev_ = __e.__ptr_; | ||||||
|                 __hold.release(); |                 __hold.release(); | ||||||
| @@ -1287,7 +1341,7 @@ list<_Tp, _Alloc>::resize(size_type __n, const value_type& __x) | |||||||
|         { |         { | ||||||
|             while (true) |             while (true) | ||||||
|             { |             { | ||||||
|                 __node_alloc_traits::destroy(__na, _STD::addressof(*__e)); |                 __node_alloc_traits::destroy(__na, _VSTD::addressof(*__e)); | ||||||
|                 __node_pointer __prev = __e.__ptr_->__prev_; |                 __node_pointer __prev = __e.__ptr_->__prev_; | ||||||
|                 __node_alloc_traits::deallocate(__na, __e.__ptr_, 1); |                 __node_alloc_traits::deallocate(__na, __e.__ptr_, 1); | ||||||
|                 if (__prev == 0) |                 if (__prev == 0) | ||||||
| @@ -1321,7 +1375,7 @@ template <class _Tp, class _Alloc> | |||||||
| void | void | ||||||
| list<_Tp, _Alloc>::splice(const_iterator __p, list& __c, const_iterator __i) | list<_Tp, _Alloc>::splice(const_iterator __p, list& __c, const_iterator __i) | ||||||
| { | { | ||||||
|     if (__p != __i && __p != _STD::next(__i)) |     if (__p != __i && __p != _VSTD::next(__i)) | ||||||
|     { |     { | ||||||
|         __node& __f = const_cast<__node&>(*__i.__ptr_); |         __node& __f = const_cast<__node&>(*__i.__ptr_); | ||||||
|         base::__unlink_nodes(__f, __f); |         base::__unlink_nodes(__f, __f); | ||||||
| @@ -1339,7 +1393,7 @@ list<_Tp, _Alloc>::splice(const_iterator __p, list& __c, const_iterator __f, con | |||||||
|     { |     { | ||||||
|         if (this != &__c) |         if (this != &__c) | ||||||
|         { |         { | ||||||
|             size_type __s = _STD::distance(__f, __l); |             size_type __s = _VSTD::distance(__f, __l); | ||||||
|             __c.__sz() -= __s; |             __c.__sz() -= __s; | ||||||
|             base::__sz() += __s; |             base::__sz() += __s; | ||||||
|         } |         } | ||||||
| @@ -1359,7 +1413,7 @@ list<_Tp, _Alloc>::remove(const value_type& __x) | |||||||
|     { |     { | ||||||
|         if (*__i == __x) |         if (*__i == __x) | ||||||
|         { |         { | ||||||
|             iterator __j = _STD::next(__i); |             iterator __j = _VSTD::next(__i); | ||||||
|             for (; __j != __e && *__j == __x; ++__j) |             for (; __j != __e && *__j == __x; ++__j) | ||||||
|                 ; |                 ; | ||||||
|             __i = erase(__i, __j); |             __i = erase(__i, __j); | ||||||
| @@ -1378,7 +1432,7 @@ list<_Tp, _Alloc>::remove_if(_Pred __pred) | |||||||
|     { |     { | ||||||
|         if (__pred(*__i)) |         if (__pred(*__i)) | ||||||
|         { |         { | ||||||
|             iterator __j = _STD::next(__i); |             iterator __j = _VSTD::next(__i); | ||||||
|             for (; __j != __e && __pred(*__j); ++__j) |             for (; __j != __e && __pred(*__j); ++__j) | ||||||
|                 ; |                 ; | ||||||
|             __i = erase(__i, __j); |             __i = erase(__i, __j); | ||||||
| @@ -1403,7 +1457,7 @@ list<_Tp, _Alloc>::unique(_BinaryPred __binary_pred) | |||||||
| { | { | ||||||
|     for (iterator __i = begin(), __e = end(); __i != __e;) |     for (iterator __i = begin(), __e = end(); __i != __e;) | ||||||
|     { |     { | ||||||
|         iterator __j = _STD::next(__i); |         iterator __j = _VSTD::next(__i); | ||||||
|         for (; __j != __e && __binary_pred(*__i, *__j); ++__j) |         for (; __j != __e && __binary_pred(*__i, *__j); ++__j) | ||||||
|             ; |             ; | ||||||
|         if (++__i != __j) |         if (++__i != __j) | ||||||
| @@ -1435,7 +1489,7 @@ list<_Tp, _Alloc>::merge(list& __c, _Comp __comp) | |||||||
|             if (__comp(*__f2, *__f1)) |             if (__comp(*__f2, *__f1)) | ||||||
|             { |             { | ||||||
|                 size_type __ds = 1; |                 size_type __ds = 1; | ||||||
|                 iterator __m2 = _STD::next(__f2); |                 iterator __m2 = _VSTD::next(__f2); | ||||||
|                 for (; __m2 != __e2 && __comp(*__m2, *__f1); ++__m2, ++__ds) |                 for (; __m2 != __e2 && __comp(*__m2, *__f1); ++__m2, ++__ds) | ||||||
|                     ; |                     ; | ||||||
|                 base::__sz() += __ds; |                 base::__sz() += __ds; | ||||||
| @@ -1444,7 +1498,7 @@ list<_Tp, _Alloc>::merge(list& __c, _Comp __comp) | |||||||
|                 __node& __l = *__m2.__ptr_->__prev_; |                 __node& __l = *__m2.__ptr_->__prev_; | ||||||
|                 __f2 = __m2; |                 __f2 = __m2; | ||||||
|                 base::__unlink_nodes(__f, __l); |                 base::__unlink_nodes(__f, __l); | ||||||
|                 __m2 = _STD::next(__f1); |                 __m2 = _VSTD::next(__f1); | ||||||
|                 __link_nodes(*__f1.__ptr_, __f, __l); |                 __link_nodes(*__f1.__ptr_, __f, __l); | ||||||
|                 __f1 = __m2; |                 __f1 = __m2; | ||||||
|             } |             } | ||||||
| @@ -1493,12 +1547,12 @@ list<_Tp, _Alloc>::__sort(iterator __f1, iterator __e2, size_type __n, _Comp& __ | |||||||
|         return __f1; |         return __f1; | ||||||
|     } |     } | ||||||
|     size_type __n2 = __n / 2; |     size_type __n2 = __n / 2; | ||||||
|     iterator __e1 = _STD::next(__f1, __n2); |     iterator __e1 = _VSTD::next(__f1, __n2); | ||||||
|     iterator  __r = __f1 = __sort(__f1, __e1, __n2, __comp); |     iterator  __r = __f1 = __sort(__f1, __e1, __n2, __comp); | ||||||
|     iterator __f2 = __e1 = __sort(__e1, __e2, __n - __n2, __comp); |     iterator __f2 = __e1 = __sort(__e1, __e2, __n - __n2, __comp); | ||||||
|     if (__comp(*__f2, *__f1)) |     if (__comp(*__f2, *__f1)) | ||||||
|     { |     { | ||||||
|         iterator __m2 = _STD::next(__f2); |         iterator __m2 = _VSTD::next(__f2); | ||||||
|         for (; __m2 != __e2 && __comp(*__m2, *__f1); ++__m2) |         for (; __m2 != __e2 && __comp(*__m2, *__f1); ++__m2) | ||||||
|             ; |             ; | ||||||
|         __node& __f = *__f2.__ptr_; |         __node& __f = *__f2.__ptr_; | ||||||
| @@ -1506,7 +1560,7 @@ list<_Tp, _Alloc>::__sort(iterator __f1, iterator __e2, size_type __n, _Comp& __ | |||||||
|         __r = __f2; |         __r = __f2; | ||||||
|         __e1 = __f2 = __m2; |         __e1 = __f2 = __m2; | ||||||
|         base::__unlink_nodes(__f, __l); |         base::__unlink_nodes(__f, __l); | ||||||
|         __m2 = _STD::next(__f1); |         __m2 = _VSTD::next(__f1); | ||||||
|         __link_nodes(*__f1.__ptr_, __f, __l); |         __link_nodes(*__f1.__ptr_, __f, __l); | ||||||
|         __f1 = __m2; |         __f1 = __m2; | ||||||
|     } |     } | ||||||
| @@ -1516,7 +1570,7 @@ list<_Tp, _Alloc>::__sort(iterator __f1, iterator __e2, size_type __n, _Comp& __ | |||||||
|     { |     { | ||||||
|         if (__comp(*__f2, *__f1)) |         if (__comp(*__f2, *__f1)) | ||||||
|         { |         { | ||||||
|             iterator __m2 = _STD::next(__f2); |             iterator __m2 = _VSTD::next(__f2); | ||||||
|             for (; __m2 != __e2 && __comp(*__m2, *__f1); ++__m2) |             for (; __m2 != __e2 && __comp(*__m2, *__f1); ++__m2) | ||||||
|                 ; |                 ; | ||||||
|             __node& __f = *__f2.__ptr_; |             __node& __f = *__f2.__ptr_; | ||||||
| @@ -1525,7 +1579,7 @@ list<_Tp, _Alloc>::__sort(iterator __f1, iterator __e2, size_type __n, _Comp& __ | |||||||
|                 __e1 = __m2; |                 __e1 = __m2; | ||||||
|             __f2 = __m2; |             __f2 = __m2; | ||||||
|             base::__unlink_nodes(__f, __l); |             base::__unlink_nodes(__f, __l); | ||||||
|             __m2 = _STD::next(__f1); |             __m2 = _VSTD::next(__f1); | ||||||
|             __link_nodes(*__f1.__ptr_, __f, __l); |             __link_nodes(*__f1.__ptr_, __f, __l); | ||||||
|             __f1 = __m2; |             __f1 = __m2; | ||||||
|         } |         } | ||||||
| @@ -1537,14 +1591,14 @@ list<_Tp, _Alloc>::__sort(iterator __f1, iterator __e2, size_type __n, _Comp& __ | |||||||
|  |  | ||||||
| template <class _Tp, class _Alloc> | template <class _Tp, class _Alloc> | ||||||
| void | void | ||||||
| list<_Tp, _Alloc>::reverse() | list<_Tp, _Alloc>::reverse() _NOEXCEPT | ||||||
| { | { | ||||||
|     if (base::__sz() > 1) |     if (base::__sz() > 1) | ||||||
|     { |     { | ||||||
|         iterator __e = end(); |         iterator __e = end(); | ||||||
|         for (iterator __i = begin(); __i != __e; --__i) |         for (iterator __i = begin(); __i != __e; --__i) | ||||||
|             _STD::swap(__i.__ptr_->__prev_, __i.__ptr_->__next_); |             _VSTD::swap(__i.__ptr_->__prev_, __i.__ptr_->__next_); | ||||||
|         _STD::swap(__e.__ptr_->__prev_, __e.__ptr_->__next_); |         _VSTD::swap(__e.__ptr_->__prev_, __e.__ptr_->__next_); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1553,7 +1607,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| bool | bool | ||||||
| operator==(const list<_Tp, _Alloc>& __x, const list<_Tp, _Alloc>& __y) | operator==(const list<_Tp, _Alloc>& __x, const list<_Tp, _Alloc>& __y) | ||||||
| { | { | ||||||
|     return __x.size() == __y.size() && _STD::equal(__x.begin(), __x.end(), __y.begin()); |     return __x.size() == __y.size() && _VSTD::equal(__x.begin(), __x.end(), __y.begin()); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, class _Alloc> | template <class _Tp, class _Alloc> | ||||||
| @@ -1561,7 +1615,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| bool | bool | ||||||
| operator< (const list<_Tp, _Alloc>& __x, const list<_Tp, _Alloc>& __y) | operator< (const list<_Tp, _Alloc>& __x, const list<_Tp, _Alloc>& __y) | ||||||
| { | { | ||||||
|     return _STD::lexicographical_compare(__x.begin(), __x.end(), __y.begin(), __y.end()); |     return _VSTD::lexicographical_compare(__x.begin(), __x.end(), __y.begin(), __y.end()); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, class _Alloc> | template <class _Tp, class _Alloc> | ||||||
| @@ -1600,6 +1654,7 @@ template <class _Tp, class _Alloc> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| void | void | ||||||
| swap(list<_Tp, _Alloc>& __x, list<_Tp, _Alloc>& __y) | swap(list<_Tp, _Alloc>& __x, list<_Tp, _Alloc>& __y) | ||||||
|  |     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||||
| { | { | ||||||
|     __x.swap(__y); |     __x.swap(__y); | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										501
									
								
								include/locale
									
									
									
									
									
								
							
							
						
						
									
										501
									
								
								include/locale
									
									
									
									
									
								
							| @@ -36,8 +36,8 @@ public: | |||||||
|         all = collate | ctype | monetary | numeric | time | messages; |         all = collate | ctype | monetary | numeric | time | messages; | ||||||
|  |  | ||||||
|     // construct/copy/destroy: |     // construct/copy/destroy: | ||||||
|     locale() throw(); |     locale() noexcept; | ||||||
|     locale(const locale& other) throw(); |     locale(const locale& other) noexcept; | ||||||
|     explicit locale(const char* std_name); |     explicit locale(const char* std_name); | ||||||
|     explicit locale(const string& std_name); |     explicit locale(const string& std_name); | ||||||
|     locale(const locale& other, const char* std_name, category); |     locale(const locale& other, const char* std_name, category); | ||||||
| @@ -45,9 +45,9 @@ public: | |||||||
|     template <class Facet> locale(const locale& other, Facet* f); |     template <class Facet> locale(const locale& other, Facet* f); | ||||||
|     locale(const locale& other, const locale& one, category); |     locale(const locale& other, const locale& one, category); | ||||||
|  |  | ||||||
|     ~locale() throw(); // not virtual |     ~locale(); // not virtual | ||||||
|  |  | ||||||
|     const locale& operator=(const locale& other) throw(); |     const locale& operator=(const locale& other) noexcept; | ||||||
|  |  | ||||||
|     template <class Facet> locale combine(const locale& other) const; |     template <class Facet> locale combine(const locale& other) const; | ||||||
|  |  | ||||||
| @@ -65,7 +65,7 @@ public: | |||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class Facet> const Facet& use_facet(const locale&); | template <class Facet> const Facet& use_facet(const locale&); | ||||||
| template <class Facet> bool has_facet(const locale&) throw(); | template <class Facet> bool has_facet(const locale&) noexcept; | ||||||
|  |  | ||||||
| // 22.3.3, convenience interfaces: | // 22.3.3, convenience interfaces: | ||||||
| template <class charT> bool isspace (charT c, const locale& loc); | template <class charT> bool isspace (charT c, const locale& loc); | ||||||
| @@ -186,165 +186,213 @@ template <class charT> class messages_byname; | |||||||
| #endif | #endif | ||||||
| #include <cstdlib> | #include <cstdlib> | ||||||
| #include <ctime> | #include <ctime> | ||||||
|  |  | ||||||
| #ifndef _WIN32 |  | ||||||
| #include <nl_types.h> | #include <nl_types.h> | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #pragma GCC system_header | #pragma GCC system_header | ||||||
|  |  | ||||||
| _LIBCPP_BEGIN_NAMESPACE_STD | _LIBCPP_BEGIN_NAMESPACE_STD | ||||||
|  |  | ||||||
|  | #ifndef _LIBCPP_STABLE_APPLE_ABI | ||||||
|  | // Get the C locale object | ||||||
|  | locale_t __cloc(); | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | typedef _VSTD::remove_pointer<locale_t>::type __locale_struct; | ||||||
|  | typedef _VSTD::unique_ptr<__locale_struct, decltype(&freelocale)> __locale_unique_ptr; | ||||||
|  | typedef _VSTD::unique_ptr<__locale_struct, decltype(&uselocale)> __locale_raii; | ||||||
|  |  | ||||||
| // OSX has nice foo_l() functions that let you turn off use of the global | // OSX has nice foo_l() functions that let you turn off use of the global | ||||||
| // locale.  Linux, not so much.  The following functions avoid the locale when | // locale.  Linux, not so much.  The following functions avoid the locale when | ||||||
| // that's possible and otherwise do the wrong thing.  FIXME. | // that's possible and otherwise do the wrong thing.  FIXME. | ||||||
| #if __APPLE__ | #ifndef _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |  | ||||||
| template <class _Tp> | #ifdef _LIBCPP_LOCALE__L_EXTENSIONS | ||||||
|  | decltype(MB_CUR_MAX_L(_VSTD::declval<locale_t>())) | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| int | __mb_cur_max_l(locale_t __l) | ||||||
| __nolocale_sprintf(char* __restrict __str, |  | ||||||
|                    const char* __restrict __format, _Tp __v) |  | ||||||
| { | { | ||||||
|     return sprintf_l(__str, 0, __format, __v); |   return MB_CUR_MAX_L(__l); | ||||||
| } | } | ||||||
|  | #else  // _LIBCPP_LOCALE__L_EXTENSIONS | ||||||
|  | _LIBCPP_ALWAYS_INLINE inline | ||||||
|  | decltype(MB_CUR_MAX) __mb_cur_max_l(locale_t __l) | ||||||
|  | { | ||||||
|  |   __locale_raii __current(uselocale(__l), uselocale); | ||||||
|  |   return MB_CUR_MAX; | ||||||
|  | } | ||||||
|  | #endif // _LIBCPP_LOCALE__L_EXTENSIONS | ||||||
|  |  | ||||||
| template <class _Tp> | _LIBCPP_ALWAYS_INLINE inline | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | wint_t __btowc_l(int __c, locale_t __l) | ||||||
| int |  | ||||||
| __nolocale_snprintf(char* __restrict __str, size_t __size, |  | ||||||
|                     const char* __restrict __format, _Tp __v) |  | ||||||
| { | { | ||||||
|     return snprintf_l(__str, __size, 0, __format, __v); | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
| } |   return btowc_l(__c, __l); | ||||||
|  |  | ||||||
| template <class _Tp> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| int |  | ||||||
| __nolocale_snprintf(char* __restrict __str, size_t __size, |  | ||||||
|                     const char* __restrict __format, int __prec, _Tp __v) |  | ||||||
| { |  | ||||||
|     return snprintf_l(__str, __size, 0, __format, __prec, __v); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| template <class _Tp> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| int |  | ||||||
| __nolocale_asprintf(char** __ret, const char* __restrict __format, _Tp __v) |  | ||||||
| { |  | ||||||
|     return asprintf_l(__ret, 0, __format, __v); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| template <class _Tp> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| int |  | ||||||
| __nolocale_asprintf(char** __ret, const char* __restrict __format, int __prec, |  | ||||||
|                                                                         _Tp __v) |  | ||||||
| { |  | ||||||
|     return asprintf_l(__ret, 0, __format, __prec, __v); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| template <class _Tp> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| int |  | ||||||
| __nolocale_sscanf(const char* __restrict __str, |  | ||||||
|                   const char* __restrict __format, _Tp* __v) |  | ||||||
| { |  | ||||||
|     return sscanf_l(__str, 0, __format, __v); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| int |  | ||||||
| __nolocale_isxdigit(int __c) |  | ||||||
| { |  | ||||||
|     return isxdigit_l(__c, 0); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| int |  | ||||||
| __nolocale_isdigit(int __c) |  | ||||||
| { |  | ||||||
|     return isdigit_l(__c, 0); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #else  // __APPLE__ |  | ||||||
| inline |  | ||||||
| #ifndef _LIBCPP_HAS_NO_ALWAYS_INLINE_VARIADICS |  | ||||||
| _LIBCPP_INLINE_VISIBILITY |  | ||||||
| #endif |  | ||||||
| int |  | ||||||
| __nolocale_sprintf(char* __restrict __str, |  | ||||||
|                    const char* __restrict __format, ...) |  | ||||||
| { |  | ||||||
|     va_list __ap; |  | ||||||
|     va_start(__ap, __format); |  | ||||||
|     int __result = vsprintf(__str, __format, __ap); |  | ||||||
|     va_end(__ap); |  | ||||||
|     return __result; |  | ||||||
| } |  | ||||||
| inline |  | ||||||
| #ifndef _LIBCPP_HAS_NO_ALWAYS_INLINE_VARIADICS |  | ||||||
| _LIBCPP_INLINE_VISIBILITY |  | ||||||
| #endif |  | ||||||
| int |  | ||||||
| __nolocale_snprintf(char* __restrict __str, size_t __size, |  | ||||||
|                     const char* __restrict __format, ...) |  | ||||||
| { |  | ||||||
|     va_list __ap; |  | ||||||
|     va_start(__ap, __format); |  | ||||||
|     int __result = vsnprintf(__str, __size, __format, __ap); |  | ||||||
|     va_end(__ap); |  | ||||||
|     return __result; |  | ||||||
| } |  | ||||||
| inline |  | ||||||
| #ifndef _LIBCPP_HAS_NO_ALWAYS_INLINE_VARIADICS |  | ||||||
| _LIBCPP_INLINE_VISIBILITY |  | ||||||
| #endif |  | ||||||
| int |  | ||||||
| __nolocale_asprintf(char** __ret, |  | ||||||
|                     const char* __restrict __format, ...) |  | ||||||
| { |  | ||||||
|     va_list __ap; |  | ||||||
|     va_start(__ap, __format); |  | ||||||
| 	int __result; |  | ||||||
| #ifdef _WIN32 |  | ||||||
| 	*__ret = (char*)malloc(4096); |  | ||||||
| 	__result = vsprintf(*__ret, __format, __ap); |  | ||||||
| 	*__ret = (char*)realloc(*__ret, __result + 1); |  | ||||||
| #else | #else | ||||||
| 	__result = vasprintf(__ret, __format, __ap); |   __locale_raii __current(uselocale(__l), uselocale); | ||||||
|  |   return btowc(__c); | ||||||
| #endif | #endif | ||||||
|     va_end(__ap); |  | ||||||
|     return __result; |  | ||||||
| } |  | ||||||
| inline |  | ||||||
| #ifndef _LIBCPP_HAS_NO_ALWAYS_INLINE_VARIADICS |  | ||||||
| _LIBCPP_INLINE_VISIBILITY |  | ||||||
| #endif |  | ||||||
| int |  | ||||||
| __nolocale_sscanf(const char* __restrict __str, |  | ||||||
|                   const char* __restrict __format, ...) |  | ||||||
| { |  | ||||||
|     va_list __ap; |  | ||||||
|     va_start(__ap, __format); |  | ||||||
|     int __result = vsscanf(__str, __format, __ap); |  | ||||||
|     va_end(__ap); |  | ||||||
|     return __result; |  | ||||||
| } |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| int |  | ||||||
| __nolocale_isxdigit(int __c) |  | ||||||
| { |  | ||||||
|     return isxdigit(__c); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | _LIBCPP_ALWAYS_INLINE inline | ||||||
| int | int __wctob_l(wint_t __c, locale_t __l) | ||||||
| __nolocale_isdigit(int __c) |  | ||||||
| { | { | ||||||
|     return isdigit(__c); | #ifdef _LIBCPP_LOCALE__L_EXTENSIONS | ||||||
|  |   return wctob_l(__c, __l); | ||||||
|  | #else | ||||||
|  |   __locale_raii __current(uselocale(__l), uselocale); | ||||||
|  |   return wctob(__c); | ||||||
|  | #endif | ||||||
| } | } | ||||||
| #endif  // __APPLE__ |  | ||||||
|  | _LIBCPP_ALWAYS_INLINE inline | ||||||
|  | size_t __wcsnrtombs_l(char *__dest, const wchar_t **__src, size_t __nwc, | ||||||
|  |                       size_t __len, mbstate_t *__ps, locale_t __l) | ||||||
|  | { | ||||||
|  | #ifdef _LIBCPP_LOCALE__L_EXTENSIONS | ||||||
|  |   return wcsnrtombs_l(__dest, __src, __nwc, __len, __ps, __l); | ||||||
|  | #else | ||||||
|  |   __locale_raii __current(uselocale(__l), uselocale); | ||||||
|  |   return wcsnrtombs(__dest, __src, __nwc, __len, __ps); | ||||||
|  | #endif | ||||||
|  | } | ||||||
|  |  | ||||||
|  | _LIBCPP_ALWAYS_INLINE inline | ||||||
|  | size_t __wcrtomb_l(char *__s, wchar_t __wc, mbstate_t *__ps, locale_t __l) | ||||||
|  | { | ||||||
|  | #ifdef _LIBCPP_LOCALE__L_EXTENSIONS | ||||||
|  |   return wcrtomb_l(__s, __wc, __ps, __l); | ||||||
|  | #else | ||||||
|  |   __locale_raii __current(uselocale(__l), uselocale); | ||||||
|  |   return wcrtomb(__s, __wc, __ps); | ||||||
|  | #endif | ||||||
|  | } | ||||||
|  |  | ||||||
|  | _LIBCPP_ALWAYS_INLINE inline | ||||||
|  | size_t __mbsnrtowcs_l(wchar_t * __dest, const char **__src, size_t __nms, | ||||||
|  |                       size_t __len, mbstate_t *__ps, locale_t __l) | ||||||
|  | { | ||||||
|  | #ifdef _LIBCPP_LOCALE__L_EXTENSIONS | ||||||
|  |   return mbsnrtowcs_l(__dest, __src, __nms__len, __ps, __l); | ||||||
|  | #else | ||||||
|  |   __locale_raii __current(uselocale(__l), uselocale); | ||||||
|  |   return mbsnrtowcs(__dest, __src, __nms, __len, __ps); | ||||||
|  | #endif | ||||||
|  | } | ||||||
|  |  | ||||||
|  | _LIBCPP_ALWAYS_INLINE inline | ||||||
|  | size_t __mbrtowc_l(wchar_t *__pwc, const char *__s, size_t __n, | ||||||
|  |                    mbstate_t *__ps, locale_t __l) | ||||||
|  | { | ||||||
|  | #ifdef _LIBCPP_LOCALE__L_EXTENSIONS | ||||||
|  |   return mbrtowc_l(__pwc, __s, __n, __ps, __l); | ||||||
|  | #else | ||||||
|  |   __locale_raii __current(uselocale(__l), uselocale); | ||||||
|  |   return mbrtowc(__pwc, __s, __n, __ps); | ||||||
|  | #endif | ||||||
|  | } | ||||||
|  |  | ||||||
|  | _LIBCPP_ALWAYS_INLINE inline | ||||||
|  | int __mbtowc_l(wchar_t *__pwc, const char *__pmb, size_t __max, locale_t __l) | ||||||
|  | { | ||||||
|  | #ifdef _LIBCPP_LOCALE__L_EXTENSIONS | ||||||
|  |   return mbtowc(__pwc, __pmb, __max, __l); | ||||||
|  | #else | ||||||
|  |   __locale_raii __current(uselocale(__l), uselocale); | ||||||
|  |   return mbtowc(__pwc, __pmb, __max); | ||||||
|  | #endif | ||||||
|  | } | ||||||
|  |  | ||||||
|  | _LIBCPP_ALWAYS_INLINE inline | ||||||
|  | size_t __mbrlen_l(const char *__s, size_t __n, mbstate_t *__ps, locale_t __l) | ||||||
|  | { | ||||||
|  | #ifdef _LIBCPP_LOCALE__L_EXTENSIONS | ||||||
|  |   return mbrlen_l(__s, __n, __ps, __l); | ||||||
|  | #else | ||||||
|  |   __locale_raii __current(uselocale(__l), uselocale); | ||||||
|  |   return mbrlen(__s, __n, __ps); | ||||||
|  | #endif | ||||||
|  | } | ||||||
|  |  | ||||||
|  | _LIBCPP_ALWAYS_INLINE inline | ||||||
|  | lconv *__localeconv_l(locale_t __l) | ||||||
|  | { | ||||||
|  | #ifdef _LIBCPP_LOCALE__L_EXTENSIONS | ||||||
|  |   return localeconv_l(__l); | ||||||
|  | #else | ||||||
|  |   __locale_raii __current(uselocale(__l), uselocale); | ||||||
|  |   return localeconv(); | ||||||
|  | #endif | ||||||
|  | } | ||||||
|  |  | ||||||
|  | _LIBCPP_ALWAYS_INLINE inline | ||||||
|  | size_t __mbsrtowcs_l(wchar_t *__dest, const char **__src, size_t __len, | ||||||
|  |                      mbstate_t *__ps, locale_t __l) | ||||||
|  | { | ||||||
|  | #ifdef _LIBCPP_LOCALE__L_EXTENSIONS | ||||||
|  |   return mbsrtowcs_l(__dest, __src, __len, __ps, __l); | ||||||
|  | #else | ||||||
|  |   __locale_raii __current(uselocale(__l), uselocale); | ||||||
|  |   return mbsrtowcs(__dest, __src, __len, __ps); | ||||||
|  | #endif | ||||||
|  | } | ||||||
|  |  | ||||||
|  | _LIBCPP_ALWAYS_INLINE inline | ||||||
|  | int __sprintf_l(char *__s, locale_t __l, const char *__format, ...) { | ||||||
|  |   va_list __va; | ||||||
|  |   va_start(__va, __format); | ||||||
|  | #ifdef _LIBCPP_LOCALE__L_EXTENSIONS | ||||||
|  |   int __res = vsprintf_l(__s, __l, __format, __va); | ||||||
|  | #else | ||||||
|  |   __locale_raii __current(uselocale(__l), uselocale); | ||||||
|  |   int __res = vsprintf(__s, __format, __va); | ||||||
|  | #endif | ||||||
|  |   va_end(__va); | ||||||
|  |   return __res; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | _LIBCPP_ALWAYS_INLINE inline | ||||||
|  | int __snprintf_l(char *__s, size_t __n, locale_t __l, const char *__format, ...) { | ||||||
|  |   va_list __va; | ||||||
|  |   va_start(__va, __format); | ||||||
|  | #ifdef _LIBCPP_LOCALE__L_EXTENSIONS | ||||||
|  |   int __res = vsnprintf_l(__s, __n, __l, __format, __va); | ||||||
|  | #else | ||||||
|  |   __locale_raii __current(uselocale(__l), uselocale); | ||||||
|  |   int __res = vsnprintf(__s, __n, __format, __va); | ||||||
|  | #endif | ||||||
|  |   va_end(__va); | ||||||
|  |   return __res; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | _LIBCPP_ALWAYS_INLINE inline | ||||||
|  | int __asprintf_l(char **__s, locale_t __l, const char *__format, ...) { | ||||||
|  |   va_list __va; | ||||||
|  |   va_start(__va, __format); | ||||||
|  | #ifdef _LIBCPP_LOCALE__L_EXTENSIONS | ||||||
|  |   int __res = vasprintf_l(__s, __l, __format, __va); | ||||||
|  | #else | ||||||
|  |   __locale_raii __current(uselocale(__l), uselocale); | ||||||
|  |   int __res = vasprintf(__s, __format, __va); | ||||||
|  | #endif | ||||||
|  |   va_end(__va); | ||||||
|  |   return __res; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | _LIBCPP_ALWAYS_INLINE inline | ||||||
|  | int __sscanf_l(const char *__s, locale_t __l, const char *__format, ...) { | ||||||
|  |   va_list __va; | ||||||
|  |   va_start(__va, __format); | ||||||
|  | #ifdef _LIBCPP_LOCALE__L_EXTENSIONS | ||||||
|  |   int __res = vsscanf_l(__s, __l, __format, __va); | ||||||
|  | #else | ||||||
|  |   __locale_raii __current(uselocale(__l), uselocale); | ||||||
|  |   int __res = vsscanf(__s, __format, __va); | ||||||
|  | #endif | ||||||
|  |   va_end(__va); | ||||||
|  |   return __res; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif  // _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |  | ||||||
| // __scan_keyword | // __scan_keyword | ||||||
| // Scans [__b, __e) until a match is found in the basic_strings range | // Scans [__b, __e) until a match is found in the basic_strings range | ||||||
| @@ -373,7 +421,7 @@ __scan_keyword(_InputIterator& __b, _InputIterator __e, | |||||||
|                bool __case_sensitive = true) |                bool __case_sensitive = true) | ||||||
| { | { | ||||||
|     typedef typename iterator_traits<_InputIterator>::value_type _CharT; |     typedef typename iterator_traits<_InputIterator>::value_type _CharT; | ||||||
|     size_t __nkw = _STD::distance(__kb, __ke); |     size_t __nkw = _VSTD::distance(__kb, __ke); | ||||||
|     const unsigned char __doesnt_match = '\0'; |     const unsigned char __doesnt_match = '\0'; | ||||||
|     const unsigned char __might_match = '\1'; |     const unsigned char __might_match = '\1'; | ||||||
|     const unsigned char __does_match = '\2'; |     const unsigned char __does_match = '\2'; | ||||||
| @@ -758,11 +806,10 @@ __num_get_signed_integral(const char* __a, const char* __a_end, | |||||||
|         int __save_errno = errno; |         int __save_errno = errno; | ||||||
|         errno = 0; |         errno = 0; | ||||||
|         char *__p2; |         char *__p2; | ||||||
|         long long __ll; | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
| #ifdef _WIN32 |         long long __ll = strtoll_l(__a, &__p2, __base, 0); | ||||||
|         __ll = _strtoi64_l(__a, &__p2, __base, 0); |  | ||||||
| #else | #else | ||||||
|         __ll = strtoll_l(__a, &__p2, __base, 0); |         long long __ll = strtoll_l(__a, &__p2, __base, __cloc()); | ||||||
| #endif | #endif | ||||||
|         int __current_errno = errno; |         int __current_errno = errno; | ||||||
|         if (__current_errno == 0) |         if (__current_errno == 0) | ||||||
| @@ -803,11 +850,10 @@ __num_get_unsigned_integral(const char* __a, const char* __a_end, | |||||||
|         int __save_errno = errno; |         int __save_errno = errno; | ||||||
|         errno = 0; |         errno = 0; | ||||||
|         char *__p2; |         char *__p2; | ||||||
|         unsigned long long __ll; | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
| #ifdef _WIN32 |         unsigned long long __ll = strtoull_l(__a, &__p2, __base, 0); | ||||||
|         __ll = _strtoui64_l(__a, &__p2, __base, 0); |  | ||||||
| #else | #else | ||||||
|         __ll = strtoull_l(__a, &__p2, __base, 0); |         unsigned long long __ll = strtoull_l(__a, &__p2, __base, __cloc()); | ||||||
| #endif | #endif | ||||||
|         int __current_errno = errno; |         int __current_errno = errno; | ||||||
|         if (__current_errno == 0) |         if (__current_errno == 0) | ||||||
| @@ -836,12 +882,10 @@ __num_get_float(const char* __a, const char* __a_end, ios_base::iostate& __err) | |||||||
|     if (__a != __a_end) |     if (__a != __a_end) | ||||||
|     { |     { | ||||||
|         char *__p2; |         char *__p2; | ||||||
|         long double __ld; | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
| #ifdef _WIN32 |         long double __ld = strtold_l(__a, &__p2, 0); | ||||||
|         // Win32 does not use "long double". |  | ||||||
|         __ld = _strtod_l(__a, &__p2, 0); |  | ||||||
| #else | #else | ||||||
|         __ld = strtold_l(__a, &__p2, 0); |         long double __ld = strtold_l(__a, &__p2, __cloc()); | ||||||
| #endif | #endif | ||||||
|         if (__p2 != __a_end) |         if (__p2 != __a_end) | ||||||
|         { |         { | ||||||
| @@ -1247,7 +1291,11 @@ num_get<_CharT, _InputIterator>::do_get(iter_type __b, iter_type __e, | |||||||
|             break; |             break; | ||||||
|     // Stage 3 |     // Stage 3 | ||||||
|     __a[sizeof(__a)-1] = 0; |     __a[sizeof(__a)-1] = 0; | ||||||
|     if (__nolocale_sscanf(__a, "%p", &__v) != 1) | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |     if (sscanf_l(__a, 0, "%p", &__v) != 1) | ||||||
|  | #else | ||||||
|  |     if (__sscanf_l(__a, __cloc(), "%p", &__v) != 1) | ||||||
|  | #endif | ||||||
|         __err = ios_base::failbit; |         __err = ios_base::failbit; | ||||||
|     // EOF checked |     // EOF checked | ||||||
|     if (__b == __e) |     if (__b == __e) | ||||||
| @@ -1352,13 +1400,21 @@ __num_put<_CharT>::__widen_and_group_float(char* __nb, char* __np, char* __ne, | |||||||
|         *__oe++ = __ct.widen(*__nf++); |         *__oe++ = __ct.widen(*__nf++); | ||||||
|         *__oe++ = __ct.widen(*__nf++); |         *__oe++ = __ct.widen(*__nf++); | ||||||
|         for (__ns = __nf; __ns < __ne; ++__ns) |         for (__ns = __nf; __ns < __ne; ++__ns) | ||||||
|             if (!__nolocale_isxdigit(*__ns)) | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |             if (!isxdigit_l(*__ns, 0)) | ||||||
|  | #else | ||||||
|  |             if (!isxdigit_l(*__ns, __cloc())) | ||||||
|  | #endif | ||||||
|                 break; |                 break; | ||||||
|     } |     } | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
|         for (__ns = __nf; __ns < __ne; ++__ns) |         for (__ns = __nf; __ns < __ne; ++__ns) | ||||||
|             if (!__nolocale_isdigit(*__ns)) | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |             if (!isdigit_l(*__ns, 0)) | ||||||
|  | #else | ||||||
|  |             if (!isdigit_l(*__ns, __cloc())) | ||||||
|  | #endif | ||||||
|                 break; |                 break; | ||||||
|     } |     } | ||||||
|     if (__grouping.empty()) |     if (__grouping.empty()) | ||||||
| @@ -1556,7 +1612,11 @@ num_put<_CharT, _OutputIterator>::do_put(iter_type __s, ios_base& __iob, | |||||||
|                           + ((numeric_limits<long>::digits % 3) != 0) |                           + ((numeric_limits<long>::digits % 3) != 0) | ||||||
|                           + 1; |                           + 1; | ||||||
|     char __nar[__nbuf]; |     char __nar[__nbuf]; | ||||||
|     int __nc = __nolocale_sprintf(__nar, __fmt, __v); | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |     int __nc = sprintf_l(__nar, 0, __fmt, __v); | ||||||
|  | #else | ||||||
|  |     int __nc = __sprintf_l(__nar, __cloc(), __fmt, __v); | ||||||
|  | #endif | ||||||
|     char* __ne = __nar + __nc; |     char* __ne = __nar + __nc; | ||||||
|     char* __np = this->__identify_padding(__nar, __ne, __iob); |     char* __np = this->__identify_padding(__nar, __ne, __iob); | ||||||
|     // Stage 2 - Widen __nar while adding thousands separators |     // Stage 2 - Widen __nar while adding thousands separators | ||||||
| @@ -1582,7 +1642,11 @@ num_put<_CharT, _OutputIterator>::do_put(iter_type __s, ios_base& __iob, | |||||||
|                           + ((numeric_limits<long long>::digits % 3) != 0) |                           + ((numeric_limits<long long>::digits % 3) != 0) | ||||||
|                           + 1; |                           + 1; | ||||||
|     char __nar[__nbuf]; |     char __nar[__nbuf]; | ||||||
|     int __nc = __nolocale_sprintf(__nar, __fmt, __v); | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |     int __nc = sprintf_l(__nar, 0, __fmt, __v); | ||||||
|  | #else | ||||||
|  |     int __nc = __sprintf_l(__nar, __cloc(), __fmt, __v); | ||||||
|  | #endif | ||||||
|     char* __ne = __nar + __nc; |     char* __ne = __nar + __nc; | ||||||
|     char* __np = this->__identify_padding(__nar, __ne, __iob); |     char* __np = this->__identify_padding(__nar, __ne, __iob); | ||||||
|     // Stage 2 - Widen __nar while adding thousands separators |     // Stage 2 - Widen __nar while adding thousands separators | ||||||
| @@ -1608,7 +1672,11 @@ num_put<_CharT, _OutputIterator>::do_put(iter_type __s, ios_base& __iob, | |||||||
|                           + ((numeric_limits<unsigned long>::digits % 3) != 0) |                           + ((numeric_limits<unsigned long>::digits % 3) != 0) | ||||||
|                           + 1; |                           + 1; | ||||||
|     char __nar[__nbuf]; |     char __nar[__nbuf]; | ||||||
|     int __nc = __nolocale_sprintf(__nar, __fmt, __v); | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |     int __nc = sprintf_l(__nar, 0, __fmt, __v); | ||||||
|  | #else | ||||||
|  |     int __nc = __sprintf_l(__nar, __cloc(), __fmt, __v); | ||||||
|  | #endif | ||||||
|     char* __ne = __nar + __nc; |     char* __ne = __nar + __nc; | ||||||
|     char* __np = this->__identify_padding(__nar, __ne, __iob); |     char* __np = this->__identify_padding(__nar, __ne, __iob); | ||||||
|     // Stage 2 - Widen __nar while adding thousands separators |     // Stage 2 - Widen __nar while adding thousands separators | ||||||
| @@ -1634,7 +1702,11 @@ num_put<_CharT, _OutputIterator>::do_put(iter_type __s, ios_base& __iob, | |||||||
|                           + ((numeric_limits<unsigned long long>::digits % 3) != 0) |                           + ((numeric_limits<unsigned long long>::digits % 3) != 0) | ||||||
|                           + 1; |                           + 1; | ||||||
|     char __nar[__nbuf]; |     char __nar[__nbuf]; | ||||||
|     int __nc = __nolocale_sprintf(__nar, __fmt, __v); | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |     int __nc = sprintf_l(__nar, 0, __fmt, __v); | ||||||
|  | #else | ||||||
|  |     int __nc = __sprintf_l(__nar, __cloc(), __fmt, __v); | ||||||
|  | #endif | ||||||
|     char* __ne = __nar + __nc; |     char* __ne = __nar + __nc; | ||||||
|     char* __np = this->__identify_padding(__nar, __ne, __iob); |     char* __np = this->__identify_padding(__nar, __ne, __iob); | ||||||
|     // Stage 2 - Widen __nar while adding thousands separators |     // Stage 2 - Widen __nar while adding thousands separators | ||||||
| @@ -1661,18 +1733,35 @@ num_put<_CharT, _OutputIterator>::do_put(iter_type __s, ios_base& __iob, | |||||||
|     char* __nb = __nar; |     char* __nb = __nar; | ||||||
|     int __nc; |     int __nc; | ||||||
|     if (__specify_precision) |     if (__specify_precision) | ||||||
|         __nc = __nolocale_snprintf(__nb, __nbuf, __fmt, | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |         __nc = snprintf_l(__nb, __nbuf, 0, __fmt, | ||||||
|                                    (int)__iob.precision(), __v); |                                    (int)__iob.precision(), __v); | ||||||
|  | #else | ||||||
|  |         __nc = __snprintf_l(__nb, __nbuf, __cloc(), __fmt, | ||||||
|  |                             (int)__iob.precision(), __v); | ||||||
|  | #endif | ||||||
|     else |     else | ||||||
|         __nc = __nolocale_snprintf(__nb, __nbuf, __fmt, __v); | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |         __nc = snprintf_l(__nb, __nbuf, 0, __fmt, __v); | ||||||
|  | #else | ||||||
|  |         __nc = __snprintf_l(__nb, __nbuf, __cloc(), __fmt, __v); | ||||||
|  | #endif | ||||||
|     unique_ptr<char, void(*)(void*)> __nbh(0, free); |     unique_ptr<char, void(*)(void*)> __nbh(0, free); | ||||||
|     if (__nc > static_cast<int>(__nbuf-1)) |     if (__nc > static_cast<int>(__nbuf-1)) | ||||||
|     { |     { | ||||||
|         if (__specify_precision) |         if (__specify_precision) | ||||||
|             __nc = __nolocale_asprintf(&__nb, __fmt, (int)__iob.precision(), | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
|                                        __v); |             __nc = asprintf_l(&__nb, 0, __fmt, (int)__iob.precision(), __v); | ||||||
|  | #else | ||||||
|  |             __nc = __asprintf_l(&__nb, __cloc(), __fmt, | ||||||
|  |                               (int)__iob.precision()); | ||||||
|  | #endif | ||||||
|         else |         else | ||||||
|             __nc = __nolocale_asprintf(&__nb, __fmt, __v); | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |             __nc = asprintf_l(&__nb, 0, __fmt, __v); | ||||||
|  | #else | ||||||
|  |             __nc = __asprintf_l(&__nb, __cloc(), __fmt, (int)__iob.precision()); | ||||||
|  | #endif | ||||||
|         if (__nb == 0) |         if (__nb == 0) | ||||||
|             __throw_bad_alloc(); |             __throw_bad_alloc(); | ||||||
|         __nbh.reset(__nb); |         __nbh.reset(__nb); | ||||||
| @@ -1702,35 +1791,46 @@ num_put<_CharT, _OutputIterator>::do_put(iter_type __s, ios_base& __iob, | |||||||
| template <class _CharT, class _OutputIterator> | template <class _CharT, class _OutputIterator> | ||||||
| _OutputIterator | _OutputIterator | ||||||
| num_put<_CharT, _OutputIterator>::do_put(iter_type __s, ios_base& __iob, | num_put<_CharT, _OutputIterator>::do_put(iter_type __s, ios_base& __iob, | ||||||
|                                          char_type __fl, long double __lv) const |                                          char_type __fl, long double __v) const | ||||||
| { | { | ||||||
|     // Stage 1 - Get number in narrow char |     // Stage 1 - Get number in narrow char | ||||||
|     char __fmt[8] = {'%', 0}; |     char __fmt[8] = {'%', 0}; | ||||||
| #ifdef _WIN32 |  | ||||||
|     const char* __len = ""; |  | ||||||
|     double __v = __lv; |  | ||||||
| #else |  | ||||||
|     const char* __len = "L"; |     const char* __len = "L"; | ||||||
|     long double __v = __lv; |  | ||||||
| #endif |  | ||||||
|     bool __specify_precision = this->__format_float(__fmt+1, __len, __iob.flags()); |     bool __specify_precision = this->__format_float(__fmt+1, __len, __iob.flags()); | ||||||
|     const unsigned __nbuf = 30; |     const unsigned __nbuf = 30; | ||||||
|     char __nar[__nbuf]; |     char __nar[__nbuf]; | ||||||
|     char* __nb = __nar; |     char* __nb = __nar; | ||||||
|     int __nc; |     int __nc; | ||||||
|     if (__specify_precision) |     if (__specify_precision) | ||||||
|         __nc = __nolocale_snprintf(__nb, __nbuf, __fmt, | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |         __nc = snprintf_l(__nb, __nbuf, 0, __fmt, | ||||||
|                                    (int)__iob.precision(), __v); |                                    (int)__iob.precision(), __v); | ||||||
|  | #else | ||||||
|  |         __nc = __snprintf_l(__nb, __nbuf, __cloc(), __fmt, | ||||||
|  |                             (int)__iob.precision(), __v); | ||||||
|  | #endif | ||||||
|     else |     else | ||||||
|         __nc = __nolocale_snprintf(__nb, __nbuf, __fmt, __v); | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |         __nc = snprintf_l(__nb, __nbuf, 0, __fmt, __v); | ||||||
|  | #else | ||||||
|  |         __nc = __snprintf_l(__nb, __nbuf, __cloc(), __fmt, __v); | ||||||
|  | #endif | ||||||
|     unique_ptr<char, void(*)(void*)> __nbh(0, free); |     unique_ptr<char, void(*)(void*)> __nbh(0, free); | ||||||
|     if (__nc > static_cast<int>(__nbuf-1)) |     if (__nc > static_cast<int>(__nbuf-1)) | ||||||
|     { |     { | ||||||
|         if (__specify_precision) |         if (__specify_precision) | ||||||
|             __nc = __nolocale_asprintf(&__nb, __fmt, (int)__iob.precision(), | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
|                                        __v); |             __nc = asprintf_l(&__nb, 0, __fmt, (int)__iob.precision(), __v); | ||||||
|  | #else | ||||||
|  |             __nc = __asprintf_l(&__nb, __cloc(), __fmt, | ||||||
|  |                               (int)__iob.precision()); | ||||||
|  | #endif | ||||||
|         else |         else | ||||||
|             __nc = __nolocale_asprintf(&__nb, __fmt, __v); | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |             __nc = asprintf_l(&__nb, 0, __fmt, __v); | ||||||
|  | #else | ||||||
|  |             __nc = __asprintf_l(&__nb, __cloc(), __fmt, (int)__iob.precision()); | ||||||
|  | #endif | ||||||
|         if (__nb == 0) |         if (__nb == 0) | ||||||
|             __throw_bad_alloc(); |             __throw_bad_alloc(); | ||||||
|         __nbh.reset(__nb); |         __nbh.reset(__nb); | ||||||
| @@ -1766,7 +1866,11 @@ num_put<_CharT, _OutputIterator>::do_put(iter_type __s, ios_base& __iob, | |||||||
|     char __fmt[6] = "%p"; |     char __fmt[6] = "%p"; | ||||||
|     const unsigned __nbuf = 20; |     const unsigned __nbuf = 20; | ||||||
|     char __nar[__nbuf]; |     char __nar[__nbuf]; | ||||||
|     int __nc = __nolocale_sprintf(__nar, __fmt, __v); | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |     int __nc = sprintf_l(__nar, 0, __fmt, __v); | ||||||
|  | #else | ||||||
|  |     int __nc = __sprintf_l(__nar, __cloc(), __fmt, __v); | ||||||
|  | #endif | ||||||
|     char* __ne = __nar + __nc; |     char* __ne = __nar + __nc; | ||||||
|     char* __np = this->__identify_padding(__nar, __ne, __iob); |     char* __np = this->__identify_padding(__nar, __ne, __iob); | ||||||
|     // Stage 2 - Widen __nar |     // Stage 2 - Widen __nar | ||||||
| @@ -2543,7 +2647,11 @@ class __time_put | |||||||
| { | { | ||||||
|     locale_t __loc_; |     locale_t __loc_; | ||||||
| protected: | protected: | ||||||
|  | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
|     _LIBCPP_ALWAYS_INLINE __time_put() : __loc_(0) {} |     _LIBCPP_ALWAYS_INLINE __time_put() : __loc_(0) {} | ||||||
|  | #else   // _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |     _LIBCPP_ALWAYS_INLINE __time_put() : __loc_(__cloc()) {} | ||||||
|  | #endif  // _LIBCPP_STABLE_APPLE_ABI | ||||||
|     __time_put(const char* __nm); |     __time_put(const char* __nm); | ||||||
|     __time_put(const string& __nm); |     __time_put(const string& __nm); | ||||||
|     ~__time_put(); |     ~__time_put(); | ||||||
| @@ -2646,7 +2754,7 @@ time_put<_CharT, _OutputIterator>::do_put(iter_type __s, ios_base& __iob, | |||||||
|     char_type* __nb = __nar; |     char_type* __nb = __nar; | ||||||
|     char_type* __ne = __nb + 100; |     char_type* __ne = __nb + 100; | ||||||
|     __do_put(__nb, __ne, __tm, __fmt, __mod); |     __do_put(__nb, __ne, __tm, __fmt, __mod); | ||||||
|     return _STD::copy(__nb, __ne, __s); |     return _VSTD::copy(__nb, __ne, __s); | ||||||
| } | } | ||||||
|  |  | ||||||
| extern template class time_put<char>; | extern template class time_put<char>; | ||||||
| @@ -3314,7 +3422,7 @@ __money_put<_CharT>::__format(char_type* __mb, char_type*& __mi, char_type*& __m | |||||||
|             break; |             break; | ||||||
|         case money_base::symbol: |         case money_base::symbol: | ||||||
|             if (!__sym.empty() && (__flags & ios_base::showbase)) |             if (!__sym.empty() && (__flags & ios_base::showbase)) | ||||||
|                 __me = _STD::copy(__sym.begin(), __sym.end(), __me); |                 __me = _VSTD::copy(__sym.begin(), __sym.end(), __me); | ||||||
|             break; |             break; | ||||||
|         case money_base::value: |         case money_base::value: | ||||||
|             { |             { | ||||||
| @@ -3373,7 +3481,7 @@ __money_put<_CharT>::__format(char_type* __mb, char_type*& __mi, char_type*& __m | |||||||
|     } |     } | ||||||
|     // print rest of sign, if any |     // print rest of sign, if any | ||||||
|     if (__sn.size() > 1) |     if (__sn.size() > 1) | ||||||
|         __me = _STD::copy(__sn.begin()+1, __sn.end(), __me); |         __me = _VSTD::copy(__sn.begin()+1, __sn.end(), __me); | ||||||
|     // set alignment |     // set alignment | ||||||
|     if ((__flags & ios_base::adjustfield) == ios_base::left) |     if ((__flags & ios_base::adjustfield) == ios_base::left) | ||||||
|         __mi = __me; |         __mi = __me; | ||||||
| @@ -3446,7 +3554,11 @@ money_put<_CharT, _OutputIterator>::do_put(iter_type __s, bool __intl, | |||||||
|     // secure memory for digit storage |     // secure memory for digit storage | ||||||
|     if (__n > __bs-1) |     if (__n > __bs-1) | ||||||
|     { |     { | ||||||
|         __n = __nolocale_asprintf(&__bb, "%.0Lf", __units); | #ifdef _LIBCPP_STABLE_APPLE_ABI | ||||||
|  |         __n = asprintf_l(&__bb, 0, "%.0Lf", __units); | ||||||
|  | #else | ||||||
|  |         __n = __asprintf_l(&__bb, __cloc(), "%.0Lf", __units); | ||||||
|  | #endif | ||||||
|         if (__bb == 0) |         if (__bb == 0) | ||||||
|             __throw_bad_alloc(); |             __throw_bad_alloc(); | ||||||
|         __hn.reset(__bb); |         __hn.reset(__bb); | ||||||
| @@ -3597,14 +3709,10 @@ template <class _CharT> | |||||||
| typename messages<_CharT>::catalog | typename messages<_CharT>::catalog | ||||||
| messages<_CharT>::do_open(const basic_string<char>& __nm, const locale&) const | messages<_CharT>::do_open(const basic_string<char>& __nm, const locale&) const | ||||||
| { | { | ||||||
| #ifdef __MINGW32__ |  | ||||||
|     return -1; |  | ||||||
| #else |  | ||||||
|     catalog __cat = reinterpret_cast<catalog>(catopen(__nm.c_str(), NL_CAT_LOCALE)); |     catalog __cat = reinterpret_cast<catalog>(catopen(__nm.c_str(), NL_CAT_LOCALE)); | ||||||
|     if (__cat != -1) |     if (__cat != -1) | ||||||
|         __cat = static_cast<catalog>((static_cast<size_t>(__cat) >> 1)); |         __cat = static_cast<catalog>((static_cast<size_t>(__cat) >> 1)); | ||||||
|     return __cat; |     return __cat; | ||||||
| #endif |  | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _CharT> | template <class _CharT> | ||||||
| @@ -3612,10 +3720,6 @@ typename messages<_CharT>::string_type | |||||||
| messages<_CharT>::do_get(catalog __c, int __set, int __msgid, | messages<_CharT>::do_get(catalog __c, int __set, int __msgid, | ||||||
|                          const string_type& __dflt) const |                          const string_type& __dflt) const | ||||||
| { | { | ||||||
| #ifdef __MINGW32__ |  | ||||||
|     string_type __w; |  | ||||||
| 	return __w; |  | ||||||
| #else |  | ||||||
|     string __ndflt; |     string __ndflt; | ||||||
|     __narrow_to_utf8<sizeof(char_type)*__CHAR_BIT__>()(back_inserter(__ndflt), |     __narrow_to_utf8<sizeof(char_type)*__CHAR_BIT__>()(back_inserter(__ndflt), | ||||||
|                                                        __dflt.c_str(), |                                                        __dflt.c_str(), | ||||||
| @@ -3628,19 +3732,16 @@ messages<_CharT>::do_get(catalog __c, int __set, int __msgid, | |||||||
|     __widen_from_utf8<sizeof(char_type)*__CHAR_BIT__>()(back_inserter(__w), |     __widen_from_utf8<sizeof(char_type)*__CHAR_BIT__>()(back_inserter(__w), | ||||||
|                                                         __n, __n + strlen(__n)); |                                                         __n, __n + strlen(__n)); | ||||||
|     return __w; |     return __w; | ||||||
| #endif |  | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _CharT> | template <class _CharT> | ||||||
| void | void | ||||||
| messages<_CharT>::do_close(catalog __c) const | messages<_CharT>::do_close(catalog __c) const | ||||||
| { | { | ||||||
| #ifndef __MINGW32__ |  | ||||||
|     if (__c != -1) |     if (__c != -1) | ||||||
|         __c <<= 1; |         __c <<= 1; | ||||||
|     nl_catd __cat = reinterpret_cast<nl_catd>(__c); |     nl_catd __cat = reinterpret_cast<nl_catd>(__c); | ||||||
|     catclose(__cat); |     catclose(__cat); | ||||||
| #endif |  | ||||||
| } | } | ||||||
|  |  | ||||||
| extern template class messages<char>; | extern template class messages<char>; | ||||||
| @@ -3759,8 +3860,8 @@ template<class _Codecvt, class _Elem, class _Wide_alloc, class _Byte_alloc> | |||||||
| inline _LIBCPP_ALWAYS_INLINE | inline _LIBCPP_ALWAYS_INLINE | ||||||
| wstring_convert<_Codecvt, _Elem, _Wide_alloc, _Byte_alloc>:: | wstring_convert<_Codecvt, _Elem, _Wide_alloc, _Byte_alloc>:: | ||||||
|     wstring_convert(wstring_convert&& __wc) |     wstring_convert(wstring_convert&& __wc) | ||||||
|         : __byte_err_string_(_STD::move(__wc.__byte_err_string_)), |         : __byte_err_string_(_VSTD::move(__wc.__byte_err_string_)), | ||||||
|           __wide_err_string_(_STD::move(__wc.__wide_err_string_)), |           __wide_err_string_(_VSTD::move(__wc.__wide_err_string_)), | ||||||
|           __cvtptr_(__wc.__cvtptr_), |           __cvtptr_(__wc.__cvtptr_), | ||||||
|           __cvtstate_(__wc.__cvtstate_), __cvtcount_(__wc.__cvtstate_) |           __cvtstate_(__wc.__cvtstate_), __cvtcount_(__wc.__cvtstate_) | ||||||
| { | { | ||||||
| @@ -4053,7 +4154,7 @@ wbuffer_convert<_Codecvt, _Elem, _Tr>::underflow() | |||||||
|             memmove(__extbuf_, __extbufnext_, __extbufend_ - __extbufnext_); |             memmove(__extbuf_, __extbufnext_, __extbufend_ - __extbufnext_); | ||||||
|             __extbufnext_ = __extbuf_ + (__extbufend_ - __extbufnext_); |             __extbufnext_ = __extbuf_ + (__extbufend_ - __extbufnext_); | ||||||
|             __extbufend_ = __extbuf_ + (__extbuf_ == __extbuf_min_ ? sizeof(__extbuf_min_) : __ebs_); |             __extbufend_ = __extbuf_ + (__extbuf_ == __extbuf_min_ ? sizeof(__extbuf_min_) : __ebs_); | ||||||
|             streamsize __nmemb = _STD::min(static_cast<streamsize>(this->egptr() - this->eback() - __unget_sz), |             streamsize __nmemb = _VSTD::min(static_cast<streamsize>(this->egptr() - this->eback() - __unget_sz), | ||||||
|                                  static_cast<streamsize>(__extbufend_ - __extbufnext_)); |                                  static_cast<streamsize>(__extbufend_ - __extbufnext_)); | ||||||
|             codecvt_base::result __r; |             codecvt_base::result __r; | ||||||
|             state_type __svs = __st_; |             state_type __svs = __st_; | ||||||
|   | |||||||
							
								
								
									
										416
									
								
								include/map
									
									
									
									
									
								
							
							
						
						
									
										416
									
								
								include/map
									
									
									
									
									
								
							| @@ -54,7 +54,11 @@ public: | |||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     // construct/copy/destroy: |     // construct/copy/destroy: | ||||||
|     map(); |     map() | ||||||
|  |         noexcept( | ||||||
|  |             is_nothrow_default_constructible<allocator_type>::value && | ||||||
|  |             is_nothrow_default_constructible<key_compare>::value && | ||||||
|  |             is_nothrow_copy_constructible<key_compare>::value); | ||||||
|     explicit map(const key_compare& comp); |     explicit map(const key_compare& comp); | ||||||
|     map(const key_compare& comp, const allocator_type& a); |     map(const key_compare& comp, const allocator_type& a); | ||||||
|     template <class InputIterator> |     template <class InputIterator> | ||||||
| @@ -64,7 +68,10 @@ public: | |||||||
|         map(InputIterator first, InputIterator last, |         map(InputIterator first, InputIterator last, | ||||||
|             const key_compare& comp, const allocator_type& a); |             const key_compare& comp, const allocator_type& a); | ||||||
|     map(const map& m); |     map(const map& m); | ||||||
|     map(map&& m); |     map(map&& m) | ||||||
|  |         noexcept( | ||||||
|  |             is_nothrow_move_constructible<allocator_type>::value && | ||||||
|  |             is_nothrow_move_constructible<key_compare>::value); | ||||||
|     explicit map(const allocator_type& a); |     explicit map(const allocator_type& a); | ||||||
|     map(const map& m, const allocator_type& a); |     map(const map& m, const allocator_type& a); | ||||||
|     map(map&& m, const allocator_type& a); |     map(map&& m, const allocator_type& a); | ||||||
| @@ -73,29 +80,33 @@ public: | |||||||
|     ~map(); |     ~map(); | ||||||
|  |  | ||||||
|     map& operator=(const map& m); |     map& operator=(const map& m); | ||||||
|     map& operator=(map&& m); |     map& operator=(map&& m) | ||||||
|  |         noexcept( | ||||||
|  |             allocator_type::propagate_on_container_move_assignment::value && | ||||||
|  |             is_nothrow_move_assignable<allocator_type>::value && | ||||||
|  |             is_nothrow_move_assignable<key_compare>::value); | ||||||
|     map& operator=(initializer_list<value_type> il); |     map& operator=(initializer_list<value_type> il); | ||||||
|  |  | ||||||
|     // iterators: |     // iterators: | ||||||
|           iterator begin(); |           iterator begin() noexcept; | ||||||
|     const_iterator begin() const; |     const_iterator begin() const noexcept; | ||||||
|           iterator end(); |           iterator end() noexcept; | ||||||
|     const_iterator end()   const; |     const_iterator end()   const noexcept; | ||||||
|  |  | ||||||
|           reverse_iterator rbegin(); |           reverse_iterator rbegin() noexcept; | ||||||
|     const_reverse_iterator rbegin() const; |     const_reverse_iterator rbegin() const noexcept; | ||||||
|           reverse_iterator rend(); |           reverse_iterator rend() noexcept; | ||||||
|     const_reverse_iterator rend()   const; |     const_reverse_iterator rend()   const noexcept; | ||||||
|  |  | ||||||
|     const_iterator         cbegin()  const; |     const_iterator         cbegin()  const noexcept; | ||||||
|     const_iterator         cend()    const; |     const_iterator         cend()    const noexcept; | ||||||
|     const_reverse_iterator crbegin() const; |     const_reverse_iterator crbegin() const noexcept; | ||||||
|     const_reverse_iterator crend()   const; |     const_reverse_iterator crend()   const noexcept; | ||||||
|  |  | ||||||
|     // capacity: |     // capacity: | ||||||
|     bool      empty()    const; |     bool      empty()    const noexcept; | ||||||
|     size_type size()     const; |     size_type size()     const noexcept; | ||||||
|     size_type max_size() const; |     size_type max_size() const noexcept; | ||||||
|  |  | ||||||
|     // element access: |     // element access: | ||||||
|     mapped_type& operator[](const key_type& k); |     mapped_type& operator[](const key_type& k); | ||||||
| @@ -122,12 +133,16 @@ public: | |||||||
|     iterator  erase(const_iterator position); |     iterator  erase(const_iterator position); | ||||||
|     size_type erase(const key_type& k); |     size_type erase(const key_type& k); | ||||||
|     iterator  erase(const_iterator first, const_iterator last); |     iterator  erase(const_iterator first, const_iterator last); | ||||||
|     void clear(); |     void clear() noexcept; | ||||||
|  |  | ||||||
|     void swap(map& m); |     void swap(map& m) | ||||||
|  |         noexcept( | ||||||
|  |             __is_nothrow_swappable<key_compare>::value && | ||||||
|  |             (!allocator_type::propagate_on_container_swap::value || | ||||||
|  |              __is_nothrow_swappable<allocator_type>::value)); | ||||||
|  |  | ||||||
|     // observers: |     // observers: | ||||||
|     allocator_type get_allocator() const; |     allocator_type get_allocator() const noexcept; | ||||||
|     key_compare    key_comp()      const; |     key_compare    key_comp()      const; | ||||||
|     value_compare  value_comp()    const; |     value_compare  value_comp()    const; | ||||||
|  |  | ||||||
| @@ -176,7 +191,8 @@ operator<=(const map<Key, T, Compare, Allocator>& x, | |||||||
| // specialized algorithms: | // specialized algorithms: | ||||||
| template <class Key, class T, class Compare, class Allocator> | template <class Key, class T, class Compare, class Allocator> | ||||||
| void | void | ||||||
| swap(map<Key, T, Compare, Allocator>& x, map<Key, T, Compare, Allocator>& y); | swap(map<Key, T, Compare, Allocator>& x, map<Key, T, Compare, Allocator>& y) | ||||||
|  |     noexcept(noexcept(x.swap(y))); | ||||||
|  |  | ||||||
| template <class Key, class T, class Compare = less<Key>, | template <class Key, class T, class Compare = less<Key>, | ||||||
|           class Allocator = allocator<pair<const Key, T>>> |           class Allocator = allocator<pair<const Key, T>>> | ||||||
| @@ -213,7 +229,12 @@ public: | |||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     // construct/copy/destroy: |     // construct/copy/destroy: | ||||||
|     explicit multimap(const key_compare& comp = key_compare()); |     multimap() | ||||||
|  |         noexcept( | ||||||
|  |             is_nothrow_default_constructible<allocator_type>::value && | ||||||
|  |             is_nothrow_default_constructible<key_compare>::value && | ||||||
|  |             is_nothrow_copy_constructible<key_compare>::value); | ||||||
|  |     explicit multimap(const key_compare& comp); | ||||||
|     multimap(const key_compare& comp, const allocator_type& a); |     multimap(const key_compare& comp, const allocator_type& a); | ||||||
|     template <class InputIterator> |     template <class InputIterator> | ||||||
|         multimap(InputIterator first, InputIterator last, const key_compare& comp); |         multimap(InputIterator first, InputIterator last, const key_compare& comp); | ||||||
| @@ -221,7 +242,10 @@ public: | |||||||
|         multimap(InputIterator first, InputIterator last, const key_compare& comp, |         multimap(InputIterator first, InputIterator last, const key_compare& comp, | ||||||
|                  const allocator_type& a); |                  const allocator_type& a); | ||||||
|     multimap(const multimap& m); |     multimap(const multimap& m); | ||||||
|     multimap(multimap&& m); |     multimap(multimap&& m) | ||||||
|  |         noexcept( | ||||||
|  |             is_nothrow_move_constructible<allocator_type>::value && | ||||||
|  |             is_nothrow_move_constructible<key_compare>::value); | ||||||
|     explicit multimap(const allocator_type& a); |     explicit multimap(const allocator_type& a); | ||||||
|     multimap(const multimap& m, const allocator_type& a); |     multimap(const multimap& m, const allocator_type& a); | ||||||
|     multimap(multimap&& m, const allocator_type& a); |     multimap(multimap&& m, const allocator_type& a); | ||||||
| @@ -231,29 +255,33 @@ public: | |||||||
|     ~multimap(); |     ~multimap(); | ||||||
|  |  | ||||||
|     multimap& operator=(const multimap& m); |     multimap& operator=(const multimap& m); | ||||||
|     multimap& operator=(multimap&& m); |     multimap& operator=(multimap&& m) | ||||||
|  |         noexcept( | ||||||
|  |             allocator_type::propagate_on_container_move_assignment::value && | ||||||
|  |             is_nothrow_move_assignable<allocator_type>::value && | ||||||
|  |             is_nothrow_move_assignable<key_compare>::value); | ||||||
|     multimap& operator=(initializer_list<value_type> il); |     multimap& operator=(initializer_list<value_type> il); | ||||||
|  |  | ||||||
|     // iterators: |     // iterators: | ||||||
|           iterator begin(); |           iterator begin() noexcept; | ||||||
|     const_iterator begin() const; |     const_iterator begin() const noexcept; | ||||||
|           iterator end(); |           iterator end() noexcept; | ||||||
|     const_iterator end()   const; |     const_iterator end()   const noexcept; | ||||||
|  |  | ||||||
|           reverse_iterator rbegin(); |           reverse_iterator rbegin() noexcept; | ||||||
|     const_reverse_iterator rbegin() const; |     const_reverse_iterator rbegin() const noexcept; | ||||||
|           reverse_iterator rend(); |           reverse_iterator rend() noexcept; | ||||||
|     const_reverse_iterator rend()   const; |     const_reverse_iterator rend()   const noexcept; | ||||||
|  |  | ||||||
|     const_iterator         cbegin()  const; |     const_iterator         cbegin()  const noexcept; | ||||||
|     const_iterator         cend()    const; |     const_iterator         cend()    const noexcept; | ||||||
|     const_reverse_iterator crbegin() const; |     const_reverse_iterator crbegin() const noexcept; | ||||||
|     const_reverse_iterator crend()   const; |     const_reverse_iterator crend()   const noexcept; | ||||||
|  |  | ||||||
|     // capacity: |     // capacity: | ||||||
|     bool      empty()    const; |     bool      empty()    const noexcept; | ||||||
|     size_type size()     const; |     size_type size()     const noexcept; | ||||||
|     size_type max_size() const; |     size_type max_size() const noexcept; | ||||||
|  |  | ||||||
|     // modifiers: |     // modifiers: | ||||||
|     template <class... Args> |     template <class... Args> | ||||||
| @@ -273,12 +301,16 @@ public: | |||||||
|     iterator  erase(const_iterator position); |     iterator  erase(const_iterator position); | ||||||
|     size_type erase(const key_type& k); |     size_type erase(const key_type& k); | ||||||
|     iterator  erase(const_iterator first, const_iterator last); |     iterator  erase(const_iterator first, const_iterator last); | ||||||
|     void clear(); |     void clear() noexcept; | ||||||
|  |  | ||||||
|     void swap(multimap& m); |     void swap(multimap& m) | ||||||
|  |         noexcept( | ||||||
|  |             __is_nothrow_swappable<key_compare>::value && | ||||||
|  |             (!allocator_type::propagate_on_container_swap::value || | ||||||
|  |              __is_nothrow_swappable<allocator_type>::value)); | ||||||
|  |  | ||||||
|     // observers: |     // observers: | ||||||
|     allocator_type get_allocator() const; |     allocator_type get_allocator() const noexcept; | ||||||
|     key_compare    key_comp()      const; |     key_compare    key_comp()      const; | ||||||
|     value_compare  value_comp()    const; |     value_compare  value_comp()    const; | ||||||
|  |  | ||||||
| @@ -328,7 +360,8 @@ operator<=(const multimap<Key, T, Compare, Allocator>& x, | |||||||
| template <class Key, class T, class Compare, class Allocator> | template <class Key, class T, class Compare, class Allocator> | ||||||
| void | void | ||||||
| swap(multimap<Key, T, Compare, Allocator>& x, | swap(multimap<Key, T, Compare, Allocator>& x, | ||||||
|      multimap<Key, T, Compare, Allocator>& y); |      multimap<Key, T, Compare, Allocator>& y) | ||||||
|  |     noexcept(noexcept(x.swap(y))); | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
|  |  | ||||||
| @@ -354,11 +387,15 @@ class __map_value_compare | |||||||
|     typedef pair<const _Key, _Tp> _CP; |     typedef pair<const _Key, _Tp> _CP; | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __map_value_compare() : _Compare() {} |     __map_value_compare() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<_Compare>::value) | ||||||
|  |         : _Compare() {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __map_value_compare(_Compare c) : _Compare(c) {} |     __map_value_compare(_Compare c) | ||||||
|  |         _NOEXCEPT_(is_nothrow_copy_constructible<_Compare>::value) | ||||||
|  |         : _Compare(c) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const _Compare& key_comp() const {return *this;} |     const _Compare& key_comp() const _NOEXCEPT {return *this;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool operator()(const _CP& __x, const _CP& __y) const |     bool operator()(const _CP& __x, const _CP& __y) const | ||||||
|         {return static_cast<const _Compare&>(*this)(__x.first, __y.first);} |         {return static_cast<const _Compare&>(*this)(__x.first, __y.first);} | ||||||
| @@ -398,11 +435,15 @@ class __map_value_compare<_Key, _Tp, _Compare, false> | |||||||
|  |  | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __map_value_compare() : comp() {} |     __map_value_compare() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<_Compare>::value) | ||||||
|  |         : comp() {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __map_value_compare(_Compare c) : comp(c) {} |     __map_value_compare(_Compare c) | ||||||
|  |         _NOEXCEPT_(is_nothrow_copy_constructible<_Compare>::value) | ||||||
|  |         : comp(c) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const _Compare& key_comp() const {return comp;} |     const _Compare& key_comp() const _NOEXCEPT {return comp;} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool operator()(const _CP& __x, const _CP& __y) const |     bool operator()(const _CP& __x, const _CP& __y) const | ||||||
| @@ -454,7 +495,7 @@ public: | |||||||
|     bool __second_constructed; |     bool __second_constructed; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __map_node_destructor(allocator_type& __na) |     explicit __map_node_destructor(allocator_type& __na) _NOEXCEPT | ||||||
|         : __na_(__na), |         : __na_(__na), | ||||||
|           __first_constructed(false), |           __first_constructed(false), | ||||||
|           __second_constructed(false) |           __second_constructed(false) | ||||||
| @@ -462,7 +503,7 @@ public: | |||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __map_node_destructor(__tree_node_destructor<allocator_type>&& __x) |     __map_node_destructor(__tree_node_destructor<allocator_type>&& __x) _NOEXCEPT | ||||||
|         : __na_(__x.__na_), |         : __na_(__x.__na_), | ||||||
|           __first_constructed(__x.__value_constructed), |           __first_constructed(__x.__value_constructed), | ||||||
|           __second_constructed(__x.__value_constructed) |           __second_constructed(__x.__value_constructed) | ||||||
| @@ -472,20 +513,22 @@ public: | |||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void operator()(pointer __p) |     void operator()(pointer __p) _NOEXCEPT | ||||||
|     { |     { | ||||||
|         if (__second_constructed) |         if (__second_constructed) | ||||||
|             __alloc_traits::destroy(__na_, _STD::addressof(__p->__value_.second)); |             __alloc_traits::destroy(__na_, _VSTD::addressof(__p->__value_.second)); | ||||||
|         if (__first_constructed) |         if (__first_constructed) | ||||||
|             __alloc_traits::destroy(__na_, _STD::addressof(__p->__value_.first)); |             __alloc_traits::destroy(__na_, _VSTD::addressof(__p->__value_.first)); | ||||||
|         if (__p) |         if (__p) | ||||||
|             __alloc_traits::deallocate(__na_, __p, 1); |             __alloc_traits::deallocate(__na_, __p, 1); | ||||||
|     } |     } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class, class, class, class> class map; | template <class _Key, class _Tp, class _Compare, class _Allocator> | ||||||
| template <class, class, class, class> class multimap; |     class map; | ||||||
| template <class> class __map_const_iterator; | template <class _Key, class _Tp, class _Compare, class _Allocator> | ||||||
|  |     class multimap; | ||||||
|  | template <class _TreeIterator> class __map_const_iterator; | ||||||
|  |  | ||||||
| template <class _TreeIterator> | template <class _TreeIterator> | ||||||
| class _LIBCPP_VISIBLE __map_iterator | class _LIBCPP_VISIBLE __map_iterator | ||||||
| @@ -509,10 +552,10 @@ public: | |||||||
|                                                                  pointer; |                                                                  pointer; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __map_iterator() {} |     __map_iterator() _NOEXCEPT {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __map_iterator(_TreeIterator __i) : __i_(__i) {} |     __map_iterator(_TreeIterator __i) _NOEXCEPT : __i_(__i) {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     reference operator*() const {return *operator->();} |     reference operator*() const {return *operator->();} | ||||||
| @@ -574,13 +617,14 @@ public: | |||||||
|                                                                  pointer; |                                                                  pointer; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __map_const_iterator() {} |     __map_const_iterator() _NOEXCEPT {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __map_const_iterator(_TreeIterator __i) : __i_(__i) {} |     __map_const_iterator(_TreeIterator __i) _NOEXCEPT : __i_(__i) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __map_const_iterator( |     __map_const_iterator( | ||||||
|             __map_iterator<typename _TreeIterator::__non_const_iterator> __i) |             __map_iterator<typename _TreeIterator::__non_const_iterator> __i) | ||||||
|  |                 _NOEXCEPT | ||||||
|                 : __i_(__i.__i_) {} |                 : __i_(__i.__i_) {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -671,11 +715,15 @@ public: | |||||||
|     typedef typename __alloc_traits::difference_type       difference_type; |     typedef typename __alloc_traits::difference_type       difference_type; | ||||||
|     typedef __map_iterator<typename __base::iterator>      iterator; |     typedef __map_iterator<typename __base::iterator>      iterator; | ||||||
|     typedef __map_const_iterator<typename __base::const_iterator> const_iterator; |     typedef __map_const_iterator<typename __base::const_iterator> const_iterator; | ||||||
|     typedef _STD::reverse_iterator<iterator>               reverse_iterator; |     typedef _VSTD::reverse_iterator<iterator>               reverse_iterator; | ||||||
|     typedef _STD::reverse_iterator<const_iterator>         const_reverse_iterator; |     typedef _VSTD::reverse_iterator<const_iterator>         const_reverse_iterator; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit map(const key_compare& __comp = key_compare()) |     explicit map(const key_compare& __comp = key_compare()) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             is_nothrow_default_constructible<allocator_type>::value && | ||||||
|  |             is_nothrow_default_constructible<key_compare>::value && | ||||||
|  |             is_nothrow_copy_constructible<key_compare>::value) | ||||||
|         : __tree_(__vc(__comp)) {} |         : __tree_(__vc(__comp)) {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -707,11 +755,19 @@ public: | |||||||
|             insert(__m.begin(), __m.end()); |             insert(__m.begin(), __m.end()); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     map& operator=(const map& __m) | ||||||
|  |         { | ||||||
|  |             __tree_ = __m.__tree_; | ||||||
|  |             return *this; | ||||||
|  |         } | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     map(map&& __m) |     map(map&& __m) | ||||||
|         : __tree_(_STD::move(__m.__tree_)) |         _NOEXCEPT_(is_nothrow_move_constructible<__base>::value) | ||||||
|  |         : __tree_(_VSTD::move(__m.__tree_)) | ||||||
|         { |         { | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -733,8 +789,9 @@ public: | |||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     map& operator=(map&& __m) |     map& operator=(map&& __m) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_assignable<__base>::value) | ||||||
|         { |         { | ||||||
|             __tree_ = _STD::move(__m.__tree_); |             __tree_ = _VSTD::move(__m.__tree_); | ||||||
|             return *this; |             return *this; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -761,38 +818,41 @@ public: | |||||||
|         } |         } | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           iterator begin()       {return __tree_.begin();} |           iterator begin() _NOEXCEPT {return __tree_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator begin() const {return __tree_.begin();} |     const_iterator begin() const _NOEXCEPT {return __tree_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           iterator end()         {return __tree_.end();} |           iterator end() _NOEXCEPT {return __tree_.end();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator end()   const {return __tree_.end();} |     const_iterator end() const _NOEXCEPT {return __tree_.end();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           reverse_iterator rbegin()       {return       reverse_iterator(end());} |           reverse_iterator rbegin() _NOEXCEPT {return reverse_iterator(end());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator rbegin() const {return const_reverse_iterator(end());} |     const_reverse_iterator rbegin() const _NOEXCEPT | ||||||
|  |         {return const_reverse_iterator(end());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           reverse_iterator rend()         {return       reverse_iterator(begin());} |           reverse_iterator rend() _NOEXCEPT | ||||||
|  |             {return       reverse_iterator(begin());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator rend()   const {return const_reverse_iterator(begin());} |     const_reverse_iterator rend() const _NOEXCEPT | ||||||
|  |         {return const_reverse_iterator(begin());} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator         cbegin()  const {return begin();} |     const_iterator cbegin() const _NOEXCEPT {return begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator         cend()    const {return end();} |     const_iterator cend() const _NOEXCEPT {return end();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator crbegin() const {return rbegin();} |     const_reverse_iterator crbegin() const _NOEXCEPT {return rbegin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator crend()   const {return rend();} |     const_reverse_iterator crend() const _NOEXCEPT {return rend();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool      empty()    const {return __tree_.size() == 0;} |     bool      empty() const _NOEXCEPT {return __tree_.size() == 0;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type size()     const {return __tree_.size();} |     size_type size() const _NOEXCEPT {return __tree_.size();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type max_size() const {return __tree_.max_size();} |     size_type max_size() const _NOEXCEPT {return __tree_.max_size();} | ||||||
|  |  | ||||||
|     mapped_type& operator[](const key_type& __k); |     mapped_type& operator[](const key_type& __k); | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -803,7 +863,7 @@ public: | |||||||
|     const mapped_type& at(const key_type& __k) const; |     const mapped_type& at(const key_type& __k) const; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     allocator_type get_allocator() const {return __tree_.__alloc();} |     allocator_type get_allocator() const _NOEXCEPT {return __tree_.__alloc();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     key_compare    key_comp()      const {return __tree_.value_comp().key_comp();} |     key_compare    key_comp()      const {return __tree_.value_comp().key_comp();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -816,16 +876,16 @@ public: | |||||||
|         emplace() {return __tree_.__emplace_unique();} |         emplace() {return __tree_.__emplace_unique();} | ||||||
|  |  | ||||||
|     template <class _A0, |     template <class _A0, | ||||||
|               class = typename enable_if<is_convertible<_A0, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _A0>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         pair<iterator, bool> |         pair<iterator, bool> | ||||||
|         emplace(_A0&& __a0) |         emplace(_A0&& __a0) | ||||||
|             {return __tree_.__emplace_unique(_STD::forward<_A0>(__a0));} |             {return __tree_.__emplace_unique(_VSTD::forward<_A0>(__a0));} | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
|  |  | ||||||
|     template <class _A0, class ..._Args, |     template <class _A0, class ..._Args, | ||||||
|               class = typename enable_if<is_convertible<_A0, key_type>::value>::type> |               class = typename enable_if<is_constructible<key_type, _A0>::value>::type> | ||||||
|         pair<iterator, bool> |         pair<iterator, bool> | ||||||
|         emplace(_A0&& __a0, _Args&& ...__args); |         emplace(_A0&& __a0, _Args&& ...__args); | ||||||
|  |  | ||||||
| @@ -837,32 +897,32 @@ public: | |||||||
|         {return __tree_.__emplace_hint_unique(__p.__i_);} |         {return __tree_.__emplace_hint_unique(__p.__i_);} | ||||||
|  |  | ||||||
|     template <class _A0, |     template <class _A0, | ||||||
|               class = typename enable_if<is_convertible<_A0, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _A0>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator |         iterator | ||||||
|         emplace_hint(const_iterator __p, _A0&& __a0) |         emplace_hint(const_iterator __p, _A0&& __a0) | ||||||
|             {return __tree_.__emplace_hint_unique(__p.__i_, _STD::forward<_A0>(__a0));} |             {return __tree_.__emplace_hint_unique(__p.__i_, _VSTD::forward<_A0>(__a0));} | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
|  |  | ||||||
|     template <class _A0, class ..._Args, |     template <class _A0, class ..._Args, | ||||||
|               class = typename enable_if<is_convertible<_A0, key_type>::value>::type> |               class = typename enable_if<is_constructible<key_type, _A0>::value>::type> | ||||||
|         iterator |         iterator | ||||||
|         emplace_hint(const_iterator __p, _A0&& __a0, _Args&& ...__args); |         emplace_hint(const_iterator __p, _A0&& __a0, _Args&& ...__args); | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||||
|  |  | ||||||
|     template <class _P, |     template <class _P, | ||||||
|               class = typename enable_if<is_convertible<_P, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _P>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         pair<iterator, bool> insert(_P&& __p) |         pair<iterator, bool> insert(_P&& __p) | ||||||
|             {return __tree_.__insert_unique(_STD::forward<_P>(__p));} |             {return __tree_.__insert_unique(_VSTD::forward<_P>(__p));} | ||||||
|  |  | ||||||
|     template <class _P, |     template <class _P, | ||||||
|               class = typename enable_if<is_convertible<_P, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _P>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator insert(const_iterator __pos, _P&& __p) |         iterator insert(const_iterator __pos, _P&& __p) | ||||||
|             {return __tree_.__insert_unique(__pos.__i_, _STD::forward<_P>(__p));} |             {return __tree_.__insert_unique(__pos.__i_, _VSTD::forward<_P>(__p));} | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
| @@ -896,10 +956,12 @@ public: | |||||||
|     iterator  erase(const_iterator __f, const_iterator __l) |     iterator  erase(const_iterator __f, const_iterator __l) | ||||||
|         {return __tree_.erase(__f.__i_, __l.__i_);} |         {return __tree_.erase(__f.__i_, __l.__i_);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void clear() {__tree_.clear();} |     void clear() _NOEXCEPT {__tree_.clear();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(map& __m) {__tree_.swap(__m.__tree_);} |     void swap(map& __m) | ||||||
|  |         _NOEXCEPT_(__is_nothrow_swappable<__base>::value) | ||||||
|  |         {__tree_.swap(__m.__tree_);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator find(const key_type& __k)             {return __tree_.find(__k);} |     iterator find(const key_type& __k)             {return __tree_.find(__k);} | ||||||
| @@ -940,11 +1002,11 @@ private: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     __node_holder __construct_node(); |     __node_holder __construct_node(); | ||||||
|     template <class _A0, |     template <class _A0, | ||||||
|               class = typename enable_if<is_convertible<_A0, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _A0>::value>::type> | ||||||
|         __node_holder __construct_node(_A0&& __a0); |         __node_holder __construct_node(_A0&& __a0); | ||||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
|     template <class _A0, class ..._Args, |     template <class _A0, class ..._Args, | ||||||
|               class = typename enable_if<is_convertible<_A0, key_type>::value>::type> |               class = typename enable_if<is_constructible<key_type, _A0>::value>::type> | ||||||
|         __node_holder __construct_node(_A0&& __a0, _Args&& ...__args); |         __node_holder __construct_node(_A0&& __a0, _Args&& ...__args); | ||||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||||
| #else  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #else  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -1042,7 +1104,7 @@ map<_Key, _Tp, _Compare, _Allocator>::__find_equal_key(const_iterator __hint, | |||||||
|     else if (__tree_.value_comp().key_comp()(__hint->first, __k))  // check after |     else if (__tree_.value_comp().key_comp()(__hint->first, __k))  // check after | ||||||
|     { |     { | ||||||
|         // *__hint < __k |         // *__hint < __k | ||||||
|         const_iterator __next = _STD::next(__hint); |         const_iterator __next = _VSTD::next(__hint); | ||||||
|         if (__next == end() || __tree_.value_comp().key_comp()(__k, __next->first)) |         if (__next == end() || __tree_.value_comp().key_comp()(__k, __next->first)) | ||||||
|         { |         { | ||||||
|             // *__hint < __k < *next(__hint) |             // *__hint < __k < *next(__hint) | ||||||
| @@ -1114,14 +1176,14 @@ map<_Key, _Tp, _Compare, _Allocator>::__find_equal_key(__node_base_const_pointer | |||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Compare, class _Allocator> | template <class _Key, class _Tp, class _Compare, class _Allocator> | ||||||
| map<_Key, _Tp, _Compare, _Allocator>::map(map&& __m, const allocator_type& __a) | map<_Key, _Tp, _Compare, _Allocator>::map(map&& __m, const allocator_type& __a) | ||||||
|     : __tree_(_STD::move(__m.__tree_), __a) |     : __tree_(_VSTD::move(__m.__tree_), __a) | ||||||
| { | { | ||||||
|     if (__a != __m.get_allocator()) |     if (__a != __m.get_allocator()) | ||||||
|     { |     { | ||||||
|         const_iterator __e = cend(); |         const_iterator __e = cend(); | ||||||
|         while (!__m.empty()) |         while (!__m.empty()) | ||||||
|             __tree_.__insert_unique(__e.__i_, |             __tree_.__insert_unique(__e.__i_, | ||||||
|                     _STD::move(__m.__tree_.remove(__m.begin().__i_)->__value_)); |                     _VSTD::move(__m.__tree_.remove(__m.begin().__i_)->__value_)); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1131,9 +1193,9 @@ map<_Key, _Tp, _Compare, _Allocator>::__construct_node() | |||||||
| { | { | ||||||
|     __node_allocator& __na = __tree_.__node_alloc(); |     __node_allocator& __na = __tree_.__node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.first)); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.first)); | ||||||
|     __h.get_deleter().__first_constructed = true; |     __h.get_deleter().__first_constructed = true; | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.second)); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.second)); | ||||||
|     __h.get_deleter().__second_constructed = true; |     __h.get_deleter().__second_constructed = true; | ||||||
|     return __h; |     return __h; | ||||||
| } | } | ||||||
| @@ -1146,7 +1208,7 @@ map<_Key, _Tp, _Compare, _Allocator>::__construct_node(_A0&& __a0) | |||||||
| { | { | ||||||
|     __node_allocator& __na = __tree_.__node_alloc(); |     __node_allocator& __na = __tree_.__node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_), _STD::forward<_A0>(__a0)); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_), _VSTD::forward<_A0>(__a0)); | ||||||
|     __h.get_deleter().__first_constructed = true; |     __h.get_deleter().__first_constructed = true; | ||||||
|     __h.get_deleter().__second_constructed = true; |     __h.get_deleter().__second_constructed = true; | ||||||
|     return __h; |     return __h; | ||||||
| @@ -1162,9 +1224,9 @@ map<_Key, _Tp, _Compare, _Allocator>::__construct_node(_A0&& __a0, _Args&& ...__ | |||||||
| { | { | ||||||
|     __node_allocator& __na = __tree_.__node_alloc(); |     __node_allocator& __na = __tree_.__node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.first), _STD::forward<_A0>(__a0)); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.first), _VSTD::forward<_A0>(__a0)); | ||||||
|     __h.get_deleter().__first_constructed = true; |     __h.get_deleter().__first_constructed = true; | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.second), _STD::forward<_Args>(__args)...); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.second), _VSTD::forward<_Args>(__args)...); | ||||||
|     __h.get_deleter().__second_constructed = true; |     __h.get_deleter().__second_constructed = true; | ||||||
|     return __h; |     return __h; | ||||||
| } | } | ||||||
| @@ -1179,11 +1241,11 @@ map<_Key, _Tp, _Compare, _Allocator>::__construct_node(const key_type& __k) | |||||||
| { | { | ||||||
|     __node_allocator& __na = __tree_.__node_alloc(); |     __node_allocator& __na = __tree_.__node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.first), __k); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.first), __k); | ||||||
|     __h.get_deleter().__first_constructed = true; |     __h.get_deleter().__first_constructed = true; | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.second)); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.second)); | ||||||
|     __h.get_deleter().__second_constructed = true; |     __h.get_deleter().__second_constructed = true; | ||||||
|     return _STD::move(__h); |     return _VSTD::move(__h); | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -1215,7 +1277,7 @@ map<_Key, _Tp, _Compare, _Allocator>::operator[](key_type&& __k) | |||||||
|     __node_pointer __r = static_cast<__node_pointer>(__child); |     __node_pointer __r = static_cast<__node_pointer>(__child); | ||||||
|     if (__child == nullptr) |     if (__child == nullptr) | ||||||
|     { |     { | ||||||
|         __node_holder __h = __construct_node(_STD::move(__k)); |         __node_holder __h = __construct_node(_VSTD::move(__k)); | ||||||
|         __tree_.__insert_node_at(__parent, __child, __h.get()); |         __tree_.__insert_node_at(__parent, __child, __h.get()); | ||||||
|         __r = __h.release(); |         __r = __h.release(); | ||||||
|     } |     } | ||||||
| @@ -1254,13 +1316,13 @@ map<_Key, _Tp, _Compare, _Allocator>::at(const key_type& __k) const | |||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Compare, class _Allocator> | template <class _Key, class _Tp, class _Compare, class _Allocator> | ||||||
| template <class _A0, class ..._Args, | template <class _A0, class ..._Args, | ||||||
|           class //= typename enable_if<is_convertible<_A0, _Key>::value>::type |           class //= typename enable_if<is_constructible<_Key, _A0>::value>::type | ||||||
|          > |          > | ||||||
| pair<typename map<_Key, _Tp, _Compare, _Allocator>::iterator, bool> | pair<typename map<_Key, _Tp, _Compare, _Allocator>::iterator, bool> | ||||||
| map<_Key, _Tp, _Compare, _Allocator>::emplace(_A0&& __a0, _Args&& ...__args) | map<_Key, _Tp, _Compare, _Allocator>::emplace(_A0&& __a0, _Args&& ...__args) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_A0>(__a0), |     __node_holder __h = __construct_node(_VSTD::forward<_A0>(__a0), | ||||||
|                                          _STD::forward<_Args>(__args)...); |                                          _VSTD::forward<_Args>(__args)...); | ||||||
|     pair<iterator, bool> __r = __tree_.__node_insert_unique(__h.get()); |     pair<iterator, bool> __r = __tree_.__node_insert_unique(__h.get()); | ||||||
|     if (__r.second) |     if (__r.second) | ||||||
|         __h.release(); |         __h.release(); | ||||||
| @@ -1269,14 +1331,14 @@ map<_Key, _Tp, _Compare, _Allocator>::emplace(_A0&& __a0, _Args&& ...__args) | |||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Compare, class _Allocator> | template <class _Key, class _Tp, class _Compare, class _Allocator> | ||||||
| template <class _A0, class ..._Args, | template <class _A0, class ..._Args, | ||||||
|           class //= typename enable_if<is_convertible<_A0, _Key>::value>::type |           class //= typename enable_if<is_constructible<_Key, _A0>::value>::type | ||||||
|          > |          > | ||||||
| typename map<_Key, _Tp, _Compare, _Allocator>::iterator | typename map<_Key, _Tp, _Compare, _Allocator>::iterator | ||||||
| map<_Key, _Tp, _Compare, _Allocator>::emplace_hint(const_iterator __p, | map<_Key, _Tp, _Compare, _Allocator>::emplace_hint(const_iterator __p, | ||||||
|                                                    _A0&& __a0, _Args&& ...__args) |                                                    _A0&& __a0, _Args&& ...__args) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_A0>(__a0), |     __node_holder __h = __construct_node(_VSTD::forward<_A0>(__a0), | ||||||
|                                          _STD::forward<_Args>(__args)...); |                                          _VSTD::forward<_Args>(__args)...); | ||||||
|     iterator __r = __tree_.__node_insert_unique(__p.__i_, __h.get()); |     iterator __r = __tree_.__node_insert_unique(__p.__i_, __h.get()); | ||||||
|     if (__r.__i_.__ptr_ == __h.get()) |     if (__r.__i_.__ptr_ == __h.get()) | ||||||
|         __h.release(); |         __h.release(); | ||||||
| @@ -1291,7 +1353,7 @@ bool | |||||||
| operator==(const map<_Key, _Tp, _Compare, _Allocator>& __x, | operator==(const map<_Key, _Tp, _Compare, _Allocator>& __x, | ||||||
|            const map<_Key, _Tp, _Compare, _Allocator>& __y) |            const map<_Key, _Tp, _Compare, _Allocator>& __y) | ||||||
| { | { | ||||||
|     return __x.size() == __y.size() && _STD::equal(__x.begin(), __x.end(), __y.begin()); |     return __x.size() == __y.size() && _VSTD::equal(__x.begin(), __x.end(), __y.begin()); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Compare, class _Allocator> | template <class _Key, class _Tp, class _Compare, class _Allocator> | ||||||
| @@ -1300,7 +1362,7 @@ bool | |||||||
| operator< (const map<_Key, _Tp, _Compare, _Allocator>& __x, | operator< (const map<_Key, _Tp, _Compare, _Allocator>& __x, | ||||||
|            const map<_Key, _Tp, _Compare, _Allocator>& __y) |            const map<_Key, _Tp, _Compare, _Allocator>& __y) | ||||||
| { | { | ||||||
|     return _STD::lexicographical_compare(__x.begin(), __x.end(), __y.begin(), __y.end()); |     return _VSTD::lexicographical_compare(__x.begin(), __x.end(), __y.begin(), __y.end()); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Compare, class _Allocator> | template <class _Key, class _Tp, class _Compare, class _Allocator> | ||||||
| @@ -1344,6 +1406,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| void | void | ||||||
| swap(map<_Key, _Tp, _Compare, _Allocator>& __x, | swap(map<_Key, _Tp, _Compare, _Allocator>& __x, | ||||||
|      map<_Key, _Tp, _Compare, _Allocator>& __y) |      map<_Key, _Tp, _Compare, _Allocator>& __y) | ||||||
|  |     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||||
| { | { | ||||||
|     __x.swap(__y); |     __x.swap(__y); | ||||||
| } | } | ||||||
| @@ -1400,11 +1463,15 @@ public: | |||||||
|     typedef typename __alloc_traits::difference_type       difference_type; |     typedef typename __alloc_traits::difference_type       difference_type; | ||||||
|     typedef __map_iterator<typename __base::iterator>      iterator; |     typedef __map_iterator<typename __base::iterator>      iterator; | ||||||
|     typedef __map_const_iterator<typename __base::const_iterator> const_iterator; |     typedef __map_const_iterator<typename __base::const_iterator> const_iterator; | ||||||
|     typedef _STD::reverse_iterator<iterator>               reverse_iterator; |     typedef _VSTD::reverse_iterator<iterator>               reverse_iterator; | ||||||
|     typedef _STD::reverse_iterator<const_iterator>         const_reverse_iterator; |     typedef _VSTD::reverse_iterator<const_iterator>         const_reverse_iterator; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit multimap(const key_compare& __comp = key_compare()) |     explicit multimap(const key_compare& __comp = key_compare()) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             is_nothrow_default_constructible<allocator_type>::value && | ||||||
|  |             is_nothrow_default_constructible<key_compare>::value && | ||||||
|  |             is_nothrow_copy_constructible<key_compare>::value) | ||||||
|         : __tree_(__vc(__comp)) {} |         : __tree_(__vc(__comp)) {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -1437,11 +1504,19 @@ public: | |||||||
|             insert(__m.begin(), __m.end()); |             insert(__m.begin(), __m.end()); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     multimap& operator=(const multimap& __m) | ||||||
|  |         { | ||||||
|  |             __tree_ = __m.__tree_; | ||||||
|  |             return *this; | ||||||
|  |         } | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     multimap(multimap&& __m) |     multimap(multimap&& __m) | ||||||
|         : __tree_(_STD::move(__m.__tree_)) |         _NOEXCEPT_(is_nothrow_move_constructible<__base>::value) | ||||||
|  |         : __tree_(_VSTD::move(__m.__tree_)) | ||||||
|         { |         { | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -1463,8 +1538,9 @@ public: | |||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     multimap& operator=(multimap&& __m) |     multimap& operator=(multimap&& __m) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_assignable<__base>::value) | ||||||
|         { |         { | ||||||
|             __tree_ = _STD::move(__m.__tree_); |             __tree_ = _VSTD::move(__m.__tree_); | ||||||
|             return *this; |             return *this; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -1490,45 +1566,48 @@ public: | |||||||
|         } |         } | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           iterator begin()       {return __tree_.begin();} |           iterator begin() _NOEXCEPT {return __tree_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator begin() const {return __tree_.begin();} |     const_iterator begin() const _NOEXCEPT {return __tree_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           iterator end()         {return __tree_.end();} |           iterator end() _NOEXCEPT {return __tree_.end();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator end()   const {return __tree_.end();} |     const_iterator end() const _NOEXCEPT {return __tree_.end();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           reverse_iterator rbegin()       {return       reverse_iterator(end());} |           reverse_iterator rbegin() _NOEXCEPT {return reverse_iterator(end());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator rbegin() const {return const_reverse_iterator(end());} |     const_reverse_iterator rbegin() const _NOEXCEPT | ||||||
|  |         {return const_reverse_iterator(end());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           reverse_iterator rend()         {return       reverse_iterator(begin());} |           reverse_iterator rend() _NOEXCEPT {return reverse_iterator(begin());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator rend()   const {return const_reverse_iterator(begin());} |     const_reverse_iterator rend() const _NOEXCEPT | ||||||
|  |         {return const_reverse_iterator(begin());} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator         cbegin()  const {return begin();} |     const_iterator cbegin()  const _NOEXCEPT {return begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator         cend()    const {return end();} |     const_iterator cend() const _NOEXCEPT {return end();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator crbegin() const {return rbegin();} |     const_reverse_iterator crbegin() const _NOEXCEPT {return rbegin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator crend()   const {return rend();} |     const_reverse_iterator crend() const _NOEXCEPT {return rend();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool      empty()    const {return __tree_.size() == 0;} |     bool empty() const _NOEXCEPT {return __tree_.size() == 0;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type size()     const {return __tree_.size();} |     size_type size() const _NOEXCEPT {return __tree_.size();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type max_size() const {return __tree_.max_size();} |     size_type max_size() const _NOEXCEPT {return __tree_.max_size();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     allocator_type get_allocator() const {return __tree_.__alloc();} |     allocator_type get_allocator() const _NOEXCEPT {return __tree_.__alloc();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     key_compare    key_comp() const {return __tree_.value_comp().key_comp();} |     key_compare    key_comp() const {return __tree_.value_comp().key_comp();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     value_compare  value_comp()    const {return value_compare(__tree_.value_comp().key_comp());} |     value_compare  value_comp() const | ||||||
|  |         {return value_compare(__tree_.value_comp().key_comp());} | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
| @@ -1536,16 +1615,16 @@ public: | |||||||
|     iterator emplace() {return __tree_.__emplace_multi();} |     iterator emplace() {return __tree_.__emplace_multi();} | ||||||
|  |  | ||||||
|     template <class _A0, |     template <class _A0, | ||||||
|               class = typename enable_if<is_convertible<_A0, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _A0>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator |         iterator | ||||||
|         emplace(_A0&& __a0) |         emplace(_A0&& __a0) | ||||||
|             {return __tree_.__emplace_multi(_STD::forward<_A0>(__a0));} |             {return __tree_.__emplace_multi(_VSTD::forward<_A0>(__a0));} | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
|  |  | ||||||
|     template <class _A0, class ..._Args, |     template <class _A0, class ..._Args, | ||||||
|               class = typename enable_if<is_convertible<_A0, key_type>::value>::type> |               class = typename enable_if<is_constructible<key_type, _A0>::value>::type> | ||||||
|         iterator |         iterator | ||||||
|         emplace(_A0&& __a0, _Args&& ...__args); |         emplace(_A0&& __a0, _Args&& ...__args); | ||||||
|  |  | ||||||
| @@ -1556,32 +1635,32 @@ public: | |||||||
|         {return __tree_.__emplace_hint_multi(__p.__i_);} |         {return __tree_.__emplace_hint_multi(__p.__i_);} | ||||||
|  |  | ||||||
|     template <class _A0, |     template <class _A0, | ||||||
|               class = typename enable_if<is_convertible<_A0, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _A0>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator |         iterator | ||||||
|         emplace_hint(const_iterator __p, _A0&& __a0) |         emplace_hint(const_iterator __p, _A0&& __a0) | ||||||
|             {return __tree_.__emplace_hint_multi(__p.__i_, _STD::forward<_A0>(__a0));} |             {return __tree_.__emplace_hint_multi(__p.__i_, _VSTD::forward<_A0>(__a0));} | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
|  |  | ||||||
|     template <class _A0, class ..._Args, |     template <class _A0, class ..._Args, | ||||||
|               class = typename enable_if<is_convertible<_A0, key_type>::value>::type> |               class = typename enable_if<is_constructible<key_type, _A0>::value>::type> | ||||||
|         iterator |         iterator | ||||||
|         emplace_hint(const_iterator __p, _A0&& __a0, _Args&& ...__args); |         emplace_hint(const_iterator __p, _A0&& __a0, _Args&& ...__args); | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||||
|  |  | ||||||
|     template <class _P, |     template <class _P, | ||||||
|               class = typename enable_if<is_convertible<_P, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _P>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator insert(_P&& __p) |         iterator insert(_P&& __p) | ||||||
|             {return __tree_.__insert_multi(_STD::forward<_P>(__p));} |             {return __tree_.__insert_multi(_VSTD::forward<_P>(__p));} | ||||||
|  |  | ||||||
|     template <class _P, |     template <class _P, | ||||||
|               class = typename enable_if<is_convertible<_P, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _P>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator insert(const_iterator __pos, _P&& __p) |         iterator insert(const_iterator __pos, _P&& __p) | ||||||
|             {return __tree_.__insert_multi(__pos.__i_, _STD::forward<_P>(__p));} |             {return __tree_.__insert_multi(__pos.__i_, _VSTD::forward<_P>(__p));} | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
| @@ -1615,7 +1694,9 @@ public: | |||||||
|     void clear() {__tree_.clear();} |     void clear() {__tree_.clear();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(multimap& __m) {__tree_.swap(__m.__tree_);} |     void swap(multimap& __m) | ||||||
|  |         _NOEXCEPT_(__is_nothrow_swappable<__base>::value) | ||||||
|  |         {__tree_.swap(__m.__tree_);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator find(const key_type& __k)             {return __tree_.find(__k);} |     iterator find(const key_type& __k)             {return __tree_.find(__k);} | ||||||
| @@ -1654,11 +1735,11 @@ private: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     __node_holder __construct_node(); |     __node_holder __construct_node(); | ||||||
|     template <class _A0, |     template <class _A0, | ||||||
|               class = typename enable_if<is_convertible<_A0, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _A0>::value>::type> | ||||||
|         __node_holder __construct_node(_A0&& __a0); |         __node_holder __construct_node(_A0&& __a0); | ||||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
|     template <class _A0, class ..._Args, |     template <class _A0, class ..._Args, | ||||||
|               class = typename enable_if<is_convertible<_A0, key_type>::value>::type> |               class = typename enable_if<is_constructible<key_type, _A0>::value>::type> | ||||||
|         __node_holder __construct_node(_A0&& __a0, _Args&& ...__args); |         __node_holder __construct_node(_A0&& __a0, _Args&& ...__args); | ||||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -1668,14 +1749,14 @@ private: | |||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Compare, class _Allocator> | template <class _Key, class _Tp, class _Compare, class _Allocator> | ||||||
| multimap<_Key, _Tp, _Compare, _Allocator>::multimap(multimap&& __m, const allocator_type& __a) | multimap<_Key, _Tp, _Compare, _Allocator>::multimap(multimap&& __m, const allocator_type& __a) | ||||||
|     : __tree_(_STD::move(__m.__tree_), __a) |     : __tree_(_VSTD::move(__m.__tree_), __a) | ||||||
| { | { | ||||||
|     if (__a != __m.get_allocator()) |     if (__a != __m.get_allocator()) | ||||||
|     { |     { | ||||||
|         const_iterator __e = cend(); |         const_iterator __e = cend(); | ||||||
|         while (!__m.empty()) |         while (!__m.empty()) | ||||||
|             __tree_.__insert_multi(__e.__i_, |             __tree_.__insert_multi(__e.__i_, | ||||||
|                     _STD::move(__m.__tree_.remove(__m.begin().__i_)->__value_)); |                     _VSTD::move(__m.__tree_.remove(__m.begin().__i_)->__value_)); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1685,23 +1766,23 @@ multimap<_Key, _Tp, _Compare, _Allocator>::__construct_node() | |||||||
| { | { | ||||||
|     __node_allocator& __na = __tree_.__node_alloc(); |     __node_allocator& __na = __tree_.__node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.first)); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.first)); | ||||||
|     __h.get_deleter().__first_constructed = true; |     __h.get_deleter().__first_constructed = true; | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.second)); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.second)); | ||||||
|     __h.get_deleter().__second_constructed = true; |     __h.get_deleter().__second_constructed = true; | ||||||
|     return __h; |     return __h; | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Compare, class _Allocator> | template <class _Key, class _Tp, class _Compare, class _Allocator> | ||||||
| template <class _A0, | template <class _A0, | ||||||
|           class // = typename enable_if<is_convertible<_A0, value_type>::value>::type |           class // = typename enable_if<is_constructible<value_type, _A0>::value>::type | ||||||
|          > |          > | ||||||
| typename multimap<_Key, _Tp, _Compare, _Allocator>::__node_holder | typename multimap<_Key, _Tp, _Compare, _Allocator>::__node_holder | ||||||
| multimap<_Key, _Tp, _Compare, _Allocator>::__construct_node(_A0&& __a0) | multimap<_Key, _Tp, _Compare, _Allocator>::__construct_node(_A0&& __a0) | ||||||
| { | { | ||||||
|     __node_allocator& __na = __tree_.__node_alloc(); |     __node_allocator& __na = __tree_.__node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_), _STD::forward<_A0>(__a0)); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_), _VSTD::forward<_A0>(__a0)); | ||||||
|     __h.get_deleter().__first_constructed = true; |     __h.get_deleter().__first_constructed = true; | ||||||
|     __h.get_deleter().__second_constructed = true; |     __h.get_deleter().__second_constructed = true; | ||||||
|     return __h; |     return __h; | ||||||
| @@ -1711,16 +1792,16 @@ multimap<_Key, _Tp, _Compare, _Allocator>::__construct_node(_A0&& __a0) | |||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Compare, class _Allocator> | template <class _Key, class _Tp, class _Compare, class _Allocator> | ||||||
| template <class _A0, class ..._Args, | template <class _A0, class ..._Args, | ||||||
|           class // = typename enable_if<is_convertible<_A0, key_type>::value>::type |           class // = typename enable_if<is_constructible<key_type, _A0>::value>::type | ||||||
|          > |          > | ||||||
| typename multimap<_Key, _Tp, _Compare, _Allocator>::__node_holder | typename multimap<_Key, _Tp, _Compare, _Allocator>::__node_holder | ||||||
| multimap<_Key, _Tp, _Compare, _Allocator>::__construct_node(_A0&& __a0, _Args&& ...__args) | multimap<_Key, _Tp, _Compare, _Allocator>::__construct_node(_A0&& __a0, _Args&& ...__args) | ||||||
| { | { | ||||||
|     __node_allocator& __na = __tree_.__node_alloc(); |     __node_allocator& __na = __tree_.__node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.first), _STD::forward<_A0>(__a0)); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.first), _VSTD::forward<_A0>(__a0)); | ||||||
|     __h.get_deleter().__first_constructed = true; |     __h.get_deleter().__first_constructed = true; | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.second), _STD::forward<_Args>(__args)...); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.second), _VSTD::forward<_Args>(__args)...); | ||||||
|     __h.get_deleter().__second_constructed = true; |     __h.get_deleter().__second_constructed = true; | ||||||
|     return __h; |     return __h; | ||||||
| } | } | ||||||
| @@ -1732,13 +1813,13 @@ multimap<_Key, _Tp, _Compare, _Allocator>::__construct_node(_A0&& __a0, _Args&& | |||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Compare, class _Allocator> | template <class _Key, class _Tp, class _Compare, class _Allocator> | ||||||
| template <class _A0, class ..._Args, | template <class _A0, class ..._Args, | ||||||
|           class //= typename enable_if<is_convertible<_A0, _Key>::value>::type |           class //= typename enable_if<is_constructible<_Key, _A0>::value>::type | ||||||
|          > |          > | ||||||
| typename multimap<_Key, _Tp, _Compare, _Allocator>::iterator | typename multimap<_Key, _Tp, _Compare, _Allocator>::iterator | ||||||
| multimap<_Key, _Tp, _Compare, _Allocator>::emplace(_A0&& __a0, _Args&& ...__args) | multimap<_Key, _Tp, _Compare, _Allocator>::emplace(_A0&& __a0, _Args&& ...__args) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_A0>(__a0), |     __node_holder __h = __construct_node(_VSTD::forward<_A0>(__a0), | ||||||
|                                          _STD::forward<_Args>(__args)...); |                                          _VSTD::forward<_Args>(__args)...); | ||||||
|     iterator __r = __tree_.__node_insert_multi(__h.get()); |     iterator __r = __tree_.__node_insert_multi(__h.get()); | ||||||
|     __h.release(); |     __h.release(); | ||||||
|     return __r; |     return __r; | ||||||
| @@ -1746,15 +1827,15 @@ multimap<_Key, _Tp, _Compare, _Allocator>::emplace(_A0&& __a0, _Args&& ...__args | |||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Compare, class _Allocator> | template <class _Key, class _Tp, class _Compare, class _Allocator> | ||||||
| template <class _A0, class ..._Args, | template <class _A0, class ..._Args, | ||||||
|           class //= typename enable_if<is_convertible<_A0, _Key>::value>::type |           class //= typename enable_if<is_constructible<_Key, _A0>::value>::type | ||||||
|          > |          > | ||||||
| typename multimap<_Key, _Tp, _Compare, _Allocator>::iterator | typename multimap<_Key, _Tp, _Compare, _Allocator>::iterator | ||||||
| multimap<_Key, _Tp, _Compare, _Allocator>::emplace_hint(const_iterator __p, | multimap<_Key, _Tp, _Compare, _Allocator>::emplace_hint(const_iterator __p, | ||||||
|                                                         _A0&& __a0, |                                                         _A0&& __a0, | ||||||
|                                                         _Args&& ...__args) |                                                         _Args&& ...__args) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_A0>(__a0), |     __node_holder __h = __construct_node(_VSTD::forward<_A0>(__a0), | ||||||
|                                          _STD::forward<_Args>(__args)...); |                                          _VSTD::forward<_Args>(__args)...); | ||||||
|     iterator __r = __tree_.__node_insert_multi(__p.__i_, __h.get()); |     iterator __r = __tree_.__node_insert_multi(__p.__i_, __h.get()); | ||||||
|     __h.release(); |     __h.release(); | ||||||
|     return __r; |     return __r; | ||||||
| @@ -1768,7 +1849,7 @@ bool | |||||||
| operator==(const multimap<_Key, _Tp, _Compare, _Allocator>& __x, | operator==(const multimap<_Key, _Tp, _Compare, _Allocator>& __x, | ||||||
|            const multimap<_Key, _Tp, _Compare, _Allocator>& __y) |            const multimap<_Key, _Tp, _Compare, _Allocator>& __y) | ||||||
| { | { | ||||||
|     return __x.size() == __y.size() && _STD::equal(__x.begin(), __x.end(), __y.begin()); |     return __x.size() == __y.size() && _VSTD::equal(__x.begin(), __x.end(), __y.begin()); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Compare, class _Allocator> | template <class _Key, class _Tp, class _Compare, class _Allocator> | ||||||
| @@ -1777,7 +1858,7 @@ bool | |||||||
| operator< (const multimap<_Key, _Tp, _Compare, _Allocator>& __x, | operator< (const multimap<_Key, _Tp, _Compare, _Allocator>& __x, | ||||||
|            const multimap<_Key, _Tp, _Compare, _Allocator>& __y) |            const multimap<_Key, _Tp, _Compare, _Allocator>& __y) | ||||||
| { | { | ||||||
|     return _STD::lexicographical_compare(__x.begin(), __x.end(), __y.begin(), __y.end()); |     return _VSTD::lexicographical_compare(__x.begin(), __x.end(), __y.begin(), __y.end()); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Compare, class _Allocator> | template <class _Key, class _Tp, class _Compare, class _Allocator> | ||||||
| @@ -1821,6 +1902,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| void | void | ||||||
| swap(multimap<_Key, _Tp, _Compare, _Allocator>& __x, | swap(multimap<_Key, _Tp, _Compare, _Allocator>& __x, | ||||||
|      multimap<_Key, _Tp, _Compare, _Allocator>& __y) |      multimap<_Key, _Tp, _Compare, _Allocator>& __y) | ||||||
|  |     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||||
| { | { | ||||||
|     __x.swap(__y); |     __x.swap(__y); | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										1063
									
								
								include/memory
									
									
									
									
									
								
							
							
						
						
									
										1063
									
								
								include/memory
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -175,6 +175,9 @@ template<class Callable, class ...Args> | |||||||
| #include <__config> | #include <__config> | ||||||
| #include <__mutex_base> | #include <__mutex_base> | ||||||
| #include <functional> | #include <functional> | ||||||
|  | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
|  | #include <tuple> | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #pragma GCC system_header | #pragma GCC system_header | ||||||
|  |  | ||||||
| @@ -455,6 +458,8 @@ private: | |||||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
|  |  | ||||||
| template <class _F> | template <class _F> | ||||||
| class __call_once_param | class __call_once_param | ||||||
| { | { | ||||||
| @@ -462,7 +467,38 @@ class __call_once_param | |||||||
| public: | public: | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __call_once_param(_F&& __f) : __f_(_STD::move(__f)) {} |     explicit __call_once_param(_F&& __f) : __f_(_VSTD::move(__f)) {} | ||||||
|  | #else | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     explicit __call_once_param(const _F& __f) : __f_(__f) {} | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     void operator()() | ||||||
|  |     { | ||||||
|  |         typedef typename __make_tuple_indices<tuple_size<_F>::value, 1>::type _Index; | ||||||
|  |         __execute(_Index()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | private: | ||||||
|  |     template <size_t ..._Indices> | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     void __execute(__tuple_indices<_Indices...>) | ||||||
|  |     { | ||||||
|  |         __invoke(_VSTD::move(_VSTD::get<0>(__f_)), _VSTD::move(_VSTD::get<_Indices>(__f_))...); | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | #else | ||||||
|  |  | ||||||
|  | template <class _F> | ||||||
|  | class __call_once_param | ||||||
|  | { | ||||||
|  |     _F __f_; | ||||||
|  | public: | ||||||
|  | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     explicit __call_once_param(_F&& __f) : __f_(_VSTD::move(__f)) {} | ||||||
| #else | #else | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __call_once_param(const _F& __f) : __f_(__f) {} |     explicit __call_once_param(const _F& __f) : __f_(__f) {} | ||||||
| @@ -475,6 +511,8 @@ public: | |||||||
|     } |     } | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | #endif | ||||||
|  |  | ||||||
| template <class _F> | template <class _F> | ||||||
| void | void | ||||||
| __call_once_proxy(void* __vp) | __call_once_proxy(void* __vp) | ||||||
| @@ -494,10 +532,9 @@ call_once(once_flag& __flag, _Callable&& __func, _Args&&... __args) | |||||||
| { | { | ||||||
|     if (__builtin_expect(__flag.__state_ , ~0ul) != ~0ul) |     if (__builtin_expect(__flag.__state_ , ~0ul) != ~0ul) | ||||||
|     { |     { | ||||||
|         typedef decltype(std::bind(std::forward<_Callable>(__func), |         typedef tuple<typename decay<_Callable>::type, typename decay<_Args>::type...> _G; | ||||||
|                          std::forward<_Args>(__args)...)) _G; |         __call_once_param<_G> __p(_G(__decay_copy(_VSTD::forward<_Callable>(__func)), | ||||||
|         __call_once_param<_G> __p(std::bind(std::forward<_Callable>(__func), |                                 __decay_copy(_VSTD::forward<_Args>(__args))...)); | ||||||
|                                  std::forward<_Args>(__args)...)); |  | ||||||
|         __call_once(__flag.__state_, &__p, &__call_once_proxy<_G>); |         __call_once(__flag.__state_, &__p, &__call_once_proxy<_G>); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										95
									
								
								include/new
									
									
									
									
									
								
							
							
						
						
									
										95
									
								
								include/new
									
									
									
									
									
								
							| @@ -21,35 +21,34 @@ class bad_alloc | |||||||
|     : public exception |     : public exception | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     bad_alloc() throw(); |     bad_alloc() noexcept; | ||||||
|     bad_alloc(const bad_alloc&) throw(); |     bad_alloc(const bad_alloc&) noexcept; | ||||||
|     bad_alloc& operator=(const bad_alloc&) throw(); |     bad_alloc& operator=(const bad_alloc&) noexcept; | ||||||
|     virtual ~bad_alloc() throw(); |     virtual const char* what() const noexcept; | ||||||
|     virtual const char* what() const throw(); |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| struct nothrow_t {}; | struct nothrow_t {}; | ||||||
| extern const nothrow_t nothrow; | extern const nothrow_t nothrow; | ||||||
| typedef void (*new_handler)(); | typedef void (*new_handler)(); | ||||||
| new_handler set_new_handler(new_handler new_p) throw(); | new_handler set_new_handler(new_handler new_p) noexcept; | ||||||
| new_handler get_new_handler() throw(); | new_handler get_new_handler() noexcept; | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
|  |  | ||||||
| void* operator new(std::size_t size) throw(std::bad_alloc);            // replaceable | void* operator new(std::size_t size);                                   // replaceable | ||||||
| void* operator new(std::size_t size, const std::nothrow_t&) throw();   // replaceable | void* operator new(std::size_t size, const std::nothrow_t&) noexcept;   // replaceable | ||||||
| void  operator delete(void* ptr) throw();                              // replaceable | void  operator delete(void* ptr) noexcept;                              // replaceable | ||||||
| void  operator delete(void* ptr, const std::nothrow_t&) throw();       // replaceable | void  operator delete(void* ptr, const std::nothrow_t&) noexcept;       // replaceable | ||||||
|  |  | ||||||
| void* operator new[](std::size_t size) throw(std::bad_alloc);          // replaceable | void* operator new[](std::size_t size);                                 // replaceable | ||||||
| void* operator new[](std::size_t size, const std::nothrow_t&) throw(); // replaceable | void* operator new[](std::size_t size, const std::nothrow_t&) noexcept; // replaceable | ||||||
| void  operator delete[](void* ptr) throw();                            // replaceable | void  operator delete[](void* ptr) noexcept;                            // replaceable | ||||||
| void  operator delete[](void* ptr, const std::nothrow_t&) throw();     // replaceable | void  operator delete[](void* ptr, const std::nothrow_t&) noexcept;     // replaceable | ||||||
|  |  | ||||||
| void* operator new  (std::size_t size, void* ptr) throw(); | void* operator new  (std::size_t size, void* ptr) noexcept; | ||||||
| void* operator new[](std::size_t size, void* ptr) throw(); | void* operator new[](std::size_t size, void* ptr) noexcept; | ||||||
| void  operator delete  (void* ptr, void*) throw(); | void  operator delete  (void* ptr, void*) noexcept; | ||||||
| void  operator delete[](void* ptr, void*) throw(); | void  operator delete[](void* ptr, void*) noexcept; | ||||||
|  |  | ||||||
| */ | */ | ||||||
|  |  | ||||||
| @@ -66,18 +65,18 @@ class _LIBCPP_EXCEPTION_ABI bad_alloc | |||||||
|     : public exception |     : public exception | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     bad_alloc() throw(); |     bad_alloc() _NOEXCEPT; | ||||||
|     virtual ~bad_alloc() throw(); |     virtual ~bad_alloc() _NOEXCEPT; | ||||||
|     virtual const char* what() const throw(); |     virtual const char* what() const _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class _LIBCPP_EXCEPTION_ABI bad_array_new_length | class _LIBCPP_EXCEPTION_ABI bad_array_new_length | ||||||
|     : public bad_alloc |     : public bad_alloc | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     bad_array_new_length() throw(); |     bad_array_new_length() _NOEXCEPT; | ||||||
|     virtual ~bad_array_new_length() throw(); |     virtual ~bad_array_new_length() _NOEXCEPT; | ||||||
|     virtual const char* what() const throw(); |     virtual const char* what() const _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| void __throw_bad_alloc();  // not in C++ spec | void __throw_bad_alloc();  // not in C++ spec | ||||||
| @@ -85,36 +84,32 @@ void __throw_bad_alloc();  // not in C++ spec | |||||||
| struct _LIBCPP_VISIBLE nothrow_t {}; | struct _LIBCPP_VISIBLE nothrow_t {}; | ||||||
| extern _LIBCPP_VISIBLE const nothrow_t nothrow; | extern _LIBCPP_VISIBLE const nothrow_t nothrow; | ||||||
| typedef void (*new_handler)(); | typedef void (*new_handler)(); | ||||||
| _LIBCPP_VISIBLE new_handler set_new_handler(new_handler) throw(); | _LIBCPP_VISIBLE new_handler set_new_handler(new_handler) _NOEXCEPT; | ||||||
| _LIBCPP_VISIBLE new_handler get_new_handler() throw(); | _LIBCPP_VISIBLE new_handler get_new_handler() _NOEXCEPT; | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
|  |  | ||||||
| #if __APPLE__ | _LIBCPP_VISIBLE void* operator new(std::size_t __sz) | ||||||
|     #include <cxxabi.h> | #if !__has_feature(cxx_noexcept) | ||||||
|     // On Darwin, there are two STL shared libraries and a lower level ABI |     throw(std::bad_alloc) | ||||||
|     // shared libray.  The global holding the current new handler is |  | ||||||
|     // in the ABI library and named __cxa_new_handler. |  | ||||||
|     #define __new_handler __cxxabiapple::__cxa_new_handler |  | ||||||
| #else  // __APPLE__ |  | ||||||
|     _LIBCPP_BEGIN_NAMESPACE_STD |  | ||||||
|         extern ::std::new_handler __new_handler; |  | ||||||
|     _LIBCPP_END_NAMESPACE_STD |  | ||||||
| #endif | #endif | ||||||
|  | ; | ||||||
|  | _LIBCPP_VISIBLE void* operator new(std::size_t __sz, const std::nothrow_t&) _NOEXCEPT; | ||||||
|  | _LIBCPP_VISIBLE void  operator delete(void* __p) _NOEXCEPT; | ||||||
|  | _LIBCPP_VISIBLE void  operator delete(void* __p, const std::nothrow_t&) _NOEXCEPT; | ||||||
|  |  | ||||||
| _LIBCPP_VISIBLE void* operator new(std::size_t) throw(std::bad_alloc); | _LIBCPP_VISIBLE void* operator new[](std::size_t __sz) | ||||||
| _LIBCPP_VISIBLE void* operator new(std::size_t, const std::nothrow_t&) throw(); | #if !__has_feature(cxx_noexcept) | ||||||
| _LIBCPP_VISIBLE void  operator delete(void*) throw(); |     throw(std::bad_alloc) | ||||||
| _LIBCPP_VISIBLE void  operator delete(void*, const std::nothrow_t&) throw(); | #endif | ||||||
|  | ; | ||||||
|  | _LIBCPP_VISIBLE void* operator new[](std::size_t __sz, const std::nothrow_t&) _NOEXCEPT; | ||||||
|  | _LIBCPP_VISIBLE void  operator delete[](void* __p) _NOEXCEPT; | ||||||
|  | _LIBCPP_VISIBLE void  operator delete[](void* __p, const std::nothrow_t&) _NOEXCEPT; | ||||||
|  |  | ||||||
| _LIBCPP_VISIBLE void* operator new[](std::size_t) throw(std::bad_alloc); | _LIBCPP_INLINE_VISIBILITY inline void* operator new  (std::size_t, void* __p) _NOEXCEPT {return __p;} | ||||||
| _LIBCPP_VISIBLE void* operator new[](std::size_t, const std::nothrow_t&) throw(); | _LIBCPP_INLINE_VISIBILITY inline void* operator new[](std::size_t, void* __p) _NOEXCEPT {return __p;} | ||||||
| _LIBCPP_VISIBLE void  operator delete[](void*) throw(); | _LIBCPP_INLINE_VISIBILITY inline void  operator delete  (void*, void*) _NOEXCEPT {} | ||||||
| _LIBCPP_VISIBLE void  operator delete[](void*, const std::nothrow_t&) throw(); | _LIBCPP_INLINE_VISIBILITY inline void  operator delete[](void*, void*) _NOEXCEPT {} | ||||||
|  |  | ||||||
| _LIBCPP_INLINE_VISIBILITY inline void* operator new  (std::size_t, void* __p) throw() {return __p;} |  | ||||||
| _LIBCPP_INLINE_VISIBILITY inline void* operator new[](std::size_t, void* __p) throw() {return __p;} |  | ||||||
| _LIBCPP_INLINE_VISIBILITY inline void  operator delete  (void*, void*) throw() {} |  | ||||||
| _LIBCPP_INLINE_VISIBILITY inline void  operator delete[](void*, void*) throw() {} |  | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_NEW | #endif  // _LIBCPP_NEW | ||||||
|   | |||||||
| @@ -154,11 +154,13 @@ public: | |||||||
|     virtual ~basic_ostream(); |     virtual ~basic_ostream(); | ||||||
| protected: | protected: | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     basic_ostream(basic_ostream&& __rhs); |     basic_ostream(basic_ostream&& __rhs); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|     // 27.7.2.3 Assign/swap |     // 27.7.2.3 Assign/swap | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     basic_ostream& operator=(basic_ostream&& __rhs); |     basic_ostream& operator=(basic_ostream&& __rhs); | ||||||
| #endif | #endif | ||||||
|     void swap(basic_ostream& __rhs); |     void swap(basic_ostream& __rhs); | ||||||
|   | |||||||
							
								
								
									
										189
									
								
								include/queue
									
									
									
									
									
								
							
							
						
						
									
										189
									
								
								include/queue
									
									
									
									
									
								
							| @@ -31,21 +31,28 @@ protected: | |||||||
|     container_type c; |     container_type c; | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     queue(); |     queue() = default; | ||||||
|  |     ~queue() = default; | ||||||
|  |  | ||||||
|  |     queue(const queue& q) = default; | ||||||
|  |     queue(queue&& q) = default; | ||||||
|  |  | ||||||
|  |     queue& operator=(const queue& q) = default; | ||||||
|  |     queue& operator=(queue&& q) = default; | ||||||
|  |  | ||||||
|     explicit queue(const container_type& c); |     explicit queue(const container_type& c); | ||||||
|     explicit queue(container_type&& c); |     explicit queue(container_type&& c) | ||||||
|     queue(queue&& q); |  | ||||||
|     template <class Alloc> |     template <class Alloc> | ||||||
|         explicit queue(const Alloc& a); |         explicit queue(const Alloc& a); | ||||||
|     template <class Alloc> |     template <class Alloc> | ||||||
|         queue(const container_type& c, const Alloc& a); |         queue(const container_type& c, const Alloc& a); | ||||||
|     template <class Alloc> |     template <class Alloc> | ||||||
|         queue(container_type&& c, const Alloc& a); |         queue(container_type&& c, const Alloc& a); | ||||||
|  |     template <class Alloc> | ||||||
|  |         queue(const queue& q, const Alloc& a); | ||||||
|     template <class Alloc> |     template <class Alloc> | ||||||
|         queue(queue&& q, const Alloc& a); |         queue(queue&& q, const Alloc& a); | ||||||
|  |  | ||||||
|     queue& operator=(queue&& q); |  | ||||||
|  |  | ||||||
|     bool      empty() const; |     bool      empty() const; | ||||||
|     size_type size() const; |     size_type size() const; | ||||||
|  |  | ||||||
| @@ -59,7 +66,7 @@ public: | |||||||
|     template <class... Args> void emplace(Args&&... args); |     template <class... Args> void emplace(Args&&... args); | ||||||
|     void pop(); |     void pop(); | ||||||
|  |  | ||||||
|     void swap(queue& q); |     void swap(queue& q) noexcept(noexcept(swap(c, q.c))); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class T, class Container> | template <class T, class Container> | ||||||
| @@ -81,7 +88,8 @@ template <class T, class Container> | |||||||
|   bool operator<=(const queue<T, Container>& x,const queue<T, Container>& y); |   bool operator<=(const queue<T, Container>& x,const queue<T, Container>& y); | ||||||
|  |  | ||||||
| template <class T, class Container> | template <class T, class Container> | ||||||
|   void swap(queue<T, Container>& x, queue<T, Container>& y); |   void swap(queue<T, Container>& x, queue<T, Container>& y) | ||||||
|  |   noexcept(noexcept(x.swap(y))); | ||||||
|  |  | ||||||
| template <class T, class Container = vector<T>, | template <class T, class Container = vector<T>, | ||||||
|           class Compare = less<typename Container::value_type>> |           class Compare = less<typename Container::value_type>> | ||||||
| @@ -99,7 +107,16 @@ protected: | |||||||
|     Compare comp; |     Compare comp; | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit priority_queue(const Compare& comp = Compare()); |     priority_queue() = default; | ||||||
|  |     ~priority_queue() = default; | ||||||
|  |  | ||||||
|  |     priority_queue(const priority_queue& q) = default; | ||||||
|  |     priority_queue(priority_queue&& q) = default; | ||||||
|  |  | ||||||
|  |     priority_queue& operator=(const priority_queue& q) = default; | ||||||
|  |     priority_queue& operator=(priority_queue&& q) = default; | ||||||
|  |  | ||||||
|  |     explicit priority_queue(const Compare& comp); | ||||||
|     priority_queue(const Compare& comp, const container_type& c); |     priority_queue(const Compare& comp, const container_type& c); | ||||||
|     explicit priority_queue(const Compare& comp, container_type&& c); |     explicit priority_queue(const Compare& comp, container_type&& c); | ||||||
|     template <class InputIterator> |     template <class InputIterator> | ||||||
| @@ -111,8 +128,6 @@ public: | |||||||
|     template <class InputIterator> |     template <class InputIterator> | ||||||
|         priority_queue(InputIterator first, InputIterator last, |         priority_queue(InputIterator first, InputIterator last, | ||||||
|                        const Compare& comp, container_type&& c); |                        const Compare& comp, container_type&& c); | ||||||
|     priority_queue(priority_queue&& q); |  | ||||||
|     priority_queue& operator=(priority_queue&& q); |  | ||||||
|     template <class Alloc> |     template <class Alloc> | ||||||
|         explicit priority_queue(const Alloc& a); |         explicit priority_queue(const Alloc& a); | ||||||
|     template <class Alloc> |     template <class Alloc> | ||||||
| @@ -123,6 +138,8 @@ public: | |||||||
|     template <class Alloc> |     template <class Alloc> | ||||||
|         priority_queue(const Compare& comp, container_type&& c, |         priority_queue(const Compare& comp, container_type&& c, | ||||||
|                        const Alloc& a); |                        const Alloc& a); | ||||||
|  |     template <class Alloc> | ||||||
|  |         priority_queue(const priority_queue& q, const Alloc& a); | ||||||
|     template <class Alloc> |     template <class Alloc> | ||||||
|         priority_queue(priority_queue&& q, const Alloc& a); |         priority_queue(priority_queue&& q, const Alloc& a); | ||||||
|  |  | ||||||
| @@ -135,12 +152,14 @@ public: | |||||||
|     template <class... Args> void emplace(Args&&... args); |     template <class... Args> void emplace(Args&&... args); | ||||||
|     void pop(); |     void pop(); | ||||||
|  |  | ||||||
|     void swap(priority_queue& q); |     void swap(priority_queue& q) | ||||||
|  |         noexcept(noexcept(swap(c, q.c)) && noexcept(swap(comp.q.comp))); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class T, class Container, class Compare> | template <class T, class Container, class Compare> | ||||||
|   void swap(priority_queue<T, Container, Compare>& x, |   void swap(priority_queue<T, Container, Compare>& x, | ||||||
|             priority_queue<T, Container, Compare>& y); |             priority_queue<T, Container, Compare>& y) | ||||||
|  |             noexcept(noexcept(x.swap(y))); | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
|  |  | ||||||
| @@ -181,14 +200,35 @@ protected: | |||||||
|  |  | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     queue() : c() {} |     queue() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<container_type>::value) | ||||||
|  |         : c() {} | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     queue(const queue& __q) : c(__q.c) {} | ||||||
|  |  | ||||||
|  | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     queue(queue&& __q) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_constructible<container_type>::value) | ||||||
|  |         : c(_VSTD::move(__q.c)) {} | ||||||
|  | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     queue& operator=(const queue& __q) {c = __q.c; return *this;} | ||||||
|  |  | ||||||
|  | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     queue& operator=(queue&& __q) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_assignable<container_type>::value) | ||||||
|  |         {c = _VSTD::move(__q.c); return *this;} | ||||||
|  | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit queue(const container_type& __c)  : c(__c) {} |     explicit queue(const container_type& __c)  : c(__c) {} | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit queue(container_type&& __c) : c(_STD::move(__c)) {} |     explicit queue(container_type&& __c) : c(_VSTD::move(__c)) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |  | ||||||
|     queue(queue&& __q) : c(_STD::move(__q.c)) {} |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     template <class _Alloc> |     template <class _Alloc> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -214,20 +254,14 @@ public: | |||||||
|         queue(container_type&& __c, const _Alloc& __a, |         queue(container_type&& __c, const _Alloc& __a, | ||||||
|                        typename enable_if<uses_allocator<container_type, |                        typename enable_if<uses_allocator<container_type, | ||||||
|                                                          _Alloc>::value>::type* = 0) |                                                          _Alloc>::value>::type* = 0) | ||||||
|             : c(_STD::move(__c), __a) {} |             : c(_VSTD::move(__c), __a) {} | ||||||
|     template <class _Alloc> |     template <class _Alloc> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         queue(queue&& __q, const _Alloc& __a, |         queue(queue&& __q, const _Alloc& __a, | ||||||
|                        typename enable_if<uses_allocator<container_type, |                        typename enable_if<uses_allocator<container_type, | ||||||
|                                                          _Alloc>::value>::type* = 0) |                                                          _Alloc>::value>::type* = 0) | ||||||
|             : c(_STD::move(__q.c), __a) {} |             : c(_VSTD::move(__q.c), __a) {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |  | ||||||
|     queue& operator=(queue&& __q) |  | ||||||
|     { |  | ||||||
|         c = _STD::move(__q.c); |  | ||||||
|         return *this; |  | ||||||
|     } |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -248,12 +282,12 @@ public: | |||||||
|     void push(const value_type& __v) {c.push_back(__v);} |     void push(const value_type& __v) {c.push_back(__v);} | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void push(value_type&& __v)      {c.push_back(_STD::move(__v));} |     void push(value_type&& __v)      {c.push_back(_VSTD::move(__v));} | ||||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
|     template <class... _Args> |     template <class... _Args> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         void emplace(_Args&&... __args) |         void emplace(_Args&&... __args) | ||||||
|             {c.emplace_back(_STD::forward<_Args>(__args)...);} |             {c.emplace_back(_VSTD::forward<_Args>(__args)...);} | ||||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -261,8 +295,9 @@ public: | |||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(queue& __q) |     void swap(queue& __q) | ||||||
|  |         _NOEXCEPT_(__is_nothrow_swappable<container_type>::value) | ||||||
|     { |     { | ||||||
|         using _STD::swap; |         using _VSTD::swap; | ||||||
|         swap(c, __q.c); |         swap(c, __q.c); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -331,6 +366,7 @@ template <class _Tp, class _Container> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| void | void | ||||||
| swap(queue<_Tp, _Container>& __x, queue<_Tp, _Container>& __y) | swap(queue<_Tp, _Container>& __x, queue<_Tp, _Container>& __y) | ||||||
|  |     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||||
| { | { | ||||||
|     __x.swap(__y); |     __x.swap(__y); | ||||||
| } | } | ||||||
| @@ -359,7 +395,36 @@ protected: | |||||||
|  |  | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit priority_queue(const value_compare& __comp = value_compare()) |     priority_queue() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<container_type>::value && | ||||||
|  |                    is_nothrow_default_constructible<value_compare>::value) | ||||||
|  |         : c(), comp() {} | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     priority_queue(const priority_queue& __q) : c(__q.c), comp(__q.comp) {} | ||||||
|  |  | ||||||
|  | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     priority_queue(priority_queue&& __q) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_constructible<container_type>::value && | ||||||
|  |                    is_nothrow_move_constructible<value_compare>::value) | ||||||
|  |         : c(_VSTD::move(__q.c)), comp(_VSTD::move(__q.comp)) {} | ||||||
|  | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     priority_queue& operator=(const priority_queue& __q) | ||||||
|  |         {c = __q.c; comp = __q.comp; return *this;} | ||||||
|  |  | ||||||
|  | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     priority_queue& operator=(priority_queue&& __q) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_assignable<container_type>::value && | ||||||
|  |                    is_nothrow_move_assignable<value_compare>::value) | ||||||
|  |         {c = _VSTD::move(__q.c); comp = _VSTD::move(__q.comp); return *this;} | ||||||
|  | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     explicit priority_queue(const value_compare& __comp) | ||||||
|         : c(), comp(__comp) {} |         : c(), comp(__comp) {} | ||||||
|     priority_queue(const value_compare& __comp, const container_type& __c); |     priority_queue(const value_compare& __comp, const container_type& __c); | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -375,8 +440,6 @@ public: | |||||||
|     template <class _InputIter> |     template <class _InputIter> | ||||||
|         priority_queue(_InputIter __f, _InputIter __l, |         priority_queue(_InputIter __f, _InputIter __l, | ||||||
|                        const value_compare& __comp, container_type&& __c); |                        const value_compare& __comp, container_type&& __c); | ||||||
|     priority_queue(priority_queue&& __q); |  | ||||||
|     priority_queue& operator=(priority_queue&& __q); |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     template <class _Alloc> |     template <class _Alloc> | ||||||
|         explicit priority_queue(const _Alloc& __a, |         explicit priority_queue(const _Alloc& __a, | ||||||
| @@ -423,7 +486,9 @@ public: | |||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     void pop(); |     void pop(); | ||||||
|  |  | ||||||
|     void swap(priority_queue& __q); |     void swap(priority_queue& __q) | ||||||
|  |         _NOEXCEPT_(__is_nothrow_swappable<container_type>::value && | ||||||
|  |                    __is_nothrow_swappable<value_compare>::value); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _Tp, class _Container, class _Compare> | template <class _Tp, class _Container, class _Compare> | ||||||
| @@ -433,7 +498,7 @@ priority_queue<_Tp, _Container, _Compare>::priority_queue(const _Compare& __comp | |||||||
|     : c(__c), |     : c(__c), | ||||||
|       comp(__comp) |       comp(__comp) | ||||||
| { | { | ||||||
|     _STD::make_heap(c.begin(), c.end(), comp); |     _VSTD::make_heap(c.begin(), c.end(), comp); | ||||||
| } | } | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -442,10 +507,10 @@ template <class _Tp, class _Container, class _Compare> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| priority_queue<_Tp, _Container, _Compare>::priority_queue(const value_compare& __comp, | priority_queue<_Tp, _Container, _Compare>::priority_queue(const value_compare& __comp, | ||||||
|                                                           container_type&& __c) |                                                           container_type&& __c) | ||||||
|     : c(_STD::move(__c)), |     : c(_VSTD::move(__c)), | ||||||
|       comp(__comp) |       comp(__comp) | ||||||
| { | { | ||||||
|     _STD::make_heap(c.begin(), c.end(), comp); |     _VSTD::make_heap(c.begin(), c.end(), comp); | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -458,7 +523,7 @@ priority_queue<_Tp, _Container, _Compare>::priority_queue(_InputIter __f, _Input | |||||||
|     : c(__f, __l), |     : c(__f, __l), | ||||||
|       comp(__comp) |       comp(__comp) | ||||||
| { | { | ||||||
|     _STD::make_heap(c.begin(), c.end(), comp); |     _VSTD::make_heap(c.begin(), c.end(), comp); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, class _Container, class _Compare> | template <class _Tp, class _Container, class _Compare> | ||||||
| @@ -471,7 +536,7 @@ priority_queue<_Tp, _Container, _Compare>::priority_queue(_InputIter __f, _Input | |||||||
|       comp(__comp) |       comp(__comp) | ||||||
| { | { | ||||||
|     c.insert(c.end(), __f, __l); |     c.insert(c.end(), __f, __l); | ||||||
|     _STD::make_heap(c.begin(), c.end(), comp); |     _VSTD::make_heap(c.begin(), c.end(), comp); | ||||||
| } | } | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -482,28 +547,11 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| priority_queue<_Tp, _Container, _Compare>::priority_queue(_InputIter __f, _InputIter __l, | priority_queue<_Tp, _Container, _Compare>::priority_queue(_InputIter __f, _InputIter __l, | ||||||
|                                                           const value_compare& __comp, |                                                           const value_compare& __comp, | ||||||
|                                                           container_type&& __c) |                                                           container_type&& __c) | ||||||
|     : c(_STD::move(__c)), |     : c(_VSTD::move(__c)), | ||||||
|       comp(__comp) |       comp(__comp) | ||||||
| { | { | ||||||
|     c.insert(c.end(), __f, __l); |     c.insert(c.end(), __f, __l); | ||||||
|     _STD::make_heap(c.begin(), c.end(), comp); |     _VSTD::make_heap(c.begin(), c.end(), comp); | ||||||
| } |  | ||||||
|  |  | ||||||
| template <class _Tp, class _Container, class _Compare> |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY |  | ||||||
| priority_queue<_Tp, _Container, _Compare>::priority_queue(priority_queue&& __q) |  | ||||||
|     : c(_STD::move(__q.c)), |  | ||||||
|       comp(_STD::move(__q.comp)) |  | ||||||
| { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| template <class _Tp, class _Container, class _Compare> |  | ||||||
| priority_queue<_Tp, _Container, _Compare>& |  | ||||||
| priority_queue<_Tp, _Container, _Compare>::operator=(priority_queue&& __q) |  | ||||||
| { |  | ||||||
|     c = _STD::move(__q.c); |  | ||||||
|     comp = _STD::move(__q.comp); |  | ||||||
|     return *this; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -541,7 +589,7 @@ priority_queue<_Tp, _Container, _Compare>::priority_queue(const value_compare& _ | |||||||
|     : c(__c, __a), |     : c(__c, __a), | ||||||
|       comp(__comp) |       comp(__comp) | ||||||
| { | { | ||||||
|     _STD::make_heap(c.begin(), c.end(), comp); |     _VSTD::make_heap(c.begin(), c.end(), comp); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, class _Container, class _Compare> | template <class _Tp, class _Container, class _Compare> | ||||||
| @@ -554,7 +602,7 @@ priority_queue<_Tp, _Container, _Compare>::priority_queue(const priority_queue& | |||||||
|     : c(__q.c, __a), |     : c(__q.c, __a), | ||||||
|       comp(__q.comp) |       comp(__q.comp) | ||||||
| { | { | ||||||
|     _STD::make_heap(c.begin(), c.end(), comp); |     _VSTD::make_heap(c.begin(), c.end(), comp); | ||||||
| } | } | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -567,10 +615,10 @@ priority_queue<_Tp, _Container, _Compare>::priority_queue(const value_compare& _ | |||||||
|                                                           const _Alloc& __a, |                                                           const _Alloc& __a, | ||||||
|                        typename enable_if<uses_allocator<container_type, |                        typename enable_if<uses_allocator<container_type, | ||||||
|                                                          _Alloc>::value>::type*) |                                                          _Alloc>::value>::type*) | ||||||
|     : c(_STD::move(__c), __a), |     : c(_VSTD::move(__c), __a), | ||||||
|       comp(__comp) |       comp(__comp) | ||||||
| { | { | ||||||
|     _STD::make_heap(c.begin(), c.end(), comp); |     _VSTD::make_heap(c.begin(), c.end(), comp); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp, class _Container, class _Compare> | template <class _Tp, class _Container, class _Compare> | ||||||
| @@ -580,10 +628,10 @@ priority_queue<_Tp, _Container, _Compare>::priority_queue(priority_queue&& __q, | |||||||
|                                                           const _Alloc& __a, |                                                           const _Alloc& __a, | ||||||
|                        typename enable_if<uses_allocator<container_type, |                        typename enable_if<uses_allocator<container_type, | ||||||
|                                                          _Alloc>::value>::type*) |                                                          _Alloc>::value>::type*) | ||||||
|     : c(_STD::move(__q.c), __a), |     : c(_VSTD::move(__q.c), __a), | ||||||
|       comp(_STD::move(__q.comp)) |       comp(_VSTD::move(__q.comp)) | ||||||
| { | { | ||||||
|     _STD::make_heap(c.begin(), c.end(), comp); |     _VSTD::make_heap(c.begin(), c.end(), comp); | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -594,7 +642,7 @@ void | |||||||
| priority_queue<_Tp, _Container, _Compare>::push(const value_type& __v) | priority_queue<_Tp, _Container, _Compare>::push(const value_type& __v) | ||||||
| { | { | ||||||
|     c.push_back(__v); |     c.push_back(__v); | ||||||
|     _STD::push_heap(c.begin(), c.end(), comp); |     _VSTD::push_heap(c.begin(), c.end(), comp); | ||||||
| } | } | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -604,8 +652,8 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| void | void | ||||||
| priority_queue<_Tp, _Container, _Compare>::push(value_type&& __v) | priority_queue<_Tp, _Container, _Compare>::push(value_type&& __v) | ||||||
| { | { | ||||||
|     c.push_back(_STD::move(__v)); |     c.push_back(_VSTD::move(__v)); | ||||||
|     _STD::push_heap(c.begin(), c.end(), comp); |     _VSTD::push_heap(c.begin(), c.end(), comp); | ||||||
| } | } | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
| @@ -616,8 +664,8 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| void | void | ||||||
| priority_queue<_Tp, _Container, _Compare>::emplace(_Args&&... __args) | priority_queue<_Tp, _Container, _Compare>::emplace(_Args&&... __args) | ||||||
| { | { | ||||||
|     c.emplace_back(_STD::forward<_Args>(__args)...); |     c.emplace_back(_VSTD::forward<_Args>(__args)...); | ||||||
|     _STD::push_heap(c.begin(), c.end(), comp); |     _VSTD::push_heap(c.begin(), c.end(), comp); | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||||
| @@ -628,7 +676,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| void | void | ||||||
| priority_queue<_Tp, _Container, _Compare>::pop() | priority_queue<_Tp, _Container, _Compare>::pop() | ||||||
| { | { | ||||||
|     _STD::pop_heap(c.begin(), c.end(), comp); |     _VSTD::pop_heap(c.begin(), c.end(), comp); | ||||||
|     c.pop_back(); |     c.pop_back(); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -636,8 +684,10 @@ template <class _Tp, class _Container, class _Compare> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| void | void | ||||||
| priority_queue<_Tp, _Container, _Compare>::swap(priority_queue& __q) | priority_queue<_Tp, _Container, _Compare>::swap(priority_queue& __q) | ||||||
|  |         _NOEXCEPT_(__is_nothrow_swappable<container_type>::value && | ||||||
|  |                    __is_nothrow_swappable<value_compare>::value) | ||||||
| { | { | ||||||
|     using _STD::swap; |     using _VSTD::swap; | ||||||
|     swap(c, __q.c); |     swap(c, __q.c); | ||||||
|     swap(comp, __q.comp); |     swap(comp, __q.comp); | ||||||
| } | } | ||||||
| @@ -647,6 +697,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| void | void | ||||||
| swap(priority_queue<_Tp, _Container, _Compare>& __x, | swap(priority_queue<_Tp, _Container, _Compare>& __x, | ||||||
|      priority_queue<_Tp, _Container, _Compare>& __y) |      priority_queue<_Tp, _Container, _Compare>& __y) | ||||||
|  |     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||||
| { | { | ||||||
|     __x.swap(__y); |     __x.swap(__y); | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										132
									
								
								include/random
									
									
									
									
									
								
							
							
						
						
									
										132
									
								
								include/random
									
									
									
									
									
								
							| @@ -2313,37 +2313,37 @@ operator==(const mersenne_twister_engine<_UI, _W, _N, _M, _R, _A, _U, _D, _S, | |||||||
|                                          _B, _T, _C, _L, _F>& __y) |                                          _B, _T, _C, _L, _F>& __y) | ||||||
| { | { | ||||||
|     if (__x.__i_ == __y.__i_) |     if (__x.__i_ == __y.__i_) | ||||||
|         return _STD::equal(__x.__x_, __x.__x_ + _N, __y.__x_); |         return _VSTD::equal(__x.__x_, __x.__x_ + _N, __y.__x_); | ||||||
|     if (__x.__i_ == 0 || __y.__i_ == 0) |     if (__x.__i_ == 0 || __y.__i_ == 0) | ||||||
|     { |     { | ||||||
|         size_t __j = _STD::min(_N - __x.__i_, _N - __y.__i_); |         size_t __j = _VSTD::min(_N - __x.__i_, _N - __y.__i_); | ||||||
|         if (!_STD::equal(__x.__x_ + __x.__i_, __x.__x_ + __x.__i_ + __j, |         if (!_VSTD::equal(__x.__x_ + __x.__i_, __x.__x_ + __x.__i_ + __j, | ||||||
|                          __y.__x_ + __y.__i_)) |                          __y.__x_ + __y.__i_)) | ||||||
|             return false; |             return false; | ||||||
|         if (__x.__i_ == 0) |         if (__x.__i_ == 0) | ||||||
|             return _STD::equal(__x.__x_ + __j, __x.__x_ + _N, __y.__x_); |             return _VSTD::equal(__x.__x_ + __j, __x.__x_ + _N, __y.__x_); | ||||||
|         return _STD::equal(__x.__x_, __x.__x_ + (_N - __j), __y.__x_ + __j); |         return _VSTD::equal(__x.__x_, __x.__x_ + (_N - __j), __y.__x_ + __j); | ||||||
|     } |     } | ||||||
|     if (__x.__i_ < __y.__i_) |     if (__x.__i_ < __y.__i_) | ||||||
|     { |     { | ||||||
|         size_t __j = _N - __y.__i_; |         size_t __j = _N - __y.__i_; | ||||||
|         if (!_STD::equal(__x.__x_ + __x.__i_, __x.__x_ + (__x.__i_ + __j), |         if (!_VSTD::equal(__x.__x_ + __x.__i_, __x.__x_ + (__x.__i_ + __j), | ||||||
|                          __y.__x_ + __y.__i_)) |                          __y.__x_ + __y.__i_)) | ||||||
|             return false; |             return false; | ||||||
|         if (!_STD::equal(__x.__x_ + (__x.__i_ + __j), __x.__x_ + _N, |         if (!_VSTD::equal(__x.__x_ + (__x.__i_ + __j), __x.__x_ + _N, | ||||||
|                          __y.__x_)) |                          __y.__x_)) | ||||||
|             return false; |             return false; | ||||||
|         return _STD::equal(__x.__x_, __x.__x_ + __x.__i_, |         return _VSTD::equal(__x.__x_, __x.__x_ + __x.__i_, | ||||||
|                            __y.__x_ + (_N - (__x.__i_ + __j))); |                            __y.__x_ + (_N - (__x.__i_ + __j))); | ||||||
|     } |     } | ||||||
|     size_t __j = _N - __x.__i_; |     size_t __j = _N - __x.__i_; | ||||||
|     if (!_STD::equal(__y.__x_ + __y.__i_, __y.__x_ + (__y.__i_ + __j), |     if (!_VSTD::equal(__y.__x_ + __y.__i_, __y.__x_ + (__y.__i_ + __j), | ||||||
|                      __x.__x_ + __x.__i_)) |                      __x.__x_ + __x.__i_)) | ||||||
|         return false; |         return false; | ||||||
|     if (!_STD::equal(__y.__x_ + (__y.__i_ + __j), __y.__x_ + _N, |     if (!_VSTD::equal(__y.__x_ + (__y.__i_ + __j), __y.__x_ + _N, | ||||||
|                      __x.__x_)) |                      __x.__x_)) | ||||||
|         return false; |         return false; | ||||||
|     return _STD::equal(__y.__x_, __y.__x_ + __y.__i_, |     return _VSTD::equal(__y.__x_, __y.__x_ + __y.__i_, | ||||||
|                        __x.__x_ + (_N - (__y.__i_ + __j))); |                        __x.__x_ + (_N - (__y.__i_ + __j))); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -2621,37 +2621,37 @@ operator==( | |||||||
|     if (__x.__c_ != __y.__c_) |     if (__x.__c_ != __y.__c_) | ||||||
|         return false; |         return false; | ||||||
|     if (__x.__i_ == __y.__i_) |     if (__x.__i_ == __y.__i_) | ||||||
|         return _STD::equal(__x.__x_, __x.__x_ + _R, __y.__x_); |         return _VSTD::equal(__x.__x_, __x.__x_ + _R, __y.__x_); | ||||||
|     if (__x.__i_ == 0 || __y.__i_ == 0) |     if (__x.__i_ == 0 || __y.__i_ == 0) | ||||||
|     { |     { | ||||||
|         size_t __j = _STD::min(_R - __x.__i_, _R - __y.__i_); |         size_t __j = _VSTD::min(_R - __x.__i_, _R - __y.__i_); | ||||||
|         if (!_STD::equal(__x.__x_ + __x.__i_, __x.__x_ + __x.__i_ + __j, |         if (!_VSTD::equal(__x.__x_ + __x.__i_, __x.__x_ + __x.__i_ + __j, | ||||||
|                          __y.__x_ + __y.__i_)) |                          __y.__x_ + __y.__i_)) | ||||||
|             return false; |             return false; | ||||||
|         if (__x.__i_ == 0) |         if (__x.__i_ == 0) | ||||||
|             return _STD::equal(__x.__x_ + __j, __x.__x_ + _R, __y.__x_); |             return _VSTD::equal(__x.__x_ + __j, __x.__x_ + _R, __y.__x_); | ||||||
|         return _STD::equal(__x.__x_, __x.__x_ + (_R - __j), __y.__x_ + __j); |         return _VSTD::equal(__x.__x_, __x.__x_ + (_R - __j), __y.__x_ + __j); | ||||||
|     } |     } | ||||||
|     if (__x.__i_ < __y.__i_) |     if (__x.__i_ < __y.__i_) | ||||||
|     { |     { | ||||||
|         size_t __j = _R - __y.__i_; |         size_t __j = _R - __y.__i_; | ||||||
|         if (!_STD::equal(__x.__x_ + __x.__i_, __x.__x_ + (__x.__i_ + __j), |         if (!_VSTD::equal(__x.__x_ + __x.__i_, __x.__x_ + (__x.__i_ + __j), | ||||||
|                          __y.__x_ + __y.__i_)) |                          __y.__x_ + __y.__i_)) | ||||||
|             return false; |             return false; | ||||||
|         if (!_STD::equal(__x.__x_ + (__x.__i_ + __j), __x.__x_ + _R, |         if (!_VSTD::equal(__x.__x_ + (__x.__i_ + __j), __x.__x_ + _R, | ||||||
|                          __y.__x_)) |                          __y.__x_)) | ||||||
|             return false; |             return false; | ||||||
|         return _STD::equal(__x.__x_, __x.__x_ + __x.__i_, |         return _VSTD::equal(__x.__x_, __x.__x_ + __x.__i_, | ||||||
|                            __y.__x_ + (_R - (__x.__i_ + __j))); |                            __y.__x_ + (_R - (__x.__i_ + __j))); | ||||||
|     } |     } | ||||||
|     size_t __j = _R - __x.__i_; |     size_t __j = _R - __x.__i_; | ||||||
|     if (!_STD::equal(__y.__x_ + __y.__i_, __y.__x_ + (__y.__i_ + __j), |     if (!_VSTD::equal(__y.__x_ + __y.__i_, __y.__x_ + (__y.__i_ + __j), | ||||||
|                      __x.__x_ + __x.__i_)) |                      __x.__x_ + __x.__i_)) | ||||||
|         return false; |         return false; | ||||||
|     if (!_STD::equal(__y.__x_ + (__y.__i_ + __j), __y.__x_ + _R, |     if (!_VSTD::equal(__y.__x_ + (__y.__i_ + __j), __y.__x_ + _R, | ||||||
|                      __x.__x_)) |                      __x.__x_)) | ||||||
|         return false; |         return false; | ||||||
|     return _STD::equal(__y.__x_, __y.__x_ + __y.__i_, |     return _VSTD::equal(__y.__x_, __y.__x_ + __y.__i_, | ||||||
|                        __x.__x_ + (_R - (__y.__i_ + __j))); |                        __x.__x_ + (_R - (__y.__i_ + __j))); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -2744,7 +2744,7 @@ public: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit discard_block_engine(_Engine&& __e) |     explicit discard_block_engine(_Engine&& __e) | ||||||
|         : __e_(_STD::move(__e)), __n_(0) {} |         : __e_(_VSTD::move(__e)), __n_(0) {} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit discard_block_engine(result_type __sd) : __e_(__sd), __n_(0) {} |     explicit discard_block_engine(result_type __sd) : __e_(__sd), __n_(0) {} | ||||||
| @@ -2944,7 +2944,7 @@ public: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit independent_bits_engine(_Engine&& __e) |     explicit independent_bits_engine(_Engine&& __e) | ||||||
|         : __e_(_STD::move(__e)) {} |         : __e_(_VSTD::move(__e)) {} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit independent_bits_engine(result_type __sd) : __e_(__sd) {} |     explicit independent_bits_engine(result_type __sd) : __e_(__sd) {} | ||||||
| @@ -3167,7 +3167,7 @@ public: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit shuffle_order_engine(_Engine&& __e) |     explicit shuffle_order_engine(_Engine&& __e) | ||||||
|         : __e_(_STD::move(__e)) {__init();} |         : __e_(_VSTD::move(__e)) {__init();} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit shuffle_order_engine(result_type __sd) : __e_(__sd) {__init();} |     explicit shuffle_order_engine(result_type __sd) : __e_(__sd) {__init();} | ||||||
| @@ -3292,7 +3292,7 @@ operator==( | |||||||
|     const shuffle_order_engine<_Eng, _K>& __x, |     const shuffle_order_engine<_Eng, _K>& __x, | ||||||
|     const shuffle_order_engine<_Eng, _K>& __y) |     const shuffle_order_engine<_Eng, _K>& __y) | ||||||
| { | { | ||||||
|     return __x._Y_ == __y._Y_ && _STD::equal(__x._V_, __x._V_ + _K, __y._V_) && |     return __x._Y_ == __y._Y_ && _VSTD::equal(__x._V_, __x._V_ + _K, __y._V_) && | ||||||
|            __x.__e_ == __y.__e_; |            __x.__e_ == __y.__e_; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -3418,7 +3418,7 @@ public: | |||||||
|     template<class _OutputIterator> |     template<class _OutputIterator> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         void param(_OutputIterator __dest) const |         void param(_OutputIterator __dest) const | ||||||
|             {_STD::copy(__v_.begin(), __v_.end(), __dest);} |             {_VSTD::copy(__v_.begin(), __v_.end(), __dest);} | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     // no copy functions |     // no copy functions | ||||||
| @@ -3443,7 +3443,7 @@ seed_seq::generate(_RandomAccessIterator __first, _RandomAccessIterator __last) | |||||||
| { | { | ||||||
|     if (__first != __last) |     if (__first != __last) | ||||||
|     { |     { | ||||||
|         _STD::fill(__first, __last, 0x8b8b8b8b); |         _VSTD::fill(__first, __last, 0x8b8b8b8b); | ||||||
|         const size_t __n = static_cast<size_t>(__last - __first); |         const size_t __n = static_cast<size_t>(__last - __first); | ||||||
|         const size_t __s = __v_.size(); |         const size_t __s = __v_.size(); | ||||||
|         const size_t __t = (__n >= 623) ? 11 |         const size_t __t = (__n >= 623) ? 11 | ||||||
| @@ -3453,7 +3453,7 @@ seed_seq::generate(_RandomAccessIterator __first, _RandomAccessIterator __last) | |||||||
|                          : (__n - 1) / 2; |                          : (__n - 1) / 2; | ||||||
|         const size_t __p = (__n - __t) / 2; |         const size_t __p = (__n - __t) / 2; | ||||||
|         const size_t __q = __p + __t; |         const size_t __q = __p + __t; | ||||||
|         const size_t __m = _STD::max(__s + 1, __n); |         const size_t __m = _VSTD::max(__s + 1, __n); | ||||||
|         // __k = 0; |         // __k = 0; | ||||||
|         { |         { | ||||||
|             result_type __r = 1664525 * _T(__first[0] ^ __first[__p] |             result_type __r = 1664525 * _T(__first[0] ^ __first[__p] | ||||||
| @@ -3639,7 +3639,7 @@ typename uniform_real_distribution<_RealType>::result_type | |||||||
| uniform_real_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) | uniform_real_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) | ||||||
| { | { | ||||||
|     return (__p.b() - __p.a()) |     return (__p.b() - __p.a()) | ||||||
|         * _STD::generate_canonical<_RealType, numeric_limits<_RealType>::digits>(__g) |         * _VSTD::generate_canonical<_RealType, numeric_limits<_RealType>::digits>(__g) | ||||||
|         + __p.a(); |         + __p.a(); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -3871,9 +3871,9 @@ binomial_distribution<_IntType>::param_type::param_type(result_type __t, double | |||||||
|     if (0 < __p_ && __p_ < 1) |     if (0 < __p_ && __p_ < 1) | ||||||
|     { |     { | ||||||
|         __r0_ = static_cast<result_type>((__t_ + 1) * __p_); |         __r0_ = static_cast<result_type>((__t_ + 1) * __p_); | ||||||
|         __pr_ = _STD::exp(_STD::lgamma(__t_ + 1.) - _STD::lgamma(__r0_ + 1.) - |         __pr_ = _VSTD::exp(_VSTD::lgamma(__t_ + 1.) - _VSTD::lgamma(__r0_ + 1.) - | ||||||
|                           _STD::lgamma(__t_ - __r0_ + 1.) + __r0_ * _STD::log(__p_) + |                           _VSTD::lgamma(__t_ - __r0_ + 1.) + __r0_ * _VSTD::log(__p_) + | ||||||
|                           (__t_ - __r0_) * _STD::log(1 - __p_)); |                           (__t_ - __r0_) * _VSTD::log(1 - __p_)); | ||||||
|         __odds_ratio_ = __p_ / (1 - __p_); |         __odds_ratio_ = __p_ / (1 - __p_); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -4025,10 +4025,10 @@ template<class _URNG> | |||||||
| _RealType | _RealType | ||||||
| exponential_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) | exponential_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) | ||||||
| { | { | ||||||
|     return -_STD::log |     return -_VSTD::log | ||||||
|                   ( |                   ( | ||||||
|                       result_type(1) - |                       result_type(1) - | ||||||
|                       _STD::generate_canonical<result_type, |                       _VSTD::generate_canonical<result_type, | ||||||
|                                        numeric_limits<result_type>::digits>(__g) |                                        numeric_limits<result_type>::digits>(__g) | ||||||
|                   ) |                   ) | ||||||
|                   / __p.lambda(); |                   / __p.lambda(); | ||||||
| @@ -4180,7 +4180,7 @@ normal_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) | |||||||
|             __v = _Uni(__g); |             __v = _Uni(__g); | ||||||
|             __s = __u * __u + __v * __v; |             __s = __u * __u + __v * __v; | ||||||
|         } while (__s > 1 || __s == 0); |         } while (__s > 1 || __s == 0); | ||||||
|         result_type _F = _STD::sqrt(-2 * _STD::log(__s) / __s); |         result_type _F = _VSTD::sqrt(-2 * _VSTD::log(__s) / __s); | ||||||
|         _V_ = __v * _F; |         _V_ = __v * _F; | ||||||
|         _V_hot_ = true; |         _V_hot_ = true; | ||||||
|         _U = __u * _F; |         _U = __u * _F; | ||||||
| @@ -4297,7 +4297,7 @@ public: | |||||||
|     template<class _URNG> |     template<class _URNG> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         result_type operator()(_URNG& __g, const param_type& __p) |         result_type operator()(_URNG& __g, const param_type& __p) | ||||||
|         {return _STD::exp(const_cast<normal_distribution<result_type>&>(__p.__nd_)(__g));} |         {return _VSTD::exp(const_cast<normal_distribution<result_type>&>(__p.__nd_)(__g));} | ||||||
|  |  | ||||||
|     // property functions |     // property functions | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -4446,7 +4446,7 @@ poisson_distribution<_IntType>::param_type::param_type(double __mean) | |||||||
|     { |     { | ||||||
|         __s_ = 0; |         __s_ = 0; | ||||||
|         __d_ = 0; |         __d_ = 0; | ||||||
|         __l_ = _STD::exp(-__mean_); |         __l_ = _VSTD::exp(-__mean_); | ||||||
|         __omega_ = 0; |         __omega_ = 0; | ||||||
|         __c3_ = 0; |         __c3_ = 0; | ||||||
|         __c2_ = 0; |         __c2_ = 0; | ||||||
| @@ -4456,7 +4456,7 @@ poisson_distribution<_IntType>::param_type::param_type(double __mean) | |||||||
|     } |     } | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
|         __s_ = _STD::sqrt(__mean_); |         __s_ = _VSTD::sqrt(__mean_); | ||||||
|         __d_ = 6 * __mean_ * __mean_; |         __d_ = 6 * __mean_ * __mean_; | ||||||
|         __l_ = static_cast<result_type>(__mean_ - 1.1484); |         __l_ = static_cast<result_type>(__mean_ - 1.1484); | ||||||
|         __omega_ = .3989423 / __s_; |         __omega_ = .3989423 / __s_; | ||||||
| @@ -4523,20 +4523,20 @@ poisson_distribution<_IntType>::operator()(_URNG& __urng, const param_type& __pr | |||||||
|                 const result_type __fac[] = {1, 1, 2, 6, 24, 120, 720, 5040, |                 const result_type __fac[] = {1, 1, 2, 6, 24, 120, 720, 5040, | ||||||
|                                              40320, 362880}; |                                              40320, 362880}; | ||||||
|                 __px = -__pr.__mean_; |                 __px = -__pr.__mean_; | ||||||
|                 __py = _STD::pow(__pr.__mean_, (double)__x) / __fac[__x]; |                 __py = _VSTD::pow(__pr.__mean_, (double)__x) / __fac[__x]; | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             { |             { | ||||||
|                 double __del = .8333333E-1 / __x; |                 double __del = .8333333E-1 / __x; | ||||||
|                 __del -= 4.8 * __del * __del * __del; |                 __del -= 4.8 * __del * __del * __del; | ||||||
|                 double __v = __difmuk / __x; |                 double __v = __difmuk / __x; | ||||||
|                 if (_STD::abs(__v) > 0.25) |                 if (_VSTD::abs(__v) > 0.25) | ||||||
|                     __px = __x * _STD::log(1 + __v) - __difmuk - __del; |                     __px = __x * _VSTD::log(1 + __v) - __difmuk - __del; | ||||||
|                 else |                 else | ||||||
|                     __px = __x * __v * __v * (((((((.1250060 * __v + -.1384794) * |                     __px = __x * __v * __v * (((((((.1250060 * __v + -.1384794) * | ||||||
|                            __v + .1421878) * __v + -.1661269) * __v + .2000118) * |                            __v + .1421878) * __v + -.1661269) * __v + .2000118) * | ||||||
|                            __v + -.2500068) * __v + .3333333) * __v + -.5) - __del; |                            __v + -.2500068) * __v + .3333333) * __v + -.5) - __del; | ||||||
|                 __py = .3989423 / _STD::sqrt(__x); |                 __py = .3989423 / _VSTD::sqrt(__x); | ||||||
|             } |             } | ||||||
|             double __r = (0.5 - __difmuk) / __pr.__s_; |             double __r = (0.5 - __difmuk) / __pr.__s_; | ||||||
|             double __r2 = __r * __r; |             double __r2 = __r * __r; | ||||||
| @@ -4545,13 +4545,13 @@ poisson_distribution<_IntType>::operator()(_URNG& __urng, const param_type& __pr | |||||||
|                                         __r2 + __pr.__c1_) * __r2 + __pr.__c0_); |                                         __r2 + __pr.__c1_) * __r2 + __pr.__c0_); | ||||||
|             if (__using_exp_dist) |             if (__using_exp_dist) | ||||||
|             { |             { | ||||||
|                 if (__pr.__c_ * _STD::abs(__u) <= __py * _STD::exp(__px + __e) - |                 if (__pr.__c_ * _VSTD::abs(__u) <= __py * _VSTD::exp(__px + __e) - | ||||||
|                                                    __fy * _STD::exp(__fx + __e)) |                                                    __fy * _VSTD::exp(__fx + __e)) | ||||||
|                     break; |                     break; | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             { |             { | ||||||
|                 if (__fy - __u * __fy <= __py * _STD::exp(__px - __fx)) |                 if (__fy - __u * __fy <= __py * _VSTD::exp(__px - __fx)) | ||||||
|                     break; |                     break; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @@ -4642,7 +4642,7 @@ public: | |||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         result_type operator()(_URNG& __g, const param_type& __p) |         result_type operator()(_URNG& __g, const param_type& __p) | ||||||
|         {return __p.b() * |         {return __p.b() * | ||||||
|             _STD::pow(exponential_distribution<result_type>()(__g), 1/__p.a());} |             _VSTD::pow(exponential_distribution<result_type>()(__g), 1/__p.a());} | ||||||
|  |  | ||||||
|     // property functions |     // property functions | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -4786,7 +4786,7 @@ _RealType | |||||||
| extreme_value_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) | extreme_value_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) | ||||||
| { | { | ||||||
|     return __p.a() - __p.b() * |     return __p.a() - __p.b() * | ||||||
|          _STD::log(-_STD::log(1-uniform_real_distribution<result_type>()(__g))); |          _VSTD::log(-_VSTD::log(1-uniform_real_distribution<result_type>()(__g))); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _CharT, class _Traits, class _RT> | template <class _CharT, class _Traits, class _RT> | ||||||
| @@ -4923,7 +4923,7 @@ gamma_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) | |||||||
|             const result_type __w = __u * (1 - __u); |             const result_type __w = __u * (1 - __u); | ||||||
|             if (__w != 0) |             if (__w != 0) | ||||||
|             { |             { | ||||||
|                 const result_type __y = _STD::sqrt(__c / __w) * |                 const result_type __y = _VSTD::sqrt(__c / __w) * | ||||||
|                                         (__u - result_type(0.5)); |                                         (__u - result_type(0.5)); | ||||||
|                 __x = __b + __y; |                 __x = __b + __y; | ||||||
|                 if (__x >= 0) |                 if (__x >= 0) | ||||||
| @@ -4931,7 +4931,7 @@ gamma_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) | |||||||
|                     const result_type __z = 64 * __w * __w * __w * __v * __v; |                     const result_type __z = 64 * __w * __w * __w * __v * __v; | ||||||
|                     if (__z <= 1 - 2 * __y * __y / __x) |                     if (__z <= 1 - 2 * __y * __y / __x) | ||||||
|                         break; |                         break; | ||||||
|                     if (_STD::log(__z) <= 2 * (__b * _STD::log(__x / __b) - __y)) |                     if (_VSTD::log(__z) <= 2 * (__b * _VSTD::log(__x / __b) - __y)) | ||||||
|                         break; |                         break; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -4945,14 +4945,14 @@ gamma_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) | |||||||
|             const result_type __es = __egen(__g); |             const result_type __es = __egen(__g); | ||||||
|             if (__u <= 1 - __a) |             if (__u <= 1 - __a) | ||||||
|             { |             { | ||||||
|                 __x = _STD::pow(__u, 1 / __a); |                 __x = _VSTD::pow(__u, 1 / __a); | ||||||
|                 if (__x <= __es) |                 if (__x <= __es) | ||||||
|                     break; |                     break; | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             { |             { | ||||||
|                 const result_type __e = -_STD::log((1-__u)/__a); |                 const result_type __e = -_VSTD::log((1-__u)/__a); | ||||||
|                 __x = _STD::pow(1 - __a + __a * __e, 1 / __a); |                 __x = _VSTD::pow(1 - __a + __a * __e, 1 / __a); | ||||||
|                 if (__x <= __e + __es) |                 if (__x <= __e + __es) | ||||||
|                     break; |                     break; | ||||||
|             } |             } | ||||||
| @@ -5424,7 +5424,7 @@ cauchy_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) | |||||||
| { | { | ||||||
|     uniform_real_distribution<result_type> __gen; |     uniform_real_distribution<result_type> __gen; | ||||||
|     // purposefully let tan arg get as close to pi/2 as it wants, tan will return a finite |     // purposefully let tan arg get as close to pi/2 as it wants, tan will return a finite | ||||||
|     return __p.a() + __p.b() * _STD::tan(3.1415926535897932384626433832795 * __gen(__g)); |     return __p.a() + __p.b() * _VSTD::tan(3.1415926535897932384626433832795 * __gen(__g)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _CharT, class _Traits, class _RT> | template <class _CharT, class _Traits, class _RT> | ||||||
| @@ -5662,7 +5662,7 @@ _RealType | |||||||
| student_t_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) | student_t_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) | ||||||
| { | { | ||||||
|     gamma_distribution<result_type> __gd(__p.n() * .5, 2); |     gamma_distribution<result_type> __gd(__p.n() * .5, 2); | ||||||
|     return __nd_(__g) * _STD::sqrt(__p.n()/__gd(__g)); |     return __nd_(__g) * _VSTD::sqrt(__p.n()/__gd(__g)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _CharT, class _Traits, class _RT> | template <class _CharT, class _Traits, class _RT> | ||||||
| @@ -5843,12 +5843,12 @@ discrete_distribution<_IntType>::param_type::__init() | |||||||
|     { |     { | ||||||
|         if (__p_.size() > 1) |         if (__p_.size() > 1) | ||||||
|         { |         { | ||||||
|             double __s = _STD::accumulate(__p_.begin(), __p_.end(), 0.0); |             double __s = _VSTD::accumulate(__p_.begin(), __p_.end(), 0.0); | ||||||
|             for (_STD::vector<double>::iterator __i = __p_.begin(), __e = __p_.end(); |             for (_VSTD::vector<double>::iterator __i = __p_.begin(), __e = __p_.end(); | ||||||
|                                                                        __i < __e; ++__i) |                                                                        __i < __e; ++__i) | ||||||
|                 *__i /= __s; |                 *__i /= __s; | ||||||
|             vector<double> __t(__p_.size() - 1); |             vector<double> __t(__p_.size() - 1); | ||||||
|             _STD::partial_sum(__p_.begin(), __p_.end() - 1, __t.begin()); |             _VSTD::partial_sum(__p_.begin(), __p_.end() - 1, __t.begin()); | ||||||
|             swap(__p_, __t); |             swap(__p_, __t); | ||||||
|         } |         } | ||||||
|         else |         else | ||||||
| @@ -5864,8 +5864,8 @@ vector<double> | |||||||
| discrete_distribution<_IntType>::param_type::probabilities() const | discrete_distribution<_IntType>::param_type::probabilities() const | ||||||
| { | { | ||||||
|     size_t __n = __p_.size(); |     size_t __n = __p_.size(); | ||||||
|     _STD::vector<double> __p(__n+1); |     _VSTD::vector<double> __p(__n+1); | ||||||
|     _STD::adjacent_difference(__p_.begin(), __p_.end(), __p.begin()); |     _VSTD::adjacent_difference(__p_.begin(), __p_.end(), __p.begin()); | ||||||
|     if (__n > 0) |     if (__n > 0) | ||||||
|         __p[__n] = 1 - __p_[__n-1]; |         __p[__n] = 1 - __p_[__n-1]; | ||||||
|     else |     else | ||||||
| @@ -5880,7 +5880,7 @@ discrete_distribution<_IntType>::operator()(_URNG& __g, const param_type& __p) | |||||||
| { | { | ||||||
|     uniform_real_distribution<double> __gen; |     uniform_real_distribution<double> __gen; | ||||||
|     return static_cast<_IntType>( |     return static_cast<_IntType>( | ||||||
|            _STD::upper_bound(__p.__p_.begin(), __p.__p_.end(), __gen(__g)) - |            _VSTD::upper_bound(__p.__p_.begin(), __p.__p_.end(), __gen(__g)) - | ||||||
|                                                               __p.__p_.begin()); |                                                               __p.__p_.begin()); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -6079,14 +6079,14 @@ void | |||||||
| piecewise_constant_distribution<_RealType>::param_type::__init() | piecewise_constant_distribution<_RealType>::param_type::__init() | ||||||
| { | { | ||||||
|     // __densities_ contains non-normalized areas |     // __densities_ contains non-normalized areas | ||||||
|     result_type __total_area = _STD::accumulate(__densities_.begin(), |     result_type __total_area = _VSTD::accumulate(__densities_.begin(), | ||||||
|                                                 __densities_.end(), |                                                 __densities_.end(), | ||||||
|                                                 result_type()); |                                                 result_type()); | ||||||
|     for (size_t __i = 0; __i < __densities_.size(); ++__i) |     for (size_t __i = 0; __i < __densities_.size(); ++__i) | ||||||
|         __densities_[__i] /= __total_area; |         __densities_[__i] /= __total_area; | ||||||
|     // __densities_ contains normalized areas |     // __densities_ contains normalized areas | ||||||
|     __areas_.assign(__densities_.size(), result_type()); |     __areas_.assign(__densities_.size(), result_type()); | ||||||
|     _STD::partial_sum(__densities_.begin(), __densities_.end() - 1, |     _VSTD::partial_sum(__densities_.begin(), __densities_.end() - 1, | ||||||
|                                                           __areas_.begin() + 1); |                                                           __areas_.begin() + 1); | ||||||
|     // __areas_ contains partial sums of normalized areas: [0, __densities_ - 1] |     // __areas_ contains partial sums of normalized areas: [0, __densities_ - 1] | ||||||
|     __densities_.back() = 1 - __areas_.back();  // correct round off error |     __densities_.back() = 1 - __areas_.back();  // correct round off error | ||||||
| @@ -6175,7 +6175,7 @@ piecewise_constant_distribution<_RealType>::operator()(_URNG& __g, const param_t | |||||||
| { | { | ||||||
|     typedef uniform_real_distribution<result_type> _Gen; |     typedef uniform_real_distribution<result_type> _Gen; | ||||||
|     result_type __u = _Gen()(__g); |     result_type __u = _Gen()(__g); | ||||||
|     ptrdiff_t __k = _STD::upper_bound(__p.__areas_.begin(), __p.__areas_.end(), |     ptrdiff_t __k = _VSTD::upper_bound(__p.__areas_.begin(), __p.__areas_.end(), | ||||||
|                                       __u) - __p.__areas_.begin() - 1; |                                       __u) - __p.__areas_.begin() - 1; | ||||||
|     return (__u - __p.__areas_[__k]) / __p.__densities_[__k] + __p.__b_[__k]; |     return (__u - __p.__areas_[__k]) / __p.__densities_[__k] + __p.__b_[__k]; | ||||||
| } | } | ||||||
| @@ -6496,7 +6496,7 @@ piecewise_linear_distribution<_RealType>::operator()(_URNG& __g, const param_typ | |||||||
| { | { | ||||||
|     typedef uniform_real_distribution<result_type> _Gen; |     typedef uniform_real_distribution<result_type> _Gen; | ||||||
|     result_type __u = _Gen()(__g); |     result_type __u = _Gen()(__g); | ||||||
|     ptrdiff_t __k = _STD::upper_bound(__p.__areas_.begin(), __p.__areas_.end(), |     ptrdiff_t __k = _VSTD::upper_bound(__p.__areas_.begin(), __p.__areas_.end(), | ||||||
|                                       __u) - __p.__areas_.begin() - 1; |                                       __u) - __p.__areas_.begin() - 1; | ||||||
|     __u -= __p.__areas_[__k]; |     __u -= __p.__areas_[__k]; | ||||||
|     const result_type __dk = __p.__densities_[__k]; |     const result_type __dk = __p.__densities_[__k]; | ||||||
| @@ -6508,7 +6508,7 @@ piecewise_linear_distribution<_RealType>::operator()(_URNG& __g, const param_typ | |||||||
|     const result_type __bk1 = __p.__b_[__k+1]; |     const result_type __bk1 = __p.__b_[__k+1]; | ||||||
|     const result_type __deltab = __bk1 - __bk; |     const result_type __deltab = __bk1 - __bk; | ||||||
|     return (__bk * __dk1 - __bk1 * __dk + |     return (__bk * __dk1 - __bk1 * __dk + | ||||||
|         _STD::sqrt(__deltab * (__deltab * __dk * __dk + 2 * __deltad * __u))) / |         _VSTD::sqrt(__deltab * (__deltab * __dk * __dk + 2 * __deltad * __u))) / | ||||||
|         __deltad; |         __deltad; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -274,10 +274,19 @@ public: | |||||||
|         >::type type; |         >::type type; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||||
|  |  | ||||||
|  | template <class _R1, class _R2> using ratio_multiply | ||||||
|  |                                     = typename __ratio_multiply<_R1, _R2>::type; | ||||||
|  |  | ||||||
|  | #else  // _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||||
|  |  | ||||||
| template <class _R1, class _R2> | template <class _R1, class _R2> | ||||||
| struct _LIBCPP_VISIBLE ratio_multiply | struct _LIBCPP_VISIBLE ratio_multiply | ||||||
|     : public __ratio_multiply<_R1, _R2>::type {}; |     : public __ratio_multiply<_R1, _R2>::type {}; | ||||||
|  |  | ||||||
|  | #endif  // _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||||
|  |  | ||||||
| template <class _R1, class _R2> | template <class _R1, class _R2> | ||||||
| struct __ratio_divide | struct __ratio_divide | ||||||
| { | { | ||||||
| @@ -292,10 +301,19 @@ public: | |||||||
|         >::type type; |         >::type type; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||||
|  |  | ||||||
|  | template <class _R1, class _R2> using ratio_divide | ||||||
|  |                                       = typename __ratio_divide<_R1, _R2>::type; | ||||||
|  |  | ||||||
|  | #else  // _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||||
|  |  | ||||||
| template <class _R1, class _R2> | template <class _R1, class _R2> | ||||||
| struct _LIBCPP_VISIBLE ratio_divide | struct _LIBCPP_VISIBLE ratio_divide | ||||||
|     : public __ratio_divide<_R1, _R2>::type {}; |     : public __ratio_divide<_R1, _R2>::type {}; | ||||||
|  |  | ||||||
|  | #endif  // _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||||
|  |  | ||||||
| template <class _R1, class _R2> | template <class _R1, class _R2> | ||||||
| struct __ratio_add | struct __ratio_add | ||||||
| { | { | ||||||
| @@ -318,10 +336,19 @@ public: | |||||||
|         >::type type; |         >::type type; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||||
|  |  | ||||||
|  | template <class _R1, class _R2> using ratio_add | ||||||
|  |                                          = typename __ratio_add<_R1, _R2>::type; | ||||||
|  |  | ||||||
|  | #else  // _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||||
|  |  | ||||||
| template <class _R1, class _R2> | template <class _R1, class _R2> | ||||||
| struct _LIBCPP_VISIBLE ratio_add | struct _LIBCPP_VISIBLE ratio_add | ||||||
|     : public __ratio_add<_R1, _R2>::type {}; |     : public __ratio_add<_R1, _R2>::type {}; | ||||||
|  |  | ||||||
|  | #endif  // _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||||
|  |  | ||||||
| template <class _R1, class _R2> | template <class _R1, class _R2> | ||||||
| struct __ratio_subtract | struct __ratio_subtract | ||||||
| { | { | ||||||
| @@ -344,10 +371,19 @@ public: | |||||||
|         >::type type; |         >::type type; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||||
|  |  | ||||||
|  | template <class _R1, class _R2> using ratio_subtract | ||||||
|  |                                     = typename __ratio_subtract<_R1, _R2>::type; | ||||||
|  |  | ||||||
|  | #else  // _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||||
|  |  | ||||||
| template <class _R1, class _R2> | template <class _R1, class _R2> | ||||||
| struct _LIBCPP_VISIBLE ratio_subtract | struct _LIBCPP_VISIBLE ratio_subtract | ||||||
|     : public __ratio_subtract<_R1, _R2>::type {}; |     : public __ratio_subtract<_R1, _R2>::type {}; | ||||||
|  |  | ||||||
|  | #endif  // _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||||
|  |  | ||||||
| // ratio_equal | // ratio_equal | ||||||
|  |  | ||||||
| template <class _R1, class _R2> | template <class _R1, class _R2> | ||||||
|   | |||||||
							
								
								
									
										204
									
								
								include/regex
									
									
									
									
									
								
							
							
						
						
									
										204
									
								
								include/regex
									
									
									
									
									
								
							| @@ -1280,7 +1280,7 @@ class __node | |||||||
|     __node(const __node&); |     __node(const __node&); | ||||||
|     __node& operator=(const __node&); |     __node& operator=(const __node&); | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __node() {} |     __node() {} | ||||||
| @@ -1300,7 +1300,7 @@ class __end_state | |||||||
|     : public __node<_CharT> |     : public __node<_CharT> | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __end_state() {} |     __end_state() {} | ||||||
| @@ -1365,7 +1365,7 @@ class __empty_state | |||||||
|     typedef __owns_one_state<_CharT> base; |     typedef __owns_one_state<_CharT> base; | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __empty_state(__node<_CharT>* __s) |     explicit __empty_state(__node<_CharT>* __s) | ||||||
| @@ -1391,7 +1391,7 @@ class __empty_non_own_state | |||||||
|     typedef __has_one_state<_CharT> base; |     typedef __has_one_state<_CharT> base; | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __empty_non_own_state(__node<_CharT>* __s) |     explicit __empty_non_own_state(__node<_CharT>* __s) | ||||||
| @@ -1417,7 +1417,7 @@ class __repeat_one_loop | |||||||
|     typedef __has_one_state<_CharT> base; |     typedef __has_one_state<_CharT> base; | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __repeat_one_loop(__node<_CharT>* __s) |     explicit __repeat_one_loop(__node<_CharT>* __s) | ||||||
| @@ -1479,7 +1479,7 @@ class __loop | |||||||
|     bool __greedy_; |     bool __greedy_; | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __loop(unsigned __loop_id, |     explicit __loop(unsigned __loop_id, | ||||||
| @@ -1578,7 +1578,7 @@ class __alternate | |||||||
|     typedef __owns_two_states<_CharT> base; |     typedef __owns_two_states<_CharT> base; | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __alternate(__owns_one_state<_CharT>* __s1, |     explicit __alternate(__owns_one_state<_CharT>* __s1, | ||||||
| @@ -1617,7 +1617,7 @@ class __begin_marked_subexpression | |||||||
|  |  | ||||||
|     unsigned __mexp_; |     unsigned __mexp_; | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __begin_marked_subexpression(unsigned __mexp, __node<_CharT>* __s) |     explicit __begin_marked_subexpression(unsigned __mexp, __node<_CharT>* __s) | ||||||
| @@ -1645,7 +1645,7 @@ class __end_marked_subexpression | |||||||
|  |  | ||||||
|     unsigned __mexp_; |     unsigned __mexp_; | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __end_marked_subexpression(unsigned __mexp, __node<_CharT>* __s) |     explicit __end_marked_subexpression(unsigned __mexp, __node<_CharT>* __s) | ||||||
| @@ -1674,7 +1674,7 @@ class __back_ref | |||||||
|  |  | ||||||
|     unsigned __mexp_; |     unsigned __mexp_; | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __back_ref(unsigned __mexp, __node<_CharT>* __s) |     explicit __back_ref(unsigned __mexp, __node<_CharT>* __s) | ||||||
| @@ -1692,7 +1692,7 @@ __back_ref<_CharT>::__exec(__state& __s) const | |||||||
|     { |     { | ||||||
|         ptrdiff_t __len = __sm.second - __sm.first; |         ptrdiff_t __len = __sm.second - __sm.first; | ||||||
|         if (__s.__last_ - __s.__current_ >= __len && |         if (__s.__last_ - __s.__current_ >= __len && | ||||||
|             _STD::equal(__sm.first, __sm.second, __s.__current_)) |             _VSTD::equal(__sm.first, __sm.second, __s.__current_)) | ||||||
|         { |         { | ||||||
|             __s.__do_ = __state::__accept_but_not_consume; |             __s.__do_ = __state::__accept_but_not_consume; | ||||||
|             __s.__current_ += __len; |             __s.__current_ += __len; | ||||||
| @@ -1722,7 +1722,7 @@ class __back_ref_icase | |||||||
|     _Traits __traits_; |     _Traits __traits_; | ||||||
|     unsigned __mexp_; |     unsigned __mexp_; | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __back_ref_icase(const _Traits& __traits, unsigned __mexp, |     explicit __back_ref_icase(const _Traits& __traits, unsigned __mexp, | ||||||
| @@ -1777,7 +1777,7 @@ class __back_ref_collate | |||||||
|     _Traits __traits_; |     _Traits __traits_; | ||||||
|     unsigned __mexp_; |     unsigned __mexp_; | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __back_ref_collate(const _Traits& __traits, unsigned __mexp, |     explicit __back_ref_collate(const _Traits& __traits, unsigned __mexp, | ||||||
| @@ -1832,7 +1832,7 @@ class __word_boundary | |||||||
|     _Traits __traits_; |     _Traits __traits_; | ||||||
|     bool __invert_; |     bool __invert_; | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __word_boundary(const _Traits& __traits, bool __invert, |     explicit __word_boundary(const _Traits& __traits, bool __invert, | ||||||
| @@ -1900,7 +1900,7 @@ class __l_anchor | |||||||
|     typedef __owns_one_state<_CharT> base; |     typedef __owns_one_state<_CharT> base; | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __l_anchor(__node<_CharT>* __s) |     __l_anchor(__node<_CharT>* __s) | ||||||
| @@ -1934,7 +1934,7 @@ class __r_anchor | |||||||
|     typedef __owns_one_state<_CharT> base; |     typedef __owns_one_state<_CharT> base; | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __r_anchor(__node<_CharT>* __s) |     __r_anchor(__node<_CharT>* __s) | ||||||
| @@ -1968,7 +1968,7 @@ class __match_any | |||||||
|     typedef __owns_one_state<_CharT> base; |     typedef __owns_one_state<_CharT> base; | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __match_any(__node<_CharT>* __s) |     __match_any(__node<_CharT>* __s) | ||||||
| @@ -2003,7 +2003,7 @@ class __match_any_but_newline | |||||||
|     typedef __owns_one_state<_CharT> base; |     typedef __owns_one_state<_CharT> base; | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __match_any_but_newline(__node<_CharT>* __s) |     __match_any_but_newline(__node<_CharT>* __s) | ||||||
| @@ -2025,7 +2025,7 @@ class __match_char | |||||||
|     __match_char(const __match_char&); |     __match_char(const __match_char&); | ||||||
|     __match_char& operator=(const __match_char&); |     __match_char& operator=(const __match_char&); | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __match_char(_CharT __c, __node<_CharT>* __s) |     __match_char(_CharT __c, __node<_CharT>* __s) | ||||||
| @@ -2065,7 +2065,7 @@ class __match_char_icase | |||||||
|     __match_char_icase(const __match_char_icase&); |     __match_char_icase(const __match_char_icase&); | ||||||
|     __match_char_icase& operator=(const __match_char_icase&); |     __match_char_icase& operator=(const __match_char_icase&); | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __match_char_icase(const _Traits& __traits, _CharT __c, __node<_CharT>* __s) |     __match_char_icase(const _Traits& __traits, _CharT __c, __node<_CharT>* __s) | ||||||
| @@ -2106,7 +2106,7 @@ class __match_char_collate | |||||||
|     __match_char_collate(const __match_char_collate&); |     __match_char_collate(const __match_char_collate&); | ||||||
|     __match_char_collate& operator=(const __match_char_collate&); |     __match_char_collate& operator=(const __match_char_collate&); | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __match_char_collate(const _Traits& __traits, _CharT __c, __node<_CharT>* __s) |     __match_char_collate(const _Traits& __traits, _CharT __c, __node<_CharT>* __s) | ||||||
| @@ -2158,7 +2158,7 @@ class __bracket_expression | |||||||
|     __bracket_expression(const __bracket_expression&); |     __bracket_expression(const __bracket_expression&); | ||||||
|     __bracket_expression& operator=(const __bracket_expression&); |     __bracket_expression& operator=(const __bracket_expression&); | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __bracket_expression(const _Traits& __traits, __node<_CharT>* __s, |     __bracket_expression(const _Traits& __traits, __node<_CharT>* __s, | ||||||
| @@ -2226,7 +2226,7 @@ public: | |||||||
|                     __b[0] = __traits_.translate_nocase(__b[0]); |                     __b[0] = __traits_.translate_nocase(__b[0]); | ||||||
|                     __e[0] = __traits_.translate_nocase(__e[0]); |                     __e[0] = __traits_.translate_nocase(__e[0]); | ||||||
|                 } |                 } | ||||||
|                 __ranges_.push_back(make_pair(_STD::move(__b), _STD::move(__e))); |                 __ranges_.push_back(make_pair(_VSTD::move(__b), _VSTD::move(__e))); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -2263,7 +2263,7 @@ __bracket_expression<_CharT, _Traits>::__exec(__state& __s) const | |||||||
|         ++__consumed; |         ++__consumed; | ||||||
|         if (__might_have_digraph_) |         if (__might_have_digraph_) | ||||||
|         { |         { | ||||||
|             const _CharT* __next = _STD::next(__s.__current_); |             const _CharT* __next = _VSTD::next(__s.__current_); | ||||||
|             if (__next != __s.__last_) |             if (__next != __s.__last_) | ||||||
|             { |             { | ||||||
|                 pair<_CharT, _CharT> __ch2(*__s.__current_, *__next); |                 pair<_CharT, _CharT> __ch2(*__s.__current_, *__next); | ||||||
| @@ -2410,7 +2410,7 @@ __exit: | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class, class> class __lookahead; | template <class _CharT, class _Traits> class __lookahead; | ||||||
|  |  | ||||||
| template <class _CharT, class _Traits = regex_traits<_CharT> > | template <class _CharT, class _Traits = regex_traits<_CharT> > | ||||||
| class _LIBCPP_VISIBLE basic_regex | class _LIBCPP_VISIBLE basic_regex | ||||||
| @@ -2430,8 +2430,8 @@ private: | |||||||
|     shared_ptr<__empty_state<_CharT> > __start_; |     shared_ptr<__empty_state<_CharT> > __start_; | ||||||
|     __owns_one_state<_CharT>* __end_; |     __owns_one_state<_CharT>* __end_; | ||||||
|  |  | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|     typedef _STD::__node<_CharT> __node; |     typedef _VSTD::__node<_CharT> __node; | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     // constants: |     // constants: | ||||||
| @@ -2834,7 +2834,7 @@ template <class _CharT, class _Traits> | |||||||
| void | void | ||||||
| basic_regex<_CharT, _Traits>::swap(basic_regex& __r) | basic_regex<_CharT, _Traits>::swap(basic_regex& __r) | ||||||
| { | { | ||||||
|     using _STD::swap; |     using _VSTD::swap; | ||||||
|     swap(__traits_, __r.__traits_); |     swap(__traits_, __r.__traits_); | ||||||
|     swap(__flags_, __r.__flags_); |     swap(__flags_, __r.__flags_); | ||||||
|     swap(__marked_count_, __r.__marked_count_); |     swap(__marked_count_, __r.__marked_count_); | ||||||
| @@ -2866,7 +2866,7 @@ class __lookahead | |||||||
|     __lookahead(const __lookahead&); |     __lookahead(const __lookahead&); | ||||||
|     __lookahead& operator=(const __lookahead&); |     __lookahead& operator=(const __lookahead&); | ||||||
| public: | public: | ||||||
|     typedef _STD::__state<_CharT> __state; |     typedef _VSTD::__state<_CharT> __state; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __lookahead(const basic_regex<_CharT, _Traits>& __exp, bool __invert, __node<_CharT>* __s) |     __lookahead(const basic_regex<_CharT, _Traits>& __exp, bool __invert, __node<_CharT>* __s) | ||||||
| @@ -2953,7 +2953,7 @@ basic_regex<_CharT, _Traits>::__parse_basic_reg_exp(_ForwardIterator __first, | |||||||
|             __first = __parse_RE_expression(__first, __last); |             __first = __parse_RE_expression(__first, __last); | ||||||
|             if (__first != __last) |             if (__first != __last) | ||||||
|             { |             { | ||||||
|                 _ForwardIterator __temp = _STD::next(__first); |                 _ForwardIterator __temp = _VSTD::next(__first); | ||||||
|                 if (__temp == __last && *__first == '$') |                 if (__temp == __last && *__first == '$') | ||||||
|                 { |                 { | ||||||
|                     __push_r_anchor(); |                     __push_r_anchor(); | ||||||
| @@ -3182,7 +3182,7 @@ basic_regex<_CharT, _Traits>::__parse_Back_open_paren(_ForwardIterator __first, | |||||||
| { | { | ||||||
|     if (__first != __last) |     if (__first != __last) | ||||||
|     { |     { | ||||||
|         _ForwardIterator __temp = _STD::next(__first); |         _ForwardIterator __temp = _VSTD::next(__first); | ||||||
|         if (__temp != __last) |         if (__temp != __last) | ||||||
|         { |         { | ||||||
|             if (*__first == '\\' && *__temp == '(') |             if (*__first == '\\' && *__temp == '(') | ||||||
| @@ -3200,7 +3200,7 @@ basic_regex<_CharT, _Traits>::__parse_Back_close_paren(_ForwardIterator __first, | |||||||
| { | { | ||||||
|     if (__first != __last) |     if (__first != __last) | ||||||
|     { |     { | ||||||
|         _ForwardIterator __temp = _STD::next(__first); |         _ForwardIterator __temp = _VSTD::next(__first); | ||||||
|         if (__temp != __last) |         if (__temp != __last) | ||||||
|         { |         { | ||||||
|             if (*__first == '\\' && *__temp == ')') |             if (*__first == '\\' && *__temp == ')') | ||||||
| @@ -3218,7 +3218,7 @@ basic_regex<_CharT, _Traits>::__parse_Back_open_brace(_ForwardIterator __first, | |||||||
| { | { | ||||||
|     if (__first != __last) |     if (__first != __last) | ||||||
|     { |     { | ||||||
|         _ForwardIterator __temp = _STD::next(__first); |         _ForwardIterator __temp = _VSTD::next(__first); | ||||||
|         if (__temp != __last) |         if (__temp != __last) | ||||||
|         { |         { | ||||||
|             if (*__first == '\\' && *__temp == '{') |             if (*__first == '\\' && *__temp == '{') | ||||||
| @@ -3236,7 +3236,7 @@ basic_regex<_CharT, _Traits>::__parse_Back_close_brace(_ForwardIterator __first, | |||||||
| { | { | ||||||
|     if (__first != __last) |     if (__first != __last) | ||||||
|     { |     { | ||||||
|         _ForwardIterator __temp = _STD::next(__first); |         _ForwardIterator __temp = _VSTD::next(__first); | ||||||
|         if (__temp != __last) |         if (__temp != __last) | ||||||
|         { |         { | ||||||
|             if (*__first == '\\' && *__temp == '}') |             if (*__first == '\\' && *__temp == '}') | ||||||
| @@ -3254,7 +3254,7 @@ basic_regex<_CharT, _Traits>::__parse_BACKREF(_ForwardIterator __first, | |||||||
| { | { | ||||||
|     if (__first != __last) |     if (__first != __last) | ||||||
|     { |     { | ||||||
|         _ForwardIterator __temp = _STD::next(__first); |         _ForwardIterator __temp = _VSTD::next(__first); | ||||||
|         if (__temp != __last) |         if (__temp != __last) | ||||||
|         { |         { | ||||||
|             if (*__first == '\\' && '1' <= *__temp && *__temp <= '9') |             if (*__first == '\\' && '1' <= *__temp && *__temp <= '9') | ||||||
| @@ -3275,7 +3275,7 @@ basic_regex<_CharT, _Traits>::__parse_ORD_CHAR(_ForwardIterator __first, | |||||||
| { | { | ||||||
|     if (__first != __last) |     if (__first != __last) | ||||||
|     { |     { | ||||||
|         _ForwardIterator __temp = _STD::next(__first); |         _ForwardIterator __temp = _VSTD::next(__first); | ||||||
|         if (__temp == __last && *__first == '$') |         if (__temp == __last && *__first == '$') | ||||||
|             return __first; |             return __first; | ||||||
|         // Not called inside a bracket |         // Not called inside a bracket | ||||||
| @@ -3333,7 +3333,7 @@ basic_regex<_CharT, _Traits>::__parse_QUOTED_CHAR(_ForwardIterator __first, | |||||||
| { | { | ||||||
|     if (__first != __last) |     if (__first != __last) | ||||||
|     { |     { | ||||||
|         _ForwardIterator __temp = _STD::next(__first); |         _ForwardIterator __temp = _VSTD::next(__first); | ||||||
|         if (__temp != __last) |         if (__temp != __last) | ||||||
|         { |         { | ||||||
|             if (*__first == '\\') |             if (*__first == '\\') | ||||||
| @@ -3364,7 +3364,7 @@ basic_regex<_CharT, _Traits>::__parse_QUOTED_CHAR_ERE(_ForwardIterator __first, | |||||||
| { | { | ||||||
|     if (__first != __last) |     if (__first != __last) | ||||||
|     { |     { | ||||||
|         _ForwardIterator __temp = _STD::next(__first); |         _ForwardIterator __temp = _VSTD::next(__first); | ||||||
|         if (__temp != __last) |         if (__temp != __last) | ||||||
|         { |         { | ||||||
|             if (*__first == '\\') |             if (*__first == '\\') | ||||||
| @@ -3674,7 +3674,7 @@ basic_regex<_CharT, _Traits>::__parse_expression_term(_ForwardIterator __first, | |||||||
| { | { | ||||||
|     if (__first != __last && *__first != ']') |     if (__first != __last && *__first != ']') | ||||||
|     { |     { | ||||||
|         _ForwardIterator __temp = _STD::next(__first); |         _ForwardIterator __temp = _VSTD::next(__first); | ||||||
|         basic_string<_CharT> __start_range; |         basic_string<_CharT> __start_range; | ||||||
|         if (__temp != __last && *__first == '[') |         if (__temp != __last && *__first == '[') | ||||||
|         { |         { | ||||||
| @@ -3703,7 +3703,7 @@ basic_regex<_CharT, _Traits>::__parse_expression_term(_ForwardIterator __first, | |||||||
|         } |         } | ||||||
|         if (__first != __last && *__first != ']') |         if (__first != __last && *__first != ']') | ||||||
|         { |         { | ||||||
|             __temp = _STD::next(__first); |             __temp = _VSTD::next(__first); | ||||||
|             if (__temp != __last && *__first == '-' && *__temp != ']') |             if (__temp != __last && *__first == '-' && *__temp != ']') | ||||||
|             { |             { | ||||||
|                 // parse a range |                 // parse a range | ||||||
| @@ -3729,7 +3729,7 @@ basic_regex<_CharT, _Traits>::__parse_expression_term(_ForwardIterator __first, | |||||||
|                         ++__first; |                         ++__first; | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 __ml->__add_range(_STD::move(__start_range), _STD::move(__end_range)); |                 __ml->__add_range(_VSTD::move(__start_range), _VSTD::move(__end_range)); | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             { |             { | ||||||
| @@ -3890,7 +3890,7 @@ basic_regex<_CharT, _Traits>::__parse_equivalence_class(_ForwardIterator __first | |||||||
|     // Found [= |     // Found [= | ||||||
|     //   This means =] must exist |     //   This means =] must exist | ||||||
|     value_type _Equal_close[2] = {'=', ']'}; |     value_type _Equal_close[2] = {'=', ']'}; | ||||||
|     _ForwardIterator __temp = _STD::search(__first, __last, _Equal_close, |     _ForwardIterator __temp = _VSTD::search(__first, __last, _Equal_close, | ||||||
|                                                             _Equal_close+2); |                                                             _Equal_close+2); | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__temp == __last) |     if (__temp == __last) | ||||||
| @@ -3925,7 +3925,7 @@ basic_regex<_CharT, _Traits>::__parse_equivalence_class(_ForwardIterator __first | |||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     __first = _STD::next(__temp, 2); |     __first = _VSTD::next(__temp, 2); | ||||||
|     return __first; |     return __first; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -3939,7 +3939,7 @@ basic_regex<_CharT, _Traits>::__parse_character_class(_ForwardIterator __first, | |||||||
|     // Found [: |     // Found [: | ||||||
|     //   This means :] must exist |     //   This means :] must exist | ||||||
|     value_type _Colon_close[2] = {':', ']'}; |     value_type _Colon_close[2] = {':', ']'}; | ||||||
|     _ForwardIterator __temp = _STD::search(__first, __last, _Colon_close, |     _ForwardIterator __temp = _VSTD::search(__first, __last, _Colon_close, | ||||||
|                                                             _Colon_close+2); |                                                             _Colon_close+2); | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__temp == __last) |     if (__temp == __last) | ||||||
| @@ -3954,7 +3954,7 @@ basic_regex<_CharT, _Traits>::__parse_character_class(_ForwardIterator __first, | |||||||
|         throw regex_error(regex_constants::error_brack); |         throw regex_error(regex_constants::error_brack); | ||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|     __ml->__add_class(__class_type); |     __ml->__add_class(__class_type); | ||||||
|     __first = _STD::next(__temp, 2); |     __first = _VSTD::next(__temp, 2); | ||||||
|     return __first; |     return __first; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -3968,7 +3968,7 @@ basic_regex<_CharT, _Traits>::__parse_collating_symbol(_ForwardIterator __first, | |||||||
|     // Found [. |     // Found [. | ||||||
|     //   This means .] must exist |     //   This means .] must exist | ||||||
|     value_type _Dot_close[2] = {'.', ']'}; |     value_type _Dot_close[2] = {'.', ']'}; | ||||||
|     _ForwardIterator __temp = _STD::search(__first, __last, _Dot_close, |     _ForwardIterator __temp = _VSTD::search(__first, __last, _Dot_close, | ||||||
|                                                             _Dot_close+2); |                                                             _Dot_close+2); | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__temp == __last) |     if (__temp == __last) | ||||||
| @@ -3987,7 +3987,7 @@ basic_regex<_CharT, _Traits>::__parse_collating_symbol(_ForwardIterator __first, | |||||||
|         throw regex_error(regex_constants::error_collate); |         throw regex_error(regex_constants::error_collate); | ||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|     } |     } | ||||||
|     __first = _STD::next(__temp, 2); |     __first = _VSTD::next(__temp, 2); | ||||||
|     return __first; |     return __first; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -4091,7 +4091,7 @@ basic_regex<_CharT, _Traits>::__parse_assertion(_ForwardIterator __first, | |||||||
|             break; |             break; | ||||||
|         case '\\': |         case '\\': | ||||||
|             { |             { | ||||||
|                 _ForwardIterator __temp = _STD::next(__first); |                 _ForwardIterator __temp = _VSTD::next(__first); | ||||||
|                 if (__temp != __last) |                 if (__temp != __last) | ||||||
|                 { |                 { | ||||||
|                     if (*__temp == 'b') |                     if (*__temp == 'b') | ||||||
| @@ -4109,7 +4109,7 @@ basic_regex<_CharT, _Traits>::__parse_assertion(_ForwardIterator __first, | |||||||
|             break; |             break; | ||||||
|         case '(': |         case '(': | ||||||
|             { |             { | ||||||
|                 _ForwardIterator __temp = _STD::next(__first); |                 _ForwardIterator __temp = _VSTD::next(__first); | ||||||
|                 if (__temp != __last && *__temp == '?') |                 if (__temp != __last && *__temp == '?') | ||||||
|                 { |                 { | ||||||
|                     if (++__temp != __last) |                     if (++__temp != __last) | ||||||
| @@ -4121,7 +4121,7 @@ basic_regex<_CharT, _Traits>::__parse_assertion(_ForwardIterator __first, | |||||||
|                                 basic_regex __exp; |                                 basic_regex __exp; | ||||||
|                                 __exp.__flags_ = __flags_; |                                 __exp.__flags_ = __flags_; | ||||||
|                                 __temp = __exp.__parse(++__temp, __last); |                                 __temp = __exp.__parse(++__temp, __last); | ||||||
|                                 __push_lookahead(_STD::move(__exp), false); |                                 __push_lookahead(_VSTD::move(__exp), false); | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|                                 if (__temp == __last || *__temp != ')') |                                 if (__temp == __last || *__temp != ')') | ||||||
|                                     throw regex_error(regex_constants::error_paren); |                                     throw regex_error(regex_constants::error_paren); | ||||||
| @@ -4134,7 +4134,7 @@ basic_regex<_CharT, _Traits>::__parse_assertion(_ForwardIterator __first, | |||||||
|                                 basic_regex __exp; |                                 basic_regex __exp; | ||||||
|                                 __exp.__flags_ = __flags_; |                                 __exp.__flags_ = __flags_; | ||||||
|                                 __temp = __exp.__parse(++__temp, __last); |                                 __temp = __exp.__parse(++__temp, __last); | ||||||
|                                 __push_lookahead(_STD::move(__exp), true); |                                 __push_lookahead(_VSTD::move(__exp), true); | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|                                 if (__temp == __last || *__temp != ')') |                                 if (__temp == __last || *__temp != ')') | ||||||
|                                     throw regex_error(regex_constants::error_paren); |                                     throw regex_error(regex_constants::error_paren); | ||||||
| @@ -4179,7 +4179,7 @@ basic_regex<_CharT, _Traits>::__parse_atom(_ForwardIterator __first, | |||||||
|                 if (__first == __last) |                 if (__first == __last) | ||||||
|                     throw regex_error(regex_constants::error_paren); |                     throw regex_error(regex_constants::error_paren); | ||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|                 _ForwardIterator __temp = _STD::next(__first); |                 _ForwardIterator __temp = _VSTD::next(__first); | ||||||
|                 if (__temp != __last && *__first == '?' && *__temp == ':') |                 if (__temp != __last && *__first == '?' && *__temp == ':') | ||||||
|                 { |                 { | ||||||
|                     ++__open_count_; |                     ++__open_count_; | ||||||
| @@ -4223,7 +4223,7 @@ basic_regex<_CharT, _Traits>::__parse_atom_escape(_ForwardIterator __first, | |||||||
| { | { | ||||||
|     if (__first != __last && *__first == '\\') |     if (__first != __last && *__first == '\\') | ||||||
|     { |     { | ||||||
|         _ForwardIterator __t1 = _STD::next(__first); |         _ForwardIterator __t1 = _VSTD::next(__first); | ||||||
|         _ForwardIterator __t2 = __parse_decimal_escape(__t1, __last); |         _ForwardIterator __t2 = __parse_decimal_escape(__t1, __last); | ||||||
|         if (__t2 != __t1) |         if (__t2 != __t1) | ||||||
|             __first = __t2; |             __first = __t2; | ||||||
| @@ -4369,7 +4369,7 @@ basic_regex<_CharT, _Traits>::__parse_character_escape(_ForwardIterator __first, | |||||||
|             ++__first; |             ++__first; | ||||||
|             break; |             break; | ||||||
|         case 'c': |         case 'c': | ||||||
|             if ((__t = _STD::next(__first)) != __last) |             if ((__t = _VSTD::next(__first)) != __last) | ||||||
|             { |             { | ||||||
|                 if ('A' <= *__t <= 'Z' || 'a' <= *__t <= 'z') |                 if ('A' <= *__t <= 'Z' || 'a' <= *__t <= 'z') | ||||||
|                 { |                 { | ||||||
| @@ -4494,7 +4494,7 @@ basic_regex<_CharT, _Traits>::__parse_grep(_ForwardIterator __first, | |||||||
|                                            _ForwardIterator __last) |                                            _ForwardIterator __last) | ||||||
| { | { | ||||||
|     __owns_one_state<_CharT>* __sa = __end_; |     __owns_one_state<_CharT>* __sa = __end_; | ||||||
|     _ForwardIterator __t1 = _STD::find(__first, __last, _CharT('\n')); |     _ForwardIterator __t1 = _VSTD::find(__first, __last, _CharT('\n')); | ||||||
|     if (__t1 != __first) |     if (__t1 != __first) | ||||||
|         __parse_basic_reg_exp(__first, __t1); |         __parse_basic_reg_exp(__first, __t1); | ||||||
|     else |     else | ||||||
| @@ -4504,7 +4504,7 @@ basic_regex<_CharT, _Traits>::__parse_grep(_ForwardIterator __first, | |||||||
|         ++__first; |         ++__first; | ||||||
|     while (__first != __last) |     while (__first != __last) | ||||||
|     { |     { | ||||||
|         __t1 = _STD::find(__first, __last, _CharT('\n')); |         __t1 = _VSTD::find(__first, __last, _CharT('\n')); | ||||||
|         __owns_one_state<_CharT>* __sb = __end_; |         __owns_one_state<_CharT>* __sb = __end_; | ||||||
|         if (__t1 != __first) |         if (__t1 != __first) | ||||||
|             __parse_basic_reg_exp(__first, __t1); |             __parse_basic_reg_exp(__first, __t1); | ||||||
| @@ -4525,7 +4525,7 @@ basic_regex<_CharT, _Traits>::__parse_egrep(_ForwardIterator __first, | |||||||
|                                             _ForwardIterator __last) |                                             _ForwardIterator __last) | ||||||
| { | { | ||||||
|     __owns_one_state<_CharT>* __sa = __end_; |     __owns_one_state<_CharT>* __sa = __end_; | ||||||
|     _ForwardIterator __t1 = _STD::find(__first, __last, _CharT('\n')); |     _ForwardIterator __t1 = _VSTD::find(__first, __last, _CharT('\n')); | ||||||
|     if (__t1 != __first) |     if (__t1 != __first) | ||||||
|         __parse_extended_reg_exp(__first, __t1); |         __parse_extended_reg_exp(__first, __t1); | ||||||
|     else |     else | ||||||
| @@ -4535,7 +4535,7 @@ basic_regex<_CharT, _Traits>::__parse_egrep(_ForwardIterator __first, | |||||||
|         ++__first; |         ++__first; | ||||||
|     while (__first != __last) |     while (__first != __last) | ||||||
|     { |     { | ||||||
|         __t1 = _STD::find(__first, __last, _CharT('\n')); |         __t1 = _VSTD::find(__first, __last, _CharT('\n')); | ||||||
|         __owns_one_state<_CharT>* __sb = __end_; |         __owns_one_state<_CharT>* __sb = __end_; | ||||||
|         if (__t1 != __first) |         if (__t1 != __first) | ||||||
|             __parse_extended_reg_exp(__first, __t1); |             __parse_extended_reg_exp(__first, __t1); | ||||||
| @@ -4732,7 +4732,7 @@ public: | |||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     difference_type length() const |     difference_type length() const | ||||||
|         {return matched ? _STD::distance(this->first, this->second) : 0;} |         {return matched ? _VSTD::distance(this->first, this->second) : 0;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     string_type str() const |     string_type str() const | ||||||
|         {return matched ? string_type(this->first, this->second) : string_type();} |         {return matched ? string_type(this->first, this->second) : string_type();} | ||||||
| @@ -5188,7 +5188,7 @@ public: | |||||||
|         {return (*this)[__sub].length();} |         {return (*this)[__sub].length();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     difference_type position(size_type __sub = 0) const |     difference_type position(size_type __sub = 0) const | ||||||
|         {return _STD::distance(__position_start_, (*this)[__sub].first);} |         {return _VSTD::distance(__position_start_, (*this)[__sub].first);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     string_type str(size_type __sub = 0) const |     string_type str(size_type __sub = 0) const | ||||||
|         {return (*this)[__sub].str();} |         {return (*this)[__sub].str();} | ||||||
| @@ -5260,18 +5260,18 @@ public: | |||||||
|         __matches_.resize(__m.size()); |         __matches_.resize(__m.size()); | ||||||
|         for (size_type __i = 0; __i < __matches_.size(); ++__i) |         for (size_type __i = 0; __i < __matches_.size(); ++__i) | ||||||
|         { |         { | ||||||
|             __matches_[__i].first = _STD::next(__f, _STD::distance(__mf, __m[__i].first)); |             __matches_[__i].first = _VSTD::next(__f, _VSTD::distance(__mf, __m[__i].first)); | ||||||
|             __matches_[__i].second = _STD::next(__f, _STD::distance(__mf, __m[__i].second)); |             __matches_[__i].second = _VSTD::next(__f, _VSTD::distance(__mf, __m[__i].second)); | ||||||
|             __matches_[__i].matched = __m[__i].matched; |             __matches_[__i].matched = __m[__i].matched; | ||||||
|         } |         } | ||||||
|         __unmatched_.first   = __l; |         __unmatched_.first   = __l; | ||||||
|         __unmatched_.second  = __l; |         __unmatched_.second  = __l; | ||||||
|         __unmatched_.matched = false; |         __unmatched_.matched = false; | ||||||
|         __prefix_.first = _STD::next(__f, _STD::distance(__mf, __m.prefix().first)); |         __prefix_.first = _VSTD::next(__f, _VSTD::distance(__mf, __m.prefix().first)); | ||||||
|         __prefix_.second = _STD::next(__f, _STD::distance(__mf, __m.prefix().second)); |         __prefix_.second = _VSTD::next(__f, _VSTD::distance(__mf, __m.prefix().second)); | ||||||
|         __prefix_.matched = __m.prefix().matched; |         __prefix_.matched = __m.prefix().matched; | ||||||
|         __suffix_.first = _STD::next(__f, _STD::distance(__mf, __m.suffix().first)); |         __suffix_.first = _VSTD::next(__f, _VSTD::distance(__mf, __m.suffix().first)); | ||||||
|         __suffix_.second = _STD::next(__f, _STD::distance(__mf, __m.suffix().second)); |         __suffix_.second = _VSTD::next(__f, _VSTD::distance(__mf, __m.suffix().second)); | ||||||
|         __suffix_.matched = __m.suffix().matched; |         __suffix_.matched = __m.suffix().matched; | ||||||
|         if (!__no_update_pos) |         if (!__no_update_pos) | ||||||
|             __position_start_ = __prefix_.first; |             __position_start_ = __prefix_.first; | ||||||
| @@ -5342,7 +5342,7 @@ match_results<_BidirectionalIterator, _Allocator>::format(_OutputIter __out, | |||||||
|         for (; __fmt_first != __fmt_last; ++__fmt_first) |         for (; __fmt_first != __fmt_last; ++__fmt_first) | ||||||
|         { |         { | ||||||
|             if (*__fmt_first == '&') |             if (*__fmt_first == '&') | ||||||
|                 __out = _STD::copy(__matches_[0].first, __matches_[0].second, |                 __out = _VSTD::copy(__matches_[0].first, __matches_[0].second, | ||||||
|                                    __out); |                                    __out); | ||||||
|             else if (*__fmt_first == '\\' && __fmt_first + 1 != __fmt_last) |             else if (*__fmt_first == '\\' && __fmt_first + 1 != __fmt_last) | ||||||
|             { |             { | ||||||
| @@ -5350,7 +5350,7 @@ match_results<_BidirectionalIterator, _Allocator>::format(_OutputIter __out, | |||||||
|                 if ('0' <= *__fmt_first && *__fmt_first <= '9') |                 if ('0' <= *__fmt_first && *__fmt_first <= '9') | ||||||
|                 { |                 { | ||||||
|                     size_t __i = *__fmt_first - '0'; |                     size_t __i = *__fmt_first - '0'; | ||||||
|                     __out = _STD::copy(__matches_[__i].first, |                     __out = _VSTD::copy(__matches_[__i].first, | ||||||
|                                        __matches_[__i].second, __out); |                                        __matches_[__i].second, __out); | ||||||
|                 } |                 } | ||||||
|                 else |                 else | ||||||
| @@ -5380,16 +5380,16 @@ match_results<_BidirectionalIterator, _Allocator>::format(_OutputIter __out, | |||||||
|                     break; |                     break; | ||||||
|                 case '&': |                 case '&': | ||||||
|                     ++__fmt_first; |                     ++__fmt_first; | ||||||
|                     __out = _STD::copy(__matches_[0].first, __matches_[0].second, |                     __out = _VSTD::copy(__matches_[0].first, __matches_[0].second, | ||||||
|                                        __out); |                                        __out); | ||||||
|                     break; |                     break; | ||||||
|                 case '`': |                 case '`': | ||||||
|                     ++__fmt_first; |                     ++__fmt_first; | ||||||
|                     __out = _STD::copy(__prefix_.first, __prefix_.second, __out); |                     __out = _VSTD::copy(__prefix_.first, __prefix_.second, __out); | ||||||
|                     break; |                     break; | ||||||
|                 case '\'': |                 case '\'': | ||||||
|                     ++__fmt_first; |                     ++__fmt_first; | ||||||
|                     __out = _STD::copy(__suffix_.first, __suffix_.second, __out); |                     __out = _VSTD::copy(__suffix_.first, __suffix_.second, __out); | ||||||
|                     break; |                     break; | ||||||
|                 default: |                 default: | ||||||
|                     if ('0' <= __fmt_first[1] && __fmt_first[1] <= '9') |                     if ('0' <= __fmt_first[1] && __fmt_first[1] <= '9') | ||||||
| @@ -5402,7 +5402,7 @@ match_results<_BidirectionalIterator, _Allocator>::format(_OutputIter __out, | |||||||
|                             ++__fmt_first; |                             ++__fmt_first; | ||||||
|                             __i = 10 * __i + *__fmt_first - '0'; |                             __i = 10 * __i + *__fmt_first - '0'; | ||||||
|                         } |                         } | ||||||
|                         __out = _STD::copy(__matches_[__i].first, |                         __out = _VSTD::copy(__matches_[__i].first, | ||||||
|                                            __matches_[__i].second, __out); |                                            __matches_[__i].second, __out); | ||||||
|                     } |                     } | ||||||
|                     else |                     else | ||||||
| @@ -5427,7 +5427,7 @@ template <class _BidirectionalIterator, class _Allocator> | |||||||
| void | void | ||||||
| match_results<_BidirectionalIterator, _Allocator>::swap(match_results& __m) | match_results<_BidirectionalIterator, _Allocator>::swap(match_results& __m) | ||||||
| { | { | ||||||
|     using _STD::swap; |     using _VSTD::swap; | ||||||
|     swap(__matches_, __m.__matches_); |     swap(__matches_, __m.__matches_); | ||||||
|     swap(__unmatched_, __m.__unmatched_); |     swap(__unmatched_, __m.__unmatched_); | ||||||
|     swap(__prefix_, __m.__prefix_); |     swap(__prefix_, __m.__prefix_); | ||||||
| @@ -5485,7 +5485,7 @@ basic_regex<_CharT, _Traits>::__match_at_start_ecma( | |||||||
| { | { | ||||||
|     vector<__state> __states; |     vector<__state> __states; | ||||||
|     ptrdiff_t __j = 0; |     ptrdiff_t __j = 0; | ||||||
|     ptrdiff_t _N = _STD::distance(__first, __last); |     ptrdiff_t _N = _VSTD::distance(__first, __last); | ||||||
|     __node* __st = __start_.get(); |     __node* __st = __start_.get(); | ||||||
|     if (__st) |     if (__st) | ||||||
|     { |     { | ||||||
| @@ -5509,7 +5509,7 @@ basic_regex<_CharT, _Traits>::__match_at_start_ecma( | |||||||
|             { |             { | ||||||
|             case __state::__end_state: |             case __state::__end_state: | ||||||
|                 __m.__matches_[0].first = __first; |                 __m.__matches_[0].first = __first; | ||||||
|                 __m.__matches_[0].second = _STD::next(__first, __s.__current_ - __first); |                 __m.__matches_[0].second = _VSTD::next(__first, __s.__current_ - __first); | ||||||
|                 __m.__matches_[0].matched = true; |                 __m.__matches_[0].matched = true; | ||||||
|                 for (unsigned __i = 0; __i < __s.__sub_matches_.size(); ++__i) |                 for (unsigned __i = 0; __i < __s.__sub_matches_.size(); ++__i) | ||||||
|                     __m.__matches_[__i+1] = __s.__sub_matches_[__i]; |                     __m.__matches_[__i+1] = __s.__sub_matches_[__i]; | ||||||
| @@ -5523,7 +5523,7 @@ basic_regex<_CharT, _Traits>::__match_at_start_ecma( | |||||||
|                 __state __snext = __s; |                 __state __snext = __s; | ||||||
|                 __s.__node_->__exec_split(true, __s); |                 __s.__node_->__exec_split(true, __s); | ||||||
|                 __snext.__node_->__exec_split(false, __snext); |                 __snext.__node_->__exec_split(false, __snext); | ||||||
|                 __states.push_back(_STD::move(__snext)); |                 __states.push_back(_VSTD::move(__snext)); | ||||||
|                 } |                 } | ||||||
|                 break; |                 break; | ||||||
|             case __state::__reject: |             case __state::__reject: | ||||||
| @@ -5551,7 +5551,7 @@ basic_regex<_CharT, _Traits>::__match_at_start_posix_nosubs( | |||||||
| { | { | ||||||
|     deque<__state> __states; |     deque<__state> __states; | ||||||
|     ptrdiff_t __highest_j = 0; |     ptrdiff_t __highest_j = 0; | ||||||
|     ptrdiff_t _N = _STD::distance(__first, __last); |     ptrdiff_t _N = _VSTD::distance(__first, __last); | ||||||
|     __node* __st = __start_.get(); |     __node* __st = __start_.get(); | ||||||
|     if (__st) |     if (__st) | ||||||
|     { |     { | ||||||
| @@ -5584,7 +5584,7 @@ basic_regex<_CharT, _Traits>::__match_at_start_posix_nosubs( | |||||||
|             case __state::__consume_input: |             case __state::__consume_input: | ||||||
|                 break; |                 break; | ||||||
|             case __state::__accept_and_consume: |             case __state::__accept_and_consume: | ||||||
|                 __states.push_front(_STD::move(__s)); |                 __states.push_front(_VSTD::move(__s)); | ||||||
|                 __states.pop_back(); |                 __states.pop_back(); | ||||||
|                 break; |                 break; | ||||||
|             case __state::__repeat: |             case __state::__repeat: | ||||||
| @@ -5595,7 +5595,7 @@ basic_regex<_CharT, _Traits>::__match_at_start_posix_nosubs( | |||||||
|                 __state __snext = __s; |                 __state __snext = __s; | ||||||
|                 __s.__node_->__exec_split(true, __s); |                 __s.__node_->__exec_split(true, __s); | ||||||
|                 __snext.__node_->__exec_split(false, __snext); |                 __snext.__node_->__exec_split(false, __snext); | ||||||
|                 __states.push_back(_STD::move(__snext)); |                 __states.push_back(_VSTD::move(__snext)); | ||||||
|                 } |                 } | ||||||
|                 break; |                 break; | ||||||
|             case __state::__reject: |             case __state::__reject: | ||||||
| @@ -5611,7 +5611,7 @@ basic_regex<_CharT, _Traits>::__match_at_start_posix_nosubs( | |||||||
|         if (__matched) |         if (__matched) | ||||||
|         { |         { | ||||||
|             __m.__matches_[0].first = __first; |             __m.__matches_[0].first = __first; | ||||||
|             __m.__matches_[0].second = _STD::next(__first, __highest_j); |             __m.__matches_[0].second = _VSTD::next(__first, __highest_j); | ||||||
|             __m.__matches_[0].matched = true; |             __m.__matches_[0].matched = true; | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
| @@ -5631,7 +5631,7 @@ basic_regex<_CharT, _Traits>::__match_at_start_posix_subs( | |||||||
|     __state __best_state; |     __state __best_state; | ||||||
|     ptrdiff_t __j = 0; |     ptrdiff_t __j = 0; | ||||||
|     ptrdiff_t __highest_j = 0; |     ptrdiff_t __highest_j = 0; | ||||||
|     ptrdiff_t _N = _STD::distance(__first, __last); |     ptrdiff_t _N = _VSTD::distance(__first, __last); | ||||||
|     __node* __st = __start_.get(); |     __node* __st = __start_.get(); | ||||||
|     if (__st) |     if (__st) | ||||||
|     { |     { | ||||||
| @@ -5678,7 +5678,7 @@ basic_regex<_CharT, _Traits>::__match_at_start_posix_subs( | |||||||
|                 __state __snext = __s; |                 __state __snext = __s; | ||||||
|                 __s.__node_->__exec_split(true, __s); |                 __s.__node_->__exec_split(true, __s); | ||||||
|                 __snext.__node_->__exec_split(false, __snext); |                 __snext.__node_->__exec_split(false, __snext); | ||||||
|                 __states.push_back(_STD::move(__snext)); |                 __states.push_back(_VSTD::move(__snext)); | ||||||
|                 } |                 } | ||||||
|                 break; |                 break; | ||||||
|             case __state::__reject: |             case __state::__reject: | ||||||
| @@ -5694,7 +5694,7 @@ basic_regex<_CharT, _Traits>::__match_at_start_posix_subs( | |||||||
|         if (__matched) |         if (__matched) | ||||||
|         { |         { | ||||||
|             __m.__matches_[0].first = __first; |             __m.__matches_[0].first = __first; | ||||||
|             __m.__matches_[0].second = _STD::next(__first, __highest_j); |             __m.__matches_[0].second = _VSTD::next(__first, __highest_j); | ||||||
|             __m.__matches_[0].matched = true; |             __m.__matches_[0].matched = true; | ||||||
|             for (unsigned __i = 0; __i < __best_state.__sub_matches_.size(); ++__i) |             for (unsigned __i = 0; __i < __best_state.__sub_matches_.size(); ++__i) | ||||||
|                 __m.__matches_[__i+1] = __best_state.__sub_matches_[__i]; |                 __m.__matches_[__i+1] = __best_state.__sub_matches_[__i]; | ||||||
| @@ -5824,7 +5824,7 @@ regex_search(const _CharT* __str, const basic_regex<_CharT, _Traits>& __e, | |||||||
|              regex_constants::match_flag_type __flags = regex_constants::match_default) |              regex_constants::match_flag_type __flags = regex_constants::match_default) | ||||||
| { | { | ||||||
|     match_results<const _CharT*> __m; |     match_results<const _CharT*> __m; | ||||||
|     return _STD::regex_search(__str, __m, __e, __flags); |     return _VSTD::regex_search(__str, __m, __e, __flags); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _ST, class _SA, class _CharT, class _Traits> | template <class _ST, class _SA, class _CharT, class _Traits> | ||||||
| @@ -5861,7 +5861,7 @@ regex_match(_BidirectionalIterator __first, _BidirectionalIterator __last, | |||||||
|             const basic_regex<_CharT, _Traits>& __e, |             const basic_regex<_CharT, _Traits>& __e, | ||||||
|             regex_constants::match_flag_type __flags = regex_constants::match_default) |             regex_constants::match_flag_type __flags = regex_constants::match_default) | ||||||
| { | { | ||||||
|     bool __r = _STD::regex_search(__first, __last, __m, __e, |     bool __r = _VSTD::regex_search(__first, __last, __m, __e, | ||||||
|                             __flags | regex_constants::match_continuous); |                             __flags | regex_constants::match_continuous); | ||||||
|     if (__r) |     if (__r) | ||||||
|     { |     { | ||||||
| @@ -5880,7 +5880,7 @@ regex_match(_BidirectionalIterator __first, _BidirectionalIterator __last, | |||||||
|             regex_constants::match_flag_type __flags = regex_constants::match_default) |             regex_constants::match_flag_type __flags = regex_constants::match_default) | ||||||
| { | { | ||||||
|     match_results<_BidirectionalIterator> __m; |     match_results<_BidirectionalIterator> __m; | ||||||
|     return _STD::regex_match(__first, __last, __m, __e, __flags); |     return _VSTD::regex_match(__first, __last, __m, __e, __flags); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _CharT, class _Allocator, class _Traits> | template <class _CharT, class _Allocator, class _Traits> | ||||||
| @@ -5890,7 +5890,7 @@ regex_match(const _CharT* __str, match_results<const _CharT*, _Allocator>& __m, | |||||||
|             const basic_regex<_CharT, _Traits>& __e, |             const basic_regex<_CharT, _Traits>& __e, | ||||||
|             regex_constants::match_flag_type __flags = regex_constants::match_default) |             regex_constants::match_flag_type __flags = regex_constants::match_default) | ||||||
| { | { | ||||||
|     return _STD::regex_match(__str, __str + _Traits::length(__str), __m, __e, __flags); |     return _VSTD::regex_match(__str, __str + _Traits::length(__str), __m, __e, __flags); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _ST, class _SA, class _Allocator, class _CharT, class _Traits> | template <class _ST, class _SA, class _Allocator, class _CharT, class _Traits> | ||||||
| @@ -5901,7 +5901,7 @@ regex_match(const basic_string<_CharT, _ST, _SA>& __s, | |||||||
|             const basic_regex<_CharT, _Traits>& __e, |             const basic_regex<_CharT, _Traits>& __e, | ||||||
|             regex_constants::match_flag_type __flags = regex_constants::match_default) |             regex_constants::match_flag_type __flags = regex_constants::match_default) | ||||||
| { | { | ||||||
|     return _STD::regex_match(__s.begin(), __s.end(), __m, __e, __flags); |     return _VSTD::regex_match(__s.begin(), __s.end(), __m, __e, __flags); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _CharT, class _Traits> | template <class _CharT, class _Traits> | ||||||
| @@ -5910,7 +5910,7 @@ bool | |||||||
| regex_match(const _CharT* __str, const basic_regex<_CharT, _Traits>& __e, | regex_match(const _CharT* __str, const basic_regex<_CharT, _Traits>& __e, | ||||||
|             regex_constants::match_flag_type __flags = regex_constants::match_default) |             regex_constants::match_flag_type __flags = regex_constants::match_default) | ||||||
| { | { | ||||||
|     return _STD::regex_match(__str, __str + _Traits::length(__str), __e, __flags); |     return _VSTD::regex_match(__str, __str + _Traits::length(__str), __e, __flags); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _ST, class _SA, class _CharT, class _Traits> | template <class _ST, class _SA, class _CharT, class _Traits> | ||||||
| @@ -5920,7 +5920,7 @@ regex_match(const basic_string<_CharT, _ST, _SA>& __s, | |||||||
|             const basic_regex<_CharT, _Traits>& __e, |             const basic_regex<_CharT, _Traits>& __e, | ||||||
|             regex_constants::match_flag_type __flags = regex_constants::match_default) |             regex_constants::match_flag_type __flags = regex_constants::match_default) | ||||||
| { | { | ||||||
|     return _STD::regex_match(__s.begin(), __s.end(), __e, __flags); |     return _VSTD::regex_match(__s.begin(), __s.end(), __e, __flags); | ||||||
| } | } | ||||||
|  |  | ||||||
| // regex_iterator | // regex_iterator | ||||||
| @@ -5985,7 +5985,7 @@ regex_iterator<_BidirectionalIterator, _CharT, _Traits>:: | |||||||
|       __pregex_(&__re), |       __pregex_(&__re), | ||||||
|       __flags_(__m) |       __flags_(__m) | ||||||
| { | { | ||||||
|     _STD::regex_search(__begin_, __end_, __match_, *__pregex_, __flags_); |     _VSTD::regex_search(__begin_, __end_, __match_, *__pregex_, __flags_); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _BidirectionalIterator, class _CharT, class _Traits> | template <class _BidirectionalIterator, class _CharT, class _Traits> | ||||||
| @@ -6017,7 +6017,7 @@ regex_iterator<_BidirectionalIterator, _CharT, _Traits>::operator++() | |||||||
|             __match_ = value_type(); |             __match_ = value_type(); | ||||||
|             return *this; |             return *this; | ||||||
|         } |         } | ||||||
|         else if (_STD::regex_search(__start, __end_, __match_, *__pregex_, |         else if (_VSTD::regex_search(__start, __end_, __match_, *__pregex_, | ||||||
|                                     __flags_ | regex_constants::match_not_null | |                                     __flags_ | regex_constants::match_not_null | | ||||||
|                                     regex_constants::match_continuous)) |                                     regex_constants::match_continuous)) | ||||||
|             return *this; |             return *this; | ||||||
| @@ -6025,7 +6025,7 @@ regex_iterator<_BidirectionalIterator, _CharT, _Traits>::operator++() | |||||||
|             ++__start; |             ++__start; | ||||||
|     } |     } | ||||||
|     __flags_ |= regex_constants::match_prev_avail; |     __flags_ |= regex_constants::match_prev_avail; | ||||||
|     if (!_STD::regex_search(__start, __end_, __match_, *__pregex_, __flags_)) |     if (!_VSTD::regex_search(__start, __end_, __match_, *__pregex_, __flags_)) | ||||||
|         __match_ = value_type(); |         __match_ = value_type(); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
| @@ -6267,7 +6267,7 @@ regex_token_iterator<_BidirectionalIterator, _CharT, _Traits>::operator++() | |||||||
|         } |         } | ||||||
|         else |         else | ||||||
|         { |         { | ||||||
|             if (_STD::find(__subs_.begin(), __subs_.end(), -1) != __subs_.end() |             if (_VSTD::find(__subs_.begin(), __subs_.end(), -1) != __subs_.end() | ||||||
|                 && __prev->suffix().length() != 0) |                 && __prev->suffix().length() != 0) | ||||||
|             { |             { | ||||||
|                 __suffix_.matched = true; |                 __suffix_.matched = true; | ||||||
| @@ -6303,7 +6303,7 @@ regex_replace(_OutputIterator __out, | |||||||
|     if (__i == __eof) |     if (__i == __eof) | ||||||
|     { |     { | ||||||
|         if (!(__flags & regex_constants::format_no_copy)) |         if (!(__flags & regex_constants::format_no_copy)) | ||||||
|             __out = _STD::copy(__first, __last, __out); |             __out = _VSTD::copy(__first, __last, __out); | ||||||
|     } |     } | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
| @@ -6311,14 +6311,14 @@ regex_replace(_OutputIterator __out, | |||||||
|         for (size_t __len = char_traits<_CharT>::length(__fmt); __i != __eof; ++__i) |         for (size_t __len = char_traits<_CharT>::length(__fmt); __i != __eof; ++__i) | ||||||
|         { |         { | ||||||
|             if (!(__flags & regex_constants::format_no_copy)) |             if (!(__flags & regex_constants::format_no_copy)) | ||||||
|                 __out = _STD::copy(__i->prefix().first, __i->prefix().second, __out); |                 __out = _VSTD::copy(__i->prefix().first, __i->prefix().second, __out); | ||||||
|             __out = __i->format(__out, __fmt, __fmt + __len, __flags); |             __out = __i->format(__out, __fmt, __fmt + __len, __flags); | ||||||
|             __lm = __i->suffix(); |             __lm = __i->suffix(); | ||||||
|             if (__flags & regex_constants::format_first_only) |             if (__flags & regex_constants::format_first_only) | ||||||
|                 break; |                 break; | ||||||
|         } |         } | ||||||
|         if (!(__flags & regex_constants::format_no_copy)) |         if (!(__flags & regex_constants::format_no_copy)) | ||||||
|             __out = _STD::copy(__lm.first, __lm.second, __out); |             __out = _VSTD::copy(__lm.first, __lm.second, __out); | ||||||
|     } |     } | ||||||
|     return __out; |     return __out; | ||||||
| } | } | ||||||
| @@ -6333,7 +6333,7 @@ regex_replace(_OutputIterator __out, | |||||||
|               const basic_string<_CharT, _ST, _SA>& __fmt, |               const basic_string<_CharT, _ST, _SA>& __fmt, | ||||||
|               regex_constants::match_flag_type __flags = regex_constants::match_default) |               regex_constants::match_flag_type __flags = regex_constants::match_default) | ||||||
| { | { | ||||||
|     return _STD::regex_replace(__out, __first, __last, __e, __fmt.c_str(), __flags); |     return _VSTD::regex_replace(__out, __first, __last, __e, __fmt.c_str(), __flags); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Traits, class _CharT, class _ST, class _SA, class _FST, | template <class _Traits, class _CharT, class _ST, class _SA, class _FST, | ||||||
| @@ -6346,7 +6346,7 @@ regex_replace(const basic_string<_CharT, _ST, _SA>& __s, | |||||||
|               regex_constants::match_flag_type __flags = regex_constants::match_default) |               regex_constants::match_flag_type __flags = regex_constants::match_default) | ||||||
| { | { | ||||||
|     basic_string<_CharT, _ST, _SA> __r; |     basic_string<_CharT, _ST, _SA> __r; | ||||||
|     _STD::regex_replace(back_inserter(__r), __s.begin(), __s.end(), __e, |     _VSTD::regex_replace(back_inserter(__r), __s.begin(), __s.end(), __e, | ||||||
|                         __fmt.c_str(), __flags); |                         __fmt.c_str(), __flags); | ||||||
|     return __r; |     return __r; | ||||||
| } | } | ||||||
| @@ -6359,7 +6359,7 @@ regex_replace(const basic_string<_CharT, _ST, _SA>& __s, | |||||||
|               regex_constants::match_flag_type __flags = regex_constants::match_default) |               regex_constants::match_flag_type __flags = regex_constants::match_default) | ||||||
| { | { | ||||||
|     basic_string<_CharT, _ST, _SA> __r; |     basic_string<_CharT, _ST, _SA> __r; | ||||||
|     _STD::regex_replace(back_inserter(__r), __s.begin(), __s.end(), __e, |     _VSTD::regex_replace(back_inserter(__r), __s.begin(), __s.end(), __e, | ||||||
|                         __fmt, __flags); |                         __fmt, __flags); | ||||||
|     return __r; |     return __r; | ||||||
| } | } | ||||||
| @@ -6373,7 +6373,7 @@ regex_replace(const _CharT* __s, | |||||||
|               regex_constants::match_flag_type __flags = regex_constants::match_default) |               regex_constants::match_flag_type __flags = regex_constants::match_default) | ||||||
| { | { | ||||||
|     basic_string<_CharT> __r; |     basic_string<_CharT> __r; | ||||||
|     _STD::regex_replace(back_inserter(__r), __s, |     _VSTD::regex_replace(back_inserter(__r), __s, | ||||||
|                         __s + char_traits<_CharT>::length(__s), __e, |                         __s + char_traits<_CharT>::length(__s), __e, | ||||||
|                         __fmt.c_str(), __flags); |                         __fmt.c_str(), __flags); | ||||||
|     return __r; |     return __r; | ||||||
| @@ -6388,7 +6388,7 @@ regex_replace(const _CharT* __s, | |||||||
|               regex_constants::match_flag_type __flags = regex_constants::match_default) |               regex_constants::match_flag_type __flags = regex_constants::match_default) | ||||||
| { | { | ||||||
|     basic_string<_CharT> __r; |     basic_string<_CharT> __r; | ||||||
|     _STD::regex_replace(back_inserter(__r), __s, |     _VSTD::regex_replace(back_inserter(__r), __s, | ||||||
|                         __s + char_traits<_CharT>::length(__s), __e, |                         __s + char_traits<_CharT>::length(__s), __e, | ||||||
|                         __fmt, __flags); |                         __fmt, __flags); | ||||||
|     return __r; |     return __r; | ||||||
|   | |||||||
| @@ -49,24 +49,25 @@ public: | |||||||
|     scoped_allocator_adaptor(); |     scoped_allocator_adaptor(); | ||||||
|     template <class OuterA2> |     template <class OuterA2> | ||||||
|         scoped_allocator_adaptor(OuterA2&& outerAlloc, |         scoped_allocator_adaptor(OuterA2&& outerAlloc, | ||||||
|                                  const InnerAllocs&... innerAllocs); |                                  const InnerAllocs&... innerAllocs) noexcept; | ||||||
|     scoped_allocator_adaptor(const scoped_allocator_adaptor& other); |     scoped_allocator_adaptor(const scoped_allocator_adaptor& other) noexcept; | ||||||
|  |     scoped_allocator_adaptor(scoped_allocator_adaptor&& other) noexcept; | ||||||
|     template <class OuterA2> |     template <class OuterA2> | ||||||
|         scoped_allocator_adaptor(const scoped_allocator_adaptor<OuterA2, InnerAllocs...>& other); |         scoped_allocator_adaptor(const scoped_allocator_adaptor<OuterA2, InnerAllocs...>& other) noexcept; | ||||||
|     template <class OuterA2> |     template <class OuterA2> | ||||||
|         scoped_allocator_adaptor(const scoped_allocator_adaptor<OuterA2, InnerAllocs...>&& other); |         scoped_allocator_adaptor(const scoped_allocator_adaptor<OuterA2, InnerAllocs...>&& other) noexcept; | ||||||
|  |  | ||||||
|     ~scoped_allocator_adaptor(); |     ~scoped_allocator_adaptor(); | ||||||
|  |  | ||||||
|     inner_allocator_type& inner_allocator(); |     inner_allocator_type& inner_allocator() noexcept; | ||||||
|     const inner_allocator_type& inner_allocator() const; |     const inner_allocator_type& inner_allocator() const noexcept; | ||||||
|  |  | ||||||
|     outer_allocator_type& outer_allocator(); |     outer_allocator_type& outer_allocator() noexcept; | ||||||
|     const outer_allocator_type& outer_allocator() const; |     const outer_allocator_type& outer_allocator() const noexcept; | ||||||
|  |  | ||||||
|     pointer allocate(size_type n); |     pointer allocate(size_type n); | ||||||
|     pointer allocate(size_type n, const_void_pointer hint); |     pointer allocate(size_type n, const_void_pointer hint); | ||||||
|     void deallocate(pointer p, size_type n); |     void deallocate(pointer p, size_type n) noexcept; | ||||||
|  |  | ||||||
|     size_type max_size() const; |     size_type max_size() const; | ||||||
|     template <class T, class... Args> void construct(T* p, Args&& args); |     template <class T, class... Args> void construct(T* p, Args&& args); | ||||||
| @@ -83,18 +84,20 @@ public: | |||||||
|         void construct(pair<T1, T2>* p, pair<U, V>&& x); |         void construct(pair<T1, T2>* p, pair<U, V>&& x); | ||||||
|     template <class T> void destroy(T* p); |     template <class T> void destroy(T* p); | ||||||
|  |  | ||||||
|     scoped_allocator_adaptor select_on_container_copy_construction() const; |     template <class T> void destroy(T* p) noexcept; | ||||||
|  |  | ||||||
|  |     scoped_allocator_adaptor select_on_container_copy_construction() const noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class OuterA1, class OuterA2, class... InnerAllocs> | template <class OuterA1, class OuterA2, class... InnerAllocs> | ||||||
|     bool |     bool | ||||||
|     operator==(const scoped_allocator_adaptor<OuterA1, InnerAllocs...>& a, |     operator==(const scoped_allocator_adaptor<OuterA1, InnerAllocs...>& a, | ||||||
|                const scoped_allocator_adaptor<OuterA2, InnerAllocs...>& b); |                const scoped_allocator_adaptor<OuterA2, InnerAllocs...>& b) noexcept; | ||||||
|  |  | ||||||
| template <class OuterA1, class OuterA2, class... InnerAllocs> | template <class OuterA1, class OuterA2, class... InnerAllocs> | ||||||
|     bool |     bool | ||||||
|     operator!=(const scoped_allocator_adaptor<OuterA1, InnerAllocs...>& a, |     operator!=(const scoped_allocator_adaptor<OuterA1, InnerAllocs...>& a, | ||||||
|                const scoped_allocator_adaptor<OuterA2, InnerAllocs...>& b); |                const scoped_allocator_adaptor<OuterA2, InnerAllocs...>& b) noexcept; | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
|  |  | ||||||
| @@ -182,7 +185,7 @@ private: | |||||||
| protected: | protected: | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __scoped_allocator_storage() {} |     __scoped_allocator_storage() _NOEXCEPT {} | ||||||
|  |  | ||||||
|     template <class _OuterA2, |     template <class _OuterA2, | ||||||
|               class = typename enable_if< |               class = typename enable_if< | ||||||
| @@ -190,8 +193,8 @@ protected: | |||||||
|                       >::type> |                       >::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         __scoped_allocator_storage(_OuterA2&& __outerAlloc, |         __scoped_allocator_storage(_OuterA2&& __outerAlloc, | ||||||
|                                    const _InnerAllocs& ...__innerAllocs) |                                    const _InnerAllocs& ...__innerAllocs) _NOEXCEPT | ||||||
|             : outer_allocator_type(_STD::forward<_OuterA2>(__outerAlloc)), |             : outer_allocator_type(_VSTD::forward<_OuterA2>(__outerAlloc)), | ||||||
|               __inner_(__innerAllocs...) {} |               __inner_(__innerAllocs...) {} | ||||||
|  |  | ||||||
|     template <class _OuterA2, |     template <class _OuterA2, | ||||||
| @@ -200,7 +203,7 @@ protected: | |||||||
|                       >::type> |                       >::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         __scoped_allocator_storage( |         __scoped_allocator_storage( | ||||||
|             const __scoped_allocator_storage<_OuterA2, _InnerAllocs...>& __other) |             const __scoped_allocator_storage<_OuterA2, _InnerAllocs...>& __other) _NOEXCEPT | ||||||
|             : outer_allocator_type(__other.outer_allocator()), |             : outer_allocator_type(__other.outer_allocator()), | ||||||
|               __inner_(__other.inner_allocator()) {} |               __inner_(__other.inner_allocator()) {} | ||||||
|  |  | ||||||
| @@ -210,9 +213,9 @@ protected: | |||||||
|                       >::type> |                       >::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         __scoped_allocator_storage( |         __scoped_allocator_storage( | ||||||
|             __scoped_allocator_storage<_OuterA2, _InnerAllocs...>&& __other) |             __scoped_allocator_storage<_OuterA2, _InnerAllocs...>&& __other) _NOEXCEPT | ||||||
|             : outer_allocator_type(_STD::move(__other.outer_allocator())), |             : outer_allocator_type(_VSTD::move(__other.outer_allocator())), | ||||||
|               __inner_(_STD::move(__other.inner_allocator())) {} |               __inner_(_VSTD::move(__other.inner_allocator())) {} | ||||||
|  |  | ||||||
|     template <class _OuterA2, |     template <class _OuterA2, | ||||||
|               class = typename enable_if< |               class = typename enable_if< | ||||||
| @@ -220,27 +223,27 @@ protected: | |||||||
|                       >::type> |                       >::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         __scoped_allocator_storage(_OuterA2&& __o, |         __scoped_allocator_storage(_OuterA2&& __o, | ||||||
|                                    const inner_allocator_type& __i) |                                    const inner_allocator_type& __i) _NOEXCEPT | ||||||
|             : outer_allocator_type(_STD::forward<_OuterA2>(__o)), |             : outer_allocator_type(_VSTD::forward<_OuterA2>(__o)), | ||||||
|               __inner_(__i) |               __inner_(__i) | ||||||
|         { |         { | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     inner_allocator_type& inner_allocator()             {return __inner_;} |     inner_allocator_type& inner_allocator() _NOEXCEPT             {return __inner_;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const inner_allocator_type& inner_allocator() const {return __inner_;} |     const inner_allocator_type& inner_allocator() const _NOEXCEPT {return __inner_;} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     outer_allocator_type& outer_allocator() |     outer_allocator_type& outer_allocator() _NOEXCEPT | ||||||
|         {return static_cast<outer_allocator_type&>(*this);} |         {return static_cast<outer_allocator_type&>(*this);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const outer_allocator_type& outer_allocator() const |     const outer_allocator_type& outer_allocator() const _NOEXCEPT | ||||||
|         {return static_cast<const outer_allocator_type&>(*this);} |         {return static_cast<const outer_allocator_type&>(*this);} | ||||||
|  |  | ||||||
|     scoped_allocator_adaptor<outer_allocator_type, _InnerAllocs...> |     scoped_allocator_adaptor<outer_allocator_type, _InnerAllocs...> | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     select_on_container_copy_construction() const |     select_on_container_copy_construction() const _NOEXCEPT | ||||||
|         { |         { | ||||||
|             return scoped_allocator_adaptor<outer_allocator_type, _InnerAllocs...> |             return scoped_allocator_adaptor<outer_allocator_type, _InnerAllocs...> | ||||||
|             ( |             ( | ||||||
| @@ -263,15 +266,15 @@ protected: | |||||||
|     typedef scoped_allocator_adaptor<_OuterAlloc> inner_allocator_type; |     typedef scoped_allocator_adaptor<_OuterAlloc> inner_allocator_type; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __scoped_allocator_storage() {} |     __scoped_allocator_storage() _NOEXCEPT {} | ||||||
|  |  | ||||||
|     template <class _OuterA2, |     template <class _OuterA2, | ||||||
|               class = typename enable_if< |               class = typename enable_if< | ||||||
|                         is_constructible<outer_allocator_type, _OuterA2>::value |                         is_constructible<outer_allocator_type, _OuterA2>::value | ||||||
|                       >::type> |                       >::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         __scoped_allocator_storage(_OuterA2&& __outerAlloc) |         __scoped_allocator_storage(_OuterA2&& __outerAlloc) _NOEXCEPT | ||||||
|             : outer_allocator_type(_STD::forward<_OuterA2>(__outerAlloc)) {} |             : outer_allocator_type(_VSTD::forward<_OuterA2>(__outerAlloc)) {} | ||||||
|  |  | ||||||
|     template <class _OuterA2, |     template <class _OuterA2, | ||||||
|               class = typename enable_if< |               class = typename enable_if< | ||||||
| @@ -279,7 +282,7 @@ protected: | |||||||
|                       >::type> |                       >::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         __scoped_allocator_storage( |         __scoped_allocator_storage( | ||||||
|             const __scoped_allocator_storage<_OuterA2>& __other) |             const __scoped_allocator_storage<_OuterA2>& __other) _NOEXCEPT | ||||||
|             : outer_allocator_type(__other.outer_allocator()) {} |             : outer_allocator_type(__other.outer_allocator()) {} | ||||||
|  |  | ||||||
|     template <class _OuterA2, |     template <class _OuterA2, | ||||||
| @@ -288,33 +291,33 @@ protected: | |||||||
|                       >::type> |                       >::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         __scoped_allocator_storage( |         __scoped_allocator_storage( | ||||||
|             __scoped_allocator_storage<_OuterA2>&& __other) |             __scoped_allocator_storage<_OuterA2>&& __other) _NOEXCEPT | ||||||
|             : outer_allocator_type(_STD::move(__other.outer_allocator())) {} |             : outer_allocator_type(_VSTD::move(__other.outer_allocator())) {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     inner_allocator_type& inner_allocator() |     inner_allocator_type& inner_allocator() _NOEXCEPT | ||||||
|         {return static_cast<inner_allocator_type&>(*this);} |         {return static_cast<inner_allocator_type&>(*this);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const inner_allocator_type& inner_allocator() const |     const inner_allocator_type& inner_allocator() const _NOEXCEPT | ||||||
|         {return static_cast<const inner_allocator_type&>(*this);} |         {return static_cast<const inner_allocator_type&>(*this);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     outer_allocator_type& outer_allocator() |     outer_allocator_type& outer_allocator() _NOEXCEPT | ||||||
|         {return static_cast<outer_allocator_type&>(*this);} |         {return static_cast<outer_allocator_type&>(*this);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const outer_allocator_type& outer_allocator() const |     const outer_allocator_type& outer_allocator() const _NOEXCEPT | ||||||
|         {return static_cast<const outer_allocator_type&>(*this);} |         {return static_cast<const outer_allocator_type&>(*this);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     scoped_allocator_adaptor<outer_allocator_type> |     scoped_allocator_adaptor<outer_allocator_type> | ||||||
|     select_on_container_copy_construction() const |     select_on_container_copy_construction() const _NOEXCEPT | ||||||
|         {return scoped_allocator_adaptor<outer_allocator_type>( |         {return scoped_allocator_adaptor<outer_allocator_type>( | ||||||
|             allocator_traits<outer_allocator_type>:: |             allocator_traits<outer_allocator_type>:: | ||||||
|                 select_on_container_copy_construction(outer_allocator()) |                 select_on_container_copy_construction(outer_allocator()) | ||||||
|         );} |         );} | ||||||
|  |  | ||||||
|     __scoped_allocator_storage(const outer_allocator_type& __o, |     __scoped_allocator_storage(const outer_allocator_type& __o, | ||||||
|                                const inner_allocator_type& __i); |                                const inner_allocator_type& __i) _NOEXCEPT; | ||||||
|  |  | ||||||
|     template <class...> friend class __scoped_allocator_storage; |     template <class...> friend class __scoped_allocator_storage; | ||||||
| }; | }; | ||||||
| @@ -343,7 +346,7 @@ struct __outermost | |||||||
| { | { | ||||||
|     typedef _Alloc type; |     typedef _Alloc type; | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     type& operator()(type& __a) const {return __a;} |     type& operator()(type& __a) const _NOEXCEPT {return __a;} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _Alloc> | template <class _Alloc> | ||||||
| @@ -351,11 +354,11 @@ struct __outermost<_Alloc, true> | |||||||
| { | { | ||||||
|     typedef typename remove_reference |     typedef typename remove_reference | ||||||
|                      < |                      < | ||||||
|                         decltype(_STD::declval<_Alloc>().outer_allocator()) |                         decltype(_VSTD::declval<_Alloc>().outer_allocator()) | ||||||
|                      >::type                                    _OuterAlloc; |                      >::type                                    _OuterAlloc; | ||||||
|     typedef typename __outermost<_OuterAlloc>::type             type; |     typedef typename __outermost<_OuterAlloc>::type             type; | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     type& operator()(_Alloc& __a) const |     type& operator()(_Alloc& __a) const _NOEXCEPT | ||||||
|         {return __outermost<_OuterAlloc>()(__a.outer_allocator());} |         {return __outermost<_OuterAlloc>()(__a.outer_allocator());} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -403,15 +406,15 @@ public: | |||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     scoped_allocator_adaptor() {} |     scoped_allocator_adaptor() _NOEXCEPT {} | ||||||
|     template <class _OuterA2, |     template <class _OuterA2, | ||||||
|               class = typename enable_if< |               class = typename enable_if< | ||||||
|                         is_constructible<outer_allocator_type, _OuterA2>::value |                         is_constructible<outer_allocator_type, _OuterA2>::value | ||||||
|                       >::type> |                       >::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         scoped_allocator_adaptor(_OuterA2&& __outerAlloc, |         scoped_allocator_adaptor(_OuterA2&& __outerAlloc, | ||||||
|                                  const _InnerAllocs& ...__innerAllocs) |                                  const _InnerAllocs& ...__innerAllocs) _NOEXCEPT | ||||||
|             : base(_STD::forward<_OuterA2>(__outerAlloc), __innerAllocs...) {} |             : base(_VSTD::forward<_OuterA2>(__outerAlloc), __innerAllocs...) {} | ||||||
|     // scoped_allocator_adaptor(const scoped_allocator_adaptor& __other) = default; |     // scoped_allocator_adaptor(const scoped_allocator_adaptor& __other) = default; | ||||||
|     template <class _OuterA2, |     template <class _OuterA2, | ||||||
|               class = typename enable_if< |               class = typename enable_if< | ||||||
| @@ -419,7 +422,7 @@ public: | |||||||
|                       >::type> |                       >::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         scoped_allocator_adaptor( |         scoped_allocator_adaptor( | ||||||
|             const scoped_allocator_adaptor<_OuterA2, _InnerAllocs...>& __other) |             const scoped_allocator_adaptor<_OuterA2, _InnerAllocs...>& __other) _NOEXCEPT | ||||||
|                 : base(__other) {} |                 : base(__other) {} | ||||||
|     template <class _OuterA2, |     template <class _OuterA2, | ||||||
|               class = typename enable_if< |               class = typename enable_if< | ||||||
| @@ -427,23 +430,23 @@ public: | |||||||
|                       >::type> |                       >::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         scoped_allocator_adaptor( |         scoped_allocator_adaptor( | ||||||
|             scoped_allocator_adaptor<_OuterA2, _InnerAllocs...>&& __other) |             scoped_allocator_adaptor<_OuterA2, _InnerAllocs...>&& __other) _NOEXCEPT | ||||||
|                 : base(_STD::move(__other)) {} |                 : base(_VSTD::move(__other)) {} | ||||||
|  |  | ||||||
|     // ~scoped_allocator_adaptor() = default; |     // ~scoped_allocator_adaptor() = default; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     inner_allocator_type& inner_allocator() |     inner_allocator_type& inner_allocator() _NOEXCEPT | ||||||
|         {return base::inner_allocator();} |         {return base::inner_allocator();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const inner_allocator_type& inner_allocator() const |     const inner_allocator_type& inner_allocator() const _NOEXCEPT | ||||||
|         {return base::inner_allocator();} |         {return base::inner_allocator();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     outer_allocator_type& outer_allocator() |     outer_allocator_type& outer_allocator() _NOEXCEPT | ||||||
|         {return base::outer_allocator();} |         {return base::outer_allocator();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const outer_allocator_type& outer_allocator() const |     const outer_allocator_type& outer_allocator() const _NOEXCEPT | ||||||
|         {return base::outer_allocator();} |         {return base::outer_allocator();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -456,7 +459,7 @@ public: | |||||||
|             allocate(outer_allocator(), __n, __hint);} |             allocate(outer_allocator(), __n, __hint);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void deallocate(pointer __p, size_type __n) |     void deallocate(pointer __p, size_type __n) _NOEXCEPT | ||||||
|         {allocator_traits<outer_allocator_type>:: |         {allocator_traits<outer_allocator_type>:: | ||||||
|             deallocate(outer_allocator(), __p, __n);} |             deallocate(outer_allocator(), __p, __n);} | ||||||
|  |  | ||||||
| @@ -468,7 +471,7 @@ public: | |||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         void construct(_Tp* __p, _Args&& ...__args) |         void construct(_Tp* __p, _Args&& ...__args) | ||||||
|             {__construct(__uses_alloc_ctor<_Tp, inner_allocator_type, _Args...>(), |             {__construct(__uses_alloc_ctor<_Tp, inner_allocator_type, _Args...>(), | ||||||
|                          __p, _STD::forward<_Args>(__args)...);} |                          __p, _VSTD::forward<_Args>(__args)...);} | ||||||
|     template <class _Tp> |     template <class _Tp> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         void destroy(_Tp* __p) |         void destroy(_Tp* __p) | ||||||
| @@ -479,7 +482,7 @@ public: | |||||||
|             } |             } | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     scoped_allocator_adaptor select_on_container_copy_construction() const |     scoped_allocator_adaptor select_on_container_copy_construction() const _NOEXCEPT | ||||||
|         {return base::select_on_container_copy_construction();} |         {return base::select_on_container_copy_construction();} | ||||||
|  |  | ||||||
| private: | private: | ||||||
| @@ -490,8 +493,8 @@ private: | |||||||
|                       >::type> |                       >::type> | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     scoped_allocator_adaptor(_OuterA2&& __o, |     scoped_allocator_adaptor(_OuterA2&& __o, | ||||||
|                              const inner_allocator_type& __i) |                              const inner_allocator_type& __i) _NOEXCEPT | ||||||
|         : base(_STD::forward<_OuterA2>(__o), __i) {} |         : base(_VSTD::forward<_OuterA2>(__o), __i) {} | ||||||
|  |  | ||||||
|     template <class _Tp, class... _Args> |     template <class _Tp, class... _Args> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -502,7 +505,7 @@ private: | |||||||
|                 ( |                 ( | ||||||
|                     _OM()(outer_allocator()), |                     _OM()(outer_allocator()), | ||||||
|                     __p, |                     __p, | ||||||
|                     _STD::forward<_Args>(__args)... |                     _VSTD::forward<_Args>(__args)... | ||||||
|                 ); |                 ); | ||||||
|             } |             } | ||||||
|  |  | ||||||
| @@ -517,7 +520,7 @@ private: | |||||||
|                     __p, |                     __p, | ||||||
|                     allocator_arg, |                     allocator_arg, | ||||||
|                     inner_allocator(), |                     inner_allocator(), | ||||||
|                     _STD::forward<_Args>(__args)... |                     _VSTD::forward<_Args>(__args)... | ||||||
|                 ); |                 ); | ||||||
|             } |             } | ||||||
|  |  | ||||||
| @@ -530,7 +533,7 @@ private: | |||||||
|                 ( |                 ( | ||||||
|                     _OM()(outer_allocator()), |                     _OM()(outer_allocator()), | ||||||
|                     __p, |                     __p, | ||||||
|                     _STD::forward<_Args>(__args)..., |                     _VSTD::forward<_Args>(__args)..., | ||||||
|                     inner_allocator() |                     inner_allocator() | ||||||
|                 ); |                 ); | ||||||
|             } |             } | ||||||
| @@ -542,16 +545,16 @@ template <class _OuterA1, class _OuterA2> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator==(const scoped_allocator_adaptor<_OuterA1>& __a, | operator==(const scoped_allocator_adaptor<_OuterA1>& __a, | ||||||
|            const scoped_allocator_adaptor<_OuterA2>& __b) |            const scoped_allocator_adaptor<_OuterA2>& __b) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __a.outer_allocator() == __b.outer_allocator(); |     return __a.outer_allocator() == __b.outer_allocator(); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _OuterA1, class _OuterA2, class... _InnerAllocs> | template <class _OuterA1, class _OuterA2, class _InnerA0, class... _InnerAllocs> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator==(const scoped_allocator_adaptor<_OuterA1, _InnerAllocs...>& __a, | operator==(const scoped_allocator_adaptor<_OuterA1, _InnerA0, _InnerAllocs...>& __a, | ||||||
|            const scoped_allocator_adaptor<_OuterA2, _InnerAllocs...>& __b) |            const scoped_allocator_adaptor<_OuterA2, _InnerA0, _InnerAllocs...>& __b) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __a.outer_allocator() == __b.outer_allocator() && |     return __a.outer_allocator() == __b.outer_allocator() && | ||||||
|            __a.inner_allocator() == __b.inner_allocator(); |            __a.inner_allocator() == __b.inner_allocator(); | ||||||
| @@ -561,7 +564,7 @@ template <class _OuterA1, class _OuterA2, class... _InnerAllocs> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator!=(const scoped_allocator_adaptor<_OuterA1, _InnerAllocs...>& __a, | operator!=(const scoped_allocator_adaptor<_OuterA1, _InnerAllocs...>& __a, | ||||||
|            const scoped_allocator_adaptor<_OuterA2, _InnerAllocs...>& __b) |            const scoped_allocator_adaptor<_OuterA2, _InnerAllocs...>& __b) _NOEXCEPT | ||||||
| { | { | ||||||
|     return !(__a == __b); |     return !(__a == __b); | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										281
									
								
								include/set
									
									
									
									
									
								
							
							
						
						
									
										281
									
								
								include/set
									
									
									
									
									
								
							| @@ -42,7 +42,12 @@ public: | |||||||
|     typedef std::reverse_iterator<const_iterator>    const_reverse_iterator; |     typedef std::reverse_iterator<const_iterator>    const_reverse_iterator; | ||||||
|  |  | ||||||
|     // construct/copy/destroy: |     // construct/copy/destroy: | ||||||
|     explicit set(const value_compare& comp = value_compare()); |     set() | ||||||
|  |         noexcept( | ||||||
|  |             is_nothrow_default_constructible<allocator_type>::value && | ||||||
|  |             is_nothrow_default_constructible<key_compare>::value && | ||||||
|  |             is_nothrow_copy_constructible<key_compare>::value); | ||||||
|  |     explicit set(const value_compare& comp); | ||||||
|     set(const value_compare& comp, const allocator_type& a); |     set(const value_compare& comp, const allocator_type& a); | ||||||
|     template <class InputIterator> |     template <class InputIterator> | ||||||
|         set(InputIterator first, InputIterator last, |         set(InputIterator first, InputIterator last, | ||||||
| @@ -51,7 +56,10 @@ public: | |||||||
|         set(InputIterator first, InputIterator last, const value_compare& comp, |         set(InputIterator first, InputIterator last, const value_compare& comp, | ||||||
|             const allocator_type& a); |             const allocator_type& a); | ||||||
|     set(const set& s); |     set(const set& s); | ||||||
|     set(set&& s); |     set(set&& s) | ||||||
|  |         noexcept( | ||||||
|  |             is_nothrow_move_constructible<allocator_type>::value && | ||||||
|  |             is_nothrow_move_constructible<key_compare>::value); | ||||||
|     explicit set(const allocator_type& a); |     explicit set(const allocator_type& a); | ||||||
|     set(const set& s, const allocator_type& a); |     set(const set& s, const allocator_type& a); | ||||||
|     set(set&& s, const allocator_type& a); |     set(set&& s, const allocator_type& a); | ||||||
| @@ -61,29 +69,33 @@ public: | |||||||
|     ~set(); |     ~set(); | ||||||
|  |  | ||||||
|     set& operator=(const set& s); |     set& operator=(const set& s); | ||||||
|     set& operator=(set&& s); |     set& operator=(set&& s) | ||||||
|  |         noexcept( | ||||||
|  |             allocator_type::propagate_on_container_move_assignment::value && | ||||||
|  |             is_nothrow_move_assignable<allocator_type>::value && | ||||||
|  |             is_nothrow_move_assignable<key_compare>::value); | ||||||
|     set& operator=(initializer_list<value_type> il); |     set& operator=(initializer_list<value_type> il); | ||||||
|  |  | ||||||
|     // iterators: |     // iterators: | ||||||
|           iterator begin(); |           iterator begin() noexcept; | ||||||
|     const_iterator begin() const; |     const_iterator begin() const noexcept; | ||||||
|           iterator end(); |           iterator end() noexcept; | ||||||
|     const_iterator end()   const; |     const_iterator end()   const noexcept; | ||||||
|  |  | ||||||
|           reverse_iterator rbegin(); |           reverse_iterator rbegin() noexcept; | ||||||
|     const_reverse_iterator rbegin() const; |     const_reverse_iterator rbegin() const noexcept; | ||||||
|           reverse_iterator rend(); |           reverse_iterator rend() noexcept; | ||||||
|     const_reverse_iterator rend()   const; |     const_reverse_iterator rend()   const noexcept; | ||||||
|  |  | ||||||
|     const_iterator         cbegin()  const; |     const_iterator         cbegin()  const noexcept; | ||||||
|     const_iterator         cend()    const; |     const_iterator         cend()    const noexcept; | ||||||
|     const_reverse_iterator crbegin() const; |     const_reverse_iterator crbegin() const noexcept; | ||||||
|     const_reverse_iterator crend()   const; |     const_reverse_iterator crend()   const noexcept; | ||||||
|  |  | ||||||
|     // capacity: |     // capacity: | ||||||
|     bool      empty()    const; |     bool      empty()    const noexcept; | ||||||
|     size_type size()     const; |     size_type size()     const noexcept; | ||||||
|     size_type max_size() const; |     size_type max_size() const noexcept; | ||||||
|  |  | ||||||
|     // modifiers: |     // modifiers: | ||||||
|     template <class... Args> |     template <class... Args> | ||||||
| @@ -101,12 +113,16 @@ public: | |||||||
|     iterator  erase(const_iterator position); |     iterator  erase(const_iterator position); | ||||||
|     size_type erase(const key_type& k); |     size_type erase(const key_type& k); | ||||||
|     iterator  erase(const_iterator first, const_iterator last); |     iterator  erase(const_iterator first, const_iterator last); | ||||||
|     void clear(); |     void clear() noexcept; | ||||||
|  |  | ||||||
|     void swap(set& s); |     void swap(set& s) | ||||||
|  |         noexcept( | ||||||
|  |             __is_nothrow_swappable<key_compare>::value && | ||||||
|  |             (!allocator_type::propagate_on_container_swap::value || | ||||||
|  |              __is_nothrow_swappable<allocator_type>::value)); | ||||||
|  |  | ||||||
|     // observers: |     // observers: | ||||||
|     allocator_type get_allocator() const; |     allocator_type get_allocator() const noexcept; | ||||||
|     key_compare    key_comp()      const; |     key_compare    key_comp()      const; | ||||||
|     value_compare  value_comp()    const; |     value_compare  value_comp()    const; | ||||||
|  |  | ||||||
| @@ -155,7 +171,8 @@ operator<=(const set<Key, Compare, Allocator>& x, | |||||||
| // specialized algorithms: | // specialized algorithms: | ||||||
| template <class Key, class Compare, class Allocator> | template <class Key, class Compare, class Allocator> | ||||||
| void | void | ||||||
| swap(set<Key, Compare, Allocator>& x, set<Key, Compare, Allocator>& y); | swap(set<Key, Compare, Allocator>& x, set<Key, Compare, Allocator>& y) | ||||||
|  |     noexcept(noexcept(x.swap(y))); | ||||||
|  |  | ||||||
| template <class Key, class Compare = less<Key>, | template <class Key, class Compare = less<Key>, | ||||||
|           class Allocator = allocator<Key>> |           class Allocator = allocator<Key>> | ||||||
| @@ -181,7 +198,12 @@ public: | |||||||
|     typedef std::reverse_iterator<const_iterator>    const_reverse_iterator; |     typedef std::reverse_iterator<const_iterator>    const_reverse_iterator; | ||||||
|  |  | ||||||
|     // construct/copy/destroy: |     // construct/copy/destroy: | ||||||
|     explicit multiset(const value_compare& comp = value_compare()); |     multiset() | ||||||
|  |         noexcept( | ||||||
|  |             is_nothrow_default_constructible<allocator_type>::value && | ||||||
|  |             is_nothrow_default_constructible<key_compare>::value && | ||||||
|  |             is_nothrow_copy_constructible<key_compare>::value); | ||||||
|  |     explicit multiset(const value_compare& comp); | ||||||
|     multiset(const value_compare& comp, const allocator_type& a); |     multiset(const value_compare& comp, const allocator_type& a); | ||||||
|     template <class InputIterator> |     template <class InputIterator> | ||||||
|         multiset(InputIterator first, InputIterator last, |         multiset(InputIterator first, InputIterator last, | ||||||
| @@ -190,7 +212,10 @@ public: | |||||||
|         multiset(InputIterator first, InputIterator last, |         multiset(InputIterator first, InputIterator last, | ||||||
|                  const value_compare& comp, const allocator_type& a); |                  const value_compare& comp, const allocator_type& a); | ||||||
|     multiset(const multiset& s); |     multiset(const multiset& s); | ||||||
|     multiset(multiset&& s); |     multiset(multiset&& s) | ||||||
|  |         noexcept( | ||||||
|  |             is_nothrow_move_constructible<allocator_type>::value && | ||||||
|  |             is_nothrow_move_constructible<key_compare>::value); | ||||||
|     explicit multiset(const allocator_type& a); |     explicit multiset(const allocator_type& a); | ||||||
|     multiset(const multiset& s, const allocator_type& a); |     multiset(const multiset& s, const allocator_type& a); | ||||||
|     multiset(multiset&& s, const allocator_type& a); |     multiset(multiset&& s, const allocator_type& a); | ||||||
| @@ -200,29 +225,33 @@ public: | |||||||
|     ~multiset(); |     ~multiset(); | ||||||
|  |  | ||||||
|     multiset& operator=(const multiset& s); |     multiset& operator=(const multiset& s); | ||||||
|     multiset& operator=(multiset&& s); |     multiset& operator=(multiset&& s) | ||||||
|  |         noexcept( | ||||||
|  |             allocator_type::propagate_on_container_move_assignment::value && | ||||||
|  |             is_nothrow_move_assignable<allocator_type>::value && | ||||||
|  |             is_nothrow_move_assignable<key_compare>::value); | ||||||
|     multiset& operator=(initializer_list<value_type> il); |     multiset& operator=(initializer_list<value_type> il); | ||||||
|  |  | ||||||
|     // iterators: |     // iterators: | ||||||
|           iterator begin(); |           iterator begin() noexcept; | ||||||
|     const_iterator begin() const; |     const_iterator begin() const noexcept; | ||||||
|           iterator end(); |           iterator end() noexcept; | ||||||
|     const_iterator end()   const; |     const_iterator end()   const noexcept; | ||||||
|  |  | ||||||
|           reverse_iterator rbegin(); |           reverse_iterator rbegin() noexcept; | ||||||
|     const_reverse_iterator rbegin() const; |     const_reverse_iterator rbegin() const noexcept; | ||||||
|           reverse_iterator rend(); |           reverse_iterator rend() noexcept; | ||||||
|     const_reverse_iterator rend()   const; |     const_reverse_iterator rend()   const noexcept; | ||||||
|  |  | ||||||
|     const_iterator         cbegin()  const; |     const_iterator         cbegin()  const noexcept; | ||||||
|     const_iterator         cend()    const; |     const_iterator         cend()    const noexcept; | ||||||
|     const_reverse_iterator crbegin() const; |     const_reverse_iterator crbegin() const noexcept; | ||||||
|     const_reverse_iterator crend()   const; |     const_reverse_iterator crend()   const noexcept; | ||||||
|  |  | ||||||
|     // capacity: |     // capacity: | ||||||
|     bool      empty()    const; |     bool      empty()    const noexcept; | ||||||
|     size_type size()     const; |     size_type size()     const noexcept; | ||||||
|     size_type max_size() const; |     size_type max_size() const noexcept; | ||||||
|  |  | ||||||
|     // modifiers: |     // modifiers: | ||||||
|     template <class... Args> |     template <class... Args> | ||||||
| @@ -240,12 +269,16 @@ public: | |||||||
|     iterator  erase(const_iterator position); |     iterator  erase(const_iterator position); | ||||||
|     size_type erase(const key_type& k); |     size_type erase(const key_type& k); | ||||||
|     iterator  erase(const_iterator first, const_iterator last); |     iterator  erase(const_iterator first, const_iterator last); | ||||||
|     void clear(); |     void clear() noexcept; | ||||||
|  |  | ||||||
|     void swap(multiset& s); |     void swap(multiset& s) | ||||||
|  |         noexcept( | ||||||
|  |             __is_nothrow_swappable<key_compare>::value && | ||||||
|  |             (!allocator_type::propagate_on_container_swap::value || | ||||||
|  |              __is_nothrow_swappable<allocator_type>::value)); | ||||||
|  |  | ||||||
|     // observers: |     // observers: | ||||||
|     allocator_type get_allocator() const; |     allocator_type get_allocator() const noexcept; | ||||||
|     key_compare    key_comp()      const; |     key_compare    key_comp()      const; | ||||||
|     value_compare  value_comp()    const; |     value_compare  value_comp()    const; | ||||||
|  |  | ||||||
| @@ -294,7 +327,8 @@ operator<=(const multiset<Key, Compare, Allocator>& x, | |||||||
| // specialized algorithms: | // specialized algorithms: | ||||||
| template <class Key, class Compare, class Allocator> | template <class Key, class Compare, class Allocator> | ||||||
| void | void | ||||||
| swap(multiset<Key, Compare, Allocator>& x, multiset<Key, Compare, Allocator>& y); | swap(multiset<Key, Compare, Allocator>& x, multiset<Key, Compare, Allocator>& y) | ||||||
|  |     noexcept(noexcept(x.swap(y))); | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
|  |  | ||||||
| @@ -336,11 +370,15 @@ public: | |||||||
|     typedef typename __base::difference_type       difference_type; |     typedef typename __base::difference_type       difference_type; | ||||||
|     typedef typename __base::const_iterator        iterator; |     typedef typename __base::const_iterator        iterator; | ||||||
|     typedef typename __base::const_iterator        const_iterator; |     typedef typename __base::const_iterator        const_iterator; | ||||||
|     typedef _STD::reverse_iterator<iterator>       reverse_iterator; |     typedef _VSTD::reverse_iterator<iterator>       reverse_iterator; | ||||||
|     typedef _STD::reverse_iterator<const_iterator> const_reverse_iterator; |     typedef _VSTD::reverse_iterator<const_iterator> const_reverse_iterator; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit set(const value_compare& __comp = value_compare()) |     explicit set(const value_compare& __comp = value_compare()) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             is_nothrow_default_constructible<allocator_type>::value && | ||||||
|  |             is_nothrow_default_constructible<key_compare>::value && | ||||||
|  |             is_nothrow_copy_constructible<key_compare>::value) | ||||||
|         : __tree_(__comp) {} |         : __tree_(__comp) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     set(const value_compare& __comp, const allocator_type& __a) |     set(const value_compare& __comp, const allocator_type& __a) | ||||||
| @@ -370,10 +408,18 @@ public: | |||||||
|             insert(__s.begin(), __s.end()); |             insert(__s.begin(), __s.end()); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     set& operator=(const set& __s) | ||||||
|  |         { | ||||||
|  |             __tree_ = __s.__tree_; | ||||||
|  |             return *this; | ||||||
|  |         } | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     set(set&& __s) |     set(set&& __s) | ||||||
|         : __tree_(_STD::move(__s.__tree_)) {} |         _NOEXCEPT_(is_nothrow_move_constructible<__base>::value) | ||||||
|  |         : __tree_(_VSTD::move(__s.__tree_)) {} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -416,56 +462,61 @@ public: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     set& operator=(set&& __s) |     set& operator=(set&& __s) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_assignable<__base>::value) | ||||||
|         { |         { | ||||||
|             __tree_ = _STD::move(__s.__tree_); |             __tree_ = _VSTD::move(__s.__tree_); | ||||||
|             return *this; |             return *this; | ||||||
|         } |         } | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           iterator begin()       {return __tree_.begin();} |           iterator begin() _NOEXCEPT       {return __tree_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator begin() const {return __tree_.begin();} |     const_iterator begin() const _NOEXCEPT {return __tree_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           iterator end()         {return __tree_.end();} |           iterator end() _NOEXCEPT         {return __tree_.end();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator end()   const {return __tree_.end();} |     const_iterator end()   const _NOEXCEPT {return __tree_.end();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           reverse_iterator rbegin()       {return       reverse_iterator(end());} |           reverse_iterator rbegin() _NOEXCEPT | ||||||
|  |             {return reverse_iterator(end());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator rbegin() const {return const_reverse_iterator(end());} |     const_reverse_iterator rbegin() const _NOEXCEPT | ||||||
|  |         {return const_reverse_iterator(end());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           reverse_iterator rend()         {return       reverse_iterator(begin());} |           reverse_iterator rend() _NOEXCEPT | ||||||
|  |             {return reverse_iterator(begin());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator rend()   const {return const_reverse_iterator(begin());} |     const_reverse_iterator rend() const _NOEXCEPT | ||||||
|  |         {return const_reverse_iterator(begin());} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator         cbegin()  const {return begin();} |     const_iterator cbegin()  const _NOEXCEPT {return begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator         cend()    const {return end();} |     const_iterator cend() const _NOEXCEPT {return end();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator crbegin() const {return rbegin();} |     const_reverse_iterator crbegin() const _NOEXCEPT {return rbegin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator crend()   const {return rend();} |     const_reverse_iterator crend() const _NOEXCEPT {return rend();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool      empty()    const {return __tree_.size() == 0;} |     bool empty() const _NOEXCEPT {return __tree_.size() == 0;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type size()     const {return __tree_.size();} |     size_type size() const _NOEXCEPT {return __tree_.size();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type max_size() const {return __tree_.max_size();} |     size_type max_size() const _NOEXCEPT {return __tree_.max_size();} | ||||||
|  |  | ||||||
|     // modifiers: |     // modifiers: | ||||||
| #if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | #if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | ||||||
|     template <class... _Args> |     template <class... _Args> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         pair<iterator, bool> emplace(_Args&&... __args) |         pair<iterator, bool> emplace(_Args&&... __args) | ||||||
|             {return __tree_.__emplace_unique(_STD::forward<_Args>(__args)...);} |             {return __tree_.__emplace_unique(_VSTD::forward<_Args>(__args)...);} | ||||||
|     template <class... _Args> |     template <class... _Args> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator emplace_hint(const_iterator __p, _Args&&... __args) |         iterator emplace_hint(const_iterator __p, _Args&&... __args) | ||||||
|             {return __tree_.__emplace_hint_unique(__p, _STD::forward<_Args>(__args)...);} |             {return __tree_.__emplace_hint_unique(__p, _VSTD::forward<_Args>(__args)...);} | ||||||
| #endif  // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | #endif  // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     pair<iterator,bool> insert(const value_type& __v) |     pair<iterator,bool> insert(const value_type& __v) | ||||||
| @@ -473,7 +524,7 @@ public: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     pair<iterator,bool> insert(value_type&& __v) |     pair<iterator,bool> insert(value_type&& __v) | ||||||
|         {return __tree_.__insert_unique(_STD::move(__v));} |         {return __tree_.__insert_unique(_VSTD::move(__v));} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator insert(const_iterator __p, const value_type& __v) |     iterator insert(const_iterator __p, const value_type& __v) | ||||||
| @@ -481,7 +532,7 @@ public: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator insert(const_iterator __p, value_type&& __v) |     iterator insert(const_iterator __p, value_type&& __v) | ||||||
|         {return __tree_.__insert_unique(__p, _STD::move(__v));} |         {return __tree_.__insert_unique(__p, _VSTD::move(__v));} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     template <class _InputIterator> |     template <class _InputIterator> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -504,13 +555,14 @@ public: | |||||||
|     iterator  erase(const_iterator __f, const_iterator __l) |     iterator  erase(const_iterator __f, const_iterator __l) | ||||||
|         {return __tree_.erase(__f, __l);} |         {return __tree_.erase(__f, __l);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void clear() {__tree_.clear();} |     void clear() _NOEXCEPT {__tree_.clear();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(set& __s) {__tree_.swap(__s.__tree_);} |     void swap(set& __s) _NOEXCEPT_(__is_nothrow_swappable<__base>::value) | ||||||
|  |         {__tree_.swap(__s.__tree_);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     allocator_type get_allocator() const {return __tree_.__alloc();} |     allocator_type get_allocator() const _NOEXCEPT {return __tree_.__alloc();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     key_compare    key_comp()      const {return __tree_.value_comp();} |     key_compare    key_comp()      const {return __tree_.value_comp();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -548,13 +600,13 @@ public: | |||||||
|  |  | ||||||
| template <class _Key, class _Compare, class _Allocator> | template <class _Key, class _Compare, class _Allocator> | ||||||
| set<_Key, _Compare, _Allocator>::set(set&& __s, const allocator_type& __a) | set<_Key, _Compare, _Allocator>::set(set&& __s, const allocator_type& __a) | ||||||
|     : __tree_(_STD::move(__s.__tree_), __a) |     : __tree_(_VSTD::move(__s.__tree_), __a) | ||||||
| { | { | ||||||
|     if (__a != __s.get_allocator()) |     if (__a != __s.get_allocator()) | ||||||
|     { |     { | ||||||
|         const_iterator __e = cend(); |         const_iterator __e = cend(); | ||||||
|         while (!__s.empty()) |         while (!__s.empty()) | ||||||
|             insert(__e, _STD::move(__s.__tree_.remove(__s.begin())->__value_)); |             insert(__e, _VSTD::move(__s.__tree_.remove(__s.begin())->__value_)); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -566,7 +618,7 @@ bool | |||||||
| operator==(const set<_Key, _Compare, _Allocator>& __x, | operator==(const set<_Key, _Compare, _Allocator>& __x, | ||||||
|            const set<_Key, _Compare, _Allocator>& __y) |            const set<_Key, _Compare, _Allocator>& __y) | ||||||
| { | { | ||||||
|     return __x.size() == __y.size() && _STD::equal(__x.begin(), __x.end(), __y.begin()); |     return __x.size() == __y.size() && _VSTD::equal(__x.begin(), __x.end(), __y.begin()); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Key, class _Compare, class _Allocator> | template <class _Key, class _Compare, class _Allocator> | ||||||
| @@ -575,7 +627,7 @@ bool | |||||||
| operator< (const set<_Key, _Compare, _Allocator>& __x, | operator< (const set<_Key, _Compare, _Allocator>& __x, | ||||||
|            const set<_Key, _Compare, _Allocator>& __y) |            const set<_Key, _Compare, _Allocator>& __y) | ||||||
| { | { | ||||||
|     return _STD::lexicographical_compare(__x.begin(), __x.end(), __y.begin(), __y.end()); |     return _VSTD::lexicographical_compare(__x.begin(), __x.end(), __y.begin(), __y.end()); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Key, class _Compare, class _Allocator> | template <class _Key, class _Compare, class _Allocator> | ||||||
| @@ -620,6 +672,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| void | void | ||||||
| swap(set<_Key, _Compare, _Allocator>& __x, | swap(set<_Key, _Compare, _Allocator>& __x, | ||||||
|      set<_Key, _Compare, _Allocator>& __y) |      set<_Key, _Compare, _Allocator>& __y) | ||||||
|  |     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||||
| { | { | ||||||
|     __x.swap(__y); |     __x.swap(__y); | ||||||
| } | } | ||||||
| @@ -652,12 +705,16 @@ public: | |||||||
|     typedef typename __base::difference_type       difference_type; |     typedef typename __base::difference_type       difference_type; | ||||||
|     typedef typename __base::const_iterator        iterator; |     typedef typename __base::const_iterator        iterator; | ||||||
|     typedef typename __base::const_iterator        const_iterator; |     typedef typename __base::const_iterator        const_iterator; | ||||||
|     typedef _STD::reverse_iterator<iterator>       reverse_iterator; |     typedef _VSTD::reverse_iterator<iterator>       reverse_iterator; | ||||||
|     typedef _STD::reverse_iterator<const_iterator> const_reverse_iterator; |     typedef _VSTD::reverse_iterator<const_iterator> const_reverse_iterator; | ||||||
|  |  | ||||||
|     // construct/copy/destroy: |     // construct/copy/destroy: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit multiset(const value_compare& __comp = value_compare()) |     explicit multiset(const value_compare& __comp = value_compare()) | ||||||
|  |         _NOEXCEPT_( | ||||||
|  |             is_nothrow_default_constructible<allocator_type>::value && | ||||||
|  |             is_nothrow_default_constructible<key_compare>::value && | ||||||
|  |             is_nothrow_copy_constructible<key_compare>::value) | ||||||
|         : __tree_(__comp) {} |         : __tree_(__comp) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     multiset(const value_compare& __comp, const allocator_type& __a) |     multiset(const value_compare& __comp, const allocator_type& __a) | ||||||
| @@ -688,10 +745,18 @@ public: | |||||||
|             insert(__s.begin(), __s.end()); |             insert(__s.begin(), __s.end()); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     multiset& operator=(const multiset& __s) | ||||||
|  |         { | ||||||
|  |             __tree_ = __s.__tree_; | ||||||
|  |             return *this; | ||||||
|  |         } | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     multiset(multiset&& __s) |     multiset(multiset&& __s) | ||||||
|         : __tree_(_STD::move(__s.__tree_)) {} |         _NOEXCEPT_(is_nothrow_move_constructible<__base>::value) | ||||||
|  |         : __tree_(_VSTD::move(__s.__tree_)) {} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit multiset(const allocator_type& __a) |     explicit multiset(const allocator_type& __a) | ||||||
| @@ -731,56 +796,61 @@ public: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     multiset& operator=(multiset&& __s) |     multiset& operator=(multiset&& __s) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_assignable<__base>::value) | ||||||
|         { |         { | ||||||
|             __tree_ = _STD::move(__s.__tree_); |             __tree_ = _VSTD::move(__s.__tree_); | ||||||
|             return *this; |             return *this; | ||||||
|         } |         } | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           iterator begin()       {return __tree_.begin();} |           iterator begin() _NOEXCEPT       {return __tree_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator begin() const {return __tree_.begin();} |     const_iterator begin() const _NOEXCEPT {return __tree_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           iterator end()         {return __tree_.end();} |           iterator end() _NOEXCEPT         {return __tree_.end();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator end()   const {return __tree_.end();} |     const_iterator end()   const _NOEXCEPT {return __tree_.end();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           reverse_iterator rbegin()       {return       reverse_iterator(end());} |           reverse_iterator rbegin() _NOEXCEPT | ||||||
|  |             {return reverse_iterator(end());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator rbegin() const {return const_reverse_iterator(end());} |     const_reverse_iterator rbegin() const _NOEXCEPT | ||||||
|  |         {return const_reverse_iterator(end());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|           reverse_iterator rend()         {return       reverse_iterator(begin());} |           reverse_iterator rend() _NOEXCEPT | ||||||
|  |             {return       reverse_iterator(begin());} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator rend()   const {return const_reverse_iterator(begin());} |     const_reverse_iterator rend() const _NOEXCEPT | ||||||
|  |         {return const_reverse_iterator(begin());} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator         cbegin()  const {return begin();} |     const_iterator cbegin()  const _NOEXCEPT {return begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator         cend()    const {return end();} |     const_iterator cend() const _NOEXCEPT {return end();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator crbegin() const {return rbegin();} |     const_reverse_iterator crbegin() const _NOEXCEPT {return rbegin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_reverse_iterator crend()   const {return rend();} |     const_reverse_iterator crend() const _NOEXCEPT {return rend();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool      empty()    const {return __tree_.size() == 0;} |     bool empty() const _NOEXCEPT {return __tree_.size() == 0;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type size()     const {return __tree_.size();} |     size_type size() const _NOEXCEPT {return __tree_.size();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type max_size() const {return __tree_.max_size();} |     size_type max_size() const _NOEXCEPT {return __tree_.max_size();} | ||||||
|  |  | ||||||
|     // modifiers: |     // modifiers: | ||||||
| #if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | #if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | ||||||
|     template <class... _Args> |     template <class... _Args> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator emplace(_Args&&... __args) |         iterator emplace(_Args&&... __args) | ||||||
|             {return __tree_.__emplace_multi(_STD::forward<_Args>(__args)...);} |             {return __tree_.__emplace_multi(_VSTD::forward<_Args>(__args)...);} | ||||||
|     template <class... _Args> |     template <class... _Args> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator emplace_hint(const_iterator __p, _Args&&... __args) |         iterator emplace_hint(const_iterator __p, _Args&&... __args) | ||||||
|             {return __tree_.__emplace_hint_multi(__p, _STD::forward<_Args>(__args)...);} |             {return __tree_.__emplace_hint_multi(__p, _VSTD::forward<_Args>(__args)...);} | ||||||
| #endif  // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | #endif  // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator insert(const value_type& __v) |     iterator insert(const value_type& __v) | ||||||
| @@ -788,7 +858,7 @@ public: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator insert(value_type&& __v) |     iterator insert(value_type&& __v) | ||||||
|         {return __tree_.__insert_multi(_STD::move(__v));} |         {return __tree_.__insert_multi(_VSTD::move(__v));} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator insert(const_iterator __p, const value_type& __v) |     iterator insert(const_iterator __p, const value_type& __v) | ||||||
| @@ -796,7 +866,7 @@ public: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator insert(const_iterator __p, value_type&& __v) |     iterator insert(const_iterator __p, value_type&& __v) | ||||||
|         {return __tree_.__insert_multi(_STD::move(__v));} |         {return __tree_.__insert_multi(_VSTD::move(__v));} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     template <class _InputIterator> |     template <class _InputIterator> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -818,13 +888,15 @@ public: | |||||||
|     iterator  erase(const_iterator __f, const_iterator __l) |     iterator  erase(const_iterator __f, const_iterator __l) | ||||||
|         {return __tree_.erase(__f, __l);} |         {return __tree_.erase(__f, __l);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void clear() {__tree_.clear();} |     void clear() _NOEXCEPT {__tree_.clear();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(multiset& __s) {__tree_.swap(__s.__tree_);} |     void swap(multiset& __s) | ||||||
|  |         _NOEXCEPT_(__is_nothrow_swappable<__base>::value) | ||||||
|  |         {__tree_.swap(__s.__tree_);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     allocator_type get_allocator() const {return __tree_.__alloc();} |     allocator_type get_allocator() const _NOEXCEPT {return __tree_.__alloc();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     key_compare    key_comp()      const {return __tree_.value_comp();} |     key_compare    key_comp()      const {return __tree_.value_comp();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -862,13 +934,13 @@ public: | |||||||
|  |  | ||||||
| template <class _Key, class _Compare, class _Allocator> | template <class _Key, class _Compare, class _Allocator> | ||||||
| multiset<_Key, _Compare, _Allocator>::multiset(multiset&& __s, const allocator_type& __a) | multiset<_Key, _Compare, _Allocator>::multiset(multiset&& __s, const allocator_type& __a) | ||||||
|     : __tree_(_STD::move(__s.__tree_), __a) |     : __tree_(_VSTD::move(__s.__tree_), __a) | ||||||
| { | { | ||||||
|     if (__a != __s.get_allocator()) |     if (__a != __s.get_allocator()) | ||||||
|     { |     { | ||||||
|         const_iterator __e = cend(); |         const_iterator __e = cend(); | ||||||
|         while (!__s.empty()) |         while (!__s.empty()) | ||||||
|             insert(__e, _STD::move(__s.__tree_.remove(__s.begin())->__value_)); |             insert(__e, _VSTD::move(__s.__tree_.remove(__s.begin())->__value_)); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -880,7 +952,7 @@ bool | |||||||
| operator==(const multiset<_Key, _Compare, _Allocator>& __x, | operator==(const multiset<_Key, _Compare, _Allocator>& __x, | ||||||
|            const multiset<_Key, _Compare, _Allocator>& __y) |            const multiset<_Key, _Compare, _Allocator>& __y) | ||||||
| { | { | ||||||
|     return __x.size() == __y.size() && _STD::equal(__x.begin(), __x.end(), __y.begin()); |     return __x.size() == __y.size() && _VSTD::equal(__x.begin(), __x.end(), __y.begin()); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Key, class _Compare, class _Allocator> | template <class _Key, class _Compare, class _Allocator> | ||||||
| @@ -889,7 +961,7 @@ bool | |||||||
| operator< (const multiset<_Key, _Compare, _Allocator>& __x, | operator< (const multiset<_Key, _Compare, _Allocator>& __x, | ||||||
|            const multiset<_Key, _Compare, _Allocator>& __y) |            const multiset<_Key, _Compare, _Allocator>& __y) | ||||||
| { | { | ||||||
|     return _STD::lexicographical_compare(__x.begin(), __x.end(), __y.begin(), __y.end()); |     return _VSTD::lexicographical_compare(__x.begin(), __x.end(), __y.begin(), __y.end()); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Key, class _Compare, class _Allocator> | template <class _Key, class _Compare, class _Allocator> | ||||||
| @@ -933,6 +1005,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| void | void | ||||||
| swap(multiset<_Key, _Compare, _Allocator>& __x, | swap(multiset<_Key, _Compare, _Allocator>& __x, | ||||||
|      multiset<_Key, _Compare, _Allocator>& __y) |      multiset<_Key, _Compare, _Allocator>& __y) | ||||||
|  |     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||||
| { | { | ||||||
|     __x.swap(__y); |     __x.swap(__y); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -261,7 +261,7 @@ basic_stringbuf<_CharT, _Traits, _Allocator>::basic_stringbuf(basic_stringbuf&& | |||||||
|     ptrdiff_t __nout = __rhs.pptr()  - __rhs.pbase(); |     ptrdiff_t __nout = __rhs.pptr()  - __rhs.pbase(); | ||||||
|     ptrdiff_t __eout = __rhs.epptr() - __rhs.pbase(); |     ptrdiff_t __eout = __rhs.epptr() - __rhs.pbase(); | ||||||
|     ptrdiff_t __hm   = __rhs.__hm_   - __rhs.pbase(); |     ptrdiff_t __hm   = __rhs.__hm_   - __rhs.pbase(); | ||||||
|     __str_ = _STD::move(__rhs.__str_); |     __str_ = _VSTD::move(__rhs.__str_); | ||||||
|     char_type* __p = const_cast<char_type*>(__str_.data()); |     char_type* __p = const_cast<char_type*>(__str_.data()); | ||||||
|     this->setg(__p, __p + __ninp, __p + __einp); |     this->setg(__p, __p + __ninp, __p + __einp); | ||||||
|     this->setp(__p, __p + __eout); |     this->setp(__p, __p + __eout); | ||||||
| @@ -284,7 +284,7 @@ basic_stringbuf<_CharT, _Traits, _Allocator>::operator=(basic_stringbuf&& __rhs) | |||||||
|     ptrdiff_t __eout = __rhs.epptr() - __rhs.pbase(); |     ptrdiff_t __eout = __rhs.epptr() - __rhs.pbase(); | ||||||
|     ptrdiff_t __hm   = __rhs.__hm_   - __rhs.pbase(); |     ptrdiff_t __hm   = __rhs.__hm_   - __rhs.pbase(); | ||||||
|     __mode_ = __rhs.__mode_; |     __mode_ = __rhs.__mode_; | ||||||
|     __str_ = _STD::move(__rhs.__str_); |     __str_ = _VSTD::move(__rhs.__str_); | ||||||
|     char_type* __p = const_cast<char_type*>(__str_.data()); |     char_type* __p = const_cast<char_type*>(__str_.data()); | ||||||
|     this->setg(__p, __p + __ninp, __p + __einp); |     this->setg(__p, __p + __ninp, __p + __einp); | ||||||
|     this->setp(__p, __p + __eout); |     this->setp(__p, __p + __eout); | ||||||
| @@ -314,7 +314,7 @@ basic_stringbuf<_CharT, _Traits, _Allocator>::swap(basic_stringbuf& __rhs) | |||||||
|     ptrdiff_t __lnout = this->pptr()  - this->pbase(); |     ptrdiff_t __lnout = this->pptr()  - this->pbase(); | ||||||
|     ptrdiff_t __leout = this->epptr() - this->pbase(); |     ptrdiff_t __leout = this->epptr() - this->pbase(); | ||||||
|     ptrdiff_t __lhm   = this->__hm_   - this->pbase(); |     ptrdiff_t __lhm   = this->__hm_   - this->pbase(); | ||||||
|     _STD::swap(__mode_, __rhs.__mode_); |     _VSTD::swap(__mode_, __rhs.__mode_); | ||||||
|     __str_.swap(__rhs.__str_); |     __str_.swap(__rhs.__str_); | ||||||
|     char_type* __p = const_cast<char_type*>(__str_.data()); |     char_type* __p = const_cast<char_type*>(__str_.data()); | ||||||
|     this->setg(__p, __p + __rninp, __p + __reinp); |     this->setg(__p, __p + __rninp, __p + __reinp); | ||||||
| @@ -451,7 +451,7 @@ basic_stringbuf<_CharT, _Traits, _Allocator>::overflow(int_type __c) | |||||||
|             } |             } | ||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|         } |         } | ||||||
|         __hm_ = _STD::max(this->pptr() + 1, __hm_); |         __hm_ = _VSTD::max(this->pptr() + 1, __hm_); | ||||||
|         if (__mode_ & ios_base::in) |         if (__mode_ & ios_base::in) | ||||||
|         { |         { | ||||||
|             char_type* __p = const_cast<char_type*>(__str_.data()); |             char_type* __p = const_cast<char_type*>(__str_.data()); | ||||||
| @@ -582,8 +582,8 @@ basic_istringstream<_CharT, _Traits, _Allocator>::basic_istringstream(const stri | |||||||
| template <class _CharT, class _Traits, class _Allocator> | template <class _CharT, class _Traits, class _Allocator> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| basic_istringstream<_CharT, _Traits, _Allocator>::basic_istringstream(basic_istringstream&& __rhs) | basic_istringstream<_CharT, _Traits, _Allocator>::basic_istringstream(basic_istringstream&& __rhs) | ||||||
|     : basic_istream<_CharT, _Traits>(_STD::move(__rhs)), |     : basic_istream<_CharT, _Traits>(_VSTD::move(__rhs)), | ||||||
|       __sb_(_STD::move(__rhs.__sb_)) |       __sb_(_VSTD::move(__rhs.__sb_)) | ||||||
| { | { | ||||||
|     basic_istream<_CharT, _Traits>::set_rdbuf(&__sb_); |     basic_istream<_CharT, _Traits>::set_rdbuf(&__sb_); | ||||||
| } | } | ||||||
| @@ -592,8 +592,8 @@ template <class _CharT, class _Traits, class _Allocator> | |||||||
| basic_istringstream<_CharT, _Traits, _Allocator>& | basic_istringstream<_CharT, _Traits, _Allocator>& | ||||||
| basic_istringstream<_CharT, _Traits, _Allocator>::operator=(basic_istringstream&& __rhs) | basic_istringstream<_CharT, _Traits, _Allocator>::operator=(basic_istringstream&& __rhs) | ||||||
| { | { | ||||||
|     basic_istream<char_type, traits_type>::operator=(_STD::move(__rhs)); |     basic_istream<char_type, traits_type>::operator=(_VSTD::move(__rhs)); | ||||||
|     __sb_ = _STD::move(__rhs.__sb_); |     __sb_ = _VSTD::move(__rhs.__sb_); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -701,8 +701,8 @@ basic_ostringstream<_CharT, _Traits, _Allocator>::basic_ostringstream(const stri | |||||||
| template <class _CharT, class _Traits, class _Allocator> | template <class _CharT, class _Traits, class _Allocator> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| basic_ostringstream<_CharT, _Traits, _Allocator>::basic_ostringstream(basic_ostringstream&& __rhs) | basic_ostringstream<_CharT, _Traits, _Allocator>::basic_ostringstream(basic_ostringstream&& __rhs) | ||||||
|     : basic_ostream<_CharT, _Traits>(_STD::move(__rhs)), |     : basic_ostream<_CharT, _Traits>(_VSTD::move(__rhs)), | ||||||
|       __sb_(_STD::move(__rhs.__sb_)) |       __sb_(_VSTD::move(__rhs.__sb_)) | ||||||
| { | { | ||||||
|     basic_ostream<_CharT, _Traits>::set_rdbuf(&__sb_); |     basic_ostream<_CharT, _Traits>::set_rdbuf(&__sb_); | ||||||
| } | } | ||||||
| @@ -711,8 +711,8 @@ template <class _CharT, class _Traits, class _Allocator> | |||||||
| basic_ostringstream<_CharT, _Traits, _Allocator>& | basic_ostringstream<_CharT, _Traits, _Allocator>& | ||||||
| basic_ostringstream<_CharT, _Traits, _Allocator>::operator=(basic_ostringstream&& __rhs) | basic_ostringstream<_CharT, _Traits, _Allocator>::operator=(basic_ostringstream&& __rhs) | ||||||
| { | { | ||||||
|     basic_ostream<char_type, traits_type>::operator=(_STD::move(__rhs)); |     basic_ostream<char_type, traits_type>::operator=(_VSTD::move(__rhs)); | ||||||
|     __sb_ = _STD::move(__rhs.__sb_); |     __sb_ = _VSTD::move(__rhs.__sb_); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -820,8 +820,8 @@ basic_stringstream<_CharT, _Traits, _Allocator>::basic_stringstream(const string | |||||||
| template <class _CharT, class _Traits, class _Allocator> | template <class _CharT, class _Traits, class _Allocator> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| basic_stringstream<_CharT, _Traits, _Allocator>::basic_stringstream(basic_stringstream&& __rhs) | basic_stringstream<_CharT, _Traits, _Allocator>::basic_stringstream(basic_stringstream&& __rhs) | ||||||
|     : basic_iostream<_CharT, _Traits>(_STD::move(__rhs)), |     : basic_iostream<_CharT, _Traits>(_VSTD::move(__rhs)), | ||||||
|       __sb_(_STD::move(__rhs.__sb_)) |       __sb_(_VSTD::move(__rhs.__sb_)) | ||||||
| { | { | ||||||
|     basic_istream<_CharT, _Traits>::set_rdbuf(&__sb_); |     basic_istream<_CharT, _Traits>::set_rdbuf(&__sb_); | ||||||
| } | } | ||||||
| @@ -830,8 +830,8 @@ template <class _CharT, class _Traits, class _Allocator> | |||||||
| basic_stringstream<_CharT, _Traits, _Allocator>& | basic_stringstream<_CharT, _Traits, _Allocator>& | ||||||
| basic_stringstream<_CharT, _Traits, _Allocator>::operator=(basic_stringstream&& __rhs) | basic_stringstream<_CharT, _Traits, _Allocator>::operator=(basic_stringstream&& __rhs) | ||||||
| { | { | ||||||
|     basic_iostream<char_type, traits_type>::operator=(_STD::move(__rhs)); |     basic_iostream<char_type, traits_type>::operator=(_VSTD::move(__rhs)); | ||||||
|     __sb_ = _STD::move(__rhs.__sb_); |     __sb_ = _VSTD::move(__rhs.__sb_); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -31,14 +31,21 @@ protected: | |||||||
|     container_type c; |     container_type c; | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit stack(); |     stack() = default; | ||||||
|  |     ~stack() = default; | ||||||
|  |  | ||||||
|  |     stack(const stack& q) = default; | ||||||
|  |     stack(stack&& q) = default; | ||||||
|  |  | ||||||
|  |     stack& operator=(const stack& q) = default; | ||||||
|  |     stack& operator=(stack&& q) = default; | ||||||
|  |  | ||||||
|     explicit stack(const container_type& c); |     explicit stack(const container_type& c); | ||||||
|     explicit stack(container_type&& c); |     explicit stack(container_type&& c); | ||||||
|     stack(stack&& s); |  | ||||||
|     stack& operator=(stack&& s); |  | ||||||
|     template <class Alloc> explicit stack(const Alloc& a); |     template <class Alloc> explicit stack(const Alloc& a); | ||||||
|     template <class Alloc> stack(const container_type& c, const Alloc& a); |     template <class Alloc> stack(const container_type& c, const Alloc& a); | ||||||
|     template <class Alloc> stack(container_type&& c, const Alloc& a); |     template <class Alloc> stack(container_type&& c, const Alloc& a); | ||||||
|  |     template <class Alloc> stack(const stack& c, const Alloc& a); | ||||||
|     template <class Alloc> stack(stack&& c, const Alloc& a); |     template <class Alloc> stack(stack&& c, const Alloc& a); | ||||||
|  |  | ||||||
|     bool empty() const; |     bool empty() const; | ||||||
| @@ -51,7 +58,7 @@ public: | |||||||
|     template <class... Args> void emplace(Args&&... args); |     template <class... Args> void emplace(Args&&... args); | ||||||
|     void pop(); |     void pop(); | ||||||
|  |  | ||||||
|     void swap(stack& c); |     void swap(stack& c) noexcept(noexcept(swap(c, q.c))); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class T, class Container> | template <class T, class Container> | ||||||
| @@ -68,7 +75,8 @@ template <class T, class Container> | |||||||
|   bool operator<=(const stack<T, Container>& x, const stack<T, Container>& y); |   bool operator<=(const stack<T, Container>& x, const stack<T, Container>& y); | ||||||
|  |  | ||||||
| template <class T, class Container> | template <class T, class Container> | ||||||
|   void swap(stack<T, Container>& x, stack<T, Container>& y); |   void swap(stack<T, Container>& x, stack<T, Container>& y) | ||||||
|  |   noexcept(noexcept(x.swap(y))); | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
|  |  | ||||||
| @@ -106,16 +114,35 @@ protected: | |||||||
|  |  | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     stack() : c() {} |     stack() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<container_type>::value) | ||||||
|  |         : c() {} | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     stack(const stack& __q) : c(__q.c) {} | ||||||
|  |  | ||||||
|  | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     stack(stack&& __q) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_constructible<container_type>::value) | ||||||
|  |         : c(_VSTD::move(__q.c)) {} | ||||||
|  | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     stack& operator=(const stack& __q) {c = __q.c; return *this;} | ||||||
|  |  | ||||||
|  | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     stack& operator=(stack&& __q) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_assignable<container_type>::value) | ||||||
|  |         {c = _VSTD::move(__q.c); return *this;} | ||||||
|  | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit stack(const container_type& __c) : c(__c) {} |     explicit stack(const container_type& __c) : c(__c) {} | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit stack(container_type&& __c) : c(_STD::move(__c)) {} |     explicit stack(container_type&& __c) : c(_VSTD::move(__c)) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |  | ||||||
|     stack(stack&& __s) : c(_STD::move(__s.c)) {} |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |  | ||||||
|     stack& operator=(stack&& __s) {c = _STD::move(__s.c); return *this;} |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     template <class _Alloc> |     template <class _Alloc> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -141,13 +168,13 @@ public: | |||||||
|         stack(container_type&& __c, const _Alloc& __a, |         stack(container_type&& __c, const _Alloc& __a, | ||||||
|               typename enable_if<uses_allocator<container_type, |               typename enable_if<uses_allocator<container_type, | ||||||
|                                                 _Alloc>::value>::type* = 0) |                                                 _Alloc>::value>::type* = 0) | ||||||
|             : c(_STD::move(__c), __a) {} |             : c(_VSTD::move(__c), __a) {} | ||||||
|     template <class _Alloc> |     template <class _Alloc> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         stack(stack&& __s, const _Alloc& __a, |         stack(stack&& __s, const _Alloc& __a, | ||||||
|               typename enable_if<uses_allocator<container_type, |               typename enable_if<uses_allocator<container_type, | ||||||
|                                                 _Alloc>::value>::type* = 0) |                                                 _Alloc>::value>::type* = 0) | ||||||
|             : c(_STD::move(__s.c), __a) {} |             : c(_VSTD::move(__s.c), __a) {} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -163,12 +190,12 @@ public: | |||||||
|     void push(const value_type& __v) {c.push_back(__v);} |     void push(const value_type& __v) {c.push_back(__v);} | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void push(value_type&& __v) {c.push_back(_STD::move(__v));} |     void push(value_type&& __v) {c.push_back(_VSTD::move(__v));} | ||||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
|     template <class... _Args> |     template <class... _Args> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         void emplace(_Args&&... __args) |         void emplace(_Args&&... __args) | ||||||
|         {c.emplace_back(_STD::forward<_Args>(__args)...);} |         {c.emplace_back(_VSTD::forward<_Args>(__args)...);} | ||||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -176,8 +203,9 @@ public: | |||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(stack& __s) |     void swap(stack& __s) | ||||||
|  |         _NOEXCEPT_(__is_nothrow_swappable<container_type>::value) | ||||||
|     { |     { | ||||||
|         using _STD::swap; |         using _VSTD::swap; | ||||||
|         swap(c, __s.c); |         swap(c, __s.c); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -244,6 +272,7 @@ template <class _Tp, class _Container> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| void | void | ||||||
| swap(stack<_Tp, _Container>& __x, stack<_Tp, _Container>& __y) | swap(stack<_Tp, _Container>& __x, stack<_Tp, _Container>& __y) | ||||||
|  |     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||||
| { | { | ||||||
|     __x.swap(__y); |     __x.swap(__y); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -33,9 +33,9 @@ class xxx_error : public exception // at least indirectly | |||||||
| { | { | ||||||
| public: | public: | ||||||
|     explicit xxx_error(const string& what_arg); |     explicit xxx_error(const string& what_arg); | ||||||
|     explicit xxx_error(const char*   what_arg);  // extension |     explicit xxx_error(const char*   what_arg); | ||||||
|  |  | ||||||
|     virtual const char* what() const // returns what_arg |     virtual const char* what() const noexcept // returns what_arg | ||||||
| }; | }; | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
| @@ -60,12 +60,12 @@ public: | |||||||
|     explicit logic_error(const string&); |     explicit logic_error(const string&); | ||||||
|     explicit logic_error(const char*); |     explicit logic_error(const char*); | ||||||
|  |  | ||||||
|     logic_error(const logic_error&) throw(); |     logic_error(const logic_error&) _NOEXCEPT; | ||||||
|     logic_error& operator=(const logic_error&) throw(); |     logic_error& operator=(const logic_error&) _NOEXCEPT; | ||||||
|  |  | ||||||
|     virtual ~logic_error() throw(); |     virtual ~logic_error() _NOEXCEPT; | ||||||
|  |  | ||||||
|     virtual const char* what() const throw(); |     virtual const char* what() const _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class _LIBCPP_EXCEPTION_ABI runtime_error | class _LIBCPP_EXCEPTION_ABI runtime_error | ||||||
| @@ -77,12 +77,12 @@ public: | |||||||
|     explicit runtime_error(const string&); |     explicit runtime_error(const string&); | ||||||
|     explicit runtime_error(const char*); |     explicit runtime_error(const char*); | ||||||
|  |  | ||||||
|     runtime_error(const runtime_error&) throw(); |     runtime_error(const runtime_error&) _NOEXCEPT; | ||||||
|     runtime_error& operator=(const runtime_error&) throw(); |     runtime_error& operator=(const runtime_error&) _NOEXCEPT; | ||||||
|  |  | ||||||
|     virtual ~runtime_error() throw(); |     virtual ~runtime_error() _NOEXCEPT; | ||||||
|  |  | ||||||
|     virtual const char* what() const throw(); |     virtual const char* what() const _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class _LIBCPP_EXCEPTION_ABI domain_error | class _LIBCPP_EXCEPTION_ABI domain_error | ||||||
| @@ -92,7 +92,7 @@ public: | |||||||
|     _LIBCPP_INLINE_VISIBILITY explicit domain_error(const string& __s) : logic_error(__s) {} |     _LIBCPP_INLINE_VISIBILITY explicit domain_error(const string& __s) : logic_error(__s) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY explicit domain_error(const char* __s)   : logic_error(__s) {} |     _LIBCPP_INLINE_VISIBILITY explicit domain_error(const char* __s)   : logic_error(__s) {} | ||||||
|  |  | ||||||
|     virtual ~domain_error() throw(); |     virtual ~domain_error() _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class _LIBCPP_EXCEPTION_ABI invalid_argument | class _LIBCPP_EXCEPTION_ABI invalid_argument | ||||||
| @@ -102,7 +102,7 @@ public: | |||||||
|     _LIBCPP_INLINE_VISIBILITY explicit invalid_argument(const string& __s) : logic_error(__s) {} |     _LIBCPP_INLINE_VISIBILITY explicit invalid_argument(const string& __s) : logic_error(__s) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY explicit invalid_argument(const char* __s)   : logic_error(__s) {} |     _LIBCPP_INLINE_VISIBILITY explicit invalid_argument(const char* __s)   : logic_error(__s) {} | ||||||
|  |  | ||||||
|     virtual ~invalid_argument() throw(); |     virtual ~invalid_argument() _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class _LIBCPP_EXCEPTION_ABI length_error | class _LIBCPP_EXCEPTION_ABI length_error | ||||||
| @@ -112,7 +112,7 @@ public: | |||||||
|     _LIBCPP_INLINE_VISIBILITY explicit length_error(const string& __s) : logic_error(__s) {} |     _LIBCPP_INLINE_VISIBILITY explicit length_error(const string& __s) : logic_error(__s) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY explicit length_error(const char* __s)   : logic_error(__s) {} |     _LIBCPP_INLINE_VISIBILITY explicit length_error(const char* __s)   : logic_error(__s) {} | ||||||
|  |  | ||||||
|     virtual ~length_error() throw(); |     virtual ~length_error() _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class _LIBCPP_EXCEPTION_ABI out_of_range | class _LIBCPP_EXCEPTION_ABI out_of_range | ||||||
| @@ -122,7 +122,7 @@ public: | |||||||
|     _LIBCPP_INLINE_VISIBILITY explicit out_of_range(const string& __s) : logic_error(__s) {} |     _LIBCPP_INLINE_VISIBILITY explicit out_of_range(const string& __s) : logic_error(__s) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY explicit out_of_range(const char* __s)   : logic_error(__s) {} |     _LIBCPP_INLINE_VISIBILITY explicit out_of_range(const char* __s)   : logic_error(__s) {} | ||||||
|  |  | ||||||
|     virtual ~out_of_range() throw(); |     virtual ~out_of_range() _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class _LIBCPP_EXCEPTION_ABI range_error | class _LIBCPP_EXCEPTION_ABI range_error | ||||||
| @@ -132,7 +132,7 @@ public: | |||||||
|     _LIBCPP_INLINE_VISIBILITY explicit range_error(const string& __s) : runtime_error(__s) {} |     _LIBCPP_INLINE_VISIBILITY explicit range_error(const string& __s) : runtime_error(__s) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY explicit range_error(const char* __s)   : runtime_error(__s) {} |     _LIBCPP_INLINE_VISIBILITY explicit range_error(const char* __s)   : runtime_error(__s) {} | ||||||
|  |  | ||||||
|     virtual ~range_error() throw(); |     virtual ~range_error() _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class _LIBCPP_EXCEPTION_ABI overflow_error | class _LIBCPP_EXCEPTION_ABI overflow_error | ||||||
| @@ -142,7 +142,7 @@ public: | |||||||
|     _LIBCPP_INLINE_VISIBILITY explicit overflow_error(const string& __s) : runtime_error(__s) {} |     _LIBCPP_INLINE_VISIBILITY explicit overflow_error(const string& __s) : runtime_error(__s) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY explicit overflow_error(const char* __s)   : runtime_error(__s) {} |     _LIBCPP_INLINE_VISIBILITY explicit overflow_error(const char* __s)   : runtime_error(__s) {} | ||||||
|  |  | ||||||
|     virtual ~overflow_error() throw(); |     virtual ~overflow_error() _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class _LIBCPP_EXCEPTION_ABI underflow_error | class _LIBCPP_EXCEPTION_ABI underflow_error | ||||||
| @@ -152,7 +152,7 @@ public: | |||||||
|     _LIBCPP_INLINE_VISIBILITY explicit underflow_error(const string& __s) : runtime_error(__s) {} |     _LIBCPP_INLINE_VISIBILITY explicit underflow_error(const string& __s) : runtime_error(__s) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY explicit underflow_error(const char* __s)   : runtime_error(__s) {} |     _LIBCPP_INLINE_VISIBILITY explicit underflow_error(const char* __s)   : runtime_error(__s) {} | ||||||
|  |  | ||||||
|     virtual ~underflow_error() throw(); |     virtual ~underflow_error() _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
|   | |||||||
| @@ -399,13 +399,13 @@ template <class _CharT, class _Traits> | |||||||
| void | void | ||||||
| basic_streambuf<_CharT, _Traits>::swap(basic_streambuf& __sb) | basic_streambuf<_CharT, _Traits>::swap(basic_streambuf& __sb) | ||||||
| { | { | ||||||
|     _STD::swap(__loc_, __sb.__loc_); |     _VSTD::swap(__loc_, __sb.__loc_); | ||||||
|     _STD::swap(__binp_, __sb.__binp_); |     _VSTD::swap(__binp_, __sb.__binp_); | ||||||
|     _STD::swap(__ninp_, __sb.__ninp_); |     _VSTD::swap(__ninp_, __sb.__ninp_); | ||||||
|     _STD::swap(__einp_, __sb.__einp_); |     _VSTD::swap(__einp_, __sb.__einp_); | ||||||
|     _STD::swap(__bout_, __sb.__bout_); |     _VSTD::swap(__bout_, __sb.__bout_); | ||||||
|     _STD::swap(__nout_, __sb.__nout_); |     _VSTD::swap(__nout_, __sb.__nout_); | ||||||
|     _STD::swap(__eout_, __sb.__eout_); |     _VSTD::swap(__eout_, __sb.__eout_); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _CharT, class _Traits> | template <class _CharT, class _Traits> | ||||||
|   | |||||||
							
								
								
									
										1060
									
								
								include/string
									
									
									
									
									
								
							
							
						
						
									
										1060
									
								
								include/string
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -150,7 +150,9 @@ public: | |||||||
|     strstreambuf(const unsigned char* __gnext, streamsize __n); |     strstreambuf(const unsigned char* __gnext, streamsize __n); | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     strstreambuf(strstreambuf&& __rhs); |     strstreambuf(strstreambuf&& __rhs); | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     strstreambuf& operator=(strstreambuf&& __rhs); |     strstreambuf& operator=(strstreambuf&& __rhs); | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
| @@ -187,6 +189,43 @@ private: | |||||||
|     void __init(char* __gnext, streamsize __n, char* __pbeg); |     void __init(char* __gnext, streamsize __n, char* __pbeg); | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | strstreambuf::strstreambuf(strstreambuf&& __rhs) | ||||||
|  |     : streambuf(__rhs), | ||||||
|  |       __strmode_(__rhs.__strmode_), | ||||||
|  |       __alsize_(__rhs.__alsize_), | ||||||
|  |       __palloc_(__rhs.__palloc_), | ||||||
|  |       __pfree_(__rhs.__pfree_) | ||||||
|  | { | ||||||
|  |     __rhs.setg(nullptr, nullptr, nullptr); | ||||||
|  |     __rhs.setp(nullptr, nullptr); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | strstreambuf& | ||||||
|  | strstreambuf::operator=(strstreambuf&& __rhs) | ||||||
|  | { | ||||||
|  |     if (eback() && (__strmode_ & __allocated) != 0 && (__strmode_ & __frozen) == 0) | ||||||
|  |     { | ||||||
|  |         if (__pfree_) | ||||||
|  |             __pfree_(eback()); | ||||||
|  |         else | ||||||
|  |             delete [] eback(); | ||||||
|  |     } | ||||||
|  |     streambuf::operator=(__rhs); | ||||||
|  |     __strmode_ = __rhs.__strmode_; | ||||||
|  |     __alsize_ = __rhs.__alsize_; | ||||||
|  |     __palloc_ = __rhs.__palloc_; | ||||||
|  |     __pfree_ = __rhs.__pfree_; | ||||||
|  |     __rhs.setg(nullptr, nullptr, nullptr); | ||||||
|  |     __rhs.setp(nullptr, nullptr); | ||||||
|  |     return *this; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
| class _LIBCPP_VISIBLE istrstream | class _LIBCPP_VISIBLE istrstream | ||||||
|     : public istream |     : public istream | ||||||
| { | { | ||||||
| @@ -207,8 +246,8 @@ public: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     istrstream(istrstream&& __rhs) |     istrstream(istrstream&& __rhs) | ||||||
|         : istream(_STD::move(__rhs)), |         : istream(_VSTD::move(__rhs)), | ||||||
|           __sb_(_STD::move(__rhs.__sb_)) |           __sb_(_VSTD::move(__rhs.__sb_)) | ||||||
|     { |     { | ||||||
|         istream::set_rdbuf(&__sb_); |         istream::set_rdbuf(&__sb_); | ||||||
|     } |     } | ||||||
| @@ -216,8 +255,8 @@ public: | |||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     istrstream& operator=(istrstream&& __rhs) |     istrstream& operator=(istrstream&& __rhs) | ||||||
|     { |     { | ||||||
|         istream::operator=(_STD::move(__rhs)); |         istream::operator=(_VSTD::move(__rhs)); | ||||||
|         __sb_ = _STD::move(__rhs.__sb_); |         __sb_ = _VSTD::move(__rhs.__sb_); | ||||||
|         return *this; |         return *this; | ||||||
|     } |     } | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -256,8 +295,8 @@ public: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     ostrstream(ostrstream&& __rhs) |     ostrstream(ostrstream&& __rhs) | ||||||
|         : ostream(_STD::move(__rhs)), |         : ostream(_VSTD::move(__rhs)), | ||||||
|           __sb_(_STD::move(__rhs.__sb_)) |           __sb_(_VSTD::move(__rhs.__sb_)) | ||||||
|     { |     { | ||||||
|         ostream::set_rdbuf(&__sb_); |         ostream::set_rdbuf(&__sb_); | ||||||
|     } |     } | ||||||
| @@ -265,8 +304,8 @@ public: | |||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     ostrstream& operator=(ostrstream&& __rhs) |     ostrstream& operator=(ostrstream&& __rhs) | ||||||
|     { |     { | ||||||
|         ostream::operator=(_STD::move(__rhs)); |         ostream::operator=(_VSTD::move(__rhs)); | ||||||
|         __sb_ = _STD::move(__rhs.__sb_); |         __sb_ = _VSTD::move(__rhs.__sb_); | ||||||
|         return *this; |         return *this; | ||||||
|     } |     } | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -316,8 +355,8 @@ public: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     strstream(strstream&& __rhs) |     strstream(strstream&& __rhs) | ||||||
|         : iostream(_STD::move(__rhs)), |         : iostream(_VSTD::move(__rhs)), | ||||||
|           __sb_(_STD::move(__rhs.__sb_)) |           __sb_(_VSTD::move(__rhs.__sb_)) | ||||||
|     { |     { | ||||||
|         iostream::set_rdbuf(&__sb_); |         iostream::set_rdbuf(&__sb_); | ||||||
|     } |     } | ||||||
| @@ -325,8 +364,8 @@ public: | |||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     strstream& operator=(strstream&& __rhs) |     strstream& operator=(strstream&& __rhs) | ||||||
|     { |     { | ||||||
|         iostream::operator=(_STD::move(__rhs)); |         iostream::operator=(_VSTD::move(__rhs)); | ||||||
|         __sb_ = _STD::move(__rhs.__sb_); |         __sb_ = _VSTD::move(__rhs.__sb_); | ||||||
|         return *this; |         return *this; | ||||||
|     } |     } | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|   | |||||||
| @@ -20,24 +20,24 @@ namespace std | |||||||
| class error_category | class error_category | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     virtual ~error_category(); |     virtual ~error_category() noexcept; | ||||||
|  |  | ||||||
|     error_category(const error_category&) = delete; |     error_category(const error_category&) = delete; | ||||||
|     error_category& operator=(const error_category&) = delete; |     error_category& operator=(const error_category&) = delete; | ||||||
|  |  | ||||||
|     virtual const char* name() const = 0; |     virtual const char* name() const noexcept = 0; | ||||||
|     virtual error_condition default_error_condition(int ev) const; |     virtual error_condition default_error_condition(int ev) const noexcept; | ||||||
|     virtual bool equivalent(int code, const error_condition& condition) const; |     virtual bool equivalent(int code, const error_condition& condition) const noexcept; | ||||||
|     virtual bool equivalent(const error_code& code, int condition) const; |     virtual bool equivalent(const error_code& code, int condition) const noexcept; | ||||||
|     virtual string message(int ev) const = 0; |     virtual string message(int ev) const = 0; | ||||||
|  |  | ||||||
|     bool operator==(const error_category& rhs) const; |     bool operator==(const error_category& rhs) const noexcept; | ||||||
|     bool operator!=(const error_category& rhs) const; |     bool operator!=(const error_category& rhs) const noexcept; | ||||||
|     bool operator<(const error_category& rhs) const; |     bool operator<(const error_category& rhs) const noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const error_category& generic_category(); | const error_category& generic_category() noexcept; | ||||||
| const error_category& system_category(); | const error_category& system_category() noexcept; | ||||||
|  |  | ||||||
| template <class T> struct is_error_code_enum | template <class T> struct is_error_code_enum | ||||||
|     : public false_type {}; |     : public false_type {}; | ||||||
| @@ -49,27 +49,27 @@ class error_code | |||||||
| { | { | ||||||
| public: | public: | ||||||
|     // constructors: |     // constructors: | ||||||
|     error_code(); |     error_code() noexcept; | ||||||
|     error_code(int val, const error_category& cat); |     error_code(int val, const error_category& cat) noexcept; | ||||||
|     template <class ErrorCodeEnum> |     template <class ErrorCodeEnum> | ||||||
|         error_code(ErrorCodeEnum e); |         error_code(ErrorCodeEnum e) noexcept; | ||||||
|  |  | ||||||
|     // modifiers: |     // modifiers: | ||||||
|     void assign(int val, const error_category& cat); |     void assign(int val, const error_category& cat) noexcept; | ||||||
|     template <class ErrorCodeEnum> |     template <class ErrorCodeEnum> | ||||||
|         error_code& operator=(ErrorCodeEnum e); |         error_code& operator=(ErrorCodeEnum e) noexcept; | ||||||
|     void clear(); |     void clear() noexcept; | ||||||
|  |  | ||||||
|     // observers: |     // observers: | ||||||
|     int value() const; |     int value() const noexcept; | ||||||
|     const error_category& category() const; |     const error_category& category() const noexcept; | ||||||
|     error_condition default_error_condition() const; |     error_condition default_error_condition() const noexcept; | ||||||
|     string message() const; |     string message() const; | ||||||
|     explicit operator bool() const; |     explicit operator bool() const noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // non-member functions: | // non-member functions: | ||||||
| bool operator<(const error_code& lhs, const error_code& rhs); | bool operator<(const error_code& lhs, const error_code& rhs) noexcept; | ||||||
| template <class charT, class traits> | template <class charT, class traits> | ||||||
|     basic_ostream<charT,traits>& |     basic_ostream<charT,traits>& | ||||||
|     operator<<(basic_ostream<charT,traits>& os, const error_code& ec); |     operator<<(basic_ostream<charT,traits>& os, const error_code& ec); | ||||||
| @@ -78,25 +78,25 @@ class error_condition | |||||||
| { | { | ||||||
| public: | public: | ||||||
|     // constructors: |     // constructors: | ||||||
|     error_condition(); |     error_condition() noexcept; | ||||||
|     error_condition(int val, const error_category& cat); |     error_condition(int val, const error_category& cat) noexcept; | ||||||
|     template <class ErrorConditionEnum> |     template <class ErrorConditionEnum> | ||||||
|         error_condition(ErrorConditionEnum e); |         error_condition(ErrorConditionEnum e) noexcept; | ||||||
|  |  | ||||||
|     // modifiers: |     // modifiers: | ||||||
|     void assign(int val, const error_category& cat); |     void assign(int val, const error_category& cat) noexcept; | ||||||
|     template <class ErrorConditionEnum> |     template <class ErrorConditionEnum> | ||||||
|         error_condition& operator=(ErrorConditionEnum e); |         error_condition& operator=(ErrorConditionEnum e) noexcept; | ||||||
|     void clear(); |     void clear() noexcept; | ||||||
|  |  | ||||||
|     // observers: |     // observers: | ||||||
|     int value() const; |     int value() const noexcept; | ||||||
|     const error_category& category() const; |     const error_category& category() const noexcept; | ||||||
|     string message() const; |     string message() const noexcept; | ||||||
|     explicit operator bool() const; |     explicit operator bool() const noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| bool operator<(const error_condition& lhs, const error_condition& rhs); | bool operator<(const error_condition& lhs, const error_condition& rhs) noexcept; | ||||||
|  |  | ||||||
| class system_error | class system_error | ||||||
|     : public runtime_error |     : public runtime_error | ||||||
| @@ -109,28 +109,28 @@ public: | |||||||
|     system_error(int ev, const error_category& ecat, const char* what_arg); |     system_error(int ev, const error_category& ecat, const char* what_arg); | ||||||
|     system_error(int ev, const error_category& ecat); |     system_error(int ev, const error_category& ecat); | ||||||
|  |  | ||||||
|     const error_code& code() const throw(); |     const error_code& code() const noexcept; | ||||||
|     const char* what() const throw(); |     const char* what() const noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| enum class errc | enum class errc | ||||||
| { | { | ||||||
| //    address_family_not_supported,       // EAFNOSUPPORT |     address_family_not_supported,       // EAFNOSUPPORT | ||||||
| //    address_in_use,                     // EADDRINUSE |     address_in_use,                     // EADDRINUSE | ||||||
| //    address_not_available,              // EADDRNOTAVAIL |     address_not_available,              // EADDRNOTAVAIL | ||||||
| //    already_connected,                  // EISCONN |     already_connected,                  // EISCONN | ||||||
|     argument_list_too_long,             // E2BIG |     argument_list_too_long,             // E2BIG | ||||||
|     argument_out_of_domain,             // EDOM |     argument_out_of_domain,             // EDOM | ||||||
|     bad_address,                        // EFAULT |     bad_address,                        // EFAULT | ||||||
|     bad_file_descriptor,                // EBADF |     bad_file_descriptor,                // EBADF | ||||||
| //    bad_message,                        // EBADMSG |     bad_message,                        // EBADMSG | ||||||
|     broken_pipe,                        // EPIPE |     broken_pipe,                        // EPIPE | ||||||
| //    connection_aborted,                 // ECONNABORTED |     connection_aborted,                 // ECONNABORTED | ||||||
| //    connection_already_in_progress,     // EALREADY |     connection_already_in_progress,     // EALREADY | ||||||
| //    connection_refused,                 // ECONNREFUSED |     connection_refused,                 // ECONNREFUSED | ||||||
| //    connection_reset,                   // ECONNRESET |     connection_reset,                   // ECONNRESET | ||||||
|     cross_device_link,                  // EXDEV |     cross_device_link,                  // EXDEV | ||||||
| //    destination_address_required,       // EDESTADDRREQ |     destination_address_required,       // EDESTADDRREQ | ||||||
|     device_or_resource_busy,            // EBUSY |     device_or_resource_busy,            // EBUSY | ||||||
|     directory_not_empty,                // ENOTEMPTY |     directory_not_empty,                // ENOTEMPTY | ||||||
|     executable_format_error,            // ENOEXEC |     executable_format_error,            // ENOEXEC | ||||||
| @@ -138,8 +138,8 @@ enum class errc | |||||||
|     file_too_large,                     // EFBIG |     file_too_large,                     // EFBIG | ||||||
|     filename_too_long,                  // ENAMETOOLONG |     filename_too_long,                  // ENAMETOOLONG | ||||||
|     function_not_supported,             // ENOSYS |     function_not_supported,             // ENOSYS | ||||||
| //    host_unreachable,                   // EHOSTUNREACH |     host_unreachable,                   // EHOSTUNREACH | ||||||
| //    identifier_removed,                 // EIDRM |     identifier_removed,                 // EIDRM | ||||||
|     illegal_byte_sequence,              // EILSEQ |     illegal_byte_sequence,              // EILSEQ | ||||||
|     inappropriate_io_control_operation, // ENOTTY |     inappropriate_io_control_operation, // ENOTTY | ||||||
|     interrupted,                        // EINTR |     interrupted,                        // EINTR | ||||||
| @@ -147,16 +147,16 @@ enum class errc | |||||||
|     invalid_seek,                       // ESPIPE |     invalid_seek,                       // ESPIPE | ||||||
|     io_error,                           // EIO |     io_error,                           // EIO | ||||||
|     is_a_directory,                     // EISDIR |     is_a_directory,                     // EISDIR | ||||||
| //    message_size,                       // EMSGSIZE |     message_size,                       // EMSGSIZE | ||||||
| //    network_down,                       // ENETDOWN |     network_down,                       // ENETDOWN | ||||||
| //    network_reset,                      // ENETRESET |     network_reset,                      // ENETRESET | ||||||
| //    network_unreachable,                // ENETUNREACH |     network_unreachable,                // ENETUNREACH | ||||||
| //    no_buffer_space,                    // ENOBUFS |     no_buffer_space,                    // ENOBUFS | ||||||
|     no_child_process,                   // ECHILD |     no_child_process,                   // ECHILD | ||||||
| //    no_link,                            // ENOLINK |     no_link,                            // ENOLINK | ||||||
|     no_lock_available,                  // ENOLCK |     no_lock_available,                  // ENOLCK | ||||||
|     no_message_available,               // ENODATA |     no_message_available,               // ENODATA | ||||||
| //    no_message,                         // ENOMSG |     no_message,                         // ENOMSG | ||||||
|     no_protocol_option,                 // ENOPROTOOPT |     no_protocol_option,                 // ENOPROTOOPT | ||||||
|     no_space_on_device,                 // ENOSPC |     no_space_on_device,                 // ENOSPC | ||||||
|     no_stream_resources,                // ENOSR |     no_stream_resources,                // ENOSR | ||||||
| @@ -198,18 +198,18 @@ enum class errc | |||||||
| template <> struct is_error_condition_enum<errc> | template <> struct is_error_condition_enum<errc> | ||||||
|     : true_type { } |     : true_type { } | ||||||
|  |  | ||||||
| error_code make_error_code(errc e); | error_code make_error_code(errc e) noexcept; | ||||||
| error_condition make_error_condition(errc e); | error_condition make_error_condition(errc e) noexcept; | ||||||
|  |  | ||||||
| // Comparison operators: | // Comparison operators: | ||||||
| bool operator==(const error_code& lhs, const error_code& rhs); | bool operator==(const error_code& lhs, const error_code& rhs) noexcept; | ||||||
| bool operator==(const error_code& lhs, const error_condition& rhs); | bool operator==(const error_code& lhs, const error_condition& rhs) noexcept; | ||||||
| bool operator==(const error_condition& lhs, const error_code& rhs); | bool operator==(const error_condition& lhs, const error_code& rhs) noexcept; | ||||||
| bool operator==(const error_condition& lhs, const error_condition& rhs); | bool operator==(const error_condition& lhs, const error_condition& rhs) noexcept; | ||||||
| bool operator!=(const error_code& lhs, const error_code& rhs); | bool operator!=(const error_code& lhs, const error_code& rhs) noexcept; | ||||||
| bool operator!=(const error_code& lhs, const error_condition& rhs); | bool operator!=(const error_code& lhs, const error_condition& rhs) noexcept; | ||||||
| bool operator!=(const error_condition& lhs, const error_code& rhs); | bool operator!=(const error_condition& lhs, const error_code& rhs) noexcept; | ||||||
| bool operator!=(const error_condition& lhs, const error_condition& rhs); | bool operator!=(const error_condition& lhs, const error_condition& rhs) noexcept; | ||||||
|  |  | ||||||
| template <> struct hash<std::error_code>; | template <> struct hash<std::error_code>; | ||||||
|  |  | ||||||
| @@ -246,42 +246,22 @@ struct _LIBCPP_VISIBLE is_error_condition_enum | |||||||
| struct errc | struct errc | ||||||
| { | { | ||||||
| enum _ { | enum _ { | ||||||
| #ifdef EAFNOSUPPORT |  | ||||||
|     address_family_not_supported        = EAFNOSUPPORT, |     address_family_not_supported        = EAFNOSUPPORT, | ||||||
| #endif |  | ||||||
| #ifdef EADDRINUSE |  | ||||||
|     address_in_use                      = EADDRINUSE, |     address_in_use                      = EADDRINUSE, | ||||||
| #endif |  | ||||||
| #ifdef EADDRNOTAVAIL |  | ||||||
|     address_not_available               = EADDRNOTAVAIL, |     address_not_available               = EADDRNOTAVAIL, | ||||||
| #endif |  | ||||||
| #ifdef EISCONN |  | ||||||
|     already_connected                   = EISCONN, |     already_connected                   = EISCONN, | ||||||
| #endif |  | ||||||
|     argument_list_too_long              = E2BIG, |     argument_list_too_long              = E2BIG, | ||||||
|     argument_out_of_domain              = EDOM, |     argument_out_of_domain              = EDOM, | ||||||
|     bad_address                         = EFAULT, |     bad_address                         = EFAULT, | ||||||
|     bad_file_descriptor                 = EBADF, |     bad_file_descriptor                 = EBADF, | ||||||
| #ifdef EBADMSG |  | ||||||
|     bad_message                         = EBADMSG, |     bad_message                         = EBADMSG, | ||||||
| #endif |  | ||||||
|     broken_pipe                         = EPIPE, |     broken_pipe                         = EPIPE, | ||||||
| #ifdef ECONNABORTED |  | ||||||
|     connection_aborted                  = ECONNABORTED, |     connection_aborted                  = ECONNABORTED, | ||||||
| #endif |  | ||||||
| #ifdef EALREADY |  | ||||||
|     connection_already_in_progress      = EALREADY, |     connection_already_in_progress      = EALREADY, | ||||||
| #endif |  | ||||||
| #ifdef ECONNREFUSED |  | ||||||
|     connection_refused                  = ECONNREFUSED, |     connection_refused                  = ECONNREFUSED, | ||||||
| #endif |  | ||||||
| #ifdef ECONNRESET |  | ||||||
|     connection_reset                    = ECONNRESET, |     connection_reset                    = ECONNRESET, | ||||||
| #endif |  | ||||||
|     cross_device_link                   = EXDEV, |     cross_device_link                   = EXDEV, | ||||||
| #ifdef EDESTADDRREQ |  | ||||||
|     destination_address_required        = EDESTADDRREQ, |     destination_address_required        = EDESTADDRREQ, | ||||||
| #endif |  | ||||||
|     device_or_resource_busy             = EBUSY, |     device_or_resource_busy             = EBUSY, | ||||||
|     directory_not_empty                 = ENOTEMPTY, |     directory_not_empty                 = ENOTEMPTY, | ||||||
|     executable_format_error             = ENOEXEC, |     executable_format_error             = ENOEXEC, | ||||||
| @@ -289,12 +269,8 @@ enum _ { | |||||||
|     file_too_large                      = EFBIG, |     file_too_large                      = EFBIG, | ||||||
|     filename_too_long                   = ENAMETOOLONG, |     filename_too_long                   = ENAMETOOLONG, | ||||||
|     function_not_supported              = ENOSYS, |     function_not_supported              = ENOSYS, | ||||||
| #ifdef EHOSTUNREACH |  | ||||||
|     host_unreachable                    = EHOSTUNREACH, |     host_unreachable                    = EHOSTUNREACH, | ||||||
| #endif |  | ||||||
| #ifdef EIDRM |  | ||||||
|     identifier_removed                  = EIDRM, |     identifier_removed                  = EIDRM, | ||||||
| #endif |  | ||||||
|     illegal_byte_sequence               = EILSEQ, |     illegal_byte_sequence               = EILSEQ, | ||||||
|     inappropriate_io_control_operation  = ENOTTY, |     inappropriate_io_control_operation  = ENOTTY, | ||||||
|     interrupted                         = EINTR, |     interrupted                         = EINTR, | ||||||
| @@ -302,37 +278,21 @@ enum _ { | |||||||
|     invalid_seek                        = ESPIPE, |     invalid_seek                        = ESPIPE, | ||||||
|     io_error                            = EIO, |     io_error                            = EIO, | ||||||
|     is_a_directory                      = EISDIR, |     is_a_directory                      = EISDIR, | ||||||
| #ifdef EMSGSIZE |  | ||||||
|     message_size                        = EMSGSIZE, |     message_size                        = EMSGSIZE, | ||||||
| #endif |  | ||||||
| #ifdef ENETDOWN |  | ||||||
|     network_down                        = ENETDOWN, |     network_down                        = ENETDOWN, | ||||||
| #endif |  | ||||||
| #ifdef ENETRESET |  | ||||||
|     network_reset                       = ENETRESET, |     network_reset                       = ENETRESET, | ||||||
| #endif |  | ||||||
| #ifdef ENETUNREACH |  | ||||||
|     network_unreachable                 = ENETUNREACH, |     network_unreachable                 = ENETUNREACH, | ||||||
| #endif |  | ||||||
| #ifdef ENOBUFS |  | ||||||
|     no_buffer_space                     = ENOBUFS, |     no_buffer_space                     = ENOBUFS, | ||||||
| #endif |  | ||||||
|     no_child_process                    = ECHILD, |     no_child_process                    = ECHILD, | ||||||
| #ifdef ENOLINK |  | ||||||
|     no_link                             = ENOLINK, |     no_link                             = ENOLINK, | ||||||
| #endif |  | ||||||
|     no_lock_available                   = ENOLCK, |     no_lock_available                   = ENOLCK, | ||||||
| #ifdef ENOMSG |  | ||||||
| #ifdef ENODATA | #ifdef ENODATA | ||||||
|     no_message_available                = ENODATA, |     no_message_available                = ENODATA, | ||||||
| #else | #else | ||||||
|     no_message_available                = ENOMSG, |     no_message_available                = ENOMSG, | ||||||
| #endif | #endif | ||||||
|     no_message                          = ENOMSG, |     no_message                          = ENOMSG, | ||||||
| #endif |  | ||||||
| #ifdef ENOPROTOOPT, |  | ||||||
|     no_protocol_option                  = ENOPROTOOPT, |     no_protocol_option                  = ENOPROTOOPT, | ||||||
| #endif |  | ||||||
|     no_space_on_device                  = ENOSPC, |     no_space_on_device                  = ENOSPC, | ||||||
| #ifdef ENOSR | #ifdef ENOSR | ||||||
|     no_stream_resources                 = ENOSR, |     no_stream_resources                 = ENOSR, | ||||||
| @@ -344,42 +304,24 @@ enum _ { | |||||||
|     no_such_file_or_directory           = ENOENT, |     no_such_file_or_directory           = ENOENT, | ||||||
|     no_such_process                     = ESRCH, |     no_such_process                     = ESRCH, | ||||||
|     not_a_directory                     = ENOTDIR, |     not_a_directory                     = ENOTDIR, | ||||||
| #ifdef ENOTSOCK |  | ||||||
|     not_a_socket                        = ENOTSOCK, |     not_a_socket                        = ENOTSOCK, | ||||||
| #endif |  | ||||||
| #ifdef ENOSTR | #ifdef ENOSTR | ||||||
|     not_a_stream                        = ENOSTR, |     not_a_stream                        = ENOSTR, | ||||||
| #else | #else | ||||||
|     not_a_stream                        = EINVAL, |     not_a_stream                        = EINVAL, | ||||||
| #endif | #endif | ||||||
| #ifdef ENOTCONN |  | ||||||
|     not_connected                       = ENOTCONN, |     not_connected                       = ENOTCONN, | ||||||
| #endif |  | ||||||
|     not_enough_memory                   = ENOMEM, |     not_enough_memory                   = ENOMEM, | ||||||
| #ifdef ENOTSUP |  | ||||||
|     not_supported                       = ENOTSUP, |     not_supported                       = ENOTSUP, | ||||||
| #endif |  | ||||||
| #ifdef ECANCELED |  | ||||||
|     operation_canceled                  = ECANCELED, |     operation_canceled                  = ECANCELED, | ||||||
| #endif |  | ||||||
| #ifdef EINPROGRESS |  | ||||||
|     operation_in_progress               = EINPROGRESS, |     operation_in_progress               = EINPROGRESS, | ||||||
| #endif |  | ||||||
|     operation_not_permitted             = EPERM, |     operation_not_permitted             = EPERM, | ||||||
| #ifdef EOPNOTSUPP |  | ||||||
|     operation_not_supported             = EOPNOTSUPP, |     operation_not_supported             = EOPNOTSUPP, | ||||||
| #endif |  | ||||||
| #ifdef EWOULDBLOCK |  | ||||||
|     operation_would_block               = EWOULDBLOCK, |     operation_would_block               = EWOULDBLOCK, | ||||||
| #endif |  | ||||||
|     owner_dead                          = EOWNERDEAD, |     owner_dead                          = EOWNERDEAD, | ||||||
|     permission_denied                   = EACCES, |     permission_denied                   = EACCES, | ||||||
| #ifdef EPROTO |  | ||||||
|     protocol_error                      = EPROTO, |     protocol_error                      = EPROTO, | ||||||
| #endif |  | ||||||
| #ifdef EPROTONOSUPPORT |  | ||||||
|     protocol_not_supported              = EPROTONOSUPPORT, |     protocol_not_supported              = EPROTONOSUPPORT, | ||||||
| #endif |  | ||||||
|     read_only_file_system               = EROFS, |     read_only_file_system               = EROFS, | ||||||
|     resource_deadlock_would_occur       = EDEADLK, |     resource_deadlock_would_occur       = EDEADLK, | ||||||
|     resource_unavailable_try_again      = EAGAIN, |     resource_unavailable_try_again      = EAGAIN, | ||||||
| @@ -387,27 +329,17 @@ enum _ { | |||||||
|     state_not_recoverable               = ENOTRECOVERABLE, |     state_not_recoverable               = ENOTRECOVERABLE, | ||||||
| #ifdef ETIME | #ifdef ETIME | ||||||
|     stream_timeout                      = ETIME, |     stream_timeout                      = ETIME, | ||||||
| #elif defined(ETIMEDOUT) | #else | ||||||
|     stream_timeout                      = ETIMEDOUT, |     stream_timeout                      = ETIMEDOUT, | ||||||
| #endif | #endif | ||||||
| #ifdef ETXTBSY |  | ||||||
|     text_file_busy                      = ETXTBSY, |     text_file_busy                      = ETXTBSY, | ||||||
| #endif |  | ||||||
| #ifdef ETIMEDOUT |  | ||||||
|     timed_out                           = ETIMEDOUT, |     timed_out                           = ETIMEDOUT, | ||||||
| #endif |  | ||||||
|     too_many_files_open_in_system       = ENFILE, |     too_many_files_open_in_system       = ENFILE, | ||||||
|     too_many_files_open                 = EMFILE, |     too_many_files_open                 = EMFILE, | ||||||
|     too_many_links                      = EMLINK, |     too_many_links                      = EMLINK, | ||||||
| #ifdef ELOOP |  | ||||||
|     too_many_symbolic_link_levels       = ELOOP, |     too_many_symbolic_link_levels       = ELOOP, | ||||||
| #endif |  | ||||||
| #ifdef EOVERFLOW |  | ||||||
|     value_too_large                     = EOVERFLOW, |     value_too_large                     = EOVERFLOW, | ||||||
| #endif |     wrong_protocol_type                 = EPROTOTYPE | ||||||
| #ifdef EPROTOTYPE |  | ||||||
|     wrong_protocol_type                 = EPROTOTYPE, |  | ||||||
| #endif |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|     _ __v_; |     _ __v_; | ||||||
| @@ -437,28 +369,28 @@ class __do_message; | |||||||
| class _LIBCPP_VISIBLE error_category | class _LIBCPP_VISIBLE error_category | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     virtual ~error_category(); |     virtual ~error_category() _NOEXCEPT; | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     error_category(); |     error_category() _NOEXCEPT; | ||||||
|     error_category(const error_category&);// = delete; |     error_category(const error_category&);// = delete; | ||||||
|     error_category& operator=(const error_category&);// = delete; |     error_category& operator=(const error_category&);// = delete; | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     virtual const char* name() const = 0; |     virtual const char* name() const _NOEXCEPT = 0; | ||||||
|     virtual error_condition default_error_condition(int __ev) const; |     virtual error_condition default_error_condition(int __ev) const _NOEXCEPT; | ||||||
|     virtual bool equivalent(int __code, const error_condition& __condition) const; |     virtual bool equivalent(int __code, const error_condition& __condition) const _NOEXCEPT; | ||||||
|     virtual bool equivalent(const error_code& __code, int __condition) const; |     virtual bool equivalent(const error_code& __code, int __condition) const _NOEXCEPT; | ||||||
|     virtual string message(int __ev) const = 0; |     virtual string message(int __ev) const = 0; | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     bool operator==(const error_category& __rhs) const {return this == &__rhs;} |     bool operator==(const error_category& __rhs) const _NOEXCEPT {return this == &__rhs;} | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     bool operator!=(const error_category& __rhs) const {return !(*this == __rhs);} |     bool operator!=(const error_category& __rhs) const _NOEXCEPT {return !(*this == __rhs);} | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     bool operator< (const error_category& __rhs) const {return this < &__rhs;} |     bool operator< (const error_category& __rhs) const _NOEXCEPT {return this < &__rhs;} | ||||||
|  |  | ||||||
|     friend class __do_message; |     friend class __do_message; | ||||||
| }; | }; | ||||||
| @@ -470,8 +402,8 @@ public: | |||||||
|     virtual string message(int ev) const; |     virtual string message(int ev) const; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const error_category& generic_category(); | const error_category& generic_category() _NOEXCEPT; | ||||||
| const error_category& system_category(); | const error_category& system_category() _NOEXCEPT; | ||||||
|  |  | ||||||
| class _LIBCPP_VISIBLE error_condition | class _LIBCPP_VISIBLE error_condition | ||||||
| { | { | ||||||
| @@ -479,19 +411,21 @@ class _LIBCPP_VISIBLE error_condition | |||||||
|     const error_category* __cat_; |     const error_category* __cat_; | ||||||
| public: | public: | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     error_condition() : __val_(0), __cat_(&generic_category()) {} |     error_condition() _NOEXCEPT : __val_(0), __cat_(&generic_category()) {} | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     error_condition(int __val, const error_category& __cat) |     error_condition(int __val, const error_category& __cat) _NOEXCEPT | ||||||
|         : __val_(__val), __cat_(&__cat) {} |         : __val_(__val), __cat_(&__cat) {} | ||||||
|  |  | ||||||
|     template <class _E> |     template <class _E> | ||||||
|         _LIBCPP_ALWAYS_INLINE |         _LIBCPP_ALWAYS_INLINE | ||||||
|         error_condition(_E __e, typename enable_if<is_error_condition_enum<_E>::value>::type* = 0) |         error_condition(_E __e, | ||||||
|  |               typename enable_if<is_error_condition_enum<_E>::value>::type* = 0 | ||||||
|  |                                                                      ) _NOEXCEPT | ||||||
|             {*this = make_error_condition(__e);} |             {*this = make_error_condition(__e);} | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     void assign(int __val, const error_category& __cat) |     void assign(int __val, const error_category& __cat) _NOEXCEPT | ||||||
|     { |     { | ||||||
|         __val_ = __val; |         __val_ = __val; | ||||||
|         __cat_ = &__cat; |         __cat_ = &__cat; | ||||||
| @@ -504,38 +438,38 @@ public: | |||||||
|             is_error_condition_enum<_E>::value, |             is_error_condition_enum<_E>::value, | ||||||
|             error_condition& |             error_condition& | ||||||
|         >::type |         >::type | ||||||
|         operator=(_E __e) |         operator=(_E __e) _NOEXCEPT | ||||||
|             {*this = make_error_condition(__e); return *this;} |             {*this = make_error_condition(__e); return *this;} | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     void clear() |     void clear() _NOEXCEPT | ||||||
|     { |     { | ||||||
|         __val_ = 0; |         __val_ = 0; | ||||||
|         __cat_ = &generic_category(); |         __cat_ = &generic_category(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     int value() const {return __val_;} |     int value() const _NOEXCEPT {return __val_;} | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     const error_category& category() const {return *__cat_;} |     const error_category& category() const _NOEXCEPT {return *__cat_;} | ||||||
|     string message() const; |     string message() const; | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     //explicit |     //explicit | ||||||
|         operator bool() const {return __val_ != 0;} |         operator bool() const _NOEXCEPT {return __val_ != 0;} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| error_condition | error_condition | ||||||
| make_error_condition(errc __e) | make_error_condition(errc __e) _NOEXCEPT | ||||||
| { | { | ||||||
|     return error_condition(static_cast<int>(__e), generic_category()); |     return error_condition(static_cast<int>(__e), generic_category()); | ||||||
| } | } | ||||||
|  |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator<(const error_condition& __x, const error_condition& __y) | operator<(const error_condition& __x, const error_condition& __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __x.category() < __y.category() |     return __x.category() < __y.category() | ||||||
|         || __x.category() == __y.category() && __x.value() < __y.value(); |         || __x.category() == __y.category() && __x.value() < __y.value(); | ||||||
| @@ -549,19 +483,21 @@ class _LIBCPP_VISIBLE error_code | |||||||
|     const error_category* __cat_; |     const error_category* __cat_; | ||||||
| public: | public: | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     error_code() : __val_(0), __cat_(&system_category()) {} |     error_code() _NOEXCEPT : __val_(0), __cat_(&system_category()) {} | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     error_code(int __val, const error_category& __cat) |     error_code(int __val, const error_category& __cat) _NOEXCEPT | ||||||
|         : __val_(__val), __cat_(&__cat) {} |         : __val_(__val), __cat_(&__cat) {} | ||||||
|  |  | ||||||
|     template <class _E> |     template <class _E> | ||||||
|         _LIBCPP_ALWAYS_INLINE |         _LIBCPP_ALWAYS_INLINE | ||||||
|         error_code(_E __e, typename enable_if<is_error_code_enum<_E>::value>::type* = 0) |         error_code(_E __e, | ||||||
|  |                    typename enable_if<is_error_code_enum<_E>::value>::type* = 0 | ||||||
|  |                                                                      ) _NOEXCEPT | ||||||
|             {*this = make_error_code(__e);} |             {*this = make_error_code(__e);} | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     void assign(int __val, const error_category& __cat) |     void assign(int __val, const error_category& __cat) _NOEXCEPT | ||||||
|     { |     { | ||||||
|         __val_ = __val; |         __val_ = __val; | ||||||
|         __cat_ = &__cat; |         __cat_ = &__cat; | ||||||
| @@ -574,43 +510,43 @@ public: | |||||||
|             is_error_code_enum<_E>::value, |             is_error_code_enum<_E>::value, | ||||||
|             error_code& |             error_code& | ||||||
|         >::type |         >::type | ||||||
|         operator=(_E __e) |         operator=(_E __e) _NOEXCEPT | ||||||
|             {*this = make_error_code(__e); return *this;} |             {*this = make_error_code(__e); return *this;} | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     void clear() |     void clear() _NOEXCEPT | ||||||
|     { |     { | ||||||
|         __val_ = 0; |         __val_ = 0; | ||||||
|         __cat_ = &system_category(); |         __cat_ = &system_category(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     int value() const {return __val_;} |     int value() const _NOEXCEPT {return __val_;} | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     const error_category& category() const {return *__cat_;} |     const error_category& category() const _NOEXCEPT {return *__cat_;} | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     error_condition default_error_condition() const |     error_condition default_error_condition() const _NOEXCEPT | ||||||
|         {return __cat_->default_error_condition(__val_);} |         {return __cat_->default_error_condition(__val_);} | ||||||
|  |  | ||||||
|     string message() const; |     string message() const; | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     //explicit |     //explicit | ||||||
|         operator bool() const {return __val_ != 0;} |         operator bool() const _NOEXCEPT {return __val_ != 0;} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| error_code | error_code | ||||||
| make_error_code(errc __e) | make_error_code(errc __e) _NOEXCEPT | ||||||
| { | { | ||||||
|     return error_code(static_cast<int>(__e), generic_category()); |     return error_code(static_cast<int>(__e), generic_category()); | ||||||
| } | } | ||||||
|  |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator<(const error_code& __x, const error_code& __y) | operator<(const error_code& __x, const error_code& __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __x.category() < __y.category() |     return __x.category() < __y.category() | ||||||
|         || __x.category() == __y.category() && __x.value() < __y.value(); |         || __x.category() == __y.category() && __x.value() < __y.value(); | ||||||
| @@ -618,14 +554,14 @@ operator<(const error_code& __x, const error_code& __y) | |||||||
|  |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator==(const error_code& __x, const error_code& __y) | operator==(const error_code& __x, const error_code& __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __x.category() == __y.category() && __x.value() == __y.value(); |     return __x.category() == __y.category() && __x.value() == __y.value(); | ||||||
| } | } | ||||||
|  |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator==(const error_code& __x, const error_condition& __y) | operator==(const error_code& __x, const error_condition& __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __x.category().equivalent(__x.value(), __y) |     return __x.category().equivalent(__x.value(), __y) | ||||||
|         || __y.category().equivalent(__x, __y.value()); |         || __y.category().equivalent(__x, __y.value()); | ||||||
| @@ -633,40 +569,44 @@ operator==(const error_code& __x, const error_condition& __y) | |||||||
|  |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator==(const error_condition& __x, const error_code& __y) | operator==(const error_condition& __x, const error_code& __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __y == __x; |     return __y == __x; | ||||||
| } | } | ||||||
|  |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator==(const error_condition& __x, const error_condition& __y) | operator==(const error_condition& __x, const error_condition& __y) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __x.category() == __y.category() && __x.value() == __y.value(); |     return __x.category() == __y.category() && __x.value() == __y.value(); | ||||||
| } | } | ||||||
|  |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator!=(const error_code& __x, const error_code& __y) {return !(__x == __y);} | operator!=(const error_code& __x, const error_code& __y) _NOEXCEPT | ||||||
|  | {return !(__x == __y);} | ||||||
|  |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator!=(const error_code& __x, const error_condition& __y) {return !(__x == __y);} | operator!=(const error_code& __x, const error_condition& __y) _NOEXCEPT | ||||||
|  | {return !(__x == __y);} | ||||||
|  |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator!=(const error_condition& __x, const error_code& __y) {return !(__x == __y);} | operator!=(const error_condition& __x, const error_code& __y) _NOEXCEPT | ||||||
|  | {return !(__x == __y);} | ||||||
|  |  | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| bool | bool | ||||||
| operator!=(const error_condition& __x, const error_condition& __y) {return !(__x == __y);} | operator!=(const error_condition& __x, const error_condition& __y) _NOEXCEPT | ||||||
|  | {return !(__x == __y);} | ||||||
|  |  | ||||||
| template <> | template <> | ||||||
| struct _LIBCPP_VISIBLE hash<error_code> | struct _LIBCPP_VISIBLE hash<error_code> | ||||||
|     : public unary_function<error_code, size_t> |     : public unary_function<error_code, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(const error_code& __ec) const |     size_t operator()(const error_code& __ec) const _NOEXCEPT | ||||||
|     { |     { | ||||||
|         return static_cast<size_t>(__ec.value()); |         return static_cast<size_t>(__ec.value()); | ||||||
|     } |     } | ||||||
| @@ -685,10 +625,10 @@ public: | |||||||
|     system_error(int __ev, const error_category& __ecat, const string& __what_arg); |     system_error(int __ev, const error_category& __ecat, const string& __what_arg); | ||||||
|     system_error(int __ev, const error_category& __ecat, const char* __what_arg); |     system_error(int __ev, const error_category& __ecat, const char* __what_arg); | ||||||
|     system_error(int __ev, const error_category& __ecat); |     system_error(int __ev, const error_category& __ecat); | ||||||
|     ~system_error() throw(); |     ~system_error() _NOEXCEPT; | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|     const error_code& code() const throw() {return __ec_;} |     const error_code& code() const _NOEXCEPT {return __ec_;} | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     static string __init(const error_code&, string); |     static string __init(const error_code&, string); | ||||||
|   | |||||||
| @@ -95,15 +95,10 @@ void sleep_for(const chrono::duration<Rep, Period>& rel_time); | |||||||
| #include <system_error> | #include <system_error> | ||||||
| #include <chrono> | #include <chrono> | ||||||
| #include <__mutex_base> | #include <__mutex_base> | ||||||
| #ifdef __MINGW32__ | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
| #define pthread_key_delete(a) (-1) | #include <tuple> | ||||||
| #define pthread_join(a,b) (-1) |  | ||||||
| #define pthread_detach(a) (-1) |  | ||||||
| #define nanosleep(a,b) (-1) |  | ||||||
| #define pthread_key_create(a,b) (-1) |  | ||||||
| #else |  | ||||||
| #include <pthread.h> |  | ||||||
| #endif | #endif | ||||||
|  | #include <pthread.h> | ||||||
|  |  | ||||||
| #pragma GCC system_header | #pragma GCC system_header | ||||||
|  |  | ||||||
| @@ -289,7 +284,7 @@ public: | |||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(thread& __t) {_STD::swap(__t_, __t.__t_);} |     void swap(thread& __t) {_VSTD::swap(__t_, __t.__t_);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool joinable() const {return __t_ != 0;} |     bool joinable() const {return __t_ != 0;} | ||||||
| @@ -323,6 +318,44 @@ public: | |||||||
|  |  | ||||||
| __thread_specific_ptr<__thread_struct>& __thread_local_data(); | __thread_specific_ptr<__thread_struct>& __thread_local_data(); | ||||||
|  |  | ||||||
|  | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
|  |  | ||||||
|  | template <class _F, class ..._Args, size_t ..._Indices> | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | void | ||||||
|  | __threaad_execute(tuple<_F, _Args...>& __t, __tuple_indices<_Indices...>) | ||||||
|  | { | ||||||
|  |     __invoke(_VSTD::move(_VSTD::get<0>(__t)), _VSTD::move(_VSTD::get<_Indices>(__t))...); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class _F> | ||||||
|  | void* | ||||||
|  | __thread_proxy(void* __vp) | ||||||
|  | { | ||||||
|  |     __thread_local_data().reset(new __thread_struct); | ||||||
|  |     std::unique_ptr<_F> __p(static_cast<_F*>(__vp)); | ||||||
|  |     typedef typename __make_tuple_indices<tuple_size<_F>::value, 1>::type _Index; | ||||||
|  |     __threaad_execute(*__p, _Index()); | ||||||
|  |     return nullptr; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class _F, class ..._Args, | ||||||
|  |           class | ||||||
|  |          > | ||||||
|  | thread::thread(_F&& __f, _Args&&... __args) | ||||||
|  | { | ||||||
|  |     typedef tuple<typename decay<_F>::type, typename decay<_Args>::type...> _G; | ||||||
|  |     _VSTD::unique_ptr<_G> __p(new _G(__decay_copy(_VSTD::forward<_F>(__f)), | ||||||
|  |                                 __decay_copy(_VSTD::forward<_Args>(__args))...)); | ||||||
|  |     int __ec = pthread_create(&__t_, 0, &__thread_proxy<_G>, __p.get()); | ||||||
|  |     if (__ec == 0) | ||||||
|  |         __p.release(); | ||||||
|  |     else | ||||||
|  |         __throw_system_error(__ec, "thread constructor failed"); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #else  // _LIBCPP_HAS_NO_VARIADICS | ||||||
|  |  | ||||||
| template <class _F> | template <class _F> | ||||||
| void* | void* | ||||||
| __thread_proxy(void* __vp) | __thread_proxy(void* __vp) | ||||||
| @@ -333,25 +366,6 @@ __thread_proxy(void* __vp) | |||||||
|     return nullptr; |     return nullptr; | ||||||
| } | } | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS |  | ||||||
|  |  | ||||||
| template <class _F, class ..._Args, |  | ||||||
|           class |  | ||||||
|          > |  | ||||||
| thread::thread(_F&& __f, _Args&&... __args) |  | ||||||
| { |  | ||||||
|     typedef decltype(bind(std::forward<_F>(__f), std::forward<_Args>(__args)...)) _G; |  | ||||||
|     std::unique_ptr<_G> __p(new _G(bind(std::forward<_F>(__f), |  | ||||||
|                               std::forward<_Args>(__args)...))); |  | ||||||
|     int __ec = pthread_create(&__t_, 0, &__thread_proxy<_G>, __p.get()); |  | ||||||
|     if (__ec == 0) |  | ||||||
|         __p.release(); |  | ||||||
|     else |  | ||||||
|         __throw_system_error(__ec, "thread constructor failed"); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #else  // _LIBCPP_HAS_NO_VARIADICS |  | ||||||
|  |  | ||||||
| template <class _F> | template <class _F> | ||||||
| thread::thread(_F __f) | thread::thread(_F __f) | ||||||
| { | { | ||||||
|   | |||||||
							
								
								
									
										137
									
								
								include/tuple
									
									
									
									
									
								
							
							
						
						
									
										137
									
								
								include/tuple
									
									
									
									
									
								
							| @@ -25,7 +25,7 @@ public: | |||||||
|     template <class... U> |     template <class... U> | ||||||
|         explicit tuple(U&&...); |         explicit tuple(U&&...); | ||||||
|     tuple(const tuple&) = default; |     tuple(const tuple&) = default; | ||||||
|     tuple(tuple&&); |     tuple(tuple&&) = default; | ||||||
|     template <class... U> |     template <class... U> | ||||||
|         tuple(const tuple<U...>&); |         tuple(const tuple<U...>&); | ||||||
|     template <class... U> |     template <class... U> | ||||||
| @@ -56,7 +56,8 @@ public: | |||||||
|         tuple(allocator_arg_t, const Alloc& a, pair<U1, U2>&&); |         tuple(allocator_arg_t, const Alloc& a, pair<U1, U2>&&); | ||||||
|  |  | ||||||
|     tuple& operator=(const tuple&); |     tuple& operator=(const tuple&); | ||||||
|     tuple& operator=(tuple&&); |     tuple& | ||||||
|  |         operator=(tuple&&) noexcept(AND(is_nothrow_move_assignable<T>::value ...)); | ||||||
|     template <class... U> |     template <class... U> | ||||||
|         tuple& operator=(const tuple<U...>&); |         tuple& operator=(const tuple<U...>&); | ||||||
|     template <class... U> |     template <class... U> | ||||||
| @@ -66,14 +67,14 @@ public: | |||||||
|     template <class U1, class U2> |     template <class U1, class U2> | ||||||
|         tuple& operator=(pair<U1, U2>&&); //iffsizeof...(T) == 2 |         tuple& operator=(pair<U1, U2>&&); //iffsizeof...(T) == 2 | ||||||
|  |  | ||||||
|     void swap(tuple&); |     void swap(tuple&) noexcept(AND(swap(declval<T&>(), declval<T&>())...)); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const unspecified ignore; | const unspecified ignore; | ||||||
|  |  | ||||||
| template <class... T> tuple<V...>  make_tuple(T&&...); | template <class... T> tuple<V...>  make_tuple(T&&...); | ||||||
| template <class... T> tuple<ATypes...> forward_as_tuple(T&&...); | template <class... T> tuple<ATypes...> forward_as_tuple(T&&...) noexcept; | ||||||
| template <class... T> tuple<T&...> tie(T&...); | template <class... T> tuple<T&...> tie(T&...) noexcept; | ||||||
| template <class... Tuples> tuple<CTypes...> tuple_cat(Tuples&&... tpls); | template <class... Tuples> tuple<CTypes...> tuple_cat(Tuples&&... tpls); | ||||||
|    |    | ||||||
| // 20.4.1.4, tuple helper classes: | // 20.4.1.4, tuple helper classes: | ||||||
| @@ -83,9 +84,15 @@ template <intsize_t I, class T> class tuple_element; // undefined | |||||||
| template <intsize_t I, class... T> class tuple_element<I, tuple<T...>>; | template <intsize_t I, class... T> class tuple_element<I, tuple<T...>>; | ||||||
|  |  | ||||||
| // 20.4.1.5, element access: | // 20.4.1.5, element access: | ||||||
| template <intsize_t I, class... T> typename tuple_element<I, tuple<T...>>::type& get(tuple<T...>&); | template <intsize_t I, class... T> | ||||||
| template <intsize_t I, class... T> typename tuple_element<I, tuple<T...>>::type const& get(const tuple<T...>&); |     typename tuple_element<I, tuple<T...>>::type& | ||||||
| template <intsize_t I, class... T> typename tuple_element<I, tuple<T...>>::type&& get(tuple<T...>&&); |     get(tuple<T...>&) noexcept; | ||||||
|  | template <intsize_t I, class... T> | ||||||
|  |     typename tuple_element<I, tuple<T...>>::type const& | ||||||
|  |     get(const tuple<T...>&) noexcept; | ||||||
|  | template <intsize_t I, class... T> | ||||||
|  |     typename tuple_element<I, tuple<T...>>::type&& | ||||||
|  |     get(tuple<T...>&&) noexcept; | ||||||
|  |  | ||||||
| // 20.4.1.6, relational operators: | // 20.4.1.6, relational operators: | ||||||
| template<class... T, class... U> bool operator==(const tuple<T...>&, const tuple<U...>&); | template<class... T, class... U> bool operator==(const tuple<T...>&, const tuple<U...>&); | ||||||
| @@ -99,7 +106,8 @@ template <class... Types, class Alloc> | |||||||
|   struct uses_allocator<tuple<Types...>, Alloc>; |   struct uses_allocator<tuple<Types...>, Alloc>; | ||||||
|  |  | ||||||
| template <class... Types> | template <class... Types> | ||||||
|   void swap(tuple<Types...>& x, tuple<Types...>& y); |   void | ||||||
|  |   swap(tuple<Types...>& x, tuple<Types...>& y) noexcept(noexcept(x.swap(y))); | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
|  |  | ||||||
| @@ -142,6 +150,7 @@ class __tuple_leaf; | |||||||
| template <size_t _Ip, class _Hp, bool _Ep> | template <size_t _Ip, class _Hp, bool _Ep> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| void swap(__tuple_leaf<_Ip, _Hp, _Ep>& __x, __tuple_leaf<_Ip, _Hp, _Ep>& __y) | void swap(__tuple_leaf<_Ip, _Hp, _Ep>& __x, __tuple_leaf<_Ip, _Hp, _Ep>& __y) | ||||||
|  |     _NOEXCEPT_(__is_nothrow_swappable<_Hp>::value) | ||||||
| { | { | ||||||
|     swap(__x.get(), __y.get()); |     swap(__x.get(), __y.get()); | ||||||
| } | } | ||||||
| @@ -182,7 +191,7 @@ public: | |||||||
|               class = typename enable_if<is_constructible<_Hp, _Tp>::value>::type> |               class = typename enable_if<is_constructible<_Hp, _Tp>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         explicit __tuple_leaf(_Tp&& __t) |         explicit __tuple_leaf(_Tp&& __t) | ||||||
|             : value(_STD::forward<_Tp>(__t)) |             : value(_VSTD::forward<_Tp>(__t)) | ||||||
|         {static_assert(!is_reference<_Hp>::value || |         {static_assert(!is_reference<_Hp>::value || | ||||||
|                         is_lvalue_reference<_Hp>::value && |                         is_lvalue_reference<_Hp>::value && | ||||||
|                         (is_lvalue_reference<_Tp>::value || |                         (is_lvalue_reference<_Tp>::value || | ||||||
| @@ -198,7 +207,7 @@ public: | |||||||
|     template <class _Tp, class _Alloc> |     template <class _Tp, class _Alloc> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         explicit __tuple_leaf(integral_constant<int, 0>, const _Alloc&, _Tp&& __t) |         explicit __tuple_leaf(integral_constant<int, 0>, const _Alloc&, _Tp&& __t) | ||||||
|             : value(_STD::forward<_Tp>(__t)) |             : value(_VSTD::forward<_Tp>(__t)) | ||||||
|         {static_assert(!is_lvalue_reference<_Hp>::value || |         {static_assert(!is_lvalue_reference<_Hp>::value || | ||||||
|                         is_lvalue_reference<_Hp>::value && |                         is_lvalue_reference<_Hp>::value && | ||||||
|                         (is_lvalue_reference<_Tp>::value || |                         (is_lvalue_reference<_Tp>::value || | ||||||
| @@ -212,7 +221,7 @@ public: | |||||||
|     template <class _Tp, class _Alloc> |     template <class _Tp, class _Alloc> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         explicit __tuple_leaf(integral_constant<int, 1>, const _Alloc& __a, _Tp&& __t) |         explicit __tuple_leaf(integral_constant<int, 1>, const _Alloc& __a, _Tp&& __t) | ||||||
|             : value(allocator_arg_t(), __a, _STD::forward<_Tp>(__t)) |             : value(allocator_arg_t(), __a, _VSTD::forward<_Tp>(__t)) | ||||||
|         {static_assert(!is_lvalue_reference<_Hp>::value || |         {static_assert(!is_lvalue_reference<_Hp>::value || | ||||||
|                         is_lvalue_reference<_Hp>::value && |                         is_lvalue_reference<_Hp>::value && | ||||||
|                         (is_lvalue_reference<_Tp>::value || |                         (is_lvalue_reference<_Tp>::value || | ||||||
| @@ -226,7 +235,7 @@ public: | |||||||
|     template <class _Tp, class _Alloc> |     template <class _Tp, class _Alloc> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         explicit __tuple_leaf(integral_constant<int, 2>, const _Alloc& __a, _Tp&& __t) |         explicit __tuple_leaf(integral_constant<int, 2>, const _Alloc& __a, _Tp&& __t) | ||||||
|             : value(_STD::forward<_Tp>(__t), __a) |             : value(_VSTD::forward<_Tp>(__t), __a) | ||||||
|         {static_assert(!is_lvalue_reference<_Hp>::value || |         {static_assert(!is_lvalue_reference<_Hp>::value || | ||||||
|                         is_lvalue_reference<_Hp>::value && |                         is_lvalue_reference<_Hp>::value && | ||||||
|                         (is_lvalue_reference<_Tp>::value || |                         (is_lvalue_reference<_Tp>::value || | ||||||
| @@ -251,14 +260,14 @@ public: | |||||||
|         __tuple_leaf& |         __tuple_leaf& | ||||||
|         operator=(_Tp&& __t) |         operator=(_Tp&& __t) | ||||||
|         { |         { | ||||||
|             value = _STD::forward<_Tp>(__t); |             value = _VSTD::forward<_Tp>(__t); | ||||||
|             return *this; |             return *this; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     int swap(__tuple_leaf& __t) |     int swap(__tuple_leaf& __t) _NOEXCEPT_(__is_nothrow_swappable<__tuple_leaf>::value) | ||||||
|     { |     { | ||||||
|         _STD::swap(*this, __t); |         _VSTD::swap(*this, __t); | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -293,22 +302,22 @@ public: | |||||||
|               class = typename enable_if<is_constructible<_Hp, _Tp>::value>::type> |               class = typename enable_if<is_constructible<_Hp, _Tp>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         explicit __tuple_leaf(_Tp&& __t) |         explicit __tuple_leaf(_Tp&& __t) | ||||||
|             : _Hp(_STD::forward<_Tp>(__t)) {} |             : _Hp(_VSTD::forward<_Tp>(__t)) {} | ||||||
|  |  | ||||||
|     template <class _Tp, class _Alloc> |     template <class _Tp, class _Alloc> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         explicit __tuple_leaf(integral_constant<int, 0>, const _Alloc&, _Tp&& __t) |         explicit __tuple_leaf(integral_constant<int, 0>, const _Alloc&, _Tp&& __t) | ||||||
|             : _Hp(_STD::forward<_Tp>(__t)) {} |             : _Hp(_VSTD::forward<_Tp>(__t)) {} | ||||||
|  |  | ||||||
|     template <class _Tp, class _Alloc> |     template <class _Tp, class _Alloc> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         explicit __tuple_leaf(integral_constant<int, 1>, const _Alloc& __a, _Tp&& __t) |         explicit __tuple_leaf(integral_constant<int, 1>, const _Alloc& __a, _Tp&& __t) | ||||||
|             : _Hp(allocator_arg_t(), __a, _STD::forward<_Tp>(__t)) {} |             : _Hp(allocator_arg_t(), __a, _VSTD::forward<_Tp>(__t)) {} | ||||||
|  |  | ||||||
|     template <class _Tp, class _Alloc> |     template <class _Tp, class _Alloc> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         explicit __tuple_leaf(integral_constant<int, 2>, const _Alloc& __a, _Tp&& __t) |         explicit __tuple_leaf(integral_constant<int, 2>, const _Alloc& __a, _Tp&& __t) | ||||||
|             : _Hp(_STD::forward<_Tp>(__t), __a) {} |             : _Hp(_VSTD::forward<_Tp>(__t), __a) {} | ||||||
|  |  | ||||||
|     template <class _Tp> |     template <class _Tp> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -320,13 +329,15 @@ public: | |||||||
|         __tuple_leaf& |         __tuple_leaf& | ||||||
|         operator=(_Tp&& __t) |         operator=(_Tp&& __t) | ||||||
|         { |         { | ||||||
|             _Hp::operator=(_STD::forward<_Tp>(__t)); |             _Hp::operator=(_VSTD::forward<_Tp>(__t)); | ||||||
|             return *this; |             return *this; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY int swap(__tuple_leaf& __t) |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     int | ||||||
|  |     swap(__tuple_leaf& __t) _NOEXCEPT_(__is_nothrow_swappable<__tuple_leaf>::value) | ||||||
|     { |     { | ||||||
|         _STD::swap(*this, __t); |         _VSTD::swap(*this, __t); | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -338,6 +349,20 @@ template <class ..._Tp> | |||||||
| _LIBCPP_INLINE_VISIBILITY | _LIBCPP_INLINE_VISIBILITY | ||||||
| void __swallow(_Tp&&...) {} | void __swallow(_Tp&&...) {} | ||||||
|  |  | ||||||
|  | template <bool ...> struct __all; | ||||||
|  |  | ||||||
|  | template <> | ||||||
|  | struct __all<> | ||||||
|  | { | ||||||
|  |     static const bool value = true; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | template <bool _B0, bool ... _B> | ||||||
|  | struct __all<_B0, _B...> | ||||||
|  | { | ||||||
|  |     static const bool value = _B0 && __all<_B...>::value; | ||||||
|  | }; | ||||||
|  |  | ||||||
| // __tuple_impl | // __tuple_impl | ||||||
|  |  | ||||||
| template<class _Indx, class ..._Tp> struct __tuple_impl; | template<class _Indx, class ..._Tp> struct __tuple_impl; | ||||||
| @@ -353,7 +378,7 @@ struct __tuple_impl<__tuple_indices<_Indx...>, _Tp...> | |||||||
|         __tuple_impl(__tuple_indices<_Uf...>, __tuple_types<_Tf...>, |         __tuple_impl(__tuple_indices<_Uf...>, __tuple_types<_Tf...>, | ||||||
|                      __tuple_indices<_Ul...>, __tuple_types<_Tl...>, |                      __tuple_indices<_Ul...>, __tuple_types<_Tl...>, | ||||||
|                      _Up&&... __u) : |                      _Up&&... __u) : | ||||||
|             __tuple_leaf<_Uf, _Tf>(_STD::forward<_Up>(__u))..., |             __tuple_leaf<_Uf, _Tf>(_VSTD::forward<_Up>(__u))..., | ||||||
|             __tuple_leaf<_Ul, _Tl>()... |             __tuple_leaf<_Ul, _Tl>()... | ||||||
|             {} |             {} | ||||||
|  |  | ||||||
| @@ -366,7 +391,7 @@ struct __tuple_impl<__tuple_indices<_Indx...>, _Tp...> | |||||||
|                      __tuple_indices<_Ul...>, __tuple_types<_Tl...>, |                      __tuple_indices<_Ul...>, __tuple_types<_Tl...>, | ||||||
|                      _Up&&... __u) : |                      _Up&&... __u) : | ||||||
|             __tuple_leaf<_Uf, _Tf>(__uses_alloc_ctor<_Tf, _Alloc, _Up>(), __a, |             __tuple_leaf<_Uf, _Tf>(__uses_alloc_ctor<_Tf, _Alloc, _Up>(), __a, | ||||||
|             _STD::forward<_Up>(__u))..., |             _VSTD::forward<_Up>(__u))..., | ||||||
|             __tuple_leaf<_Ul, _Tl>(__uses_alloc_ctor<_Tl, _Alloc>(), __a)... |             __tuple_leaf<_Ul, _Tl>(__uses_alloc_ctor<_Tl, _Alloc>(), __a)... | ||||||
|             {} |             {} | ||||||
|  |  | ||||||
| @@ -378,8 +403,8 @@ struct __tuple_impl<__tuple_indices<_Indx...>, _Tp...> | |||||||
|              > |              > | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         __tuple_impl(_Tuple&& __t) |         __tuple_impl(_Tuple&& __t) | ||||||
|             : __tuple_leaf<_Indx, _Tp>(_STD::forward<typename tuple_element<_Indx, |             : __tuple_leaf<_Indx, _Tp>(_VSTD::forward<typename tuple_element<_Indx, | ||||||
|                                        typename __make_tuple_types<_Tuple>::type>::type>(_STD::get<_Indx>(__t)))... |                                        typename __make_tuple_types<_Tuple>::type>::type>(_VSTD::get<_Indx>(__t)))... | ||||||
|             {} |             {} | ||||||
|  |  | ||||||
|     template <class _Alloc, class _Tuple, |     template <class _Alloc, class _Tuple, | ||||||
| @@ -392,8 +417,8 @@ struct __tuple_impl<__tuple_indices<_Indx...>, _Tp...> | |||||||
|         __tuple_impl(allocator_arg_t, const _Alloc& __a, _Tuple&& __t) |         __tuple_impl(allocator_arg_t, const _Alloc& __a, _Tuple&& __t) | ||||||
|             : __tuple_leaf<_Indx, _Tp>(__uses_alloc_ctor<_Tp, _Alloc, typename tuple_element<_Indx, |             : __tuple_leaf<_Indx, _Tp>(__uses_alloc_ctor<_Tp, _Alloc, typename tuple_element<_Indx, | ||||||
|                                        typename __make_tuple_types<_Tuple>::type>::type>(), __a, |                                        typename __make_tuple_types<_Tuple>::type>::type>(), __a, | ||||||
|                                        _STD::forward<typename tuple_element<_Indx, |                                        _VSTD::forward<typename tuple_element<_Indx, | ||||||
|                                        typename __make_tuple_types<_Tuple>::type>::type>(_STD::get<_Indx>(__t)))... |                                        typename __make_tuple_types<_Tuple>::type>::type>(_VSTD::get<_Indx>(__t)))... | ||||||
|             {} |             {} | ||||||
|  |  | ||||||
|     template <class _Tuple> |     template <class _Tuple> | ||||||
| @@ -405,13 +430,14 @@ struct __tuple_impl<__tuple_indices<_Indx...>, _Tp...> | |||||||
|         >::type |         >::type | ||||||
|         operator=(_Tuple&& __t) |         operator=(_Tuple&& __t) | ||||||
|         { |         { | ||||||
|             __swallow(__tuple_leaf<_Indx, _Tp>::operator=(_STD::forward<typename tuple_element<_Indx, |             __swallow(__tuple_leaf<_Indx, _Tp>::operator=(_VSTD::forward<typename tuple_element<_Indx, | ||||||
|                                        typename __make_tuple_types<_Tuple>::type>::type>(_STD::get<_Indx>(__t)))...); |                                        typename __make_tuple_types<_Tuple>::type>::type>(_VSTD::get<_Indx>(__t)))...); | ||||||
|             return *this; |             return *this; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(__tuple_impl& __t) |     void swap(__tuple_impl& __t) | ||||||
|  |         _NOEXCEPT_(__all<__is_nothrow_swappable<_Tp>::value...>::value) | ||||||
|     { |     { | ||||||
|         __swallow(__tuple_leaf<_Indx, _Tp>::swap(static_cast<__tuple_leaf<_Indx, _Tp>&>(__t))...); |         __swallow(__tuple_leaf<_Indx, _Tp>::swap(static_cast<__tuple_leaf<_Indx, _Tp>&>(__t))...); | ||||||
|     } |     } | ||||||
| @@ -473,7 +499,7 @@ public: | |||||||
|                     typename __make_tuple_types<tuple, sizeof...(_Up)>::type(), |                     typename __make_tuple_types<tuple, sizeof...(_Up)>::type(), | ||||||
|                     typename __make_tuple_indices<sizeof...(_Tp), sizeof...(_Up)>::type(), |                     typename __make_tuple_indices<sizeof...(_Tp), sizeof...(_Up)>::type(), | ||||||
|                     typename __make_tuple_types<tuple, sizeof...(_Tp), sizeof...(_Up)>::type(), |                     typename __make_tuple_types<tuple, sizeof...(_Tp), sizeof...(_Up)>::type(), | ||||||
|                     _STD::forward<_Up>(__u)...) {} |                     _VSTD::forward<_Up>(__u)...) {} | ||||||
|  |  | ||||||
|     template <class _Alloc, class ..._Up, |     template <class _Alloc, class ..._Up, | ||||||
|               class = typename enable_if |               class = typename enable_if | ||||||
| @@ -496,7 +522,7 @@ public: | |||||||
|                     typename __make_tuple_types<tuple, sizeof...(_Up)>::type(), |                     typename __make_tuple_types<tuple, sizeof...(_Up)>::type(), | ||||||
|                     typename __make_tuple_indices<sizeof...(_Tp), sizeof...(_Up)>::type(), |                     typename __make_tuple_indices<sizeof...(_Tp), sizeof...(_Up)>::type(), | ||||||
|                     typename __make_tuple_types<tuple, sizeof...(_Tp), sizeof...(_Up)>::type(), |                     typename __make_tuple_types<tuple, sizeof...(_Tp), sizeof...(_Up)>::type(), | ||||||
|                     _STD::forward<_Up>(__u)...) {} |                     _VSTD::forward<_Up>(__u)...) {} | ||||||
|  |  | ||||||
|     template <class _Tuple, |     template <class _Tuple, | ||||||
|               class = typename enable_if |               class = typename enable_if | ||||||
| @@ -506,7 +532,7 @@ public: | |||||||
|              > |              > | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         tuple(_Tuple&& __t) |         tuple(_Tuple&& __t) | ||||||
|             : base_(_STD::forward<_Tuple>(__t)) {} |             : base_(_VSTD::forward<_Tuple>(__t)) {} | ||||||
|  |  | ||||||
|     template <class _Alloc, class _Tuple, |     template <class _Alloc, class _Tuple, | ||||||
|               class = typename enable_if |               class = typename enable_if | ||||||
| @@ -516,7 +542,7 @@ public: | |||||||
|              > |              > | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         tuple(allocator_arg_t, const _Alloc& __a, _Tuple&& __t) |         tuple(allocator_arg_t, const _Alloc& __a, _Tuple&& __t) | ||||||
|             : base_(allocator_arg_t(), __a, _STD::forward<_Tuple>(__t)) {} |             : base_(allocator_arg_t(), __a, _VSTD::forward<_Tuple>(__t)) {} | ||||||
|  |  | ||||||
|     template <class _Tuple, |     template <class _Tuple, | ||||||
|               class = typename enable_if |               class = typename enable_if | ||||||
| @@ -528,12 +554,13 @@ public: | |||||||
|         tuple& |         tuple& | ||||||
|         operator=(_Tuple&& __t) |         operator=(_Tuple&& __t) | ||||||
|         { |         { | ||||||
|             base_.operator=(_STD::forward<_Tuple>(__t)); |             base_.operator=(_VSTD::forward<_Tuple>(__t)); | ||||||
|             return *this; |             return *this; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(tuple& __t) {base_.swap(__t.base_);} |     void swap(tuple& __t) _NOEXCEPT_(__all<__is_nothrow_swappable<_Tp>::value...>::value) | ||||||
|  |         {base_.swap(__t.base_);} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <> | template <> | ||||||
| @@ -555,13 +582,19 @@ public: | |||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|         tuple(allocator_arg_t, const _Alloc&, array<_U, 0>) {} |         tuple(allocator_arg_t, const _Alloc&, array<_U, 0>) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(tuple&) {} |     void swap(tuple&) _NOEXCEPT {} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class ..._Tp> | template <class ..._Tp> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | typename enable_if | ||||||
|  | < | ||||||
|  |     __all<__is_swappable<_Tp>::value...>::value, | ||||||
|     void |     void | ||||||
| swap(tuple<_Tp...>& __t, tuple<_Tp...>& __u) {__t.swap(__u);} | >::type | ||||||
|  | swap(tuple<_Tp...>& __t, tuple<_Tp...>& __u) | ||||||
|  |                  _NOEXCEPT_(__all<__is_nothrow_swappable<_Tp>::value...>::value) | ||||||
|  |     {__t.swap(__u);} | ||||||
|  |  | ||||||
| // get | // get | ||||||
|  |  | ||||||
| @@ -643,7 +676,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| tuple<typename __make_tuple_return<_Tp>::type...> | tuple<typename __make_tuple_return<_Tp>::type...> | ||||||
| make_tuple(_Tp&&... __t) | make_tuple(_Tp&&... __t) | ||||||
| { | { | ||||||
|     return tuple<typename __make_tuple_return<_Tp>::type...>(_STD::forward<_Tp>(__t)...); |     return tuple<typename __make_tuple_return<_Tp>::type...>(_VSTD::forward<_Tp>(__t)...); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class... _Tp> | template <class... _Tp> | ||||||
| @@ -651,7 +684,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| tuple<_Tp&&...> | tuple<_Tp&&...> | ||||||
| forward_as_tuple(_Tp&&... __t) | forward_as_tuple(_Tp&&... __t) | ||||||
| { | { | ||||||
|     return tuple<_Tp&&...>(_STD::forward<_Tp>(__t)...); |     return tuple<_Tp&&...>(_VSTD::forward<_Tp>(__t)...); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <size_t _I> | template <size_t _I> | ||||||
| @@ -849,8 +882,8 @@ struct __tuple_cat<tuple<_Types...>, __tuple_indices<_I0...>, __tuple_indices<_J | |||||||
|     typename __tuple_cat_return_ref<tuple<_Types...>&&, _Tuple0&&>::type |     typename __tuple_cat_return_ref<tuple<_Types...>&&, _Tuple0&&>::type | ||||||
|     operator()(tuple<_Types...> __t, _Tuple0&& __t0) |     operator()(tuple<_Types...> __t, _Tuple0&& __t0) | ||||||
|     { |     { | ||||||
|         return _STD::forward_as_tuple(_STD::forward<_Types>(get<_I0>(__t))..., |         return _VSTD::forward_as_tuple(_VSTD::forward<_Types>(get<_I0>(__t))..., | ||||||
|                                       get<_J0>(_STD::forward<_Tuple0>(__t0))...); |                                       get<_J0>(_VSTD::forward<_Tuple0>(__t0))...); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     template <class _Tuple0, class _Tuple1, class ..._Tuples> |     template <class _Tuple0, class _Tuple1, class ..._Tuples> | ||||||
| @@ -864,12 +897,12 @@ struct __tuple_cat<tuple<_Types...>, __tuple_indices<_I0...>, __tuple_indices<_J | |||||||
|            tuple<_Types..., typename __apply_cv<_Tuple0, typename tuple_element<_J0, _T0>::type>::type&&...>, |            tuple<_Types..., typename __apply_cv<_Tuple0, typename tuple_element<_J0, _T0>::type>::type&&...>, | ||||||
|            typename __make_tuple_indices<sizeof ...(_Types) + tuple_size<_T0>::value>::type, |            typename __make_tuple_indices<sizeof ...(_Types) + tuple_size<_T0>::value>::type, | ||||||
|            typename __make_tuple_indices<tuple_size<_T1>::value>::type>() |            typename __make_tuple_indices<tuple_size<_T1>::value>::type>() | ||||||
|                            (_STD::forward_as_tuple( |                            (_VSTD::forward_as_tuple( | ||||||
|                               _STD::forward<_Types>(get<_I0>(__t))..., |                               _VSTD::forward<_Types>(get<_I0>(__t))..., | ||||||
|                               get<_J0>(_STD::forward<_Tuple0>(__t0))... |                               get<_J0>(_VSTD::forward<_Tuple0>(__t0))... | ||||||
|                             ), |                             ), | ||||||
|                             _STD::forward<_Tuple1>(__t1), |                             _VSTD::forward<_Tuple1>(__t1), | ||||||
|                             _STD::forward<_Tuples>(__tpls)...); |                             _VSTD::forward<_Tuples>(__tpls)...); | ||||||
|     } |     } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -881,8 +914,8 @@ tuple_cat(_Tuple0&& __t0, _Tuples&&... __tpls) | |||||||
|     typedef typename remove_reference<_Tuple0>::type _T0; |     typedef typename remove_reference<_Tuple0>::type _T0; | ||||||
|     return __tuple_cat<tuple<>, __tuple_indices<>, |     return __tuple_cat<tuple<>, __tuple_indices<>, | ||||||
|                   typename __make_tuple_indices<tuple_size<_T0>::value>::type>() |                   typename __make_tuple_indices<tuple_size<_T0>::value>::type>() | ||||||
|                   (tuple<>(), _STD::forward<_Tuple0>(__t0), |                   (tuple<>(), _VSTD::forward<_Tuple0>(__t0), | ||||||
|                                             _STD::forward<_Tuples>(__tpls)...); |                                             _VSTD::forward<_Tuples>(__tpls)...); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class ..._Tp, class _Alloc> | template <class ..._Tp, class _Alloc> | ||||||
| @@ -895,8 +928,8 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| pair<_T1, _T2>::pair(piecewise_construct_t, | pair<_T1, _T2>::pair(piecewise_construct_t, | ||||||
|                      tuple<_Args1...>& __first_args, tuple<_Args2...>& __second_args, |                      tuple<_Args1...>& __first_args, tuple<_Args2...>& __second_args, | ||||||
|                      __tuple_indices<_I1...>, __tuple_indices<_I2...>) |                      __tuple_indices<_I1...>, __tuple_indices<_I2...>) | ||||||
|     :  first(_STD::forward<_Args1>(get<_I1>( __first_args))...), |     :  first(_VSTD::forward<_Args1>(get<_I1>( __first_args))...), | ||||||
|       second(_STD::forward<_Args2>(get<_I2>(__second_args))...) |       second(_VSTD::forward<_Args2>(get<_I2>(__second_args))...) | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										1014
									
								
								include/type_traits
									
									
									
									
									
								
							
							
						
						
									
										1014
									
								
								include/type_traits
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -21,24 +21,24 @@ namespace std | |||||||
| class type_index | class type_index | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     type_index(const type_info& rhs); |     type_index(const type_info& rhs) noexcept; | ||||||
|  |  | ||||||
|     bool operator==(const type_index& rhs) const; |     bool operator==(const type_index& rhs) const noexcept; | ||||||
|     bool operator!=(const type_index& rhs) const; |     bool operator!=(const type_index& rhs) const noexcept; | ||||||
|     bool operator< (const type_index& rhs) const; |     bool operator< (const type_index& rhs) const noexcept; | ||||||
|     bool operator<=(const type_index& rhs) const; |     bool operator<=(const type_index& rhs) const noexcept; | ||||||
|     bool operator> (const type_index& rhs) const; |     bool operator> (const type_index& rhs) const noexcept; | ||||||
|     bool operator>=(const type_index& rhs) const; |     bool operator>=(const type_index& rhs) const noexcept; | ||||||
|  |  | ||||||
|     size_t hash_code() const; |     size_t hash_code() const noexcept; | ||||||
|     const char* name() const; |     const char* name() const noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <> | template <> | ||||||
| struct hash<type_index> | struct hash<type_index> | ||||||
|     : public unary_function<type_index, size_t> |     : public unary_function<type_index, size_t> | ||||||
| { | { | ||||||
|     size_t operator()(type_index index) const; |     size_t operator()(type_index index) const noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
| @@ -58,25 +58,31 @@ class _LIBCPP_VISIBLE type_index | |||||||
|     const type_info* __t_; |     const type_info* __t_; | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     type_index(const type_info& __y) : __t_(&__y) {} |     type_index(const type_info& __y) _NOEXCEPT : __t_(&__y) {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool operator==(const type_index& __y) const {return *__t_ == *__y.__t_;} |     bool operator==(const type_index& __y) const _NOEXCEPT | ||||||
|  |         {return *__t_ == *__y.__t_;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool operator!=(const type_index& __y) const {return *__t_ != *__y.__t_;} |     bool operator!=(const type_index& __y) const _NOEXCEPT | ||||||
|  |         {return *__t_ != *__y.__t_;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool operator< (const type_index& __y) const {return  __t_->before(*__y.__t_);} |     bool operator< (const type_index& __y) const _NOEXCEPT | ||||||
|  |         {return  __t_->before(*__y.__t_);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool operator<=(const type_index& __y) const {return !__y.__t_->before(*__t_);} |     bool operator<=(const type_index& __y) const _NOEXCEPT | ||||||
|  |         {return !__y.__t_->before(*__t_);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool operator> (const type_index& __y) const {return  __y.__t_->before(*__t_);} |     bool operator> (const type_index& __y) const _NOEXCEPT | ||||||
|  |         {return  __y.__t_->before(*__t_);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool operator>=(const type_index& __y) const {return !__t_->before(*__y.__t_);} |     bool operator>=(const type_index& __y) const _NOEXCEPT | ||||||
|  |         {return !__t_->before(*__y.__t_);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t hash_code() const {return __t_->hash_code();} |     size_t hash_code() const _NOEXCEPT {return __t_->hash_code();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const char* name() const {return __t_->name();} |     const char* name() const _NOEXCEPT {return __t_->name();} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class _Tp> struct _LIBCPP_VISIBLE hash; | template <class _Tp> struct _LIBCPP_VISIBLE hash; | ||||||
| @@ -86,7 +92,8 @@ struct _LIBCPP_VISIBLE hash<type_index> | |||||||
|     : public unary_function<type_index, size_t> |     : public unary_function<type_index, size_t> | ||||||
| { | { | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(type_index __index) const {return __index.hash_code();} |     size_t operator()(type_index __index) const _NOEXCEPT | ||||||
|  |         {return __index.hash_code();} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| _LIBCPP_END_NAMESPACE_STD | _LIBCPP_END_NAMESPACE_STD | ||||||
|   | |||||||
| @@ -22,12 +22,12 @@ class type_info | |||||||
| public: | public: | ||||||
|     virtual ~type_info(); |     virtual ~type_info(); | ||||||
|  |  | ||||||
|     bool operator==(const type_info& rhs) const; |     bool operator==(const type_info& rhs) const noexcept; | ||||||
|     bool operator!=(const type_info& rhs) const; |     bool operator!=(const type_info& rhs) const noexcept; | ||||||
|  |  | ||||||
|     bool before(const type_info& rhs) const; |     bool before(const type_info& rhs) const noexcept; | ||||||
|     size_t hash_code() const throw(); |     size_t hash_code() const noexcept; | ||||||
|     const char* name() const; |     const char* name() const noexcept; | ||||||
|  |  | ||||||
|     type_info(const type_info& rhs) = delete; |     type_info(const type_info& rhs) = delete; | ||||||
|     type_info& operator=(const type_info& rhs) = delete; |     type_info& operator=(const type_info& rhs) = delete; | ||||||
| @@ -37,20 +37,20 @@ class bad_cast | |||||||
|     : public exception |     : public exception | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     bad_cast() throw(); |     bad_cast() noexcept; | ||||||
|     bad_cast(const bad_cast&) throw(); |     bad_cast(const bad_cast&) noexcept; | ||||||
|     bad_cast& operator=(const bad_cast&) throw(); |     bad_cast& operator=(const bad_cast&) noexcept; | ||||||
|     virtual const char* what() const throw(); |     virtual const char* what() const noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class bad_typeid | class bad_typeid | ||||||
|     : public exception |     : public exception | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     bad_typeid() throw(); |     bad_typeid() noexcept; | ||||||
|     bad_typeid(const bad_typeid&) throw(); |     bad_typeid(const bad_typeid&) noexcept; | ||||||
|     bad_typeid& operator=(const bad_typeid&) throw(); |     bad_typeid& operator=(const bad_typeid&) noexcept; | ||||||
|     virtual const char* what() const throw(); |     virtual const char* what() const noexcept; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
| @@ -81,20 +81,20 @@ public: | |||||||
|     virtual ~type_info(); |     virtual ~type_info(); | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const char* name() const {return __type_name;} |     const char* name() const _NOEXCEPT {return __type_name;} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool before(const type_info& __arg) const |     bool before(const type_info& __arg) const _NOEXCEPT | ||||||
|         {return __type_name < __arg.__type_name;} |         {return __type_name < __arg.__type_name;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t hash_code() const throw() |     size_t hash_code() const _NOEXCEPT | ||||||
|         {return *reinterpret_cast<const size_t*>(&__type_name);} |         {return *reinterpret_cast<const size_t*>(&__type_name);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool operator==(const type_info& __arg) const |     bool operator==(const type_info& __arg) const _NOEXCEPT | ||||||
|         {return __type_name == __arg.__type_name;} |         {return __type_name == __arg.__type_name;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool operator!=(const type_info& __arg) const |     bool operator!=(const type_info& __arg) const _NOEXCEPT | ||||||
|         {return !operator==(__arg);} |         {return !operator==(__arg);} | ||||||
|  |  | ||||||
| }; | }; | ||||||
| @@ -103,18 +103,18 @@ class _LIBCPP_EXCEPTION_ABI bad_cast | |||||||
|     : public exception |     : public exception | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     bad_cast() throw(); |     bad_cast() _NOEXCEPT; | ||||||
|     virtual ~bad_cast() throw(); |     virtual ~bad_cast() _NOEXCEPT; | ||||||
|     virtual const char* what() const throw(); |     virtual const char* what() const _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class _LIBCPP_EXCEPTION_ABI bad_typeid | class _LIBCPP_EXCEPTION_ABI bad_typeid | ||||||
|     : public exception |     : public exception | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     bad_typeid() throw(); |     bad_typeid() _NOEXCEPT; | ||||||
|     virtual ~bad_typeid() throw(); |     virtual ~bad_typeid() _NOEXCEPT; | ||||||
|     virtual const char* what() const throw(); |     virtual const char* what() const _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
|   | |||||||
| @@ -44,7 +44,12 @@ public: | |||||||
|     typedef /unspecified/ local_iterator; |     typedef /unspecified/ local_iterator; | ||||||
|     typedef /unspecified/ const_local_iterator; |     typedef /unspecified/ const_local_iterator; | ||||||
|  |  | ||||||
|     explicit unordered_map(size_type n = 0, const hasher& hf = hasher(), |     unordered_map() | ||||||
|  |         noexcept( | ||||||
|  |             is_nothrow_default_constructible<hasher>::value && | ||||||
|  |             is_nothrow_default_constructible<key_equal>::value && | ||||||
|  |             is_nothrow_default_constructible<allocator_type>::value); | ||||||
|  |     explicit unordered_map(size_type n, const hasher& hf = hasher(), | ||||||
|                            const key_equal& eql = key_equal(), |                            const key_equal& eql = key_equal(), | ||||||
|                            const allocator_type& a = allocator_type()); |                            const allocator_type& a = allocator_type()); | ||||||
|     template <class InputIterator> |     template <class InputIterator> | ||||||
| @@ -55,28 +60,37 @@ public: | |||||||
|     explicit unordered_map(const allocator_type&); |     explicit unordered_map(const allocator_type&); | ||||||
|     unordered_map(const unordered_map&); |     unordered_map(const unordered_map&); | ||||||
|     unordered_map(const unordered_map&, const Allocator&); |     unordered_map(const unordered_map&, const Allocator&); | ||||||
|     unordered_map(unordered_map&&); |     unordered_map(unordered_map&&) | ||||||
|  |         noexcept( | ||||||
|  |             is_nothrow_move_constructible<hasher>::value && | ||||||
|  |             is_nothrow_move_constructible<key_equal>::value && | ||||||
|  |             is_nothrow_move_constructible<allocator_type>::value); | ||||||
|     unordered_map(unordered_map&&, const Allocator&); |     unordered_map(unordered_map&&, const Allocator&); | ||||||
|     unordered_map(initializer_list<value_type>, size_type n = 0, |     unordered_map(initializer_list<value_type>, size_type n = 0, | ||||||
|                   const hasher& hf = hasher(), const key_equal& eql = key_equal(), |                   const hasher& hf = hasher(), const key_equal& eql = key_equal(), | ||||||
|                   const allocator_type& a = allocator_type()); |                   const allocator_type& a = allocator_type()); | ||||||
|     ~unordered_map(); |     ~unordered_map(); | ||||||
|     unordered_map& operator=(const unordered_map&); |     unordered_map& operator=(const unordered_map&); | ||||||
|     unordered_map& operator=(unordered_map&&); |     unordered_map& operator=(unordered_map&&) | ||||||
|  |         noexcept( | ||||||
|  |             allocator_type::propagate_on_container_move_assignment::value && | ||||||
|  |             is_nothrow_move_assignable<allocator_type>::value && | ||||||
|  |             is_nothrow_move_assignable<hasher>::value && | ||||||
|  |             is_nothrow_move_assignable<key_equal>::value); | ||||||
|     unordered_map& operator=(initializer_list<value_type>); |     unordered_map& operator=(initializer_list<value_type>); | ||||||
|  |  | ||||||
|     allocator_type get_allocator() const; |     allocator_type get_allocator() const noexcept; | ||||||
|  |  | ||||||
|     bool      empty() const; |     bool      empty() const noexcept; | ||||||
|     size_type size() const; |     size_type size() const noexcept; | ||||||
|     size_type max_size() const; |     size_type max_size() const noexcept; | ||||||
|  |  | ||||||
|     iterator       begin(); |     iterator       begin() noexcept; | ||||||
|     iterator       end(); |     iterator       end() noexcept; | ||||||
|     const_iterator begin()  const; |     const_iterator begin()  const noexcept; | ||||||
|     const_iterator end()    const; |     const_iterator end()    const noexcept; | ||||||
|     const_iterator cbegin() const; |     const_iterator cbegin() const noexcept; | ||||||
|     const_iterator cend()   const; |     const_iterator cend()   const noexcept; | ||||||
|  |  | ||||||
|     template <class... Args> |     template <class... Args> | ||||||
|         pair<iterator, bool> emplace(Args&&... args); |         pair<iterator, bool> emplace(Args&&... args); | ||||||
| @@ -95,9 +109,14 @@ public: | |||||||
|     iterator erase(const_iterator position); |     iterator erase(const_iterator position); | ||||||
|     size_type erase(const key_type& k); |     size_type erase(const key_type& k); | ||||||
|     iterator erase(const_iterator first, const_iterator last); |     iterator erase(const_iterator first, const_iterator last); | ||||||
|     void clear(); |     void clear() noexcept; | ||||||
|  |  | ||||||
|     void swap(unordered_map&); |     void swap(unordered_map&) | ||||||
|  |         noexcept( | ||||||
|  |             (!allocator_type::propagate_on_container_swap::value || | ||||||
|  |              __is_nothrow_swappable<allocator_type>::value) && | ||||||
|  |             __is_nothrow_swappable<hasher>::value && | ||||||
|  |             __is_nothrow_swappable<key_equal>::value); | ||||||
|  |  | ||||||
|     hasher hash_function() const; |     hasher hash_function() const; | ||||||
|     key_equal key_eq() const; |     key_equal key_eq() const; | ||||||
| @@ -114,8 +133,8 @@ public: | |||||||
|     mapped_type&       at(const key_type& k); |     mapped_type&       at(const key_type& k); | ||||||
|     const mapped_type& at(const key_type& k) const; |     const mapped_type& at(const key_type& k) const; | ||||||
|  |  | ||||||
|     size_type bucket_count() const; |     size_type bucket_count() const noexcept; | ||||||
|     size_type max_bucket_count() const; |     size_type max_bucket_count() const noexcept; | ||||||
|  |  | ||||||
|     size_type bucket_size(size_type n) const; |     size_type bucket_size(size_type n) const; | ||||||
|     size_type bucket(const key_type& k) const; |     size_type bucket(const key_type& k) const; | ||||||
| @@ -127,8 +146,8 @@ public: | |||||||
|     const_local_iterator cbegin(size_type n) const; |     const_local_iterator cbegin(size_type n) const; | ||||||
|     const_local_iterator cend(size_type n) const; |     const_local_iterator cend(size_type n) const; | ||||||
|  |  | ||||||
|     float load_factor() const; |     float load_factor() const noexcept; | ||||||
|     float max_load_factor() const; |     float max_load_factor() const noexcept; | ||||||
|     void max_load_factor(float z); |     void max_load_factor(float z); | ||||||
|     void rehash(size_type n); |     void rehash(size_type n); | ||||||
|     void reserve(size_type n); |     void reserve(size_type n); | ||||||
| @@ -136,7 +155,8 @@ public: | |||||||
|  |  | ||||||
| template <class Key, class T, class Hash, class Pred, class Alloc> | template <class Key, class T, class Hash, class Pred, class Alloc> | ||||||
|     void swap(unordered_map<Key, T, Hash, Pred, Alloc>& x, |     void swap(unordered_map<Key, T, Hash, Pred, Alloc>& x, | ||||||
|               unordered_map<Key, T, Hash, Pred, Alloc>& y); |               unordered_map<Key, T, Hash, Pred, Alloc>& y) | ||||||
|  |               noexcept(noexcept(x.swap(y))); | ||||||
|  |  | ||||||
| template <class Key, class T, class Hash, class Pred, class Alloc> | template <class Key, class T, class Hash, class Pred, class Alloc> | ||||||
|     bool |     bool | ||||||
| @@ -172,7 +192,12 @@ public: | |||||||
|     typedef /unspecified/ local_iterator; |     typedef /unspecified/ local_iterator; | ||||||
|     typedef /unspecified/ const_local_iterator; |     typedef /unspecified/ const_local_iterator; | ||||||
|  |  | ||||||
|     explicit unordered_multimap(size_type n = 0, const hasher& hf = hasher(), |     unordered_multimap() | ||||||
|  |         noexcept( | ||||||
|  |             is_nothrow_default_constructible<hasher>::value && | ||||||
|  |             is_nothrow_default_constructible<key_equal>::value && | ||||||
|  |             is_nothrow_default_constructible<allocator_type>::value); | ||||||
|  |     explicit unordered_multimap(size_type n, const hasher& hf = hasher(), | ||||||
|                            const key_equal& eql = key_equal(), |                            const key_equal& eql = key_equal(), | ||||||
|                            const allocator_type& a = allocator_type()); |                            const allocator_type& a = allocator_type()); | ||||||
|     template <class InputIterator> |     template <class InputIterator> | ||||||
| @@ -183,28 +208,37 @@ public: | |||||||
|     explicit unordered_multimap(const allocator_type&); |     explicit unordered_multimap(const allocator_type&); | ||||||
|     unordered_multimap(const unordered_multimap&); |     unordered_multimap(const unordered_multimap&); | ||||||
|     unordered_multimap(const unordered_multimap&, const Allocator&); |     unordered_multimap(const unordered_multimap&, const Allocator&); | ||||||
|     unordered_multimap(unordered_multimap&&); |     unordered_multimap(unordered_multimap&&) | ||||||
|  |         noexcept( | ||||||
|  |             is_nothrow_move_constructible<hasher>::value && | ||||||
|  |             is_nothrow_move_constructible<key_equal>::value && | ||||||
|  |             is_nothrow_move_constructible<allocator_type>::value); | ||||||
|     unordered_multimap(unordered_multimap&&, const Allocator&); |     unordered_multimap(unordered_multimap&&, const Allocator&); | ||||||
|     unordered_multimap(initializer_list<value_type>, size_type n = 0, |     unordered_multimap(initializer_list<value_type>, size_type n = 0, | ||||||
|                   const hasher& hf = hasher(), const key_equal& eql = key_equal(), |                   const hasher& hf = hasher(), const key_equal& eql = key_equal(), | ||||||
|                   const allocator_type& a = allocator_type()); |                   const allocator_type& a = allocator_type()); | ||||||
|     ~unordered_multimap(); |     ~unordered_multimap(); | ||||||
|     unordered_multimap& operator=(const unordered_multimap&); |     unordered_multimap& operator=(const unordered_multimap&); | ||||||
|     unordered_multimap& operator=(unordered_multimap&&); |     unordered_multimap& operator=(unordered_multimap&&) | ||||||
|  |         noexcept( | ||||||
|  |             allocator_type::propagate_on_container_move_assignment::value && | ||||||
|  |             is_nothrow_move_assignable<allocator_type>::value && | ||||||
|  |             is_nothrow_move_assignable<hasher>::value && | ||||||
|  |             is_nothrow_move_assignable<key_equal>::value); | ||||||
|     unordered_multimap& operator=(initializer_list<value_type>); |     unordered_multimap& operator=(initializer_list<value_type>); | ||||||
|  |  | ||||||
|     allocator_type get_allocator() const; |     allocator_type get_allocator() const noexcept; | ||||||
|  |  | ||||||
|     bool      empty() const; |     bool      empty() const noexcept; | ||||||
|     size_type size() const; |     size_type size() const noexcept; | ||||||
|     size_type max_size() const; |     size_type max_size() const noexcept; | ||||||
|  |  | ||||||
|     iterator       begin(); |     iterator       begin() noexcept; | ||||||
|     iterator       end(); |     iterator       end() noexcept; | ||||||
|     const_iterator begin()  const; |     const_iterator begin()  const noexcept; | ||||||
|     const_iterator end()    const; |     const_iterator end()    const noexcept; | ||||||
|     const_iterator cbegin() const; |     const_iterator cbegin() const noexcept; | ||||||
|     const_iterator cend()   const; |     const_iterator cend()   const noexcept; | ||||||
|  |  | ||||||
|     template <class... Args> |     template <class... Args> | ||||||
|         iterator emplace(Args&&... args); |         iterator emplace(Args&&... args); | ||||||
| @@ -223,9 +257,14 @@ public: | |||||||
|     iterator erase(const_iterator position); |     iterator erase(const_iterator position); | ||||||
|     size_type erase(const key_type& k); |     size_type erase(const key_type& k); | ||||||
|     iterator erase(const_iterator first, const_iterator last); |     iterator erase(const_iterator first, const_iterator last); | ||||||
|     void clear(); |     void clear() noexcept; | ||||||
|  |  | ||||||
|     void swap(unordered_multimap&); |     void swap(unordered_multimap&) | ||||||
|  |         noexcept( | ||||||
|  |             (!allocator_type::propagate_on_container_swap::value || | ||||||
|  |              __is_nothrow_swappable<allocator_type>::value) && | ||||||
|  |             __is_nothrow_swappable<hasher>::value && | ||||||
|  |             __is_nothrow_swappable<key_equal>::value); | ||||||
|  |  | ||||||
|     hasher hash_function() const; |     hasher hash_function() const; | ||||||
|     key_equal key_eq() const; |     key_equal key_eq() const; | ||||||
| @@ -236,8 +275,8 @@ public: | |||||||
|     pair<iterator, iterator>             equal_range(const key_type& k); |     pair<iterator, iterator>             equal_range(const key_type& k); | ||||||
|     pair<const_iterator, const_iterator> equal_range(const key_type& k) const; |     pair<const_iterator, const_iterator> equal_range(const key_type& k) const; | ||||||
|  |  | ||||||
|     size_type bucket_count() const; |     size_type bucket_count() const noexcept; | ||||||
|     size_type max_bucket_count() const; |     size_type max_bucket_count() const noexcept; | ||||||
|  |  | ||||||
|     size_type bucket_size(size_type n) const; |     size_type bucket_size(size_type n) const; | ||||||
|     size_type bucket(const key_type& k) const; |     size_type bucket(const key_type& k) const; | ||||||
| @@ -249,8 +288,8 @@ public: | |||||||
|     const_local_iterator cbegin(size_type n) const; |     const_local_iterator cbegin(size_type n) const; | ||||||
|     const_local_iterator cend(size_type n) const; |     const_local_iterator cend(size_type n) const; | ||||||
|  |  | ||||||
|     float load_factor() const; |     float load_factor() const noexcept; | ||||||
|     float max_load_factor() const; |     float max_load_factor() const noexcept; | ||||||
|     void max_load_factor(float z); |     void max_load_factor(float z); | ||||||
|     void rehash(size_type n); |     void rehash(size_type n); | ||||||
|     void reserve(size_type n); |     void reserve(size_type n); | ||||||
| @@ -258,7 +297,8 @@ public: | |||||||
|  |  | ||||||
| template <class Key, class T, class Hash, class Pred, class Alloc> | template <class Key, class T, class Hash, class Pred, class Alloc> | ||||||
|     void swap(unordered_multimap<Key, T, Hash, Pred, Alloc>& x, |     void swap(unordered_multimap<Key, T, Hash, Pred, Alloc>& x, | ||||||
|               unordered_multimap<Key, T, Hash, Pred, Alloc>& y); |               unordered_multimap<Key, T, Hash, Pred, Alloc>& y) | ||||||
|  |               noexcept(noexcept(x.swap(y))); | ||||||
|  |  | ||||||
| template <class Key, class T, class Hash, class Pred, class Alloc> | template <class Key, class T, class Hash, class Pred, class Alloc> | ||||||
|     bool |     bool | ||||||
| @@ -289,11 +329,15 @@ class __unordered_map_hasher | |||||||
| { | { | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __unordered_map_hasher() : _Hash() {} |     __unordered_map_hasher() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<_Hash>::value) | ||||||
|  |         : _Hash() {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __unordered_map_hasher(const _Hash& __h) : _Hash(__h) {} |     __unordered_map_hasher(const _Hash& __h) | ||||||
|  |         _NOEXCEPT_(is_nothrow_copy_constructible<_Hash>::value) | ||||||
|  |         : _Hash(__h) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const _Hash& hash_function() const {return *this;} |     const _Hash& hash_function() const _NOEXCEPT {return *this;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(const _Tp& __x) const |     size_t operator()(const _Tp& __x) const | ||||||
|         {return static_cast<const _Hash&>(*this)(__x.first);} |         {return static_cast<const _Hash&>(*this)(__x.first);} | ||||||
| @@ -308,11 +352,15 @@ class __unordered_map_hasher<_Tp, _Hash, false> | |||||||
|     _Hash __hash_; |     _Hash __hash_; | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __unordered_map_hasher() : __hash_() {} |     __unordered_map_hasher() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<_Hash>::value) | ||||||
|  |         : __hash_() {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __unordered_map_hasher(const _Hash& __h) : __hash_(__h) {} |     __unordered_map_hasher(const _Hash& __h) | ||||||
|  |         _NOEXCEPT_(is_nothrow_copy_constructible<_Hash>::value) | ||||||
|  |         : __hash_(__h) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const _Hash& hash_function() const {return __hash_;} |     const _Hash& hash_function() const _NOEXCEPT {return __hash_;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_t operator()(const _Tp& __x) const |     size_t operator()(const _Tp& __x) const | ||||||
|         {return __hash_(__x.first);} |         {return __hash_(__x.first);} | ||||||
| @@ -327,11 +375,15 @@ class __unordered_map_equal | |||||||
| { | { | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __unordered_map_equal() : _Pred() {} |     __unordered_map_equal() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<_Pred>::value) | ||||||
|  |         : _Pred() {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __unordered_map_equal(const _Pred& __p) : _Pred(__p) {} |     __unordered_map_equal(const _Pred& __p) | ||||||
|  |         _NOEXCEPT_(is_nothrow_copy_constructible<_Pred>::value) | ||||||
|  |         : _Pred(__p) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const _Pred& key_eq() const {return *this;} |     const _Pred& key_eq() const _NOEXCEPT {return *this;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool operator()(const _Tp& __x, const _Tp& __y) const |     bool operator()(const _Tp& __x, const _Tp& __y) const | ||||||
|         {return static_cast<const _Pred&>(*this)(__x.first, __y.first);} |         {return static_cast<const _Pred&>(*this)(__x.first, __y.first);} | ||||||
| @@ -353,11 +405,15 @@ class __unordered_map_equal<_Tp, _Pred, false> | |||||||
|     _Pred __pred_; |     _Pred __pred_; | ||||||
| public: | public: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __unordered_map_equal() : __pred_() {} |     __unordered_map_equal() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<_Pred>::value) | ||||||
|  |         : __pred_() {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __unordered_map_equal(const _Pred& __p) : __pred_(__p) {} |     __unordered_map_equal(const _Pred& __p) | ||||||
|  |         _NOEXCEPT_(is_nothrow_copy_constructible<_Pred>::value) | ||||||
|  |         : __pred_(__p) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const _Pred& key_eq() const {return __pred_;} |     const _Pred& key_eq() const _NOEXCEPT {return __pred_;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool operator()(const _Tp& __x, const _Tp& __y) const |     bool operator()(const _Tp& __x, const _Tp& __y) const | ||||||
|         {return __pred_(__x.first, __y.first);} |         {return __pred_(__x.first, __y.first);} | ||||||
| @@ -394,7 +450,7 @@ public: | |||||||
|     bool __second_constructed; |     bool __second_constructed; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     explicit __hash_map_node_destructor(allocator_type& __na) |     explicit __hash_map_node_destructor(allocator_type& __na) _NOEXCEPT | ||||||
|         : __na_(__na), |         : __na_(__na), | ||||||
|           __first_constructed(false), |           __first_constructed(false), | ||||||
|           __second_constructed(false) |           __second_constructed(false) | ||||||
| @@ -403,6 +459,7 @@ public: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __hash_map_node_destructor(__hash_node_destructor<allocator_type>&& __x) |     __hash_map_node_destructor(__hash_node_destructor<allocator_type>&& __x) | ||||||
|  |         _NOEXCEPT | ||||||
|         : __na_(__x.__na_), |         : __na_(__x.__na_), | ||||||
|           __first_constructed(__x.__value_constructed), |           __first_constructed(__x.__value_constructed), | ||||||
|           __second_constructed(__x.__value_constructed) |           __second_constructed(__x.__value_constructed) | ||||||
| @@ -421,12 +478,12 @@ public: | |||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void operator()(pointer __p) |     void operator()(pointer __p) _NOEXCEPT | ||||||
|     { |     { | ||||||
|         if (__second_constructed) |         if (__second_constructed) | ||||||
|             __alloc_traits::destroy(__na_, _STD::addressof(__p->__value_.second)); |             __alloc_traits::destroy(__na_, _VSTD::addressof(__p->__value_.second)); | ||||||
|         if (__first_constructed) |         if (__first_constructed) | ||||||
|             __alloc_traits::destroy(__na_, _STD::addressof(__p->__value_.first)); |             __alloc_traits::destroy(__na_, _VSTD::addressof(__p->__value_.first)); | ||||||
|         if (__p) |         if (__p) | ||||||
|             __alloc_traits::deallocate(__na_, __p, 1); |             __alloc_traits::deallocate(__na_, __p, 1); | ||||||
|     } |     } | ||||||
| @@ -454,10 +511,10 @@ public: | |||||||
|                                                                  pointer; |                                                                  pointer; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __hash_map_iterator() {} |     __hash_map_iterator() _NOEXCEPT {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __hash_map_iterator(_HashIterator __i) : __i_(__i) {} |     __hash_map_iterator(_HashIterator __i) _NOEXCEPT : __i_(__i) {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     reference operator*() const {return *operator->();} |     reference operator*() const {return *operator->();} | ||||||
| @@ -503,20 +560,21 @@ public: | |||||||
|     typedef const value_type&                                    reference; |     typedef const value_type&                                    reference; | ||||||
|     typedef typename __pointer_traits::template |     typedef typename __pointer_traits::template | ||||||
| #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES | #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||||
|             rebind<value_type> |             rebind<const value_type> | ||||||
| #else | #else | ||||||
|             rebind<value_type>::other |             rebind<const value_type>::other | ||||||
| #endif | #endif | ||||||
|                                                                  pointer; |                                                                  pointer; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __hash_map_const_iterator() {} |     __hash_map_const_iterator() _NOEXCEPT {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __hash_map_const_iterator(_HashIterator __i) : __i_(__i) {} |     __hash_map_const_iterator(_HashIterator __i) _NOEXCEPT : __i_(__i) {} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     __hash_map_const_iterator( |     __hash_map_const_iterator( | ||||||
|             __hash_map_iterator<typename _HashIterator::__non_const_iterator> __i) |             __hash_map_iterator<typename _HashIterator::__non_const_iterator> __i) | ||||||
|  |                  _NOEXCEPT | ||||||
|                 : __i_(__i.__i_) {} |                 : __i_(__i.__i_) {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -599,7 +657,9 @@ public: | |||||||
|     typedef __hash_map_const_iterator<typename __table::const_local_iterator> const_local_iterator; |     typedef __hash_map_const_iterator<typename __table::const_local_iterator> const_local_iterator; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     unordered_map() {} // = default; |     unordered_map() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<__table>::value) | ||||||
|  |         {} // = default; | ||||||
|     explicit unordered_map(size_type __n, const hasher& __hf = hasher(), |     explicit unordered_map(size_type __n, const hasher& __hf = hasher(), | ||||||
|                            const key_equal& __eql = key_equal()); |                            const key_equal& __eql = key_equal()); | ||||||
|     unordered_map(size_type __n, const hasher& __hf, |     unordered_map(size_type __n, const hasher& __hf, | ||||||
| @@ -620,7 +680,8 @@ public: | |||||||
|     unordered_map(const unordered_map& __u); |     unordered_map(const unordered_map& __u); | ||||||
|     unordered_map(const unordered_map& __u, const allocator_type& __a); |     unordered_map(const unordered_map& __u, const allocator_type& __a); | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     unordered_map(unordered_map&& __u); |     unordered_map(unordered_map&& __u) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_constructible<__table>::value); | ||||||
|     unordered_map(unordered_map&& __u, const allocator_type& __a); |     unordered_map(unordered_map&& __u, const allocator_type& __a); | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     unordered_map(initializer_list<value_type> __il); |     unordered_map(initializer_list<value_type> __il); | ||||||
| @@ -630,35 +691,41 @@ public: | |||||||
|                   const hasher& __hf, const key_equal& __eql, |                   const hasher& __hf, const key_equal& __eql, | ||||||
|                   const allocator_type& __a); |                   const allocator_type& __a); | ||||||
|     // ~unordered_map() = default; |     // ~unordered_map() = default; | ||||||
|     // unordered_map& operator=(const unordered_map& __u) = default; |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     unordered_map& operator=(const unordered_map& __u) | ||||||
|  |     { | ||||||
|  |         __table_ = __u.__table_; | ||||||
|  |         return *this; | ||||||
|  |     } | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     unordered_map& operator=(unordered_map&& __u); |     unordered_map& operator=(unordered_map&& __u) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_assignable<__table>::value); | ||||||
| #endif | #endif | ||||||
|     unordered_map& operator=(initializer_list<value_type> __il); |     unordered_map& operator=(initializer_list<value_type> __il); | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     allocator_type get_allocator() const |     allocator_type get_allocator() const _NOEXCEPT | ||||||
|         {return allocator_type(__table_.__node_alloc());} |         {return allocator_type(__table_.__node_alloc());} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool      empty() const {return __table_.size() == 0;} |     bool      empty() const _NOEXCEPT {return __table_.size() == 0;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type size() const  {return __table_.size();} |     size_type size() const _NOEXCEPT  {return __table_.size();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type max_size() const {return __table_.max_size();} |     size_type max_size() const _NOEXCEPT {return __table_.max_size();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator       begin()        {return __table_.begin();} |     iterator       begin() _NOEXCEPT        {return __table_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator       end()          {return __table_.end();} |     iterator       end() _NOEXCEPT          {return __table_.end();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator begin()  const {return __table_.begin();} |     const_iterator begin()  const _NOEXCEPT {return __table_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator end()    const {return __table_.end();} |     const_iterator end()    const _NOEXCEPT {return __table_.end();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator cbegin() const {return __table_.begin();} |     const_iterator cbegin() const _NOEXCEPT {return __table_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator cend()   const {return __table_.end();} |     const_iterator cend()   const _NOEXCEPT {return __table_.end();} | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -666,15 +733,15 @@ public: | |||||||
|         {return __table_.__emplace_unique();} |         {return __table_.__emplace_unique();} | ||||||
|  |  | ||||||
|     template <class _A0, |     template <class _A0, | ||||||
|               class = typename enable_if<is_convertible<_A0, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _A0>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         pair<iterator, bool> emplace(_A0&& __a0) |         pair<iterator, bool> emplace(_A0&& __a0) | ||||||
|             {return __table_.__emplace_unique(_STD::forward<_A0>(__a0));} |             {return __table_.__emplace_unique(_VSTD::forward<_A0>(__a0));} | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
|  |  | ||||||
|     template <class _A0, class... _Args, |     template <class _A0, class... _Args, | ||||||
|               class = typename enable_if<is_convertible<_A0, key_type>::value>::type> |               class = typename enable_if<is_constructible<key_type, _A0>::value>::type> | ||||||
|         pair<iterator, bool> emplace(_A0&& __a0, _Args&&... __args); |         pair<iterator, bool> emplace(_A0&& __a0, _Args&&... __args); | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||||
| @@ -684,19 +751,19 @@ public: | |||||||
|         {return __table_.__emplace_unique().first;} |         {return __table_.__emplace_unique().first;} | ||||||
|  |  | ||||||
|     template <class _A0, |     template <class _A0, | ||||||
|               class = typename enable_if<is_convertible<_A0, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _A0>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator emplace_hint(const_iterator, _A0&& __a0) |         iterator emplace_hint(const_iterator, _A0&& __a0) | ||||||
|             {return __table_.__emplace_unique(_STD::forward<_A0>(__a0)).first;} |             {return __table_.__emplace_unique(_VSTD::forward<_A0>(__a0)).first;} | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
|  |  | ||||||
|     template <class _A0, class... _Args, |     template <class _A0, class... _Args, | ||||||
|               class = typename enable_if<is_convertible<_A0, key_type>::value>::type> |               class = typename enable_if<is_constructible<key_type, _A0>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator emplace_hint(const_iterator, _A0&& __a0, _Args&&... __args) |         iterator emplace_hint(const_iterator, _A0&& __a0, _Args&&... __args) | ||||||
|             {return emplace(_STD::forward<_A0>(__a0), |             {return emplace(_VSTD::forward<_A0>(__a0), | ||||||
|                             _STD::forward<_Args>(__args)...).first;} |                             _VSTD::forward<_Args>(__args)...).first;} | ||||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -704,20 +771,20 @@ public: | |||||||
|         {return __table_.__insert_unique(__x);} |         {return __table_.__insert_unique(__x);} | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     template <class _P, |     template <class _P, | ||||||
|               class = typename enable_if<is_convertible<_P, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _P>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         pair<iterator, bool> insert(_P&& __x) |         pair<iterator, bool> insert(_P&& __x) | ||||||
|             {return __table_.__insert_unique(_STD::forward<_P>(__x));} |             {return __table_.__insert_unique(_VSTD::forward<_P>(__x));} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator insert(const_iterator, const value_type& __x) |     iterator insert(const_iterator, const value_type& __x) | ||||||
|         {return insert(__x).first;} |         {return insert(__x).first;} | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     template <class _P, |     template <class _P, | ||||||
|               class = typename enable_if<is_convertible<_P, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _P>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator insert(const_iterator, _P&& __x) |         iterator insert(const_iterator, _P&& __x) | ||||||
|             {return insert(_STD::forward<_P>(__x)).first;} |             {return insert(_VSTD::forward<_P>(__x)).first;} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     template <class _InputIterator> |     template <class _InputIterator> | ||||||
|         void insert(_InputIterator __first, _InputIterator __last); |         void insert(_InputIterator __first, _InputIterator __last); | ||||||
| @@ -733,10 +800,12 @@ public: | |||||||
|     iterator erase(const_iterator __first, const_iterator __last) |     iterator erase(const_iterator __first, const_iterator __last) | ||||||
|         {return __table_.erase(__first.__i_, __last.__i_);} |         {return __table_.erase(__first.__i_, __last.__i_);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void clear() {__table_.clear();} |     void clear() _NOEXCEPT {__table_.clear();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(unordered_map& __u) {__table_.swap(__u.__table_);} |     void swap(unordered_map& __u) | ||||||
|  |         _NOEXCEPT_(__is_nothrow_swappable<__table>::value) | ||||||
|  |         {__table_.swap(__u.__table_);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     hasher hash_function() const |     hasher hash_function() const | ||||||
| @@ -767,9 +836,9 @@ public: | |||||||
|     const mapped_type& at(const key_type& __k) const; |     const mapped_type& at(const key_type& __k) const; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type bucket_count() const {return __table_.bucket_count();} |     size_type bucket_count() const _NOEXCEPT {return __table_.bucket_count();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type max_bucket_count() const {return __table_.max_bucket_count();} |     size_type max_bucket_count() const _NOEXCEPT {return __table_.max_bucket_count();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type bucket_size(size_type __n) const |     size_type bucket_size(size_type __n) const | ||||||
| @@ -791,9 +860,9 @@ public: | |||||||
|     const_local_iterator cend(size_type __n) const   {return __table_.cend(__n);} |     const_local_iterator cend(size_type __n) const   {return __table_.cend(__n);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     float load_factor() const {return __table_.load_factor();} |     float load_factor() const _NOEXCEPT {return __table_.load_factor();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     float max_load_factor() const {return __table_.max_load_factor();} |     float max_load_factor() const _NOEXCEPT {return __table_.max_load_factor();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void max_load_factor(float __mlf) {__table_.max_load_factor(__mlf);} |     void max_load_factor(float __mlf) {__table_.max_load_factor(__mlf);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -805,11 +874,11 @@ private: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
|     template <class _A0, class... _Args, |     template <class _A0, class... _Args, | ||||||
|               class = typename enable_if<is_convertible<_A0, key_type>::value>::type> |               class = typename enable_if<is_constructible<key_type, _A0>::value>::type> | ||||||
|         __node_holder __construct_node(_A0&& __a0, _Args&&... __args); |         __node_holder __construct_node(_A0&& __a0, _Args&&... __args); | ||||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||||
|     template <class _A0, |     template <class _A0, | ||||||
|               class = typename enable_if<is_convertible<_A0, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _A0>::value>::type> | ||||||
|         __node_holder __construct_node(_A0&& __a0); |         __node_holder __construct_node(_A0&& __a0); | ||||||
| #else  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #else  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     __node_holder __construct_node(const key_type& __k); |     __node_holder __construct_node(const key_type& __k); | ||||||
| @@ -895,21 +964,22 @@ template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::unordered_map( | unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::unordered_map( | ||||||
|         unordered_map&& __u) |         unordered_map&& __u) | ||||||
|     : __table_(_STD::move(__u.__table_)) |     _NOEXCEPT_(is_nothrow_move_constructible<__table>::value) | ||||||
|  |     : __table_(_VSTD::move(__u.__table_)) | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | ||||||
| unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::unordered_map( | unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::unordered_map( | ||||||
|         unordered_map&& __u, const allocator_type& __a) |         unordered_map&& __u, const allocator_type& __a) | ||||||
|     : __table_(_STD::move(__u.__table_), __a) |     : __table_(_VSTD::move(__u.__table_), __a) | ||||||
| { | { | ||||||
|     if (__a != __u.get_allocator()) |     if (__a != __u.get_allocator()) | ||||||
|     { |     { | ||||||
|         iterator __i = __u.begin(); |         iterator __i = __u.begin(); | ||||||
|         while (__u.size() != 0) |         while (__u.size() != 0) | ||||||
|             __table_.__insert_unique( |             __table_.__insert_unique( | ||||||
|                 _STD::move(__u.__table_.remove((__i++).__i_)->__value_) |                 _VSTD::move(__u.__table_.remove((__i++).__i_)->__value_) | ||||||
|                                     ); |                                     ); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -949,8 +1019,9 @@ template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>& | unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>& | ||||||
| unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::operator=(unordered_map&& __u) | unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::operator=(unordered_map&& __u) | ||||||
|  |     _NOEXCEPT_(is_nothrow_move_assignable<__table>::value) | ||||||
| { | { | ||||||
|     __table_ = _STD::move(__u.__table_); |     __table_ = _VSTD::move(__u.__table_); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -971,7 +1042,7 @@ unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::operator=( | |||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | ||||||
| template <class _A0, class... _Args, | template <class _A0, class... _Args, | ||||||
|           class // = typename enable_if<is_convertible<_A0, key_type>::value>::type |           class // = typename enable_if<is_constructible<key_type, _A0>::value>::type | ||||||
|          > |          > | ||||||
| typename unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::__node_holder | typename unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::__node_holder | ||||||
| unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::__construct_node(_A0&& __a0, | unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::__construct_node(_A0&& __a0, | ||||||
| @@ -979,11 +1050,11 @@ unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::__construct_node(_A0&& __a0, | |||||||
| { | { | ||||||
|     __node_allocator& __na = __table_.__node_alloc(); |     __node_allocator& __na = __table_.__node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.first), |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.first), | ||||||
|                              _STD::forward<_A0>(__a0)); |                              _VSTD::forward<_A0>(__a0)); | ||||||
|     __h.get_deleter().__first_constructed = true; |     __h.get_deleter().__first_constructed = true; | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.second), |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.second), | ||||||
|                              _STD::forward<_Args>(__args)...); |                              _VSTD::forward<_Args>(__args)...); | ||||||
|     __h.get_deleter().__second_constructed = true; |     __h.get_deleter().__second_constructed = true; | ||||||
|     return __h; |     return __h; | ||||||
| } | } | ||||||
| @@ -992,15 +1063,15 @@ unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::__construct_node(_A0&& __a0, | |||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | ||||||
| template <class _A0, | template <class _A0, | ||||||
|           class // = typename enable_if<is_convertible<_A0, value_type>::value>::type |           class // = typename enable_if<is_constructible<value_type, _A0>::value>::type | ||||||
|          > |          > | ||||||
| typename unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::__node_holder | typename unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::__node_holder | ||||||
| unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::__construct_node(_A0&& __a0) | unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::__construct_node(_A0&& __a0) | ||||||
| { | { | ||||||
|     __node_allocator& __na = __table_.__node_alloc(); |     __node_allocator& __na = __table_.__node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_), |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_), | ||||||
|                              _STD::forward<_A0>(__a0)); |                              _VSTD::forward<_A0>(__a0)); | ||||||
|     __h.get_deleter().__first_constructed = true; |     __h.get_deleter().__first_constructed = true; | ||||||
|     __h.get_deleter().__second_constructed = true; |     __h.get_deleter().__second_constructed = true; | ||||||
|     return __h; |     return __h; | ||||||
| @@ -1010,13 +1081,13 @@ unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::__construct_node(_A0&& __a0) | |||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | ||||||
| template <class _A0, class... _Args, | template <class _A0, class... _Args, | ||||||
|           class // = typename enable_if<is_convertible<_A0, key_type>::value>::type |           class // = typename enable_if<is_constructible<key_type, _A0>::value>::type | ||||||
|          > |          > | ||||||
| pair<typename unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::iterator, bool> | pair<typename unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::iterator, bool> | ||||||
| unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::emplace(_A0&& __a0, _Args&&... __args) | unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::emplace(_A0&& __a0, _Args&&... __args) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_A0>(__a0), |     __node_holder __h = __construct_node(_VSTD::forward<_A0>(__a0), | ||||||
|                                          _STD::forward<_Args>(__args)...); |                                          _VSTD::forward<_Args>(__args)...); | ||||||
|     pair<iterator, bool> __r = __table_.__node_insert_unique(__h.get()); |     pair<iterator, bool> __r = __table_.__node_insert_unique(__h.get()); | ||||||
|     if (__r.second) |     if (__r.second) | ||||||
|         __h.release(); |         __h.release(); | ||||||
| @@ -1032,11 +1103,11 @@ unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::__construct_node(const key_type& | |||||||
| { | { | ||||||
|     __node_allocator& __na = __table_.__node_alloc(); |     __node_allocator& __na = __table_.__node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.first), __k); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.first), __k); | ||||||
|     __h.get_deleter().__first_constructed = true; |     __h.get_deleter().__first_constructed = true; | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.second)); |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.second)); | ||||||
|     __h.get_deleter().__second_constructed = true; |     __h.get_deleter().__second_constructed = true; | ||||||
|     return _STD::move(__h); |     return _VSTD::move(__h); | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -1074,7 +1145,7 @@ unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::operator[](key_type&& __k) | |||||||
|     iterator __i = find(__k); |     iterator __i = find(__k); | ||||||
|     if (__i != end()) |     if (__i != end()) | ||||||
|         return __i->second; |         return __i->second; | ||||||
|     __node_holder __h = __construct_node(_STD::move(__k)); |     __node_holder __h = __construct_node(_VSTD::move(__k)); | ||||||
|     pair<iterator, bool> __r = __table_.__node_insert_unique(__h.get()); |     pair<iterator, bool> __r = __table_.__node_insert_unique(__h.get()); | ||||||
|     __h.release(); |     __h.release(); | ||||||
|     return __r.first->second; |     return __r.first->second; | ||||||
| @@ -1111,6 +1182,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| void | void | ||||||
| swap(unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>& __x, | swap(unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>& __x, | ||||||
|      unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>& __y) |      unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>& __y) | ||||||
|  |     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||||
| { | { | ||||||
|     __x.swap(__y); |     __x.swap(__y); | ||||||
| } | } | ||||||
| @@ -1193,7 +1265,9 @@ public: | |||||||
|     typedef __hash_map_const_iterator<typename __table::const_local_iterator> const_local_iterator; |     typedef __hash_map_const_iterator<typename __table::const_local_iterator> const_local_iterator; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     unordered_multimap() {} // = default |     unordered_multimap() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<__table>::value) | ||||||
|  |         {} // = default; | ||||||
|     explicit unordered_multimap(size_type __n, const hasher& __hf = hasher(), |     explicit unordered_multimap(size_type __n, const hasher& __hf = hasher(), | ||||||
|                                 const key_equal& __eql = key_equal()); |                                 const key_equal& __eql = key_equal()); | ||||||
|     unordered_multimap(size_type __n, const hasher& __hf, |     unordered_multimap(size_type __n, const hasher& __hf, | ||||||
| @@ -1214,7 +1288,8 @@ public: | |||||||
|     unordered_multimap(const unordered_multimap& __u); |     unordered_multimap(const unordered_multimap& __u); | ||||||
|     unordered_multimap(const unordered_multimap& __u, const allocator_type& __a); |     unordered_multimap(const unordered_multimap& __u, const allocator_type& __a); | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     unordered_multimap(unordered_multimap&& __u); |     unordered_multimap(unordered_multimap&& __u) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_constructible<__table>::value); | ||||||
|     unordered_multimap(unordered_multimap&& __u, const allocator_type& __a); |     unordered_multimap(unordered_multimap&& __u, const allocator_type& __a); | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     unordered_multimap(initializer_list<value_type> __il); |     unordered_multimap(initializer_list<value_type> __il); | ||||||
| @@ -1225,35 +1300,41 @@ public: | |||||||
|                        const hasher& __hf, const key_equal& __eql, |                        const hasher& __hf, const key_equal& __eql, | ||||||
|                        const allocator_type& __a); |                        const allocator_type& __a); | ||||||
|     // ~unordered_multimap() = default; |     // ~unordered_multimap() = default; | ||||||
|     // unordered_multimap& operator=(const unordered_multimap& __u) = default; |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     unordered_multimap& operator=(const unordered_multimap& __u) | ||||||
|  |     { | ||||||
|  |         __table_ = __u.__table_; | ||||||
|  |         return *this; | ||||||
|  |     } | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     unordered_multimap& operator=(unordered_multimap&& __u); |     unordered_multimap& operator=(unordered_multimap&& __u) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_assignable<__table>::value); | ||||||
| #endif | #endif | ||||||
|     unordered_multimap& operator=(initializer_list<value_type> __il); |     unordered_multimap& operator=(initializer_list<value_type> __il); | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     allocator_type get_allocator() const |     allocator_type get_allocator() const _NOEXCEPT | ||||||
|         {return allocator_type(__table_.__node_alloc());} |         {return allocator_type(__table_.__node_alloc());} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool      empty() const {return __table_.size() == 0;} |     bool      empty() const _NOEXCEPT {return __table_.size() == 0;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type size() const  {return __table_.size();} |     size_type size() const _NOEXCEPT  {return __table_.size();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type max_size() const {return __table_.max_size();} |     size_type max_size() const _NOEXCEPT {return __table_.max_size();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator       begin()        {return __table_.begin();} |     iterator       begin() _NOEXCEPT        {return __table_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator       end()          {return __table_.end();} |     iterator       end() _NOEXCEPT          {return __table_.end();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator begin()  const {return __table_.begin();} |     const_iterator begin()  const _NOEXCEPT {return __table_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator end()    const {return __table_.end();} |     const_iterator end()    const _NOEXCEPT {return __table_.end();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator cbegin() const {return __table_.begin();} |     const_iterator cbegin() const _NOEXCEPT {return __table_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator cend()   const {return __table_.end();} |     const_iterator cend()   const _NOEXCEPT {return __table_.end();} | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -1261,15 +1342,15 @@ public: | |||||||
|         {return __table_.__emplace_multi();} |         {return __table_.__emplace_multi();} | ||||||
|  |  | ||||||
|     template <class _A0, |     template <class _A0, | ||||||
|               class = typename enable_if<is_convertible<_A0, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _A0>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator emplace(_A0&& __a0) |         iterator emplace(_A0&& __a0) | ||||||
|             {return __table_.__emplace_multi(_STD::forward<_A0>(__a0));} |             {return __table_.__emplace_multi(_VSTD::forward<_A0>(__a0));} | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
|  |  | ||||||
|     template <class _A0, class... _Args, |     template <class _A0, class... _Args, | ||||||
|               class = typename enable_if<is_convertible<_A0, key_type>::value>::type> |               class = typename enable_if<is_constructible<key_type, _A0>::value>::type> | ||||||
|         iterator emplace(_A0&& __a0, _Args&&... __args); |         iterator emplace(_A0&& __a0, _Args&&... __args); | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||||
| @@ -1279,15 +1360,15 @@ public: | |||||||
|         {return __table_.__emplace_hint_multi(__p.__i_);} |         {return __table_.__emplace_hint_multi(__p.__i_);} | ||||||
|  |  | ||||||
|     template <class _A0, |     template <class _A0, | ||||||
|               class = typename enable_if<is_convertible<_A0, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _A0>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator emplace_hint(const_iterator __p, _A0&& __a0) |         iterator emplace_hint(const_iterator __p, _A0&& __a0) | ||||||
|             {return __table_.__emplace_hint_multi(__p.__i_, _STD::forward<_A0>(__a0));} |             {return __table_.__emplace_hint_multi(__p.__i_, _VSTD::forward<_A0>(__a0));} | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
|  |  | ||||||
|     template <class _A0, class... _Args, |     template <class _A0, class... _Args, | ||||||
|               class = typename enable_if<is_convertible<_A0, key_type>::value>::type> |               class = typename enable_if<is_constructible<key_type, _A0>::value>::type> | ||||||
|         iterator emplace_hint(const_iterator __p, _A0&& __a0, _Args&&... __args); |         iterator emplace_hint(const_iterator __p, _A0&& __a0, _Args&&... __args); | ||||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -1295,20 +1376,20 @@ public: | |||||||
|     iterator insert(const value_type& __x) {return __table_.__insert_multi(__x);} |     iterator insert(const value_type& __x) {return __table_.__insert_multi(__x);} | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     template <class _P, |     template <class _P, | ||||||
|               class = typename enable_if<is_convertible<_P, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _P>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator insert(_P&& __x) |         iterator insert(_P&& __x) | ||||||
|             {return __table_.__insert_multi(_STD::forward<_P>(__x));} |             {return __table_.__insert_multi(_VSTD::forward<_P>(__x));} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator insert(const_iterator __p, const value_type& __x) |     iterator insert(const_iterator __p, const value_type& __x) | ||||||
|         {return __table_.__insert_multi(__p.__i_, __x);} |         {return __table_.__insert_multi(__p.__i_, __x);} | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     template <class _P, |     template <class _P, | ||||||
|               class = typename enable_if<is_convertible<_P, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _P>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator insert(const_iterator __p, _P&& __x) |         iterator insert(const_iterator __p, _P&& __x) | ||||||
|             {return __table_.__insert_multi(__p.__i_, _STD::forward<_P>(__x));} |             {return __table_.__insert_multi(__p.__i_, _VSTD::forward<_P>(__x));} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     template <class _InputIterator> |     template <class _InputIterator> | ||||||
|         void insert(_InputIterator __first, _InputIterator __last); |         void insert(_InputIterator __first, _InputIterator __last); | ||||||
| @@ -1324,10 +1405,12 @@ public: | |||||||
|     iterator erase(const_iterator __first, const_iterator __last) |     iterator erase(const_iterator __first, const_iterator __last) | ||||||
|         {return __table_.erase(__first.__i_, __last.__i_);} |         {return __table_.erase(__first.__i_, __last.__i_);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void clear() {__table_.clear();} |     void clear() _NOEXCEPT {__table_.clear();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(unordered_multimap& __u) {__table_.swap(__u.__table_);} |     void swap(unordered_multimap& __u) | ||||||
|  |         _NOEXCEPT_(__is_nothrow_swappable<__table>::value) | ||||||
|  |         {__table_.swap(__u.__table_);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     hasher hash_function() const |     hasher hash_function() const | ||||||
| @@ -1350,9 +1433,10 @@ public: | |||||||
|         {return __table_.__equal_range_multi(__k);} |         {return __table_.__equal_range_multi(__k);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type bucket_count() const {return __table_.bucket_count();} |     size_type bucket_count() const _NOEXCEPT {return __table_.bucket_count();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type max_bucket_count() const {return __table_.max_bucket_count();} |     size_type max_bucket_count() const _NOEXCEPT | ||||||
|  |         {return __table_.max_bucket_count();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type bucket_size(size_type __n) const |     size_type bucket_size(size_type __n) const | ||||||
| @@ -1374,9 +1458,9 @@ public: | |||||||
|     const_local_iterator cend(size_type __n) const   {return __table_.cend(__n);} |     const_local_iterator cend(size_type __n) const   {return __table_.cend(__n);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     float load_factor() const {return __table_.load_factor();} |     float load_factor() const _NOEXCEPT {return __table_.load_factor();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     float max_load_factor() const {return __table_.max_load_factor();} |     float max_load_factor() const _NOEXCEPT {return __table_.max_load_factor();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void max_load_factor(float __mlf) {__table_.max_load_factor(__mlf);} |     void max_load_factor(float __mlf) {__table_.max_load_factor(__mlf);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -1387,10 +1471,10 @@ public: | |||||||
| private: | private: | ||||||
| #if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | #if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | ||||||
|     template <class _A0, class... _Args, |     template <class _A0, class... _Args, | ||||||
|               class = typename enable_if<is_convertible<_A0, key_type>::value>::type> |               class = typename enable_if<is_constructible<key_type, _A0>::value>::type> | ||||||
|         __node_holder __construct_node(_A0&& __a0, _Args&&... __args); |         __node_holder __construct_node(_A0&& __a0, _Args&&... __args); | ||||||
|     template <class _A0, |     template <class _A0, | ||||||
|               class = typename enable_if<is_convertible<_A0, value_type>::value>::type> |               class = typename enable_if<is_constructible<value_type, _A0>::value>::type> | ||||||
|         __node_holder __construct_node(_A0&& __a0); |         __node_holder __construct_node(_A0&& __a0); | ||||||
| #endif  // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | #endif  // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | ||||||
| }; | }; | ||||||
| @@ -1474,14 +1558,15 @@ template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::unordered_multimap( | unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::unordered_multimap( | ||||||
|         unordered_multimap&& __u) |         unordered_multimap&& __u) | ||||||
|     : __table_(_STD::move(__u.__table_)) |     _NOEXCEPT_(is_nothrow_move_constructible<__table>::value) | ||||||
|  |     : __table_(_VSTD::move(__u.__table_)) | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | ||||||
| unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::unordered_multimap( | unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::unordered_multimap( | ||||||
|         unordered_multimap&& __u, const allocator_type& __a) |         unordered_multimap&& __u, const allocator_type& __a) | ||||||
|     : __table_(_STD::move(__u.__table_), __a) |     : __table_(_VSTD::move(__u.__table_), __a) | ||||||
| { | { | ||||||
|     if (__a != __u.get_allocator()) |     if (__a != __u.get_allocator()) | ||||||
|     { |     { | ||||||
| @@ -1489,7 +1574,7 @@ unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::unordered_multimap( | |||||||
|         while (__u.size() != 0) |         while (__u.size() != 0) | ||||||
| { | { | ||||||
|             __table_.__insert_multi( |             __table_.__insert_multi( | ||||||
|                 _STD::move(__u.__table_.remove((__i++).__i_)->__value_) |                 _VSTD::move(__u.__table_.remove((__i++).__i_)->__value_) | ||||||
|                                    ); |                                    ); | ||||||
| } | } | ||||||
|     } |     } | ||||||
| @@ -1530,8 +1615,9 @@ template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>& | unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>& | ||||||
| unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::operator=(unordered_multimap&& __u) | unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::operator=(unordered_multimap&& __u) | ||||||
|  |     _NOEXCEPT_(is_nothrow_move_assignable<__table>::value) | ||||||
| { | { | ||||||
|     __table_ = _STD::move(__u.__table_); |     __table_ = _VSTD::move(__u.__table_); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1552,7 +1638,7 @@ unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::operator=( | |||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | ||||||
| template <class _A0, class... _Args, | template <class _A0, class... _Args, | ||||||
|           class // = typename enable_if<is_convertible<_A0, key_type>::value>::type |           class // = typename enable_if<is_constructible<key_type, _A0>::value>::type | ||||||
|          > |          > | ||||||
| typename unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::__node_holder | typename unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::__node_holder | ||||||
| unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::__construct_node( | unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::__construct_node( | ||||||
| @@ -1560,11 +1646,11 @@ unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::__construct_node( | |||||||
| { | { | ||||||
|     __node_allocator& __na = __table_.__node_alloc(); |     __node_allocator& __na = __table_.__node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.first), |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.first), | ||||||
|                              _STD::forward<_A0>(__a0)); |                              _VSTD::forward<_A0>(__a0)); | ||||||
|     __h.get_deleter().__first_constructed = true; |     __h.get_deleter().__first_constructed = true; | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.second), |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.second), | ||||||
|                              _STD::forward<_Args>(__args)...); |                              _VSTD::forward<_Args>(__args)...); | ||||||
|     __h.get_deleter().__second_constructed = true; |     __h.get_deleter().__second_constructed = true; | ||||||
|     return __h; |     return __h; | ||||||
| } | } | ||||||
| @@ -1573,15 +1659,15 @@ unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::__construct_node( | |||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | ||||||
| template <class _A0, | template <class _A0, | ||||||
|           class // = typename enable_if<is_convertible<_A0, value_type>::value>::type |           class // = typename enable_if<is_constructible<value_type, _A0>::value>::type | ||||||
|          > |          > | ||||||
| typename unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::__node_holder | typename unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::__node_holder | ||||||
| unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::__construct_node(_A0&& __a0) | unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::__construct_node(_A0&& __a0) | ||||||
| { | { | ||||||
|     __node_allocator& __na = __table_.__node_alloc(); |     __node_allocator& __na = __table_.__node_alloc(); | ||||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); |     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_), |     __node_traits::construct(__na, _VSTD::addressof(__h->__value_), | ||||||
|                              _STD::forward<_A0>(__a0)); |                              _VSTD::forward<_A0>(__a0)); | ||||||
|     __h.get_deleter().__first_constructed = true; |     __h.get_deleter().__first_constructed = true; | ||||||
|     __h.get_deleter().__second_constructed = true; |     __h.get_deleter().__second_constructed = true; | ||||||
|     return __h; |     return __h; | ||||||
| @@ -1591,13 +1677,13 @@ unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::__construct_node(_A0&& __a0 | |||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | ||||||
| template <class _A0, class... _Args, | template <class _A0, class... _Args, | ||||||
|           class // = typename enable_if<is_convertible<_A0, key_type>::value>::type |           class // = typename enable_if<is_constructible<key_type, _A0>::value>::type | ||||||
|          > |          > | ||||||
| typename unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::iterator | typename unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::iterator | ||||||
| unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::emplace(_A0&& __a0, _Args&&... __args) | unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::emplace(_A0&& __a0, _Args&&... __args) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_A0>(__a0), |     __node_holder __h = __construct_node(_VSTD::forward<_A0>(__a0), | ||||||
|                                          _STD::forward<_Args>(__args)...); |                                          _VSTD::forward<_Args>(__args)...); | ||||||
|     iterator __r = __table_.__node_insert_multi(__h.get()); |     iterator __r = __table_.__node_insert_multi(__h.get()); | ||||||
|     __h.release(); |     __h.release(); | ||||||
|     return __r; |     return __r; | ||||||
| @@ -1605,14 +1691,14 @@ unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::emplace(_A0&& __a0, _Args&& | |||||||
|  |  | ||||||
| template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | ||||||
| template <class _A0, class... _Args, | template <class _A0, class... _Args, | ||||||
|           class // = typename enable_if<is_convertible<_A0, key_type>::value>::type |           class // = typename enable_if<is_constructible<key_type, _A0>::value>::type | ||||||
|          > |          > | ||||||
| typename unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::iterator | typename unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::iterator | ||||||
| unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::emplace_hint( | unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>::emplace_hint( | ||||||
|         const_iterator __p, _A0&& __a0, _Args&&... __args) |         const_iterator __p, _A0&& __a0, _Args&&... __args) | ||||||
| { | { | ||||||
|     __node_holder __h = __construct_node(_STD::forward<_A0>(__a0), |     __node_holder __h = __construct_node(_VSTD::forward<_A0>(__a0), | ||||||
|                                          _STD::forward<_Args>(__args)...); |                                          _VSTD::forward<_Args>(__args)...); | ||||||
|     iterator __r = __table_.__node_insert_multi(__p.__i_, __h.get()); |     iterator __r = __table_.__node_insert_multi(__p.__i_, __h.get()); | ||||||
|     __h.release(); |     __h.release(); | ||||||
|     return __r; |     return __r; | ||||||
| @@ -1637,6 +1723,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| void | void | ||||||
| swap(unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>& __x, | swap(unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>& __x, | ||||||
|      unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>& __y) |      unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>& __y) | ||||||
|  |     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||||
| { | { | ||||||
|     __x.swap(__y); |     __x.swap(__y); | ||||||
| } | } | ||||||
| @@ -1655,9 +1742,9 @@ operator==(const unordered_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>& __x, | |||||||
|     { |     { | ||||||
|         _EqRng __xeq = __x.equal_range(__i->first); |         _EqRng __xeq = __x.equal_range(__i->first); | ||||||
|         _EqRng __yeq = __y.equal_range(__i->first); |         _EqRng __yeq = __y.equal_range(__i->first); | ||||||
|         if (_STD::distance(__xeq.first, __xeq.second) != |         if (_VSTD::distance(__xeq.first, __xeq.second) != | ||||||
|             _STD::distance(__yeq.first, __yeq.second) || |             _VSTD::distance(__yeq.first, __yeq.second) || | ||||||
|                   !_STD::is_permutation(__xeq.first, __xeq.second, __yeq.first)) |                   !_VSTD::is_permutation(__xeq.first, __xeq.second, __yeq.first)) | ||||||
|             return false; |             return false; | ||||||
|         __i = __xeq.second; |         __i = __xeq.second; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -43,7 +43,12 @@ public: | |||||||
|     typedef /unspecified/ local_iterator; |     typedef /unspecified/ local_iterator; | ||||||
|     typedef /unspecified/ const_local_iterator; |     typedef /unspecified/ const_local_iterator; | ||||||
|  |  | ||||||
|     explicit unordered_set(size_type n = 0, const hasher& hf = hasher(), |     unordered_set() | ||||||
|  |         noexcept( | ||||||
|  |             is_nothrow_default_constructible<hasher>::value && | ||||||
|  |             is_nothrow_default_constructible<key_equal>::value && | ||||||
|  |             is_nothrow_default_constructible<allocator_type>::value); | ||||||
|  |     explicit unordered_set(size_type n, const hasher& hf = hasher(), | ||||||
|                            const key_equal& eql = key_equal(), |                            const key_equal& eql = key_equal(), | ||||||
|                            const allocator_type& a = allocator_type()); |                            const allocator_type& a = allocator_type()); | ||||||
|     template <class InputIterator> |     template <class InputIterator> | ||||||
| @@ -54,28 +59,37 @@ public: | |||||||
|     explicit unordered_set(const allocator_type&); |     explicit unordered_set(const allocator_type&); | ||||||
|     unordered_set(const unordered_set&); |     unordered_set(const unordered_set&); | ||||||
|     unordered_set(const unordered_set&, const Allocator&); |     unordered_set(const unordered_set&, const Allocator&); | ||||||
|     unordered_set(unordered_set&&); |     unordered_set(unordered_set&&) | ||||||
|  |         noexcept( | ||||||
|  |             is_nothrow_move_constructible<hasher>::value && | ||||||
|  |             is_nothrow_move_constructible<key_equal>::value && | ||||||
|  |             is_nothrow_move_constructible<allocator_type>::value); | ||||||
|     unordered_set(unordered_set&&, const Allocator&); |     unordered_set(unordered_set&&, const Allocator&); | ||||||
|     unordered_set(initializer_list<value_type>, size_type n = 0, |     unordered_set(initializer_list<value_type>, size_type n = 0, | ||||||
|                   const hasher& hf = hasher(), const key_equal& eql = key_equal(), |                   const hasher& hf = hasher(), const key_equal& eql = key_equal(), | ||||||
|                   const allocator_type& a = allocator_type()); |                   const allocator_type& a = allocator_type()); | ||||||
|     ~unordered_set(); |     ~unordered_set(); | ||||||
|     unordered_set& operator=(const unordered_set&); |     unordered_set& operator=(const unordered_set&); | ||||||
|     unordered_set& operator=(unordered_set&&); |     unordered_set& operator=(unordered_set&&) | ||||||
|  |         noexcept( | ||||||
|  |             allocator_type::propagate_on_container_move_assignment::value && | ||||||
|  |             is_nothrow_move_assignable<allocator_type>::value && | ||||||
|  |             is_nothrow_move_assignable<hasher>::value && | ||||||
|  |             is_nothrow_move_assignable<key_equal>::value); | ||||||
|     unordered_set& operator=(initializer_list<value_type>); |     unordered_set& operator=(initializer_list<value_type>); | ||||||
|  |  | ||||||
|     allocator_type get_allocator() const; |     allocator_type get_allocator() const noexcept; | ||||||
|  |  | ||||||
|     bool      empty() const; |     bool      empty() const noexcept; | ||||||
|     size_type size() const; |     size_type size() const noexcept; | ||||||
|     size_type max_size() const; |     size_type max_size() const noexcept; | ||||||
|  |  | ||||||
|     iterator       begin(); |     iterator       begin() noexcept; | ||||||
|     iterator       end(); |     iterator       end() noexcept; | ||||||
|     const_iterator begin()  const; |     const_iterator begin()  const noexcept; | ||||||
|     const_iterator end()    const; |     const_iterator end()    const noexcept; | ||||||
|     const_iterator cbegin() const; |     const_iterator cbegin() const noexcept; | ||||||
|     const_iterator cend()   const; |     const_iterator cend()   const noexcept; | ||||||
|  |  | ||||||
|     template <class... Args> |     template <class... Args> | ||||||
|         pair<iterator, bool> emplace(Args&&... args); |         pair<iterator, bool> emplace(Args&&... args); | ||||||
| @@ -92,9 +106,14 @@ public: | |||||||
|     iterator erase(const_iterator position); |     iterator erase(const_iterator position); | ||||||
|     size_type erase(const key_type& k); |     size_type erase(const key_type& k); | ||||||
|     iterator erase(const_iterator first, const_iterator last); |     iterator erase(const_iterator first, const_iterator last); | ||||||
|     void clear(); |     void clear() noexcept; | ||||||
|  |  | ||||||
|     void swap(unordered_set&); |     void swap(unordered_set&) | ||||||
|  |         noexcept( | ||||||
|  |             (!allocator_type::propagate_on_container_swap::value || | ||||||
|  |              __is_nothrow_swappable<allocator_type>::value) && | ||||||
|  |             __is_nothrow_swappable<hasher>::value && | ||||||
|  |             __is_nothrow_swappable<key_equal>::value); | ||||||
|  |  | ||||||
|     hasher hash_function() const; |     hasher hash_function() const; | ||||||
|     key_equal key_eq() const; |     key_equal key_eq() const; | ||||||
| @@ -105,8 +124,8 @@ public: | |||||||
|     pair<iterator, iterator>             equal_range(const key_type& k); |     pair<iterator, iterator>             equal_range(const key_type& k); | ||||||
|     pair<const_iterator, const_iterator> equal_range(const key_type& k) const; |     pair<const_iterator, const_iterator> equal_range(const key_type& k) const; | ||||||
|  |  | ||||||
|     size_type bucket_count() const; |     size_type bucket_count() const noexcept; | ||||||
|     size_type max_bucket_count() const; |     size_type max_bucket_count() const noexcept; | ||||||
|  |  | ||||||
|     size_type bucket_size(size_type n) const; |     size_type bucket_size(size_type n) const; | ||||||
|     size_type bucket(const key_type& k) const; |     size_type bucket(const key_type& k) const; | ||||||
| @@ -118,8 +137,8 @@ public: | |||||||
|     const_local_iterator cbegin(size_type n) const; |     const_local_iterator cbegin(size_type n) const; | ||||||
|     const_local_iterator cend(size_type n) const; |     const_local_iterator cend(size_type n) const; | ||||||
|  |  | ||||||
|     float load_factor() const; |     float load_factor() const noexcept; | ||||||
|     float max_load_factor() const; |     float max_load_factor() const noexcept; | ||||||
|     void max_load_factor(float z); |     void max_load_factor(float z); | ||||||
|     void rehash(size_type n); |     void rehash(size_type n); | ||||||
|     void reserve(size_type n); |     void reserve(size_type n); | ||||||
| @@ -127,7 +146,8 @@ public: | |||||||
|  |  | ||||||
| template <class Value, class Hash, class Pred, class Alloc> | template <class Value, class Hash, class Pred, class Alloc> | ||||||
|     void swap(unordered_set<Value, Hash, Pred, Alloc>& x, |     void swap(unordered_set<Value, Hash, Pred, Alloc>& x, | ||||||
|               unordered_set<Value, Hash, Pred, Alloc>& y); |               unordered_set<Value, Hash, Pred, Alloc>& y) | ||||||
|  |               noexcept(noexcept(x.swap(y))); | ||||||
|  |  | ||||||
| template <class Value, class Hash, class Pred, class Alloc> | template <class Value, class Hash, class Pred, class Alloc> | ||||||
|     bool |     bool | ||||||
| @@ -162,7 +182,12 @@ public: | |||||||
|     typedef /unspecified/ local_iterator; |     typedef /unspecified/ local_iterator; | ||||||
|     typedef /unspecified/ const_local_iterator; |     typedef /unspecified/ const_local_iterator; | ||||||
|  |  | ||||||
|     explicit unordered_multiset(size_type n = 0, const hasher& hf = hasher(), |     unordered_multiset() | ||||||
|  |         noexcept( | ||||||
|  |             is_nothrow_default_constructible<hasher>::value && | ||||||
|  |             is_nothrow_default_constructible<key_equal>::value && | ||||||
|  |             is_nothrow_default_constructible<allocator_type>::value); | ||||||
|  |     explicit unordered_multiset(size_type n, const hasher& hf = hasher(), | ||||||
|                            const key_equal& eql = key_equal(), |                            const key_equal& eql = key_equal(), | ||||||
|                            const allocator_type& a = allocator_type()); |                            const allocator_type& a = allocator_type()); | ||||||
|     template <class InputIterator> |     template <class InputIterator> | ||||||
| @@ -173,28 +198,37 @@ public: | |||||||
|     explicit unordered_multiset(const allocator_type&); |     explicit unordered_multiset(const allocator_type&); | ||||||
|     unordered_multiset(const unordered_multiset&); |     unordered_multiset(const unordered_multiset&); | ||||||
|     unordered_multiset(const unordered_multiset&, const Allocator&); |     unordered_multiset(const unordered_multiset&, const Allocator&); | ||||||
|     unordered_multiset(unordered_multiset&&); |     unordered_multiset(unordered_multiset&&) | ||||||
|  |         noexcept( | ||||||
|  |             is_nothrow_move_constructible<hasher>::value && | ||||||
|  |             is_nothrow_move_constructible<key_equal>::value && | ||||||
|  |             is_nothrow_move_constructible<allocator_type>::value); | ||||||
|     unordered_multiset(unordered_multiset&&, const Allocator&); |     unordered_multiset(unordered_multiset&&, const Allocator&); | ||||||
|     unordered_multiset(initializer_list<value_type>, size_type n = /see below/, |     unordered_multiset(initializer_list<value_type>, size_type n = /see below/, | ||||||
|                   const hasher& hf = hasher(), const key_equal& eql = key_equal(), |                   const hasher& hf = hasher(), const key_equal& eql = key_equal(), | ||||||
|                   const allocator_type& a = allocator_type()); |                   const allocator_type& a = allocator_type()); | ||||||
|     ~unordered_multiset(); |     ~unordered_multiset(); | ||||||
|     unordered_multiset& operator=(const unordered_multiset&); |     unordered_multiset& operator=(const unordered_multiset&); | ||||||
|     unordered_multiset& operator=(unordered_multiset&&); |     unordered_multiset& operator=(unordered_multiset&&) | ||||||
|  |         noexcept( | ||||||
|  |             allocator_type::propagate_on_container_move_assignment::value && | ||||||
|  |             is_nothrow_move_assignable<allocator_type>::value && | ||||||
|  |             is_nothrow_move_assignable<hasher>::value && | ||||||
|  |             is_nothrow_move_assignable<key_equal>::value); | ||||||
|     unordered_multiset& operator=(initializer_list<value_type>); |     unordered_multiset& operator=(initializer_list<value_type>); | ||||||
|  |  | ||||||
|     allocator_type get_allocator() const; |     allocator_type get_allocator() const noexcept; | ||||||
|  |  | ||||||
|     bool      empty() const; |     bool      empty() const noexcept; | ||||||
|     size_type size() const; |     size_type size() const noexcept; | ||||||
|     size_type max_size() const; |     size_type max_size() const noexcept; | ||||||
|  |  | ||||||
|     iterator       begin(); |     iterator       begin() noexcept; | ||||||
|     iterator       end(); |     iterator       end() noexcept; | ||||||
|     const_iterator begin()  const; |     const_iterator begin()  const noexcept; | ||||||
|     const_iterator end()    const; |     const_iterator end()    const noexcept; | ||||||
|     const_iterator cbegin() const; |     const_iterator cbegin() const noexcept; | ||||||
|     const_iterator cend()   const; |     const_iterator cend()   const noexcept; | ||||||
|  |  | ||||||
|     template <class... Args> |     template <class... Args> | ||||||
|         iterator emplace(Args&&... args); |         iterator emplace(Args&&... args); | ||||||
| @@ -211,9 +245,14 @@ public: | |||||||
|     iterator erase(const_iterator position); |     iterator erase(const_iterator position); | ||||||
|     size_type erase(const key_type& k); |     size_type erase(const key_type& k); | ||||||
|     iterator erase(const_iterator first, const_iterator last); |     iterator erase(const_iterator first, const_iterator last); | ||||||
|     void clear(); |     void clear() noexcept; | ||||||
|  |  | ||||||
|     void swap(unordered_multiset&); |     void swap(unordered_multiset&) | ||||||
|  |         noexcept( | ||||||
|  |             (!allocator_type::propagate_on_container_swap::value || | ||||||
|  |              __is_nothrow_swappable<allocator_type>::value) && | ||||||
|  |             __is_nothrow_swappable<hasher>::value && | ||||||
|  |             __is_nothrow_swappable<key_equal>::value); | ||||||
|  |  | ||||||
|     hasher hash_function() const; |     hasher hash_function() const; | ||||||
|     key_equal key_eq() const; |     key_equal key_eq() const; | ||||||
| @@ -224,8 +263,8 @@ public: | |||||||
|     pair<iterator, iterator>             equal_range(const key_type& k); |     pair<iterator, iterator>             equal_range(const key_type& k); | ||||||
|     pair<const_iterator, const_iterator> equal_range(const key_type& k) const; |     pair<const_iterator, const_iterator> equal_range(const key_type& k) const; | ||||||
|  |  | ||||||
|     size_type bucket_count() const; |     size_type bucket_count() const noexcept; | ||||||
|     size_type max_bucket_count() const; |     size_type max_bucket_count() const noexcept; | ||||||
|  |  | ||||||
|     size_type bucket_size(size_type n) const; |     size_type bucket_size(size_type n) const; | ||||||
|     size_type bucket(const key_type& k) const; |     size_type bucket(const key_type& k) const; | ||||||
| @@ -237,8 +276,8 @@ public: | |||||||
|     const_local_iterator cbegin(size_type n) const; |     const_local_iterator cbegin(size_type n) const; | ||||||
|     const_local_iterator cend(size_type n) const; |     const_local_iterator cend(size_type n) const; | ||||||
|  |  | ||||||
|     float load_factor() const; |     float load_factor() const noexcept; | ||||||
|     float max_load_factor() const; |     float max_load_factor() const noexcept; | ||||||
|     void max_load_factor(float z); |     void max_load_factor(float z); | ||||||
|     void rehash(size_type n); |     void rehash(size_type n); | ||||||
|     void reserve(size_type n); |     void reserve(size_type n); | ||||||
| @@ -246,7 +285,8 @@ public: | |||||||
|  |  | ||||||
| template <class Value, class Hash, class Pred, class Alloc> | template <class Value, class Hash, class Pred, class Alloc> | ||||||
|     void swap(unordered_multiset<Value, Hash, Pred, Alloc>& x, |     void swap(unordered_multiset<Value, Hash, Pred, Alloc>& x, | ||||||
|               unordered_multiset<Value, Hash, Pred, Alloc>& y); |               unordered_multiset<Value, Hash, Pred, Alloc>& y) | ||||||
|  |               noexcept(noexcept(x.swap(y))); | ||||||
|  |  | ||||||
| template <class Value, class Hash, class Pred, class Alloc> | template <class Value, class Hash, class Pred, class Alloc> | ||||||
|     bool |     bool | ||||||
| @@ -300,7 +340,9 @@ public: | |||||||
|     typedef typename __table::const_local_iterator const_local_iterator; |     typedef typename __table::const_local_iterator const_local_iterator; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     unordered_set() {} // = default; |     unordered_set() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<__table>::value) | ||||||
|  |         {} // = default; | ||||||
|     explicit unordered_set(size_type __n, const hasher& __hf = hasher(), |     explicit unordered_set(size_type __n, const hasher& __hf = hasher(), | ||||||
|                            const key_equal& __eql = key_equal()); |                            const key_equal& __eql = key_equal()); | ||||||
|     unordered_set(size_type __n, const hasher& __hf, const key_equal& __eql, |     unordered_set(size_type __n, const hasher& __hf, const key_equal& __eql, | ||||||
| @@ -319,7 +361,8 @@ public: | |||||||
|     unordered_set(const unordered_set& __u); |     unordered_set(const unordered_set& __u); | ||||||
|     unordered_set(const unordered_set& __u, const allocator_type& __a); |     unordered_set(const unordered_set& __u, const allocator_type& __a); | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     unordered_set(unordered_set&& __u); |     unordered_set(unordered_set&& __u) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_constructible<__table>::value); | ||||||
|     unordered_set(unordered_set&& __u, const allocator_type& __a); |     unordered_set(unordered_set&& __u, const allocator_type& __a); | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     unordered_set(initializer_list<value_type> __il); |     unordered_set(initializer_list<value_type> __il); | ||||||
| @@ -330,45 +373,51 @@ public: | |||||||
|                   const hasher& __hf, const key_equal& __eql, |                   const hasher& __hf, const key_equal& __eql, | ||||||
|                   const allocator_type& __a); |                   const allocator_type& __a); | ||||||
|     // ~unordered_set() = default; |     // ~unordered_set() = default; | ||||||
|     // unordered_set& operator=(const unordered_set& __u) = default; |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     unordered_set& operator=(const unordered_set& __u) | ||||||
|  |     { | ||||||
|  |         __table_ = __u.__table_; | ||||||
|  |         return *this; | ||||||
|  |     } | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     unordered_set& operator=(unordered_set&& __u); |     unordered_set& operator=(unordered_set&& __u) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_assignable<__table>::value); | ||||||
| #endif | #endif | ||||||
|     unordered_set& operator=(initializer_list<value_type> __il); |     unordered_set& operator=(initializer_list<value_type> __il); | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     allocator_type get_allocator() const |     allocator_type get_allocator() const _NOEXCEPT | ||||||
|         {return allocator_type(__table_.__node_alloc());} |         {return allocator_type(__table_.__node_alloc());} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool      empty() const {return __table_.size() == 0;} |     bool      empty() const _NOEXCEPT {return __table_.size() == 0;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type size() const  {return __table_.size();} |     size_type size() const _NOEXCEPT  {return __table_.size();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type max_size() const {return __table_.max_size();} |     size_type max_size() const _NOEXCEPT {return __table_.max_size();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator       begin()        {return __table_.begin();} |     iterator       begin() _NOEXCEPT        {return __table_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator       end()          {return __table_.end();} |     iterator       end() _NOEXCEPT          {return __table_.end();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator begin()  const {return __table_.begin();} |     const_iterator begin()  const _NOEXCEPT {return __table_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator end()    const {return __table_.end();} |     const_iterator end()    const _NOEXCEPT {return __table_.end();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator cbegin() const {return __table_.begin();} |     const_iterator cbegin() const _NOEXCEPT {return __table_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator cend()   const {return __table_.end();} |     const_iterator cend()   const _NOEXCEPT {return __table_.end();} | ||||||
|  |  | ||||||
| #if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | #if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | ||||||
|     template <class... _Args> |     template <class... _Args> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         pair<iterator, bool> emplace(_Args&&... __args) |         pair<iterator, bool> emplace(_Args&&... __args) | ||||||
|             {return __table_.__emplace_unique(_STD::forward<_Args>(__args)...);} |             {return __table_.__emplace_unique(_VSTD::forward<_Args>(__args)...);} | ||||||
|     template <class... _Args> |     template <class... _Args> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator emplace_hint(const_iterator, _Args&&... __args) |         iterator emplace_hint(const_iterator, _Args&&... __args) | ||||||
|             {return __table_.__emplace_unique(_STD::forward<_Args>(__args)...).first;} |             {return __table_.__emplace_unique(_VSTD::forward<_Args>(__args)...).first;} | ||||||
| #endif  // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | #endif  // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     pair<iterator, bool> insert(const value_type& __x) |     pair<iterator, bool> insert(const value_type& __x) | ||||||
| @@ -376,7 +425,7 @@ public: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     pair<iterator, bool> insert(value_type&& __x) |     pair<iterator, bool> insert(value_type&& __x) | ||||||
|         {return __table_.__insert_unique(_STD::move(__x));} |         {return __table_.__insert_unique(_VSTD::move(__x));} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator insert(const_iterator, const value_type& __x) |     iterator insert(const_iterator, const value_type& __x) | ||||||
| @@ -384,7 +433,7 @@ public: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator insert(const_iterator, value_type&& __x) |     iterator insert(const_iterator, value_type&& __x) | ||||||
|         {return insert(_STD::move(__x)).first;} |         {return insert(_VSTD::move(__x)).first;} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     template <class _InputIterator> |     template <class _InputIterator> | ||||||
|         void insert(_InputIterator __first, _InputIterator __last); |         void insert(_InputIterator __first, _InputIterator __last); | ||||||
| @@ -400,10 +449,12 @@ public: | |||||||
|     iterator erase(const_iterator __first, const_iterator __last) |     iterator erase(const_iterator __first, const_iterator __last) | ||||||
|         {return __table_.erase(__first, __last);} |         {return __table_.erase(__first, __last);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void clear() {__table_.clear();} |     void clear() _NOEXCEPT {__table_.clear();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(unordered_set& __u) {__table_.swap(__u.__table_);} |     void swap(unordered_set& __u) | ||||||
|  |         _NOEXCEPT_(__is_nothrow_swappable<__table>::value) | ||||||
|  |         {__table_.swap(__u.__table_);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     hasher hash_function() const {return __table_.hash_function();} |     hasher hash_function() const {return __table_.hash_function();} | ||||||
| @@ -424,9 +475,9 @@ public: | |||||||
|         {return __table_.__equal_range_unique(__k);} |         {return __table_.__equal_range_unique(__k);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type bucket_count() const {return __table_.bucket_count();} |     size_type bucket_count() const _NOEXCEPT {return __table_.bucket_count();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type max_bucket_count() const {return __table_.max_bucket_count();} |     size_type max_bucket_count() const _NOEXCEPT {return __table_.max_bucket_count();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type bucket_size(size_type __n) const {return __table_.bucket_size(__n);} |     size_type bucket_size(size_type __n) const {return __table_.bucket_size(__n);} | ||||||
| @@ -447,9 +498,9 @@ public: | |||||||
|     const_local_iterator cend(size_type __n) const   {return __table_.cend(__n);} |     const_local_iterator cend(size_type __n) const   {return __table_.cend(__n);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     float load_factor() const {return __table_.load_factor();} |     float load_factor() const _NOEXCEPT {return __table_.load_factor();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     float max_load_factor() const {return __table_.max_load_factor();} |     float max_load_factor() const _NOEXCEPT {return __table_.max_load_factor();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void max_load_factor(float __mlf) {__table_.max_load_factor(__mlf);} |     void max_load_factor(float __mlf) {__table_.max_load_factor(__mlf);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -536,20 +587,21 @@ template <class _Value, class _Hash, class _Pred, class _Alloc> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| unordered_set<_Value, _Hash, _Pred, _Alloc>::unordered_set( | unordered_set<_Value, _Hash, _Pred, _Alloc>::unordered_set( | ||||||
|         unordered_set&& __u) |         unordered_set&& __u) | ||||||
|     : __table_(_STD::move(__u.__table_)) |     _NOEXCEPT_(is_nothrow_move_constructible<__table>::value) | ||||||
|  |     : __table_(_VSTD::move(__u.__table_)) | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Value, class _Hash, class _Pred, class _Alloc> | template <class _Value, class _Hash, class _Pred, class _Alloc> | ||||||
| unordered_set<_Value, _Hash, _Pred, _Alloc>::unordered_set( | unordered_set<_Value, _Hash, _Pred, _Alloc>::unordered_set( | ||||||
|         unordered_set&& __u, const allocator_type& __a) |         unordered_set&& __u, const allocator_type& __a) | ||||||
|     : __table_(_STD::move(__u.__table_), __a) |     : __table_(_VSTD::move(__u.__table_), __a) | ||||||
| { | { | ||||||
|     if (__a != __u.get_allocator()) |     if (__a != __u.get_allocator()) | ||||||
|     { |     { | ||||||
|         iterator __i = __u.begin(); |         iterator __i = __u.begin(); | ||||||
|         while (__u.size() != 0) |         while (__u.size() != 0) | ||||||
|             __table_.__insert_unique(_STD::move(__u.__table_.remove(__i++)->__value_)); |             __table_.__insert_unique(_VSTD::move(__u.__table_.remove(__i++)->__value_)); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -588,8 +640,9 @@ template <class _Value, class _Hash, class _Pred, class _Alloc> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| unordered_set<_Value, _Hash, _Pred, _Alloc>& | unordered_set<_Value, _Hash, _Pred, _Alloc>& | ||||||
| unordered_set<_Value, _Hash, _Pred, _Alloc>::operator=(unordered_set&& __u) | unordered_set<_Value, _Hash, _Pred, _Alloc>::operator=(unordered_set&& __u) | ||||||
|  |     _NOEXCEPT_(is_nothrow_move_assignable<__table>::value) | ||||||
| { | { | ||||||
|     __table_ = _STD::move(__u.__table_); |     __table_ = _VSTD::move(__u.__table_); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -621,6 +674,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| void | void | ||||||
| swap(unordered_set<_Value, _Hash, _Pred, _Alloc>& __x, | swap(unordered_set<_Value, _Hash, _Pred, _Alloc>& __x, | ||||||
|      unordered_set<_Value, _Hash, _Pred, _Alloc>& __y) |      unordered_set<_Value, _Hash, _Pred, _Alloc>& __y) | ||||||
|  |     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||||
| { | { | ||||||
|     __x.swap(__y); |     __x.swap(__y); | ||||||
| } | } | ||||||
| @@ -684,7 +738,9 @@ public: | |||||||
|     typedef typename __table::const_local_iterator const_local_iterator; |     typedef typename __table::const_local_iterator const_local_iterator; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     unordered_multiset() {} // = default |     unordered_multiset() | ||||||
|  |         _NOEXCEPT_(is_nothrow_default_constructible<__table>::value) | ||||||
|  |         {} // = default | ||||||
|     explicit unordered_multiset(size_type __n, const hasher& __hf = hasher(), |     explicit unordered_multiset(size_type __n, const hasher& __hf = hasher(), | ||||||
|                                 const key_equal& __eql = key_equal()); |                                 const key_equal& __eql = key_equal()); | ||||||
|     unordered_multiset(size_type __n, const hasher& __hf, |     unordered_multiset(size_type __n, const hasher& __hf, | ||||||
| @@ -703,7 +759,8 @@ public: | |||||||
|     unordered_multiset(const unordered_multiset& __u); |     unordered_multiset(const unordered_multiset& __u); | ||||||
|     unordered_multiset(const unordered_multiset& __u, const allocator_type& __a); |     unordered_multiset(const unordered_multiset& __u, const allocator_type& __a); | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     unordered_multiset(unordered_multiset&& __u); |     unordered_multiset(unordered_multiset&& __u) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_constructible<__table>::value); | ||||||
|     unordered_multiset(unordered_multiset&& __u, const allocator_type& __a); |     unordered_multiset(unordered_multiset&& __u, const allocator_type& __a); | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     unordered_multiset(initializer_list<value_type> __il); |     unordered_multiset(initializer_list<value_type> __il); | ||||||
| @@ -714,51 +771,57 @@ public: | |||||||
|                        const hasher& __hf, const key_equal& __eql, |                        const hasher& __hf, const key_equal& __eql, | ||||||
|                        const allocator_type& __a); |                        const allocator_type& __a); | ||||||
|     // ~unordered_multiset() = default; |     // ~unordered_multiset() = default; | ||||||
|     // unordered_multiset& operator=(const unordered_multiset& __u) = default; |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     unordered_multiset& operator=(const unordered_multiset& __u) | ||||||
|  |     { | ||||||
|  |         __table_ = __u.__table_; | ||||||
|  |         return *this; | ||||||
|  |     } | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     unordered_multiset& operator=(unordered_multiset&& __u); |     unordered_multiset& operator=(unordered_multiset&& __u) | ||||||
|  |         _NOEXCEPT_(is_nothrow_move_assignable<__table>::value); | ||||||
| #endif | #endif | ||||||
|     unordered_multiset& operator=(initializer_list<value_type> __il); |     unordered_multiset& operator=(initializer_list<value_type> __il); | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     allocator_type get_allocator() const |     allocator_type get_allocator() const _NOEXCEPT | ||||||
|         {return allocator_type(__table_.__node_alloc());} |         {return allocator_type(__table_.__node_alloc());} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     bool      empty() const {return __table_.size() == 0;} |     bool      empty() const _NOEXCEPT {return __table_.size() == 0;} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type size() const  {return __table_.size();} |     size_type size() const _NOEXCEPT  {return __table_.size();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type max_size() const {return __table_.max_size();} |     size_type max_size() const _NOEXCEPT {return __table_.max_size();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator       begin()        {return __table_.begin();} |     iterator       begin() _NOEXCEPT        {return __table_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator       end()          {return __table_.end();} |     iterator       end() _NOEXCEPT          {return __table_.end();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator begin()  const {return __table_.begin();} |     const_iterator begin()  const _NOEXCEPT {return __table_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator end()    const {return __table_.end();} |     const_iterator end()    const _NOEXCEPT {return __table_.end();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator cbegin() const {return __table_.begin();} |     const_iterator cbegin() const _NOEXCEPT {return __table_.begin();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const_iterator cend()   const {return __table_.end();} |     const_iterator cend()   const _NOEXCEPT {return __table_.end();} | ||||||
|  |  | ||||||
| #if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | #if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | ||||||
|     template <class... _Args> |     template <class... _Args> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator emplace(_Args&&... __args) |         iterator emplace(_Args&&... __args) | ||||||
|             {return __table_.__emplace_multi(_STD::forward<_Args>(__args)...);} |             {return __table_.__emplace_multi(_VSTD::forward<_Args>(__args)...);} | ||||||
|     template <class... _Args> |     template <class... _Args> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         iterator emplace_hint(const_iterator __p, _Args&&... __args) |         iterator emplace_hint(const_iterator __p, _Args&&... __args) | ||||||
|             {return __table_.__emplace_hint_multi(__p, _STD::forward<_Args>(__args)...);} |             {return __table_.__emplace_hint_multi(__p, _VSTD::forward<_Args>(__args)...);} | ||||||
| #endif  // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | #endif  // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator insert(const value_type& __x) {return __table_.__insert_multi(__x);} |     iterator insert(const value_type& __x) {return __table_.__insert_multi(__x);} | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator insert(value_type&& __x) {return __table_.__insert_multi(_STD::move(__x));} |     iterator insert(value_type&& __x) {return __table_.__insert_multi(_VSTD::move(__x));} | ||||||
| #endif | #endif | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator insert(const_iterator __p, const value_type& __x) |     iterator insert(const_iterator __p, const value_type& __x) | ||||||
| @@ -766,7 +829,7 @@ public: | |||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     iterator insert(const_iterator __p, value_type&& __x) |     iterator insert(const_iterator __p, value_type&& __x) | ||||||
|         {return __table_.__insert_multi(__p, _STD::move(__x));} |         {return __table_.__insert_multi(__p, _VSTD::move(__x));} | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     template <class _InputIterator> |     template <class _InputIterator> | ||||||
|         void insert(_InputIterator __first, _InputIterator __last); |         void insert(_InputIterator __first, _InputIterator __last); | ||||||
| @@ -782,10 +845,12 @@ public: | |||||||
|     iterator erase(const_iterator __first, const_iterator __last) |     iterator erase(const_iterator __first, const_iterator __last) | ||||||
|         {return __table_.erase(__first, __last);} |         {return __table_.erase(__first, __last);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void clear() {__table_.clear();} |     void clear() _NOEXCEPT {__table_.clear();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void swap(unordered_multiset& __u) {__table_.swap(__u.__table_);} |     void swap(unordered_multiset& __u) | ||||||
|  |         _NOEXCEPT_(__is_nothrow_swappable<__table>::value) | ||||||
|  |         {__table_.swap(__u.__table_);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     hasher hash_function() const {return __table_.hash_function();} |     hasher hash_function() const {return __table_.hash_function();} | ||||||
| @@ -806,9 +871,9 @@ public: | |||||||
|         {return __table_.__equal_range_multi(__k);} |         {return __table_.__equal_range_multi(__k);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type bucket_count() const {return __table_.bucket_count();} |     size_type bucket_count() const _NOEXCEPT {return __table_.bucket_count();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type max_bucket_count() const {return __table_.max_bucket_count();} |     size_type max_bucket_count() const _NOEXCEPT {return __table_.max_bucket_count();} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     size_type bucket_size(size_type __n) const {return __table_.bucket_size(__n);} |     size_type bucket_size(size_type __n) const {return __table_.bucket_size(__n);} | ||||||
| @@ -829,9 +894,9 @@ public: | |||||||
|     const_local_iterator cend(size_type __n) const   {return __table_.cend(__n);} |     const_local_iterator cend(size_type __n) const   {return __table_.cend(__n);} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     float load_factor() const {return __table_.load_factor();} |     float load_factor() const _NOEXCEPT {return __table_.load_factor();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     float max_load_factor() const {return __table_.max_load_factor();} |     float max_load_factor() const _NOEXCEPT {return __table_.max_load_factor();} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     void max_load_factor(float __mlf) {__table_.max_load_factor(__mlf);} |     void max_load_factor(float __mlf) {__table_.max_load_factor(__mlf);} | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -919,20 +984,21 @@ template <class _Value, class _Hash, class _Pred, class _Alloc> | |||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| unordered_multiset<_Value, _Hash, _Pred, _Alloc>::unordered_multiset( | unordered_multiset<_Value, _Hash, _Pred, _Alloc>::unordered_multiset( | ||||||
|         unordered_multiset&& __u) |         unordered_multiset&& __u) | ||||||
|     : __table_(_STD::move(__u.__table_)) |     _NOEXCEPT_(is_nothrow_move_constructible<__table>::value) | ||||||
|  |     : __table_(_VSTD::move(__u.__table_)) | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Value, class _Hash, class _Pred, class _Alloc> | template <class _Value, class _Hash, class _Pred, class _Alloc> | ||||||
| unordered_multiset<_Value, _Hash, _Pred, _Alloc>::unordered_multiset( | unordered_multiset<_Value, _Hash, _Pred, _Alloc>::unordered_multiset( | ||||||
|         unordered_multiset&& __u, const allocator_type& __a) |         unordered_multiset&& __u, const allocator_type& __a) | ||||||
|     : __table_(_STD::move(__u.__table_), __a) |     : __table_(_VSTD::move(__u.__table_), __a) | ||||||
| { | { | ||||||
|     if (__a != __u.get_allocator()) |     if (__a != __u.get_allocator()) | ||||||
|     { |     { | ||||||
|         iterator __i = __u.begin(); |         iterator __i = __u.begin(); | ||||||
|         while (__u.size() != 0) |         while (__u.size() != 0) | ||||||
|             __table_.__insert_multi(_STD::move(__u.__table_.remove(__i++)->__value_)); |             __table_.__insert_multi(_VSTD::move(__u.__table_.remove(__i++)->__value_)); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -972,8 +1038,9 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| unordered_multiset<_Value, _Hash, _Pred, _Alloc>& | unordered_multiset<_Value, _Hash, _Pred, _Alloc>& | ||||||
| unordered_multiset<_Value, _Hash, _Pred, _Alloc>::operator=( | unordered_multiset<_Value, _Hash, _Pred, _Alloc>::operator=( | ||||||
|         unordered_multiset&& __u) |         unordered_multiset&& __u) | ||||||
|  |     _NOEXCEPT_(is_nothrow_move_assignable<__table>::value) | ||||||
| { | { | ||||||
|     __table_ = _STD::move(__u.__table_); |     __table_ = _VSTD::move(__u.__table_); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1005,6 +1072,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| void | void | ||||||
| swap(unordered_multiset<_Value, _Hash, _Pred, _Alloc>& __x, | swap(unordered_multiset<_Value, _Hash, _Pred, _Alloc>& __x, | ||||||
|      unordered_multiset<_Value, _Hash, _Pred, _Alloc>& __y) |      unordered_multiset<_Value, _Hash, _Pred, _Alloc>& __y) | ||||||
|  |     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||||
| { | { | ||||||
|     __x.swap(__y); |     __x.swap(__y); | ||||||
| } | } | ||||||
| @@ -1023,9 +1091,9 @@ operator==(const unordered_multiset<_Value, _Hash, _Pred, _Alloc>& __x, | |||||||
|     { |     { | ||||||
|         _EqRng __xeq = __x.equal_range(*__i); |         _EqRng __xeq = __x.equal_range(*__i); | ||||||
|         _EqRng __yeq = __y.equal_range(*__i); |         _EqRng __yeq = __y.equal_range(*__i); | ||||||
|         if (_STD::distance(__xeq.first, __xeq.second) != |         if (_VSTD::distance(__xeq.first, __xeq.second) != | ||||||
|             _STD::distance(__yeq.first, __yeq.second) || |             _VSTD::distance(__yeq.first, __yeq.second) || | ||||||
|                   !_STD::is_permutation(__xeq.first, __xeq.second, __yeq.first)) |                   !_VSTD::is_permutation(__xeq.first, __xeq.second, __yeq.first)) | ||||||
|             return false; |             return false; | ||||||
|         __i = __xeq.second; |         __i = __xeq.second; | ||||||
|     } |     } | ||||||
|   | |||||||
							
								
								
									
										160
									
								
								include/utility
									
									
									
									
									
								
							
							
						
						
									
										160
									
								
								include/utility
									
									
									
									
									
								
							| @@ -29,11 +29,19 @@ namespace rel_ops | |||||||
|     template<class T> bool operator>=(const T&, const T&); |     template<class T> bool operator>=(const T&, const T&); | ||||||
| } | } | ||||||
|  |  | ||||||
| template<class T> void swap(T& a, T& b); | template<class T> | ||||||
| template <class T, size_t N> void swap(T (&a)[N], T (&b)[N]); | void | ||||||
|  | swap(T& a, T& b) noexcept(is_nothrow_move_constructible<T>::value && | ||||||
|  |                           is_nothrow_move_assignable<T>::value); | ||||||
|  |  | ||||||
| template <class T, class U> T&& forward(U&&); | template <class T, size_t N> | ||||||
| template <class T> typename remove_reference<T>::type&& move(T&&); | void | ||||||
|  | swap(T (&a)[N], T (&b)[N]) noexcept(noexcept(swap(*a, *b))); | ||||||
|  |  | ||||||
|  | template <class T> T&& forward(typename remove_reference<T>::type& t) noexcept; | ||||||
|  | template <class T> T&& forward(typename remove_reference<T>::type&& t) noexcept; | ||||||
|  |  | ||||||
|  | template <class T> typename remove_reference<T>::type&& move(T&&) noexcept; | ||||||
|  |  | ||||||
| template <class T> | template <class T> | ||||||
|     typename conditional |     typename conditional | ||||||
| @@ -42,7 +50,7 @@ template <class T> | |||||||
|         const T&, |         const T&, | ||||||
|         T&& |         T&& | ||||||
|     >::type |     >::type | ||||||
|     move_if_noexcept(T& x); |     move_if_noexcept(T& x) noexcept; | ||||||
|  |  | ||||||
| template <class T> typename add_rvalue_reference<T>::type declval() noexcept; | template <class T> typename add_rvalue_reference<T>::type declval() noexcept; | ||||||
|  |  | ||||||
| @@ -56,6 +64,7 @@ struct pair | |||||||
|     T2 second; |     T2 second; | ||||||
|  |  | ||||||
|     pair(const pair&) = default; |     pair(const pair&) = default; | ||||||
|  |     pair(pair&&) = default; | ||||||
|     constexpr pair(); |     constexpr pair(); | ||||||
|     pair(const T1& x, const T2& y); |     pair(const T1& x, const T2& y); | ||||||
|     template <class U, class V> pair(U&& x, V&& y); |     template <class U, class V> pair(U&& x, V&& y); | ||||||
| @@ -66,10 +75,12 @@ struct pair | |||||||
|              tuple<Args2...> second_args); |              tuple<Args2...> second_args); | ||||||
|  |  | ||||||
|     template <class U, class V> pair& operator=(const pair<U, V>& p); |     template <class U, class V> pair& operator=(const pair<U, V>& p); | ||||||
|     pair& operator=(pair&& p); |     pair& operator=(pair&& p) noexcept(is_nothrow_move_assignable<T1>::value && | ||||||
|  |                                        is_nothrow_move_assignable<T2>::value); | ||||||
|     template <class U, class V> pair& operator=(pair<U, V>&& p); |     template <class U, class V> pair& operator=(pair<U, V>&& p); | ||||||
|  |  | ||||||
|     void swap(pair& p); |     void swap(pair& p) noexcept(noexcept(swap(first, p.first)) && | ||||||
|  |                                 noexcept(swap(second, p.second))); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class T1, class T2> bool operator==(const pair<T1,T2>&, const pair<T1,T2>&); | template <class T1, class T2> bool operator==(const pair<T1,T2>&, const pair<T1,T2>&); | ||||||
| @@ -80,7 +91,9 @@ template <class T1, class T2> bool operator>=(const pair<T1,T2>&, const pair<T1, | |||||||
| template <class T1, class T2> bool operator<=(const pair<T1,T2>&, const pair<T1,T2>&); | template <class T1, class T2> bool operator<=(const pair<T1,T2>&, const pair<T1,T2>&); | ||||||
|  |  | ||||||
| template <class T1, class T2> pair<V1, V2> make_pair(T1&&, T2&&); | template <class T1, class T2> pair<V1, V2> make_pair(T1&&, T2&&); | ||||||
| template <class T1, class T2> void swap(pair<T1, T2>& x, pair<T1, T2>& y); | template <class T1, class T2> | ||||||
|  | void | ||||||
|  | swap(pair<T1, T2>& x, pair<T1, T2>& y) noexcept(noexcept(x.swap(y))); | ||||||
|  |  | ||||||
| struct piecewise_construct_t { }; | struct piecewise_construct_t { }; | ||||||
| constexpr piecewise_construct_t piecewise_construct = piecewise_construct_t(); | constexpr piecewise_construct_t piecewise_construct = piecewise_construct_t(); | ||||||
| @@ -94,15 +107,15 @@ template <class T1, class T2> struct tuple_element<1, std::pair<T1, T2> >; | |||||||
|  |  | ||||||
| template<size_t I, class T1, class T2> | template<size_t I, class T1, class T2> | ||||||
|     typename tuple_element<I, std::pair<T1, T2> >::type& |     typename tuple_element<I, std::pair<T1, T2> >::type& | ||||||
|     get(std::pair<T1, T2>&); |     get(std::pair<T1, T2>&) noexcept; | ||||||
|  |  | ||||||
| template<size_t I, class T1, class T2> | template<size_t I, class T1, class T2> | ||||||
|     const typename const tuple_element<I, std::pair<T1, T2> >::type& |     const typename const tuple_element<I, std::pair<T1, T2> >::type& | ||||||
|     get(const std::pair<T1, T2>&); |     get(const std::pair<T1, T2>&) noexcept; | ||||||
|  |  | ||||||
| template<size_t I, class T1, class T2> | template<size_t I, class T1, class T2> | ||||||
|     typename tuple_element<I, std::pair<T1, T2> >::type&& |     typename tuple_element<I, std::pair<T1, T2> >::type&& | ||||||
|     get(std::pair<T1, T2>&&); |     get(std::pair<T1, T2>&&) noexcept; | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
|  |  | ||||||
| @@ -168,9 +181,9 @@ swap_ranges(_ForwardIterator1 __first1, _ForwardIterator1 __last1, _ForwardItera | |||||||
| template<class _Tp, size_t _N> | template<class _Tp, size_t _N> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| void | void | ||||||
| swap(_Tp (&__a)[_N], _Tp (&__b)[_N]) | swap(_Tp (&__a)[_N], _Tp (&__b)[_N]) _NOEXCEPT_(__is_nothrow_swappable<_Tp>::value) | ||||||
| { | { | ||||||
|     _STD::swap_ranges(__a, __a + _N, __b); |     _VSTD::swap_ranges(__a, __a + _N, __b); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp> | template <class _Tp> | ||||||
| @@ -185,18 +198,15 @@ typename conditional | |||||||
| #else  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #else  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| const _Tp& | const _Tp& | ||||||
| #endif | #endif | ||||||
| move_if_noexcept(_Tp& __x) | move_if_noexcept(_Tp& __x) _NOEXCEPT | ||||||
| { | { | ||||||
|     return _STD::move(__x); |     return _VSTD::move(__x); | ||||||
| } | } | ||||||
|  |  | ||||||
| struct _LIBCPP_VISIBLE piecewise_construct_t { }; | struct _LIBCPP_VISIBLE piecewise_construct_t { }; | ||||||
| //constexpr | //constexpr | ||||||
| extern const piecewise_construct_t piecewise_construct;// = piecewise_construct_t(); | extern const piecewise_construct_t piecewise_construct;// = piecewise_construct_t(); | ||||||
|  |  | ||||||
| template <class _T1, class _T2> struct pair; |  | ||||||
| template <class _T1, class _T2> void swap(pair<_T1, _T2>&, pair<_T1, _T2>&); |  | ||||||
|  |  | ||||||
| template <class _T1, class _T2> | template <class _T1, class _T2> | ||||||
| struct _LIBCPP_VISIBLE pair | struct _LIBCPP_VISIBLE pair | ||||||
| { | { | ||||||
| @@ -206,6 +216,9 @@ struct _LIBCPP_VISIBLE pair | |||||||
|     _T1 first; |     _T1 first; | ||||||
|     _T2 second; |     _T2 second; | ||||||
|  |  | ||||||
|  |     // pair(const pair&) = default; | ||||||
|  |     // pair(pair&&) = default; | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY pair() : first(), second() {} |     _LIBCPP_INLINE_VISIBILITY pair() : first(), second() {} | ||||||
|  |  | ||||||
|     _LIBCPP_INLINE_VISIBILITY pair(const _T1& __x, const _T2& __y) |     _LIBCPP_INLINE_VISIBILITY pair(const _T1& __x, const _T2& __y) | ||||||
| @@ -213,29 +226,69 @@ struct _LIBCPP_VISIBLE pair | |||||||
|  |  | ||||||
|     template<class _U1, class _U2> |     template<class _U1, class _U2> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         pair(const pair<_U1, _U2>& __p, |         pair(const pair<_U1, _U2>& __p | ||||||
|                  typename enable_if<is_convertible<_U1, _T1>::value && | #ifndef _LIBCPP_HAS_NO_ADVANCED_SFINAE | ||||||
|                                     is_convertible<_U2, _T2>::value>::type* = 0) |                  ,typename enable_if<is_constructible<_T1, _U1>::value && | ||||||
|  |                                     is_constructible<_T2, _U2>::value>::type* = 0 | ||||||
|  | #endif | ||||||
|  |                                       ) | ||||||
|             : first(__p.first), second(__p.second) {} |             : first(__p.first), second(__p.second) {} | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     pair(const pair& __p) | ||||||
|  |         _NOEXCEPT_(is_nothrow_copy_constructible<first_type>::value && | ||||||
|  |                    is_nothrow_copy_constructible<second_type>::value) | ||||||
|  |         : first(__p.first), | ||||||
|  |           second(__p.second) | ||||||
|  |     { | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     pair& operator=(const pair& __p) | ||||||
|  |         _NOEXCEPT_(is_nothrow_copy_assignable<first_type>::value && | ||||||
|  |                    is_nothrow_copy_assignable<second_type>::value) | ||||||
|  |     { | ||||||
|  |         first = __p.first; | ||||||
|  |         second = __p.second; | ||||||
|  |         return *this; | ||||||
|  |     } | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
|     template <class _U1, class _U2, |     template <class _U1, class _U2, | ||||||
|               class = typename enable_if<is_convertible<_U1, first_type >::value && |               class = typename enable_if<is_constructible<first_type, _U1 >::value && | ||||||
|                                          is_convertible<_U2, second_type>::value>::type> |                                          is_constructible<second_type, _U2>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         pair(_U1&& __u1, _U2&& __u2) |         pair(_U1&& __u1, _U2&& __u2) | ||||||
|             : first(_STD::forward<_U1>(__u1)), |             : first(_VSTD::forward<_U1>(__u1)), | ||||||
|               second(_STD::forward<_U2>(__u2)) |               second(_VSTD::forward<_U2>(__u2)) | ||||||
|             {} |             {} | ||||||
|  |  | ||||||
|     template<class _U1, class _U2> |     template<class _U1, class _U2> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         pair(pair<_U1, _U2>&& __p, |         pair(pair<_U1, _U2>&& __p, | ||||||
|                  typename enable_if<is_convertible<_U1, _T1>::value && |                  typename enable_if<is_constructible<_T1, _U1>::value && | ||||||
|                                     is_convertible<_U2, _T2>::value>::type* = 0) |                                     is_constructible<_T2, _U2>::value>::type* = 0) | ||||||
|             : first(_STD::forward<_U1>(__p.first)), |             : first(_VSTD::forward<_U1>(__p.first)), | ||||||
|               second(_STD::forward<_U2>(__p.second)) {} |               second(_VSTD::forward<_U2>(__p.second)) {} | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     pair(pair&& __p) _NOEXCEPT_(is_nothrow_move_constructible<first_type>::value && | ||||||
|  |                                 is_nothrow_move_constructible<second_type>::value) | ||||||
|  |         : first(_VSTD::forward<first_type>(__p.first)), | ||||||
|  |           second(_VSTD::forward<second_type>(__p.second)) | ||||||
|  |     { | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     pair& | ||||||
|  |     operator=(pair&& __p) _NOEXCEPT_(is_nothrow_move_assignable<first_type>::value && | ||||||
|  |                                      is_nothrow_move_assignable<second_type>::value) | ||||||
|  |     { | ||||||
|  |         first = _VSTD::forward<first_type>(__p.first); | ||||||
|  |         second = _VSTD::forward<second_type>(__p.second); | ||||||
|  |         return *this; | ||||||
|  |     } | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
|  |  | ||||||
| @@ -243,9 +296,9 @@ struct _LIBCPP_VISIBLE pair | |||||||
|              class = typename enable_if<__tuple_convertible<_Tuple, pair>::value>::type> |              class = typename enable_if<__tuple_convertible<_Tuple, pair>::value>::type> | ||||||
|         _LIBCPP_INLINE_VISIBILITY |         _LIBCPP_INLINE_VISIBILITY | ||||||
|         pair(_Tuple&& __p) |         pair(_Tuple&& __p) | ||||||
|             : first(_STD::forward<typename tuple_element<0, |             : first(_VSTD::forward<typename tuple_element<0, | ||||||
|                                   typename __make_tuple_types<_Tuple>::type>::type>(get<0>(__p))), |                                   typename __make_tuple_types<_Tuple>::type>::type>(get<0>(__p))), | ||||||
|               second(_STD::forward<typename tuple_element<1, |               second(_VSTD::forward<typename tuple_element<1, | ||||||
|                                    typename __make_tuple_types<_Tuple>::type>::type>(get<1>(__p))) |                                    typename __make_tuple_types<_Tuple>::type>::type>(get<1>(__p))) | ||||||
|             {} |             {} | ||||||
|  |  | ||||||
| @@ -269,15 +322,22 @@ struct _LIBCPP_VISIBLE pair | |||||||
|             typedef typename __make_tuple_types<_Tuple>::type _TupleRef; |             typedef typename __make_tuple_types<_Tuple>::type _TupleRef; | ||||||
|             typedef typename tuple_element<0, _TupleRef>::type _U0; |             typedef typename tuple_element<0, _TupleRef>::type _U0; | ||||||
|             typedef typename tuple_element<1, _TupleRef>::type _U1; |             typedef typename tuple_element<1, _TupleRef>::type _U1; | ||||||
|             first  = _STD::forward<_U0>(_STD::get<0>(__p)); |             first  = _VSTD::forward<_U0>(_VSTD::get<0>(__p)); | ||||||
|             second = _STD::forward<_U1>(_STD::get<1>(__p)); |             second = _VSTD::forward<_U1>(_VSTD::get<1>(__p)); | ||||||
|             return *this; |             return *this; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|     void _LIBCPP_INLINE_VISIBILITY swap(pair& __p) {_STD::swap(*this, __p);} |     _LIBCPP_INLINE_VISIBILITY | ||||||
|  |     void | ||||||
|  |     swap(pair& __p) _NOEXCEPT_(__is_nothrow_swappable<first_type>::value && | ||||||
|  |                                __is_nothrow_swappable<second_type>::value) | ||||||
|  |     { | ||||||
|  |         _VSTD::iter_swap(&first, &__p.first); | ||||||
|  |         _VSTD::iter_swap(&second, &__p.second); | ||||||
|  |     } | ||||||
| private: | private: | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||||
| @@ -339,11 +399,17 @@ operator<=(const pair<_T1,_T2>& __x, const pair<_T1,_T2>& __y) | |||||||
|  |  | ||||||
| template <class _T1, class _T2> | template <class _T1, class _T2> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | typename enable_if | ||||||
|  | < | ||||||
|  |     __is_swappable<_T1>::value && | ||||||
|  |     __is_swappable<_T2>::value, | ||||||
|     void |     void | ||||||
|  | >::type | ||||||
| swap(pair<_T1, _T2>& __x, pair<_T1, _T2>& __y) | swap(pair<_T1, _T2>& __x, pair<_T1, _T2>& __y) | ||||||
|  |                      _NOEXCEPT_((__is_nothrow_swappable<_T1>::value && | ||||||
|  |                                  __is_nothrow_swappable<_T2>::value)) | ||||||
| { | { | ||||||
|     swap(__x.first, __y.first); |     __x.swap(__y); | ||||||
|     swap(__x.second, __y.second); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -374,7 +440,7 @@ pair<typename __make_pair_return<_T1>::type, typename __make_pair_return<_T2>::t | |||||||
| make_pair(_T1&& __t1, _T2&& __t2) | make_pair(_T1&& __t1, _T2&& __t2) | ||||||
| { | { | ||||||
|     return pair<typename __make_pair_return<_T1>::type, typename __make_pair_return<_T2>::type> |     return pair<typename __make_pair_return<_T1>::type, typename __make_pair_return<_T2>::type> | ||||||
|                (_STD::forward<_T1>(__t1), _STD::forward<_T2>(__t2)); |                (_VSTD::forward<_T1>(__t1), _VSTD::forward<_T2>(__t2)); | ||||||
| } | } | ||||||
|  |  | ||||||
| #else  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #else  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| @@ -436,13 +502,13 @@ struct __get_pair<0> | |||||||
|     static |     static | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     _T1& |     _T1& | ||||||
|     get(pair<_T1, _T2>& __p) {return __p.first;} |     get(pair<_T1, _T2>& __p) _NOEXCEPT {return __p.first;} | ||||||
|  |  | ||||||
|     template <class _T1, class _T2> |     template <class _T1, class _T2> | ||||||
|     static |     static | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const _T1& |     const _T1& | ||||||
|     get(const pair<_T1, _T2>& __p) {return __p.first;} |     get(const pair<_T1, _T2>& __p) _NOEXCEPT {return __p.first;} | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
| @@ -450,7 +516,7 @@ struct __get_pair<0> | |||||||
|     static |     static | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     _T1&& |     _T1&& | ||||||
|     get(pair<_T1, _T2>&& __p) {return _STD::forward<_T1>(__p.first);} |     get(pair<_T1, _T2>&& __p) _NOEXCEPT {return _VSTD::forward<_T1>(__p.first);} | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| }; | }; | ||||||
| @@ -462,13 +528,13 @@ struct __get_pair<1> | |||||||
|     static |     static | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     _T2& |     _T2& | ||||||
|     get(pair<_T1, _T2>& __p) {return __p.second;} |     get(pair<_T1, _T2>& __p) _NOEXCEPT {return __p.second;} | ||||||
|  |  | ||||||
|     template <class _T1, class _T2> |     template <class _T1, class _T2> | ||||||
|     static |     static | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     const _T2& |     const _T2& | ||||||
|     get(const pair<_T1, _T2>& __p) {return __p.second;} |     get(const pair<_T1, _T2>& __p) _NOEXCEPT {return __p.second;} | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|  |  | ||||||
| @@ -476,7 +542,7 @@ struct __get_pair<1> | |||||||
|     static |     static | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
|     _T2&& |     _T2&& | ||||||
|     get(pair<_T1, _T2>&& __p) {return _STD::forward<_T2>(__p.second);} |     get(pair<_T1, _T2>&& __p) _NOEXCEPT {return _VSTD::forward<_T2>(__p.second);} | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
| }; | }; | ||||||
| @@ -484,7 +550,7 @@ struct __get_pair<1> | |||||||
| template <size_t _Ip, class _T1, class _T2> | template <size_t _Ip, class _T1, class _T2> | ||||||
| _LIBCPP_INLINE_VISIBILITY inline | _LIBCPP_INLINE_VISIBILITY inline | ||||||
| typename tuple_element<_Ip, pair<_T1, _T2> >::type& | typename tuple_element<_Ip, pair<_T1, _T2> >::type& | ||||||
| get(pair<_T1, _T2>& __p) | get(pair<_T1, _T2>& __p) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __get_pair<_Ip>::get(__p); |     return __get_pair<_Ip>::get(__p); | ||||||
| } | } | ||||||
| @@ -492,7 +558,7 @@ get(pair<_T1, _T2>& __p) | |||||||
| template <size_t _Ip, class _T1, class _T2> | template <size_t _Ip, class _T1, class _T2> | ||||||
| _LIBCPP_INLINE_VISIBILITY inline | _LIBCPP_INLINE_VISIBILITY inline | ||||||
| const typename tuple_element<_Ip, pair<_T1, _T2> >::type& | const typename tuple_element<_Ip, pair<_T1, _T2> >::type& | ||||||
| get(const pair<_T1, _T2>& __p) | get(const pair<_T1, _T2>& __p) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __get_pair<_Ip>::get(__p); |     return __get_pair<_Ip>::get(__p); | ||||||
| } | } | ||||||
| @@ -502,9 +568,9 @@ get(const pair<_T1, _T2>& __p) | |||||||
| template <size_t _Ip, class _T1, class _T2> | template <size_t _Ip, class _T1, class _T2> | ||||||
| _LIBCPP_INLINE_VISIBILITY inline | _LIBCPP_INLINE_VISIBILITY inline | ||||||
| typename tuple_element<_Ip, pair<_T1, _T2> >::type&& | typename tuple_element<_Ip, pair<_T1, _T2> >::type&& | ||||||
| get(pair<_T1, _T2>&& __p) | get(pair<_T1, _T2>&& __p) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __get_pair<_Ip>::get(_STD::move(__p)); |     return __get_pair<_Ip>::get(_VSTD::move(__p)); | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||||
|   | |||||||
| @@ -817,6 +817,8 @@ public: | |||||||
|     valarray& operator=(const gslice_array<value_type>& __ga); |     valarray& operator=(const gslice_array<value_type>& __ga); | ||||||
|     valarray& operator=(const mask_array<value_type>& __ma); |     valarray& operator=(const mask_array<value_type>& __ma); | ||||||
|     valarray& operator=(const indirect_array<value_type>& __ia); |     valarray& operator=(const indirect_array<value_type>& __ia); | ||||||
|  |     template <class _ValExpr> | ||||||
|  |         valarray& operator=(const __val_expr<_ValExpr>& __v); | ||||||
|  |  | ||||||
|     // element access: |     // element access: | ||||||
|     _LIBCPP_INLINE_VISIBILITY |     _LIBCPP_INLINE_VISIBILITY | ||||||
| @@ -2862,7 +2864,7 @@ valarray<_Tp>::operator=(const valarray& __v) | |||||||
|     { |     { | ||||||
|         if (size() != __v.size()) |         if (size() != __v.size()) | ||||||
|             resize(__v.size()); |             resize(__v.size()); | ||||||
|         _STD::copy(__v.__begin_, __v.__end_, __begin_); |         _VSTD::copy(__v.__begin_, __v.__end_, __begin_); | ||||||
|     } |     } | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
| @@ -2889,7 +2891,7 @@ valarray<_Tp>::operator=(initializer_list<value_type> __il) | |||||||
| { | { | ||||||
|     if (size() != __il.size()) |     if (size() != __il.size()) | ||||||
|         resize(__il.size()); |         resize(__il.size()); | ||||||
|     _STD::copy(__il.begin(), __il.end(), __begin_); |     _VSTD::copy(__il.begin(), __il.end(), __begin_); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -2900,7 +2902,7 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| valarray<_Tp>& | valarray<_Tp>& | ||||||
| valarray<_Tp>::operator=(const value_type& __x) | valarray<_Tp>::operator=(const value_type& __x) | ||||||
| { | { | ||||||
|     _STD::fill(__begin_, __end_, __x); |     _VSTD::fill(__begin_, __end_, __x); | ||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -2958,6 +2960,21 @@ valarray<_Tp>::operator=(const indirect_array<value_type>& __ia) | |||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | template <class _Tp> | ||||||
|  | template <class _ValExpr> | ||||||
|  | inline _LIBCPP_INLINE_VISIBILITY | ||||||
|  | valarray<_Tp>& | ||||||
|  | valarray<_Tp>::operator=(const __val_expr<_ValExpr>& __v) | ||||||
|  | { | ||||||
|  |     size_t __n = __v.size(); | ||||||
|  |     if (size() != __n) | ||||||
|  |         resize(__n); | ||||||
|  |     value_type* __t = __begin_; | ||||||
|  |     for (size_t __i = 0; __i != __n; ++__t, ++__i) | ||||||
|  |         *__t = result_type(__v[__i]); | ||||||
|  |     return *this; | ||||||
|  | } | ||||||
|  |  | ||||||
| template <class _Tp> | template <class _Tp> | ||||||
| inline _LIBCPP_INLINE_VISIBILITY | inline _LIBCPP_INLINE_VISIBILITY | ||||||
| __val_expr<__slice_expr<const valarray<_Tp>&> > | __val_expr<__slice_expr<const valarray<_Tp>&> > | ||||||
| @@ -3415,8 +3432,8 @@ inline _LIBCPP_INLINE_VISIBILITY | |||||||
| void | void | ||||||
| valarray<_Tp>::swap(valarray& __v) | valarray<_Tp>::swap(valarray& __v) | ||||||
| { | { | ||||||
|     _STD::swap(__begin_, __v.__begin_); |     _VSTD::swap(__begin_, __v.__begin_); | ||||||
|     _STD::swap(__end_, __v.__end_); |     _VSTD::swap(__end_, __v.__end_); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp> | template <class _Tp> | ||||||
| @@ -3440,7 +3457,7 @@ valarray<_Tp>::min() const | |||||||
| { | { | ||||||
|     if (__begin_ == __end_) |     if (__begin_ == __end_) | ||||||
|         return value_type(); |         return value_type(); | ||||||
|     return *_STD::min_element(__begin_, __end_); |     return *_VSTD::min_element(__begin_, __end_); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp> | template <class _Tp> | ||||||
| @@ -3450,7 +3467,7 @@ valarray<_Tp>::max() const | |||||||
| { | { | ||||||
|     if (__begin_ == __end_) |     if (__begin_ == __end_) | ||||||
|         return value_type(); |         return value_type(); | ||||||
|     return *_STD::max_element(__begin_, __end_); |     return *_VSTD::max_element(__begin_, __end_); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class _Tp> | template <class _Tp> | ||||||
| @@ -3469,14 +3486,14 @@ valarray<_Tp>::shift(int __i) const | |||||||
|         value_type* __te; |         value_type* __te; | ||||||
|         if (__i >= 0) |         if (__i >= 0) | ||||||
|         { |         { | ||||||
|             __i = _STD::min(__i, static_cast<int>(__n)); |             __i = _VSTD::min(__i, static_cast<int>(__n)); | ||||||
|             __sb = __begin_ + __i; |             __sb = __begin_ + __i; | ||||||
|             __tb = __r.__begin_; |             __tb = __r.__begin_; | ||||||
|             __te = __r.__begin_ + (__n - __i); |             __te = __r.__begin_ + (__n - __i); | ||||||
|         } |         } | ||||||
|         else |         else | ||||||
|         { |         { | ||||||
|             __i = _STD::min(-__i, static_cast<int>(__n)); |             __i = _VSTD::min(-__i, static_cast<int>(__n)); | ||||||
|             __sb = __begin_; |             __sb = __begin_; | ||||||
|             __tb = __r.__begin_ + __i; |             __tb = __r.__begin_ + __i; | ||||||
|             __te = __r.__begin_ + __n; |             __te = __r.__begin_ + __n; | ||||||
|   | |||||||
							
								
								
									
										688
									
								
								include/vector
									
									
									
									
									
								
							
							
						
						
									
										688
									
								
								include/vector
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -27,12 +27,13 @@ endif() | |||||||
| append_if(libraries LIBCXX_HAS_PTHREAD_LIB pthread) | append_if(libraries LIBCXX_HAS_PTHREAD_LIB pthread) | ||||||
| append_if(libraries LIBCXX_HAS_C_LIB c) | append_if(libraries LIBCXX_HAS_C_LIB c) | ||||||
| append_if(libraries LIBCXX_HAS_M_LIB m) | append_if(libraries LIBCXX_HAS_M_LIB m) | ||||||
|  | append_if(libraries LIBCXX_HAS_RT_LIB rt) | ||||||
| append_if(libraries LIBCXX_HAS_GCC_S_LIB gcc_s) | append_if(libraries LIBCXX_HAS_GCC_S_LIB gcc_s) | ||||||
|  |  | ||||||
| target_link_libraries(cxx ${libraries}) | target_link_libraries(cxx ${libraries}) | ||||||
|  |  | ||||||
| # Setup flags. | # Setup flags. | ||||||
| #append_if(compile_flags LIBCXX_HAS_FPIC_FLAG -fPIC) | append_if(compile_flags LIBCXX_HAS_FPIC_FLAG -fPIC) | ||||||
| append_if(link_flags LIBCXX_HAS_NODEFAULTLIBS_FLAG -nodefaultlibs) | append_if(link_flags LIBCXX_HAS_NODEFAULTLIBS_FLAG -nodefaultlibs) | ||||||
|  |  | ||||||
| set_target_properties(cxx | set_target_properties(cxx | ||||||
|   | |||||||
							
								
								
									
										37
									
								
								lib/buildit
									
									
									
									
									
								
							
							
						
						
									
										37
									
								
								lib/buildit
									
									
									
									
									
								
							| @@ -17,19 +17,29 @@ then | |||||||
| 	CXX=clang++ | 	CXX=clang++ | ||||||
| fi | fi | ||||||
|  |  | ||||||
|  | if [ -z "$CC" ] | ||||||
|  | then | ||||||
|  |     CC=clang | ||||||
|  | fi | ||||||
|  |  | ||||||
| if [ -z $MACOSX_DEPLOYMENT_TARGET ] | if [ -z $MACOSX_DEPLOYMENT_TARGET ] | ||||||
|  | then | ||||||
|  | 	if [ -z $IPHONEOS_DEPLOYMENT_TARGET ] | ||||||
| 	then | 	then | ||||||
| 		MACOSX_DEPLOYMENT_TARGET=10.6 | 		MACOSX_DEPLOYMENT_TARGET=10.6 | ||||||
| 	fi | 	fi | ||||||
|  | fi | ||||||
|  |  | ||||||
| if [ -z $RC_ProjectSourceVersion ] | if [ -z $RC_ProjectSourceVersion ] | ||||||
| then | then | ||||||
|   RC_ProjectSourceVersion=1 |   RC_ProjectSourceVersion=1 | ||||||
| fi | fi | ||||||
|  |  | ||||||
|  | EXTRA_FLAGS="-std=c++0x " | ||||||
|  |  | ||||||
| case $TRIPLE in | case $TRIPLE in | ||||||
|   *-apple-*) |   *-apple-*) | ||||||
|     if [ -z $RC_BUILDIT ] |     if [ -z $RC_XBS ] | ||||||
|     then |     then | ||||||
|       RC_CFLAGS="-arch i386 -arch x86_64" |       RC_CFLAGS="-arch i386 -arch x86_64" | ||||||
|     fi |     fi | ||||||
| @@ -45,15 +55,26 @@ case $TRIPLE in | |||||||
| 			-Wl,-unexported_symbols_list,libc++unexp.exp  \ | 			-Wl,-unexported_symbols_list,libc++unexp.exp  \ | ||||||
| 			/usr/lib/libSystem.B.dylib" | 			/usr/lib/libSystem.B.dylib" | ||||||
| 	else | 	else | ||||||
| 	    EXTRA_FLAGS="-std=c++0x" | 		RE_EXPORT_LINE="/usr/lib/libc++abi.dylib -Wl,-reexported_symbols_list,libc++abi.exp" | ||||||
|  | 		if [ -n "$SDKROOT" ] | ||||||
|  | 		then | ||||||
|  | 			EXTRA_FLAGS+="-isysroot ${SDKROOT}" | ||||||
|  | 			if echo "${RC_ARCHS}" | grep -q "armv7"   | ||||||
|  | 			then | ||||||
|  | 				RE_EXPORT_LINE="${SDKROOT}/usr/lib/libc++abi.dylib -Wl,-reexported_symbols_list,libc++sjlj-abi.exp" | ||||||
|  | 			else | ||||||
|  | 				RE_EXPORT_LINE="-Wl,-reexport_library,${SDKROOT}/usr/lib/libc++abi.dylib" | ||||||
|  | 			fi | ||||||
|  | 			CXX=`xcrun -sdk "${SDKROOT}"  -find clang++` | ||||||
|  | 			CC=`xcrun -sdk "${SDKROOT}"  -find clang` | ||||||
|  | 		fi | ||||||
| 	    LDSHARED_FLAGS="-o libc++.1.dylib \ | 	    LDSHARED_FLAGS="-o libc++.1.dylib \ | ||||||
| 			-dynamiclib -nodefaultlibs  \ | 			-dynamiclib -nodefaultlibs  \ | ||||||
| 			-current_version ${RC_ProjectSourceVersion} -compatibility_version 1 \ | 			-current_version ${RC_ProjectSourceVersion} -compatibility_version 1 \ | ||||||
| 			-install_name /usr/lib/libc++.1.dylib \ | 			-install_name /usr/lib/libc++.1.dylib \ | ||||||
| 			${SDKROOT}/usr/lib/libc++abi.dylib \ |  | ||||||
| 			-lSystem  \ | 			-lSystem  \ | ||||||
| 			-Wl,-unexported_symbols_list,libc++unexp.exp  \ | 			-Wl,-unexported_symbols_list,libc++unexp.exp  \ | ||||||
| 			-Wl,-reexported_symbols_list,libc++abi.exp \ | 			${RE_EXPORT_LINE}  \ | ||||||
| 			-Wl,-force_symbols_not_weak_list,notweak.exp " | 			-Wl,-force_symbols_not_weak_list,notweak.exp " | ||||||
| 	fi | 	fi | ||||||
|     ;; |     ;; | ||||||
| @@ -62,11 +83,11 @@ case $TRIPLE in | |||||||
|     SOEXT=so |     SOEXT=so | ||||||
|     LDSHARED_FLAGS="-o libc++.so.1.0 \ |     LDSHARED_FLAGS="-o libc++.so.1.0 \ | ||||||
|         -shared -nodefaultlibs -Wl,-soname,libc++.so.1 \ |         -shared -nodefaultlibs -Wl,-soname,libc++.so.1 \ | ||||||
|         -lpthread -lrt -lc" |         -lpthread -lrt -lc -lstdc++" | ||||||
|     ;; |     ;; | ||||||
| esac | esac | ||||||
|  |  | ||||||
| if [ -z $RC_BUILDIT ] | if [ -z $RC_XBS ] | ||||||
| then | then | ||||||
|     rm -f libc++.1.$SOEXT* |     rm -f libc++.1.$SOEXT* | ||||||
| fi | fi | ||||||
| @@ -78,11 +99,11 @@ for FILE in ../src/*.cpp; do | |||||||
| done | done | ||||||
|  |  | ||||||
|  |  | ||||||
| cc *.o $RC_CFLAGS $LDSHARED_FLAGS | $CC *.o $RC_CFLAGS $LDSHARED_FLAGS $EXTRA_FLAGS | ||||||
|  |  | ||||||
| #libtool -static -o libc++.a *.o | #libtool -static -o libc++.a *.o | ||||||
|  |  | ||||||
| if [ -z $RC_BUILDIT ] | if [ -z $RC_XBS ] | ||||||
| then | then | ||||||
|     rm *.o |     rm *.o | ||||||
| fi | fi | ||||||
|   | |||||||
							
								
								
									
										159
									
								
								lib/libc++sjlj-abi.exp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										159
									
								
								lib/libc++sjlj-abi.exp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,159 @@ | |||||||
|  | ___cxa_allocate_exception | ||||||
|  | ___cxa_end_catch | ||||||
|  | ___cxa_demangle | ||||||
|  | ___cxa_current_exception_type | ||||||
|  | ___cxa_call_unexpected | ||||||
|  | ___cxa_free_exception | ||||||
|  | ___cxa_get_exception_ptr | ||||||
|  | ___cxa_get_globals | ||||||
|  | ___cxa_get_globals_fast | ||||||
|  | ___cxa_guard_abort | ||||||
|  | ___cxa_guard_acquire | ||||||
|  | ___cxa_guard_release | ||||||
|  | ___cxa_rethrow | ||||||
|  | ___cxa_pure_virtual | ||||||
|  | ___cxa_begin_catch | ||||||
|  | ___cxa_throw | ||||||
|  | ___cxa_vec_cctor | ||||||
|  | ___cxa_vec_cleanup | ||||||
|  | ___cxa_vec_ctor | ||||||
|  | ___cxa_vec_delete | ||||||
|  | ___cxa_vec_delete2 | ||||||
|  | ___cxa_vec_delete3 | ||||||
|  | ___cxa_vec_dtor | ||||||
|  | ___cxa_vec_new | ||||||
|  | ___cxa_vec_new2 | ||||||
|  | ___cxa_vec_new3 | ||||||
|  | ___dynamic_cast | ||||||
|  | ___gxx_personality_sj0 | ||||||
|  | __ZTIDi | ||||||
|  | __ZTIDn | ||||||
|  | __ZTIDs | ||||||
|  | __ZTIPDi | ||||||
|  | __ZTIPDn | ||||||
|  | __ZTIPDs | ||||||
|  | __ZTIPKDi | ||||||
|  | __ZTIPKDn | ||||||
|  | __ZTIPKDs | ||||||
|  | __ZTSPm | ||||||
|  | __ZTSPl | ||||||
|  | __ZTSPj | ||||||
|  | __ZTSPi | ||||||
|  | __ZTSPh | ||||||
|  | __ZTSPf | ||||||
|  | __ZTSPe | ||||||
|  | __ZTSPd | ||||||
|  | __ZTSPc | ||||||
|  | __ZTSPb | ||||||
|  | __ZTSPa | ||||||
|  | __ZTSPKc | ||||||
|  | __ZTSPKy | ||||||
|  | __ZTSPKx | ||||||
|  | __ZTSPKw | ||||||
|  | __ZTSPKv | ||||||
|  | __ZTSPKt | ||||||
|  | __ZTSPKs | ||||||
|  | __ZTSPKm | ||||||
|  | __ZTSPKl | ||||||
|  | __ZTSPKi | ||||||
|  | __ZTSPKh | ||||||
|  | __ZTSPs | ||||||
|  | __ZTSPt | ||||||
|  | __ZTSPv | ||||||
|  | __ZTSPw | ||||||
|  | __ZTSPKa | ||||||
|  | __ZTSPx | ||||||
|  | __ZTSPy | ||||||
|  | __ZTSPKd | ||||||
|  | __ZTSPKe | ||||||
|  | __ZTSPKj | ||||||
|  | __ZTSPKb | ||||||
|  | __ZTSPKf | ||||||
|  | __ZTSv | ||||||
|  | __ZTSt | ||||||
|  | __ZTSs | ||||||
|  | __ZTSm | ||||||
|  | __ZTSl | ||||||
|  | __ZTSj | ||||||
|  | __ZTSi | ||||||
|  | __ZTSh | ||||||
|  | __ZTSf | ||||||
|  | __ZTSe | ||||||
|  | __ZTSd | ||||||
|  | __ZTSc | ||||||
|  | __ZTSw | ||||||
|  | __ZTSx | ||||||
|  | __ZTSy | ||||||
|  | __ZTSb | ||||||
|  | __ZTSa | ||||||
|  | __ZTIPKh | ||||||
|  | __ZTIPKf | ||||||
|  | __ZTIPKe | ||||||
|  | __ZTIPKd | ||||||
|  | __ZTIPKc | ||||||
|  | __ZTIPKb | ||||||
|  | __ZTIPKa | ||||||
|  | __ZTIPy | ||||||
|  | __ZTIPx | ||||||
|  | __ZTIPw | ||||||
|  | __ZTIPv | ||||||
|  | __ZTIPt | ||||||
|  | __ZTIPs | ||||||
|  | __ZTIPm | ||||||
|  | __ZTIPl | ||||||
|  | __ZTIPj | ||||||
|  | __ZTIPi | ||||||
|  | __ZTIPKi | ||||||
|  | __ZTIPKj | ||||||
|  | __ZTIPKl | ||||||
|  | __ZTIPKm | ||||||
|  | __ZTIPKs | ||||||
|  | __ZTIPKt | ||||||
|  | __ZTIPKv | ||||||
|  | __ZTIPKw | ||||||
|  | __ZTIPKx | ||||||
|  | __ZTIPKy | ||||||
|  | __ZTIPa | ||||||
|  | __ZTIPb | ||||||
|  | __ZTIPc | ||||||
|  | __ZTIPd | ||||||
|  | __ZTIPe | ||||||
|  | __ZTIPf | ||||||
|  | __ZTIPh | ||||||
|  | __ZTVN10__cxxabiv129__pointer_to_member_type_infoE | ||||||
|  | __ZTVN10__cxxabiv116__enum_type_infoE | ||||||
|  | __ZTVN10__cxxabiv117__array_type_infoE | ||||||
|  | __ZTVN10__cxxabiv117__class_type_infoE | ||||||
|  | __ZTVN10__cxxabiv117__pbase_type_infoE | ||||||
|  | __ZTVN10__cxxabiv119__pointer_type_infoE | ||||||
|  | __ZTVN10__cxxabiv120__function_type_infoE | ||||||
|  | __ZTVN10__cxxabiv120__si_class_type_infoE | ||||||
|  | __ZTVN10__cxxabiv121__vmi_class_type_infoE | ||||||
|  | __ZTVN10__cxxabiv123__fundamental_type_infoE | ||||||
|  | __ZTIa | ||||||
|  | __ZTIb | ||||||
|  | __ZTIc | ||||||
|  | __ZTId | ||||||
|  | __ZTIe | ||||||
|  | __ZTIf | ||||||
|  | __ZTIh | ||||||
|  | __ZTIi | ||||||
|  | __ZTIj | ||||||
|  | __ZTIl | ||||||
|  | __ZTIm | ||||||
|  | __ZTIs | ||||||
|  | __ZTIt | ||||||
|  | __ZTSN10__cxxabiv129__pointer_to_member_type_infoE | ||||||
|  | __ZTSN10__cxxabiv123__fundamental_type_infoE | ||||||
|  | __ZTSN10__cxxabiv121__vmi_class_type_infoE | ||||||
|  | __ZTSN10__cxxabiv120__si_class_type_infoE | ||||||
|  | __ZTSN10__cxxabiv120__function_type_infoE | ||||||
|  | __ZTSN10__cxxabiv119__pointer_type_infoE | ||||||
|  | __ZTSN10__cxxabiv117__pbase_type_infoE | ||||||
|  | __ZTSN10__cxxabiv117__class_type_infoE | ||||||
|  | __ZTSN10__cxxabiv117__array_type_infoE | ||||||
|  | __ZTSN10__cxxabiv116__enum_type_infoE | ||||||
|  | __ZTIy | ||||||
|  | __ZTIx | ||||||
|  | __ZTIw | ||||||
|  | __ZTIv | ||||||
| @@ -25,7 +25,7 @@ namespace chrono | |||||||
| // system_clock | // system_clock | ||||||
|  |  | ||||||
| system_clock::time_point | system_clock::time_point | ||||||
| system_clock::now() | system_clock::now() _NOEXCEPT | ||||||
| { | { | ||||||
|     timeval tv; |     timeval tv; | ||||||
|     gettimeofday(&tv, 0); |     gettimeofday(&tv, 0); | ||||||
| @@ -33,13 +33,13 @@ system_clock::now() | |||||||
| } | } | ||||||
|  |  | ||||||
| time_t | time_t | ||||||
| system_clock::to_time_t(const time_point& t) | system_clock::to_time_t(const time_point& t) _NOEXCEPT | ||||||
| { | { | ||||||
|     return time_t(duration_cast<seconds>(t.time_since_epoch()).count()); |     return time_t(duration_cast<seconds>(t.time_since_epoch()).count()); | ||||||
| } | } | ||||||
|  |  | ||||||
| system_clock::time_point | system_clock::time_point | ||||||
| system_clock::from_time_t(time_t t) | system_clock::from_time_t(time_t t) _NOEXCEPT | ||||||
| { | { | ||||||
|     return system_clock::time_point(seconds(t)); |     return system_clock::time_point(seconds(t)); | ||||||
| } | } | ||||||
| @@ -97,7 +97,7 @@ init_steady_clock() | |||||||
| #pragma GCC visibility pop | #pragma GCC visibility pop | ||||||
|  |  | ||||||
| steady_clock::time_point | steady_clock::time_point | ||||||
| steady_clock::now() | steady_clock::now() _NOEXCEPT | ||||||
| { | { | ||||||
|     static FP fp = init_steady_clock(); |     static FP fp = init_steady_clock(); | ||||||
|     return time_point(duration(fp())); |     return time_point(duration(fp())); | ||||||
| @@ -114,18 +114,12 @@ steady_clock::now() | |||||||
| //  instead. | //  instead. | ||||||
|  |  | ||||||
| steady_clock::time_point | steady_clock::time_point | ||||||
| steady_clock::now() | steady_clock::now() _NOEXCEPT | ||||||
| { | { | ||||||
| #ifdef __MINGW32__ |  | ||||||
|     timeval tv; |  | ||||||
|     gettimeofday(&tv, 0); |  | ||||||
|     return time_point(seconds(tv.tv_sec) + microseconds(tv.tv_usec)); |  | ||||||
| #else |  | ||||||
|     struct timespec tp; |     struct timespec tp; | ||||||
|     if (0 != clock_gettime(CLOCK_MONOTONIC, &tp)) |     if (0 != clock_gettime(CLOCK_MONOTONIC, &tp)) | ||||||
|         __throw_system_error(errno, "clock_gettime(CLOCK_MONOTONIC) failed"); |         __throw_system_error(errno, "clock_gettime(CLOCK_MONOTONIC) failed"); | ||||||
|     return time_point(seconds(tp.tv_sec) + nanoseconds(tp.tv_nsec)); |     return time_point(seconds(tp.tv_sec) + nanoseconds(tp.tv_nsec)); | ||||||
| #endif |  | ||||||
| } | } | ||||||
| #endif  // __APPLE__ | #endif  // __APPLE__ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -57,10 +57,8 @@ condition_variable::__do_timed_wait(unique_lock<mutex>& lk, | |||||||
|     ts.tv_sec = static_cast<decltype(ts.tv_sec)>(s.count()); |     ts.tv_sec = static_cast<decltype(ts.tv_sec)>(s.count()); | ||||||
|     ts.tv_nsec = static_cast<decltype(ts.tv_nsec)>((d - s).count()); |     ts.tv_nsec = static_cast<decltype(ts.tv_nsec)>((d - s).count()); | ||||||
|     int ec = pthread_cond_timedwait(&__cv_, lk.mutex()->native_handle(), &ts); |     int ec = pthread_cond_timedwait(&__cv_, lk.mutex()->native_handle(), &ts); | ||||||
| #ifndef __MINGW32__ |  | ||||||
|     if (ec != 0 && ec != ETIMEDOUT) |     if (ec != 0 && ec != ETIMEDOUT) | ||||||
|         __throw_system_error(ec, "condition_variable timed_wait failed"); |         __throw_system_error(ec, "condition_variable timed_wait failed"); | ||||||
| #endif |  | ||||||
| } | } | ||||||
|  |  | ||||||
| void | void | ||||||
|   | |||||||
| @@ -24,17 +24,18 @@ | |||||||
| #endif  // __APPLE__ | #endif  // __APPLE__ | ||||||
|  |  | ||||||
| std::unexpected_handler | std::unexpected_handler | ||||||
| std::set_unexpected(std::unexpected_handler func) throw() | std::set_unexpected(std::unexpected_handler func) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __sync_lock_test_and_set(&__unexpected_handler, func); |     return __sync_lock_test_and_set(&__unexpected_handler, func); | ||||||
| } | } | ||||||
|  |  | ||||||
| std::unexpected_handler | std::unexpected_handler | ||||||
| std::get_unexpected() throw() | std::get_unexpected() _NOEXCEPT | ||||||
| { | { | ||||||
|     return __sync_fetch_and_add(&__unexpected_handler, (std::unexpected_handler)0); |     return __sync_fetch_and_add(&__unexpected_handler, (std::unexpected_handler)0); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | _ATTRIBUTE(noreturn) | ||||||
| void | void | ||||||
| std::unexpected() | std::unexpected() | ||||||
| { | { | ||||||
| @@ -44,19 +45,20 @@ std::unexpected() | |||||||
| } | } | ||||||
|  |  | ||||||
| std::terminate_handler | std::terminate_handler | ||||||
| std::set_terminate(std::terminate_handler func) throw() | std::set_terminate(std::terminate_handler func) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __sync_lock_test_and_set(&__terminate_handler, func); |     return __sync_lock_test_and_set(&__terminate_handler, func); | ||||||
| } | } | ||||||
|  |  | ||||||
| std::terminate_handler | std::terminate_handler | ||||||
| std::get_terminate() throw() | std::get_terminate() _NOEXCEPT | ||||||
| { | { | ||||||
|     return __sync_fetch_and_add(&__terminate_handler, (std::terminate_handler)0); |     return __sync_fetch_and_add(&__terminate_handler, (std::terminate_handler)0); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | _ATTRIBUTE(noreturn) | ||||||
| void | void | ||||||
| std::terminate() | std::terminate() _NOEXCEPT | ||||||
| { | { | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     try |     try | ||||||
| @@ -75,11 +77,8 @@ std::terminate() | |||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
| } | } | ||||||
|  |  | ||||||
| bool std::uncaught_exception() throw() | bool std::uncaught_exception() _NOEXCEPT | ||||||
| { | { | ||||||
| #ifdef _LIBCPP_NO_EXCEPTIONS |  | ||||||
|     return false; |  | ||||||
| #endif |  | ||||||
| #if __APPLE__ | #if __APPLE__ | ||||||
|     // on Darwin, there is a helper function so __cxa_get_globals is private |     // on Darwin, there is a helper function so __cxa_get_globals is private | ||||||
|     return __cxxabiapple::__cxa_uncaught_exception(); |     return __cxxabiapple::__cxa_uncaught_exception(); | ||||||
| @@ -95,25 +94,25 @@ bool std::uncaught_exception() throw() | |||||||
| namespace std | namespace std | ||||||
| { | { | ||||||
|  |  | ||||||
| exception::~exception() throw() | exception::~exception() _NOEXCEPT | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| bad_exception::~bad_exception() throw() | bad_exception::~bad_exception() _NOEXCEPT | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| const char* exception::what() const throw() | const char* exception::what() const _NOEXCEPT | ||||||
| { | { | ||||||
|   return "std::exception"; |   return "std::exception"; | ||||||
| } | } | ||||||
|  |  | ||||||
| const char* bad_exception::what() const throw() | const char* bad_exception::what() const _NOEXCEPT | ||||||
| { | { | ||||||
|   return "std::bad_exception"; |   return "std::bad_exception"; | ||||||
| } | } | ||||||
|  |  | ||||||
| exception_ptr::~exception_ptr() | exception_ptr::~exception_ptr() _NOEXCEPT | ||||||
| { | { | ||||||
| #if __APPLE__ | #if __APPLE__ | ||||||
|     __cxxabiapple::__cxa_decrement_exception_refcount(__ptr_); |     __cxxabiapple::__cxa_decrement_exception_refcount(__ptr_); | ||||||
| @@ -123,7 +122,7 @@ exception_ptr::~exception_ptr() | |||||||
| #endif  // __APPLE__ | #endif  // __APPLE__ | ||||||
| } | } | ||||||
|  |  | ||||||
| exception_ptr::exception_ptr(const exception_ptr& other) | exception_ptr::exception_ptr(const exception_ptr& other) _NOEXCEPT | ||||||
|     : __ptr_(other.__ptr_) |     : __ptr_(other.__ptr_) | ||||||
| { | { | ||||||
| #if __APPLE__ | #if __APPLE__ | ||||||
| @@ -134,7 +133,7 @@ exception_ptr::exception_ptr(const exception_ptr& other) | |||||||
| #endif  // __APPLE__ | #endif  // __APPLE__ | ||||||
| } | } | ||||||
|  |  | ||||||
| exception_ptr& exception_ptr::operator=(const exception_ptr& other) | exception_ptr& exception_ptr::operator=(const exception_ptr& other) _NOEXCEPT | ||||||
| { | { | ||||||
| #if __APPLE__ | #if __APPLE__ | ||||||
|     if (__ptr_ != other.__ptr_) |     if (__ptr_ != other.__ptr_) | ||||||
| @@ -150,17 +149,18 @@ exception_ptr& exception_ptr::operator=(const exception_ptr& other) | |||||||
| #endif  // __APPLE__ | #endif  // __APPLE__ | ||||||
| } | } | ||||||
|  |  | ||||||
| nested_exception::nested_exception() | nested_exception::nested_exception() _NOEXCEPT | ||||||
|     : __ptr_(current_exception()) |     : __ptr_(current_exception()) | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| nested_exception::~nested_exception() | nested_exception::~nested_exception() _NOEXCEPT | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
|  | _ATTRIBUTE(noreturn) | ||||||
| void | void | ||||||
| nested_exception::rethrow_nested /*[[noreturn]]*/ () const | nested_exception::rethrow_nested() const | ||||||
| { | { | ||||||
|     if (__ptr_ == nullptr) |     if (__ptr_ == nullptr) | ||||||
|         terminate(); |         terminate(); | ||||||
| @@ -169,7 +169,7 @@ nested_exception::rethrow_nested /*[[noreturn]]*/ () const | |||||||
|  |  | ||||||
| } // std | } // std | ||||||
|  |  | ||||||
| std::exception_ptr std::current_exception() | std::exception_ptr std::current_exception() _NOEXCEPT | ||||||
| { | { | ||||||
| #if __APPLE__ | #if __APPLE__ | ||||||
|     // be nicer if there was a constructor that took a ptr, then |     // be nicer if there was a constructor that took a ptr, then | ||||||
|   | |||||||
| @@ -16,12 +16,12 @@ class _LIBCPP_HIDDEN __future_error_category | |||||||
|     : public __do_message |     : public __do_message | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     virtual const char* name() const; |     virtual const char* name() const _NOEXCEPT; | ||||||
|     virtual string message(int ev) const; |     virtual string message(int ev) const; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const char* | const char* | ||||||
| __future_error_category::name() const | __future_error_category::name() const _NOEXCEPT | ||||||
| { | { | ||||||
|     return "future"; |     return "future"; | ||||||
| } | } | ||||||
| @@ -59,8 +59,12 @@ future_error::future_error(error_code __ec) | |||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
|  | future_error::~future_error() _NOEXCEPT | ||||||
|  | { | ||||||
|  | } | ||||||
|  |  | ||||||
| void | void | ||||||
| __assoc_sub_state::__on_zero_shared() | __assoc_sub_state::__on_zero_shared() _NOEXCEPT | ||||||
| { | { | ||||||
|     delete this; |     delete this; | ||||||
| } | } | ||||||
| @@ -69,8 +73,10 @@ void | |||||||
| __assoc_sub_state::set_value() | __assoc_sub_state::set_value() | ||||||
| { | { | ||||||
|     unique_lock<mutex> __lk(__mut_); |     unique_lock<mutex> __lk(__mut_); | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__has_value()) |     if (__has_value()) | ||||||
|         throw future_error(make_error_code(future_errc::promise_already_satisfied)); |         throw future_error(make_error_code(future_errc::promise_already_satisfied)); | ||||||
|  | #endif | ||||||
|     __state_ |= __constructed | ready; |     __state_ |= __constructed | ready; | ||||||
|     __lk.unlock(); |     __lk.unlock(); | ||||||
|     __cv_.notify_all(); |     __cv_.notify_all(); | ||||||
| @@ -80,8 +86,10 @@ void | |||||||
| __assoc_sub_state::set_value_at_thread_exit() | __assoc_sub_state::set_value_at_thread_exit() | ||||||
| { | { | ||||||
|     unique_lock<mutex> __lk(__mut_); |     unique_lock<mutex> __lk(__mut_); | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__has_value()) |     if (__has_value()) | ||||||
|         throw future_error(make_error_code(future_errc::promise_already_satisfied)); |         throw future_error(make_error_code(future_errc::promise_already_satisfied)); | ||||||
|  | #endif | ||||||
|     __state_ |= __constructed; |     __state_ |= __constructed; | ||||||
|     __thread_local_data()->__make_ready_at_thread_exit(this); |     __thread_local_data()->__make_ready_at_thread_exit(this); | ||||||
|     __lk.unlock(); |     __lk.unlock(); | ||||||
| @@ -91,8 +99,10 @@ void | |||||||
| __assoc_sub_state::set_exception(exception_ptr __p) | __assoc_sub_state::set_exception(exception_ptr __p) | ||||||
| { | { | ||||||
|     unique_lock<mutex> __lk(__mut_); |     unique_lock<mutex> __lk(__mut_); | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__has_value()) |     if (__has_value()) | ||||||
|         throw future_error(make_error_code(future_errc::promise_already_satisfied)); |         throw future_error(make_error_code(future_errc::promise_already_satisfied)); | ||||||
|  | #endif | ||||||
|     __exception_ = __p; |     __exception_ = __p; | ||||||
|     __state_ |= ready; |     __state_ |= ready; | ||||||
|     __lk.unlock(); |     __lk.unlock(); | ||||||
| @@ -103,8 +113,10 @@ void | |||||||
| __assoc_sub_state::set_exception_at_thread_exit(exception_ptr __p) | __assoc_sub_state::set_exception_at_thread_exit(exception_ptr __p) | ||||||
| { | { | ||||||
|     unique_lock<mutex> __lk(__mut_); |     unique_lock<mutex> __lk(__mut_); | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__has_value()) |     if (__has_value()) | ||||||
|         throw future_error(make_error_code(future_errc::promise_already_satisfied)); |         throw future_error(make_error_code(future_errc::promise_already_satisfied)); | ||||||
|  | #endif | ||||||
|     __exception_ = __p; |     __exception_ = __p; | ||||||
|     __thread_local_data()->__make_ready_at_thread_exit(this); |     __thread_local_data()->__make_ready_at_thread_exit(this); | ||||||
|     __lk.unlock(); |     __lk.unlock(); | ||||||
| @@ -155,14 +167,18 @@ __assoc_sub_state::__sub_wait(unique_lock<mutex>& __lk) | |||||||
| void | void | ||||||
| __assoc_sub_state::__execute() | __assoc_sub_state::__execute() | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     throw future_error(make_error_code(future_errc::no_state)); |     throw future_error(make_error_code(future_errc::no_state)); | ||||||
|  | #endif | ||||||
| } | } | ||||||
|  |  | ||||||
| future<void>::future(__assoc_sub_state* __state) | future<void>::future(__assoc_sub_state* __state) | ||||||
|     : __state_(__state) |     : __state_(__state) | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_->__has_future_attached()) |     if (__state_->__has_future_attached()) | ||||||
|         throw future_error(make_error_code(future_errc::future_already_retrieved)); |         throw future_error(make_error_code(future_errc::future_already_retrieved)); | ||||||
|  | #endif | ||||||
|     __state_->__add_shared(); |     __state_->__add_shared(); | ||||||
|     __state_->__set_future_attached(); |     __state_->__set_future_attached(); | ||||||
| } | } | ||||||
| @@ -202,40 +218,50 @@ promise<void>::~promise() | |||||||
| future<void> | future<void> | ||||||
| promise<void>::get_future() | promise<void>::get_future() | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_ == nullptr) |     if (__state_ == nullptr) | ||||||
|         throw future_error(make_error_code(future_errc::no_state)); |         throw future_error(make_error_code(future_errc::no_state)); | ||||||
|  | #endif | ||||||
|     return future<void>(__state_); |     return future<void>(__state_); | ||||||
| } | } | ||||||
|  |  | ||||||
| void | void | ||||||
| promise<void>::set_value() | promise<void>::set_value() | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_ == nullptr) |     if (__state_ == nullptr) | ||||||
|         throw future_error(make_error_code(future_errc::no_state)); |         throw future_error(make_error_code(future_errc::no_state)); | ||||||
|  | #endif | ||||||
|     __state_->set_value(); |     __state_->set_value(); | ||||||
| } | } | ||||||
|  |  | ||||||
| void | void | ||||||
| promise<void>::set_exception(exception_ptr __p) | promise<void>::set_exception(exception_ptr __p) | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_ == nullptr) |     if (__state_ == nullptr) | ||||||
|         throw future_error(make_error_code(future_errc::no_state)); |         throw future_error(make_error_code(future_errc::no_state)); | ||||||
|  | #endif | ||||||
|     __state_->set_exception(__p); |     __state_->set_exception(__p); | ||||||
| } | } | ||||||
|  |  | ||||||
| void | void | ||||||
| promise<void>::set_value_at_thread_exit() | promise<void>::set_value_at_thread_exit() | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_ == nullptr) |     if (__state_ == nullptr) | ||||||
|         throw future_error(make_error_code(future_errc::no_state)); |         throw future_error(make_error_code(future_errc::no_state)); | ||||||
|  | #endif | ||||||
|     __state_->set_value_at_thread_exit(); |     __state_->set_value_at_thread_exit(); | ||||||
| } | } | ||||||
|  |  | ||||||
| void | void | ||||||
| promise<void>::set_exception_at_thread_exit(exception_ptr __p) | promise<void>::set_exception_at_thread_exit(exception_ptr __p) | ||||||
| { | { | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     if (__state_ == nullptr) |     if (__state_ == nullptr) | ||||||
|         throw future_error(make_error_code(future_errc::no_state)); |         throw future_error(make_error_code(future_errc::no_state)); | ||||||
|  | #endif | ||||||
|     __state_->set_exception_at_thread_exit(__p); |     __state_->set_exception_at_thread_exit(__p); | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										42
									
								
								src/ios.cpp
									
									
									
									
									
								
							
							
						
						
									
										42
									
								
								src/ios.cpp
									
									
									
									
									
								
							| @@ -38,12 +38,12 @@ class _LIBCPP_HIDDEN __iostream_category | |||||||
|     : public __do_message |     : public __do_message | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     virtual const char* name() const; |     virtual const char* name() const _NOEXCEPT; | ||||||
|     virtual string message(int ev) const; |     virtual string message(int ev) const; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const char* | const char* | ||||||
| __iostream_category::name() const | __iostream_category::name() const _NOEXCEPT | ||||||
| { | { | ||||||
|     return "iostream"; |     return "iostream"; | ||||||
| } | } | ||||||
| @@ -165,7 +165,7 @@ ios_base::iword(int index) | |||||||
|         size_t newcap; |         size_t newcap; | ||||||
|         const size_t mx = std::numeric_limits<size_t>::max(); |         const size_t mx = std::numeric_limits<size_t>::max(); | ||||||
|         if (req_size < mx/2) |         if (req_size < mx/2) | ||||||
|             newcap = _STD::max(2 * __iarray_cap_, req_size); |             newcap = _VSTD::max(2 * __iarray_cap_, req_size); | ||||||
|         else |         else | ||||||
|             newcap = mx; |             newcap = mx; | ||||||
|         long* iarray = (long*)realloc(__iarray_, newcap * sizeof(long)); |         long* iarray = (long*)realloc(__iarray_, newcap * sizeof(long)); | ||||||
| @@ -193,7 +193,7 @@ ios_base::pword(int index) | |||||||
|         size_t newcap; |         size_t newcap; | ||||||
|         const size_t mx = std::numeric_limits<size_t>::max(); |         const size_t mx = std::numeric_limits<size_t>::max(); | ||||||
|         if (req_size < mx/2) |         if (req_size < mx/2) | ||||||
|             newcap = _STD::max(2 * __parray_cap_, req_size); |             newcap = _VSTD::max(2 * __parray_cap_, req_size); | ||||||
|         else |         else | ||||||
|             newcap = mx; |             newcap = mx; | ||||||
|         void** parray = (void**)realloc(__parray_, newcap * sizeof(void*)); |         void** parray = (void**)realloc(__parray_, newcap * sizeof(void*)); | ||||||
| @@ -223,7 +223,7 @@ ios_base::register_callback(event_callback fn, int index) | |||||||
|         size_t newcap; |         size_t newcap; | ||||||
|         const size_t mx = std::numeric_limits<size_t>::max(); |         const size_t mx = std::numeric_limits<size_t>::max(); | ||||||
|         if (req_size < mx/2) |         if (req_size < mx/2) | ||||||
|             newcap = _STD::max(2 * __event_cap_, req_size); |             newcap = _VSTD::max(2 * __event_cap_, req_size); | ||||||
|         else |         else | ||||||
|             newcap = mx; |             newcap = mx; | ||||||
|         event_callback* fns = (event_callback*)realloc(__fn_, newcap * sizeof(event_callback)); |         event_callback* fns = (event_callback*)realloc(__fn_, newcap * sizeof(event_callback)); | ||||||
| @@ -403,24 +403,24 @@ ios_base::move(ios_base& rhs) | |||||||
| void | void | ||||||
| ios_base::swap(ios_base& rhs) | ios_base::swap(ios_base& rhs) | ||||||
| { | { | ||||||
|     _STD::swap(__fmtflags_, rhs.__fmtflags_); |     _VSTD::swap(__fmtflags_, rhs.__fmtflags_); | ||||||
|     _STD::swap(__precision_, rhs.__precision_); |     _VSTD::swap(__precision_, rhs.__precision_); | ||||||
|     _STD::swap(__width_, rhs.__width_); |     _VSTD::swap(__width_, rhs.__width_); | ||||||
|     _STD::swap(__rdstate_, rhs.__rdstate_); |     _VSTD::swap(__rdstate_, rhs.__rdstate_); | ||||||
|     _STD::swap(__exceptions_, rhs.__exceptions_); |     _VSTD::swap(__exceptions_, rhs.__exceptions_); | ||||||
|     locale& lhs_loc = *(locale*)&__loc_; |     locale& lhs_loc = *(locale*)&__loc_; | ||||||
|     locale& rhs_loc = *(locale*)&rhs.__loc_; |     locale& rhs_loc = *(locale*)&rhs.__loc_; | ||||||
|     _STD::swap(lhs_loc, rhs_loc); |     _VSTD::swap(lhs_loc, rhs_loc); | ||||||
|     _STD::swap(__fn_, rhs.__fn_); |     _VSTD::swap(__fn_, rhs.__fn_); | ||||||
|     _STD::swap(__index_, rhs.__index_); |     _VSTD::swap(__index_, rhs.__index_); | ||||||
|     _STD::swap(__event_size_, rhs.__event_size_); |     _VSTD::swap(__event_size_, rhs.__event_size_); | ||||||
|     _STD::swap(__event_cap_, rhs.__event_cap_); |     _VSTD::swap(__event_cap_, rhs.__event_cap_); | ||||||
|     _STD::swap(__iarray_, rhs.__iarray_); |     _VSTD::swap(__iarray_, rhs.__iarray_); | ||||||
|     _STD::swap(__iarray_size_, rhs.__iarray_size_); |     _VSTD::swap(__iarray_size_, rhs.__iarray_size_); | ||||||
|     _STD::swap(__iarray_cap_, rhs.__iarray_cap_); |     _VSTD::swap(__iarray_cap_, rhs.__iarray_cap_); | ||||||
|     _STD::swap(__parray_, rhs.__parray_); |     _VSTD::swap(__parray_, rhs.__parray_); | ||||||
|     _STD::swap(__parray_size_, rhs.__parray_size_); |     _VSTD::swap(__parray_size_, rhs.__parray_size_); | ||||||
|     _STD::swap(__parray_cap_, rhs.__parray_cap_); |     _VSTD::swap(__parray_cap_, rhs.__parray_cap_); | ||||||
| } | } | ||||||
|  |  | ||||||
| void | void | ||||||
|   | |||||||
| @@ -33,11 +33,11 @@ ios_base::Init __start_std_streams; | |||||||
| ios_base::Init::Init() | ios_base::Init::Init() | ||||||
| { | { | ||||||
|     cin.tie(&cout); |     cin.tie(&cout); | ||||||
|     _STD::unitbuf(cerr); |     _VSTD::unitbuf(cerr); | ||||||
|     cerr.tie(&cout); |     cerr.tie(&cout); | ||||||
|  |  | ||||||
|     wcin.tie(&wcout); |     wcin.tie(&wcout); | ||||||
|     _STD::unitbuf(wcerr); |     _VSTD::unitbuf(wcerr); | ||||||
|     wcerr.tie(&wcout); |     wcerr.tie(&wcout); | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										570
									
								
								src/locale.cpp
									
									
									
									
									
								
							
							
						
						
									
										570
									
								
								src/locale.cpp
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -16,14 +16,14 @@ namespace | |||||||
|  |  | ||||||
| template <class T> | template <class T> | ||||||
| inline T | inline T | ||||||
| increment(T& t) | increment(T& t) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __sync_add_and_fetch(&t, 1); |     return __sync_add_and_fetch(&t, 1); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class T> | template <class T> | ||||||
| inline T | inline T | ||||||
| decrement(T& t) | decrement(T& t) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __sync_add_and_fetch(&t, -1); |     return __sync_add_and_fetch(&t, -1); | ||||||
| } | } | ||||||
| @@ -32,10 +32,10 @@ decrement(T& t) | |||||||
|  |  | ||||||
| const allocator_arg_t allocator_arg = allocator_arg_t(); | const allocator_arg_t allocator_arg = allocator_arg_t(); | ||||||
|  |  | ||||||
| bad_weak_ptr::~bad_weak_ptr() throw() {} | bad_weak_ptr::~bad_weak_ptr() _NOEXCEPT {} | ||||||
|  |  | ||||||
| const char* | const char* | ||||||
| bad_weak_ptr::what() const throw() | bad_weak_ptr::what() const _NOEXCEPT | ||||||
| { | { | ||||||
|     return "bad_weak_ptr"; |     return "bad_weak_ptr"; | ||||||
| } | } | ||||||
| @@ -45,13 +45,13 @@ __shared_count::~__shared_count() | |||||||
| } | } | ||||||
|  |  | ||||||
| void | void | ||||||
| __shared_count::__add_shared() | __shared_count::__add_shared() _NOEXCEPT | ||||||
| { | { | ||||||
|     increment(__shared_owners_); |     increment(__shared_owners_); | ||||||
| } | } | ||||||
|  |  | ||||||
| bool | bool | ||||||
| __shared_count::__release_shared() | __shared_count::__release_shared() _NOEXCEPT | ||||||
| { | { | ||||||
|     if (decrement(__shared_owners_) == -1) |     if (decrement(__shared_owners_) == -1) | ||||||
|     { |     { | ||||||
| @@ -66,33 +66,33 @@ __shared_weak_count::~__shared_weak_count() | |||||||
| } | } | ||||||
|  |  | ||||||
| void | void | ||||||
| __shared_weak_count::__add_shared() | __shared_weak_count::__add_shared() _NOEXCEPT | ||||||
| { | { | ||||||
|     __shared_count::__add_shared(); |     __shared_count::__add_shared(); | ||||||
| } | } | ||||||
|  |  | ||||||
| void | void | ||||||
| __shared_weak_count::__add_weak() | __shared_weak_count::__add_weak() _NOEXCEPT | ||||||
| { | { | ||||||
|     increment(__shared_weak_owners_); |     increment(__shared_weak_owners_); | ||||||
| } | } | ||||||
|  |  | ||||||
| void | void | ||||||
| __shared_weak_count::__release_shared() | __shared_weak_count::__release_shared() _NOEXCEPT | ||||||
| { | { | ||||||
|     if (__shared_count::__release_shared()) |     if (__shared_count::__release_shared()) | ||||||
|         __release_weak(); |         __release_weak(); | ||||||
| } | } | ||||||
|  |  | ||||||
| void | void | ||||||
| __shared_weak_count::__release_weak() | __shared_weak_count::__release_weak() _NOEXCEPT | ||||||
| { | { | ||||||
|     if (decrement(__shared_weak_owners_) == -1) |     if (decrement(__shared_weak_owners_) == -1) | ||||||
|         __on_zero_shared_weak(); |         __on_zero_shared_weak(); | ||||||
| } | } | ||||||
|  |  | ||||||
| __shared_weak_count* | __shared_weak_count* | ||||||
| __shared_weak_count::lock() | __shared_weak_count::lock() _NOEXCEPT | ||||||
| { | { | ||||||
|     long object_owners = __shared_owners_; |     long object_owners = __shared_owners_; | ||||||
|     while (object_owners != -1) |     while (object_owners != -1) | ||||||
| @@ -112,7 +112,7 @@ __shared_weak_count::lock() | |||||||
| #ifndef _LIBCPP_NO_RTTI | #ifndef _LIBCPP_NO_RTTI | ||||||
|  |  | ||||||
| const void* | const void* | ||||||
| __shared_weak_count::__get_deleter(const type_info&) const | __shared_weak_count::__get_deleter(const type_info&) const _NOEXCEPT | ||||||
| { | { | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| @@ -135,7 +135,7 @@ undeclare_no_pointers(char*, size_t) | |||||||
| } | } | ||||||
|  |  | ||||||
| pointer_safety | pointer_safety | ||||||
| get_pointer_safety() | get_pointer_safety() _NOEXCEPT | ||||||
| { | { | ||||||
|     return pointer_safety::relaxed; |     return pointer_safety::relaxed; | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										124
									
								
								src/new.cpp
									
									
									
									
									
								
							
							
						
						
									
										124
									
								
								src/new.cpp
									
									
									
									
									
								
							| @@ -18,16 +18,116 @@ | |||||||
|     // in the ABI library and named __cxa_new_handler. |     // in the ABI library and named __cxa_new_handler. | ||||||
|     #define __new_handler __cxxabiapple::__cxa_new_handler |     #define __new_handler __cxxabiapple::__cxa_new_handler | ||||||
| #else  // __APPLE__ | #else  // __APPLE__ | ||||||
|     _LIBCPP_BEGIN_NAMESPACE_STD |     static std::new_handler __new_handler; | ||||||
|         ::std::new_handler __new_handler; |  | ||||||
|     _LIBCPP_END_NAMESPACE_STD |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if 0 |  | ||||||
| // Implement all new and delete operators as weak definitions | // Implement all new and delete operators as weak definitions | ||||||
| // in this shared library, so that they can be overriden by programs | // in this shared library, so that they can be overriden by programs | ||||||
| // that define non-weak copies of the functions. | // that define non-weak copies of the functions. | ||||||
|  |  | ||||||
|  | __attribute__((__weak__, __visibility__("default"))) | ||||||
|  | void * | ||||||
|  | operator new(std::size_t size) | ||||||
|  | #if !__has_feature(cxx_noexcept) | ||||||
|  |     throw(std::bad_alloc) | ||||||
| #endif | #endif | ||||||
|  | { | ||||||
|  |     if (size == 0) | ||||||
|  |         size = 1; | ||||||
|  |     void* p; | ||||||
|  |     while ((p = ::malloc(size)) == 0) | ||||||
|  |     { | ||||||
|  |         // If malloc fails and there is a new_handler, | ||||||
|  |         // call it to try free up memory. | ||||||
|  |         std::new_handler nh = std::get_new_handler(); | ||||||
|  |         if (nh) | ||||||
|  |             nh(); | ||||||
|  |         else | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|  |             throw std::bad_alloc(); | ||||||
|  | #else | ||||||
|  |             break; | ||||||
|  | #endif | ||||||
|  |     } | ||||||
|  |     return p; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | __attribute__((__weak__, __visibility__("default"))) | ||||||
|  | void* | ||||||
|  | operator new(size_t size, const std::nothrow_t&) _NOEXCEPT | ||||||
|  | { | ||||||
|  |     void* p = 0; | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|  |     try | ||||||
|  |     { | ||||||
|  | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|  |         p = ::operator new(size); | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|  |     } | ||||||
|  |     catch (...) | ||||||
|  |     { | ||||||
|  |     } | ||||||
|  | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|  |     return p; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | __attribute__((__weak__, __visibility__("default"))) | ||||||
|  | void* | ||||||
|  | operator new[](size_t size) | ||||||
|  | #if !__has_feature(cxx_noexcept) | ||||||
|  |     throw(std::bad_alloc) | ||||||
|  | #endif | ||||||
|  | { | ||||||
|  |     return ::operator new(size); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | __attribute__((__weak__, __visibility__("default"))) | ||||||
|  | void* | ||||||
|  | operator new[](size_t size, const std::nothrow_t& nothrow) _NOEXCEPT | ||||||
|  | { | ||||||
|  |     void* p = 0; | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|  |     try | ||||||
|  |     { | ||||||
|  | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|  |         p = ::operator new[](size); | ||||||
|  | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|  |     } | ||||||
|  |     catch (...) | ||||||
|  |     { | ||||||
|  |     } | ||||||
|  | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|  |     return p; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | __attribute__((__weak__, __visibility__("default"))) | ||||||
|  | void | ||||||
|  | operator delete(void* ptr) _NOEXCEPT | ||||||
|  | { | ||||||
|  |     if (ptr) | ||||||
|  |         ::free(ptr); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | __attribute__((__weak__, __visibility__("default"))) | ||||||
|  | void | ||||||
|  | operator delete(void* ptr, const std::nothrow_t&) _NOEXCEPT | ||||||
|  | { | ||||||
|  |     ::operator delete(ptr); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | __attribute__((__weak__, __visibility__("default"))) | ||||||
|  | void | ||||||
|  | operator delete[] (void* ptr) _NOEXCEPT | ||||||
|  | { | ||||||
|  |     ::operator delete (ptr); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | __attribute__((__weak__, __visibility__("default"))) | ||||||
|  | void | ||||||
|  | operator delete[] (void* ptr, const std::nothrow_t&) _NOEXCEPT | ||||||
|  | { | ||||||
|  |     ::operator delete[](ptr); | ||||||
|  | } | ||||||
|  |  | ||||||
| namespace std | namespace std | ||||||
| { | { | ||||||
| @@ -35,41 +135,41 @@ namespace std | |||||||
| const nothrow_t nothrow = {}; | const nothrow_t nothrow = {}; | ||||||
|  |  | ||||||
| new_handler | new_handler | ||||||
| set_new_handler(new_handler handler) throw() | set_new_handler(new_handler handler) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __sync_lock_test_and_set(&__new_handler, handler); |     return __sync_lock_test_and_set(&__new_handler, handler); | ||||||
| } | } | ||||||
|  |  | ||||||
| new_handler | new_handler | ||||||
| get_new_handler() throw() | get_new_handler() _NOEXCEPT | ||||||
| { | { | ||||||
|     return __sync_fetch_and_add(&__new_handler, (new_handler)0); |     return __sync_fetch_and_add(&__new_handler, (new_handler)0); | ||||||
| } | } | ||||||
|  |  | ||||||
| bad_alloc::bad_alloc() throw() | bad_alloc::bad_alloc() _NOEXCEPT | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| bad_alloc::~bad_alloc() throw() | bad_alloc::~bad_alloc() _NOEXCEPT | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| const char* | const char* | ||||||
| bad_alloc::what() const throw() | bad_alloc::what() const _NOEXCEPT | ||||||
| { | { | ||||||
|     return "std::bad_alloc"; |     return "std::bad_alloc"; | ||||||
| } | } | ||||||
|  |  | ||||||
| bad_array_new_length::bad_array_new_length() throw() | bad_array_new_length::bad_array_new_length() _NOEXCEPT | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| bad_array_new_length::~bad_array_new_length() throw() | bad_array_new_length::~bad_array_new_length() _NOEXCEPT | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| const char* | const char* | ||||||
| bad_array_new_length::what() const throw() | bad_array_new_length::what() const _NOEXCEPT | ||||||
| { | { | ||||||
|     return "bad_array_new_length"; |     return "bad_array_new_length"; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,7 +0,0 @@ | |||||||
| #include "new" |  | ||||||
|  |  | ||||||
| void |  | ||||||
| operator delete[] (void* ptr) throw () |  | ||||||
| { |  | ||||||
|     ::operator delete (ptr); |  | ||||||
| } |  | ||||||
| @@ -1,7 +0,0 @@ | |||||||
| #include "new" |  | ||||||
|  |  | ||||||
| void |  | ||||||
| operator delete[] (void* ptr, const std::nothrow_t&) throw () |  | ||||||
| { |  | ||||||
|     ::operator delete[](ptr); |  | ||||||
| } |  | ||||||
| @@ -1,10 +0,0 @@ | |||||||
| #include <stdlib.h> |  | ||||||
|  |  | ||||||
| #include "new" |  | ||||||
|  |  | ||||||
| void |  | ||||||
| operator delete(void* ptr) throw () |  | ||||||
| { |  | ||||||
|     if (ptr) |  | ||||||
|         ::free(ptr); |  | ||||||
| } |  | ||||||
| @@ -1,7 +0,0 @@ | |||||||
| #include "new" |  | ||||||
|  |  | ||||||
| void |  | ||||||
| operator delete(void* ptr, const std::nothrow_t&) throw () |  | ||||||
| { |  | ||||||
|     ::operator delete(ptr); |  | ||||||
| } |  | ||||||
| @@ -1,7 +0,0 @@ | |||||||
| #include "new" |  | ||||||
|  |  | ||||||
| void* |  | ||||||
| operator new[](size_t size) throw (std::bad_alloc) |  | ||||||
| { |  | ||||||
|     return ::operator new(size); |  | ||||||
| } |  | ||||||
| @@ -1,19 +0,0 @@ | |||||||
| #include "new" |  | ||||||
|  |  | ||||||
| void* |  | ||||||
| operator new[](size_t size, const std::nothrow_t& nothrow) throw() |  | ||||||
| { |  | ||||||
|     void* p = 0; |  | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS |  | ||||||
|     try |  | ||||||
|     { |  | ||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS |  | ||||||
|         p = ::operator new[](size); |  | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS |  | ||||||
|     } |  | ||||||
|     catch (...) |  | ||||||
|     { |  | ||||||
|     } |  | ||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS |  | ||||||
|     return p; |  | ||||||
| } |  | ||||||
| @@ -1,26 +0,0 @@ | |||||||
| #include <stdlib.h> |  | ||||||
|  |  | ||||||
| #include "new" |  | ||||||
|  |  | ||||||
| void * |  | ||||||
| operator new(std::size_t size) throw (std::bad_alloc) |  | ||||||
| { |  | ||||||
|     if (size == 0) |  | ||||||
|         size = 1; |  | ||||||
|     void* p; |  | ||||||
|     while ((p = ::malloc(size)) == 0) |  | ||||||
|     { |  | ||||||
|         // If malloc fails and there is a new_handler, |  | ||||||
|         // call it to try free up memory. |  | ||||||
|         std::new_handler nh = std::get_new_handler(); |  | ||||||
|         if (nh) |  | ||||||
|             nh(); |  | ||||||
|         else |  | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS |  | ||||||
|             throw std::bad_alloc(); |  | ||||||
| #else |  | ||||||
|             break; |  | ||||||
| #endif |  | ||||||
|     } |  | ||||||
|     return p; |  | ||||||
| } |  | ||||||
| @@ -1,19 +0,0 @@ | |||||||
| #include "new" |  | ||||||
|  |  | ||||||
| void* |  | ||||||
| operator new(size_t size, const std::nothrow_t&) throw() |  | ||||||
| { |  | ||||||
|     void* p = 0; |  | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS |  | ||||||
|     try |  | ||||||
|     { |  | ||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS |  | ||||||
|         p = ::operator new(size); |  | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS |  | ||||||
|     } |  | ||||||
|     catch (...) |  | ||||||
|     { |  | ||||||
|     } |  | ||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS |  | ||||||
|     return p; |  | ||||||
| } |  | ||||||
| @@ -229,7 +229,7 @@ string | |||||||
| __get_collation_name(const char* s) | __get_collation_name(const char* s) | ||||||
| { | { | ||||||
|     const collationnames* i = |     const collationnames* i = | ||||||
|             _STD::lower_bound(begin(collatenames), end(collatenames), s, use_strcmp()); |             _VSTD::lower_bound(begin(collatenames), end(collatenames), s, use_strcmp()); | ||||||
|     string r; |     string r; | ||||||
|     if (i != end(collatenames) && strcmp(s, i->elem_) == 0) |     if (i != end(collatenames) && strcmp(s, i->elem_) == 0) | ||||||
|         r = char(i->char_); |         r = char(i->char_); | ||||||
| @@ -240,7 +240,7 @@ ctype_base::mask | |||||||
| __get_classname(const char* s, bool __icase) | __get_classname(const char* s, bool __icase) | ||||||
| { | { | ||||||
|     const classnames* i = |     const classnames* i = | ||||||
|             _STD::lower_bound(begin(ClassNames), end(ClassNames), s, use_strcmp()); |             _VSTD::lower_bound(begin(ClassNames), end(ClassNames), s, use_strcmp()); | ||||||
|     ctype_base::mask r = 0; |     ctype_base::mask r = 0; | ||||||
|     if (i != end(ClassNames) && strcmp(s, i->elem_) == 0) |     if (i != end(ClassNames) && strcmp(s, i->elem_) == 0) | ||||||
|     { |     { | ||||||
|   | |||||||
| @@ -34,13 +34,13 @@ private: | |||||||
|     static const std::ptrdiff_t offset = static_cast<std::ptrdiff_t>(2*sizeof(unused_t) + |     static const std::ptrdiff_t offset = static_cast<std::ptrdiff_t>(2*sizeof(unused_t) + | ||||||
|                                                                        sizeof(count_t)); |                                                                        sizeof(count_t)); | ||||||
|  |  | ||||||
|     count_t& count() const throw() {return (count_t&)(*(str_ - sizeof(count_t)));} |     count_t& count() const _NOEXCEPT {return (count_t&)(*(str_ - sizeof(count_t)));} | ||||||
| public: | public: | ||||||
|     explicit __libcpp_nmstr(const char* msg); |     explicit __libcpp_nmstr(const char* msg); | ||||||
|     __libcpp_nmstr(const __libcpp_nmstr& s) _LIBCPP_CANTTHROW; |     __libcpp_nmstr(const __libcpp_nmstr& s) _LIBCPP_CANTTHROW; | ||||||
|     __libcpp_nmstr& operator=(const __libcpp_nmstr& s) _LIBCPP_CANTTHROW; |     __libcpp_nmstr& operator=(const __libcpp_nmstr& s) _LIBCPP_CANTTHROW; | ||||||
|     ~__libcpp_nmstr() _LIBCPP_CANTTHROW; |     ~__libcpp_nmstr() _LIBCPP_CANTTHROW; | ||||||
|     const char* c_str() const throw() {return str_;} |     const char* c_str() const _NOEXCEPT {return str_;} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| __libcpp_nmstr::__libcpp_nmstr(const char* msg) | __libcpp_nmstr::__libcpp_nmstr(const char* msg) | ||||||
| @@ -98,14 +98,14 @@ logic_error::logic_error(const char* msg) | |||||||
|     ::new(&s) __libcpp_nmstr(msg); |     ::new(&s) __libcpp_nmstr(msg); | ||||||
| } | } | ||||||
|  |  | ||||||
| logic_error::logic_error(const logic_error& le) throw() | logic_error::logic_error(const logic_error& le) _NOEXCEPT | ||||||
| { | { | ||||||
|     __libcpp_nmstr& s = (__libcpp_nmstr&)__imp_; |     __libcpp_nmstr& s = (__libcpp_nmstr&)__imp_; | ||||||
|     ::new(&s) __libcpp_nmstr((const __libcpp_nmstr&)le.__imp_); |     ::new(&s) __libcpp_nmstr((const __libcpp_nmstr&)le.__imp_); | ||||||
| } | } | ||||||
|  |  | ||||||
| logic_error& | logic_error& | ||||||
| logic_error::operator=(const logic_error& le) throw() | logic_error::operator=(const logic_error& le) _NOEXCEPT | ||||||
| { | { | ||||||
|     __libcpp_nmstr& s1 = (__libcpp_nmstr&)__imp_; |     __libcpp_nmstr& s1 = (__libcpp_nmstr&)__imp_; | ||||||
|     const __libcpp_nmstr& s2 = (const __libcpp_nmstr&)le.__imp_; |     const __libcpp_nmstr& s2 = (const __libcpp_nmstr&)le.__imp_; | ||||||
| @@ -113,14 +113,14 @@ logic_error::operator=(const logic_error& le) throw() | |||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| logic_error::~logic_error() throw() | logic_error::~logic_error() _NOEXCEPT | ||||||
| { | { | ||||||
|     __libcpp_nmstr& s = (__libcpp_nmstr&)__imp_; |     __libcpp_nmstr& s = (__libcpp_nmstr&)__imp_; | ||||||
|     s.~__libcpp_nmstr(); |     s.~__libcpp_nmstr(); | ||||||
| } | } | ||||||
|  |  | ||||||
| const char* | const char* | ||||||
| logic_error::what() const throw() | logic_error::what() const _NOEXCEPT | ||||||
| { | { | ||||||
|     __libcpp_nmstr& s = (__libcpp_nmstr&)__imp_; |     __libcpp_nmstr& s = (__libcpp_nmstr&)__imp_; | ||||||
|     return s.c_str(); |     return s.c_str(); | ||||||
| @@ -138,14 +138,14 @@ runtime_error::runtime_error(const char* msg) | |||||||
|     ::new(&s) __libcpp_nmstr(msg); |     ::new(&s) __libcpp_nmstr(msg); | ||||||
| } | } | ||||||
|  |  | ||||||
| runtime_error::runtime_error(const runtime_error& le) throw() | runtime_error::runtime_error(const runtime_error& le) _NOEXCEPT | ||||||
| { | { | ||||||
|     __libcpp_nmstr& s = (__libcpp_nmstr&)__imp_; |     __libcpp_nmstr& s = (__libcpp_nmstr&)__imp_; | ||||||
|     ::new(&s) __libcpp_nmstr((const __libcpp_nmstr&)le.__imp_); |     ::new(&s) __libcpp_nmstr((const __libcpp_nmstr&)le.__imp_); | ||||||
| } | } | ||||||
|  |  | ||||||
| runtime_error& | runtime_error& | ||||||
| runtime_error::operator=(const runtime_error& le) throw() | runtime_error::operator=(const runtime_error& le) _NOEXCEPT | ||||||
| { | { | ||||||
|     __libcpp_nmstr& s1 = (__libcpp_nmstr&)__imp_; |     __libcpp_nmstr& s1 = (__libcpp_nmstr&)__imp_; | ||||||
|     const __libcpp_nmstr& s2 = (const __libcpp_nmstr&)le.__imp_; |     const __libcpp_nmstr& s2 = (const __libcpp_nmstr&)le.__imp_; | ||||||
| @@ -153,26 +153,26 @@ runtime_error::operator=(const runtime_error& le) throw() | |||||||
|     return *this; |     return *this; | ||||||
| } | } | ||||||
|  |  | ||||||
| runtime_error::~runtime_error() throw() | runtime_error::~runtime_error() _NOEXCEPT | ||||||
| { | { | ||||||
|     __libcpp_nmstr& s = (__libcpp_nmstr&)__imp_; |     __libcpp_nmstr& s = (__libcpp_nmstr&)__imp_; | ||||||
|     s.~__libcpp_nmstr(); |     s.~__libcpp_nmstr(); | ||||||
| } | } | ||||||
|  |  | ||||||
| const char* | const char* | ||||||
| runtime_error::what() const throw() | runtime_error::what() const _NOEXCEPT | ||||||
| { | { | ||||||
|     __libcpp_nmstr& s = (__libcpp_nmstr&)__imp_; |     __libcpp_nmstr& s = (__libcpp_nmstr&)__imp_; | ||||||
|     return s.c_str(); |     return s.c_str(); | ||||||
| } | } | ||||||
|  |  | ||||||
| domain_error::~domain_error() throw() {} | domain_error::~domain_error() _NOEXCEPT {} | ||||||
| invalid_argument::~invalid_argument() throw() {} | invalid_argument::~invalid_argument() _NOEXCEPT {} | ||||||
| length_error::~length_error() throw() {} | length_error::~length_error() _NOEXCEPT {} | ||||||
| out_of_range::~out_of_range() throw() {} | out_of_range::~out_of_range() _NOEXCEPT {} | ||||||
|  |  | ||||||
| range_error::~range_error() throw() {} | range_error::~range_error() _NOEXCEPT {} | ||||||
| overflow_error::~overflow_error() throw() {} | overflow_error::~overflow_error() _NOEXCEPT {} | ||||||
| underflow_error::~underflow_error() throw() {} | underflow_error::~underflow_error() _NOEXCEPT {} | ||||||
|  |  | ||||||
| }  // std | }  // std | ||||||
|   | |||||||
| @@ -7,17 +7,11 @@ | |||||||
| // | // | ||||||
| //===----------------------------------------------------------------------===// | //===----------------------------------------------------------------------===// | ||||||
|  |  | ||||||
| #define MINGW_HAS_SECURE_API |  | ||||||
|  |  | ||||||
| #include "string" | #include "string" | ||||||
| #include "cstdlib" | #include "cstdlib" | ||||||
| #include "cwchar" | #include "cwchar" | ||||||
| #include "cerrno" | #include "cerrno" | ||||||
|  |  | ||||||
| #ifdef _WIN32 |  | ||||||
| #define swprintf swprintf_s |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| _LIBCPP_BEGIN_NAMESPACE_STD | _LIBCPP_BEGIN_NAMESPACE_STD | ||||||
|  |  | ||||||
| template class __basic_string_common<true>; | template class __basic_string_common<true>; | ||||||
| @@ -25,52 +19,6 @@ template class __basic_string_common<true>; | |||||||
| template class basic_string<char>; | template class basic_string<char>; | ||||||
| template class basic_string<wchar_t>; | template class basic_string<wchar_t>; | ||||||
|  |  | ||||||
| template enable_if<__is_forward_iterator<char const*>::value, void>::type |  | ||||||
|     basic_string<char, char_traits<char>, allocator<char> > |  | ||||||
|     ::__init<char const*>(char const*, char const*); |  | ||||||
|  |  | ||||||
| template enable_if<__is_forward_iterator<wchar_t const*>::value, void>::type |  | ||||||
|     basic_string<wchar_t, char_traits<wchar_t>, allocator<wchar_t> > |  | ||||||
|     ::__init<wchar_t const*>(wchar_t const*, wchar_t const*); |  | ||||||
|  |  | ||||||
| template |  | ||||||
|     enable_if<__is_forward_iterator<char*>::value, |  | ||||||
|     basic_string<char, char_traits<char>, allocator<char> >&>::type |  | ||||||
|     basic_string<char, char_traits<char>, allocator<char> >:: |  | ||||||
|     append<char*>(char*, char*); |  | ||||||
|  |  | ||||||
| template |  | ||||||
|     enable_if<__is_forward_iterator<wchar_t*>::value, |  | ||||||
|     basic_string<wchar_t, char_traits<wchar_t>, allocator<wchar_t> >&>::type |  | ||||||
|     basic_string<wchar_t, char_traits<wchar_t>, allocator<wchar_t> >:: |  | ||||||
|     append<wchar_t*>(wchar_t*, wchar_t*); |  | ||||||
|  |  | ||||||
| template |  | ||||||
|     enable_if<__is_forward_iterator<char const*>::value, |  | ||||||
|     string::iterator>::type |  | ||||||
|     string:: |  | ||||||
|     insert<char const*>(string::const_iterator, char const*, char const*); |  | ||||||
|  |  | ||||||
| template |  | ||||||
|     enable_if<__is_forward_iterator<wchar_t const*>::value, |  | ||||||
|     wstring::iterator>::type |  | ||||||
|     wstring:: |  | ||||||
|     insert<wchar_t const*>(wstring::const_iterator, wchar_t const*, wchar_t const*); |  | ||||||
|  |  | ||||||
| template |  | ||||||
|     enable_if<__is_input_iterator<char const*>::value, string&>::type |  | ||||||
|     string:: |  | ||||||
|     replace<char const*>(string::const_iterator, string::const_iterator, char const*, char const*); |  | ||||||
|  |  | ||||||
| template |  | ||||||
|     enable_if<__is_input_iterator<wchar_t const*>::value, wstring&>::type |  | ||||||
|     wstring:: |  | ||||||
|     replace<wchar_t const*>(wstring::const_iterator, wstring::const_iterator, wchar_t const*, wchar_t const*); |  | ||||||
|  |  | ||||||
| template |  | ||||||
|     enable_if<__is_forward_iterator<wchar_t*>::value, wstring&>::type |  | ||||||
|     wstring::assign<wchar_t*>(wchar_t*, wchar_t*); |  | ||||||
|  |  | ||||||
| template | template | ||||||
|     string |     string | ||||||
|     operator+<char, char_traits<char>, allocator<char> >(char const*, string const&); |     operator+<char, char_traits<char>, allocator<char> >(char const*, string const&); | ||||||
|   | |||||||
| @@ -100,41 +100,6 @@ strstreambuf::strstreambuf(const unsigned char* __gnext, streamsize __n) | |||||||
|     __init((char*)__gnext, __n, nullptr); |     __init((char*)__gnext, __n, nullptr); | ||||||
| } | } | ||||||
|  |  | ||||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES |  | ||||||
|  |  | ||||||
| strstreambuf::strstreambuf(strstreambuf&& __rhs) |  | ||||||
|     : streambuf(__rhs), |  | ||||||
|       __strmode_(__rhs.__strmode_), |  | ||||||
|       __alsize_(__rhs.__alsize_), |  | ||||||
|       __palloc_(__rhs.__palloc_), |  | ||||||
|       __pfree_(__rhs.__pfree_) |  | ||||||
| { |  | ||||||
|     __rhs.setg(nullptr, nullptr, nullptr); |  | ||||||
|     __rhs.setp(nullptr, nullptr); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| strstreambuf& |  | ||||||
| strstreambuf::operator=(strstreambuf&& __rhs) |  | ||||||
| { |  | ||||||
|     if (eback() && (__strmode_ & __allocated) != 0 && (__strmode_ & __frozen) == 0) |  | ||||||
|     { |  | ||||||
|         if (__pfree_) |  | ||||||
|             __pfree_(eback()); |  | ||||||
|         else |  | ||||||
|             delete [] eback(); |  | ||||||
|     } |  | ||||||
|     streambuf::operator=(__rhs); |  | ||||||
|     __strmode_ = __rhs.__strmode_; |  | ||||||
|     __alsize_ = __rhs.__alsize_; |  | ||||||
|     __palloc_ = __rhs.__palloc_; |  | ||||||
|     __pfree_ = __rhs.__pfree_; |  | ||||||
|     __rhs.setg(nullptr, nullptr, nullptr); |  | ||||||
|     __rhs.setp(nullptr, nullptr); |  | ||||||
|     return *this; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES |  | ||||||
|  |  | ||||||
| strstreambuf::~strstreambuf() | strstreambuf::~strstreambuf() | ||||||
| { | { | ||||||
|     if (eback() && (__strmode_ & __allocated) != 0 && (__strmode_ & __frozen) == 0) |     if (eback() && (__strmode_ & __allocated) != 0 && (__strmode_ & __frozen) == 0) | ||||||
| @@ -150,10 +115,10 @@ void | |||||||
| strstreambuf::swap(strstreambuf& __rhs) | strstreambuf::swap(strstreambuf& __rhs) | ||||||
| { | { | ||||||
|     streambuf::swap(__rhs); |     streambuf::swap(__rhs); | ||||||
|     _STD::swap(__strmode_, __rhs.__strmode_); |     _VSTD::swap(__strmode_, __rhs.__strmode_); | ||||||
|     _STD::swap(__alsize_, __rhs.__alsize_); |     _VSTD::swap(__alsize_, __rhs.__alsize_); | ||||||
|     _STD::swap(__palloc_, __rhs.__palloc_); |     _VSTD::swap(__palloc_, __rhs.__palloc_); | ||||||
|     _STD::swap(__pfree_, __rhs.__pfree_); |     _VSTD::swap(__pfree_, __rhs.__pfree_); | ||||||
| } | } | ||||||
|  |  | ||||||
| void | void | ||||||
| @@ -302,7 +267,7 @@ strstreambuf::seekoff(off_type __off, ios_base::seekdir __way, ios_base::openmod | |||||||
|         { |         { | ||||||
|             char* newpos = eback() + newoff; |             char* newpos = eback() + newoff; | ||||||
|             if (pos_in) |             if (pos_in) | ||||||
|                 setg(eback(), newpos, _STD::max(newpos, egptr())); |                 setg(eback(), newpos, _VSTD::max(newpos, egptr())); | ||||||
|             if (pos_out) |             if (pos_out) | ||||||
|             { |             { | ||||||
|                 // min(pbase, newpos), newpos, epptr() |                 // min(pbase, newpos), newpos, epptr() | ||||||
| @@ -332,7 +297,7 @@ strstreambuf::seekpos(pos_type __sp, ios_base::openmode __which) | |||||||
|             { |             { | ||||||
|                 char* newpos = eback() + newoff; |                 char* newpos = eback() + newoff; | ||||||
|                 if (pos_in) |                 if (pos_in) | ||||||
|                     setg(eback(), newpos, _STD::max(newpos, egptr())); |                     setg(eback(), newpos, _VSTD::max(newpos, egptr())); | ||||||
|                 if (pos_out) |                 if (pos_out) | ||||||
|                 { |                 { | ||||||
|                     // min(pbase, newpos), newpos, epptr() |                     // min(pbase, newpos), newpos, epptr() | ||||||
|   | |||||||
| @@ -15,28 +15,28 @@ _LIBCPP_BEGIN_NAMESPACE_STD | |||||||
|  |  | ||||||
| // class error_category | // class error_category | ||||||
|  |  | ||||||
| error_category::error_category() | error_category::error_category() _NOEXCEPT | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| error_category::~error_category() | error_category::~error_category() _NOEXCEPT | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| error_condition | error_condition | ||||||
| error_category::default_error_condition(int ev) const | error_category::default_error_condition(int ev) const _NOEXCEPT | ||||||
| { | { | ||||||
|     return error_condition(ev, *this); |     return error_condition(ev, *this); | ||||||
| } | } | ||||||
|  |  | ||||||
| bool | bool | ||||||
| error_category::equivalent(int code, const error_condition& condition) const | error_category::equivalent(int code, const error_condition& condition) const _NOEXCEPT | ||||||
| { | { | ||||||
|     return default_error_condition(code) == condition; |     return default_error_condition(code) == condition; | ||||||
| } | } | ||||||
|  |  | ||||||
| bool | bool | ||||||
| error_category::equivalent(const error_code& code, int condition) const | error_category::equivalent(const error_code& code, int condition) const _NOEXCEPT | ||||||
| { | { | ||||||
|     return *this == code.category() && code.value() == condition; |     return *this == code.category() && code.value() == condition; | ||||||
| } | } | ||||||
| @@ -51,12 +51,12 @@ class _LIBCPP_HIDDEN __generic_error_category | |||||||
|     : public __do_message |     : public __do_message | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     virtual const char* name() const; |     virtual const char* name() const _NOEXCEPT; | ||||||
|     virtual string message(int ev) const; |     virtual string message(int ev) const; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const char* | const char* | ||||||
| __generic_error_category::name() const | __generic_error_category::name() const _NOEXCEPT | ||||||
| { | { | ||||||
|     return "generic"; |     return "generic"; | ||||||
| } | } | ||||||
| @@ -72,7 +72,7 @@ __generic_error_category::message(int ev) const | |||||||
| } | } | ||||||
|  |  | ||||||
| const error_category& | const error_category& | ||||||
| generic_category() | generic_category() _NOEXCEPT | ||||||
| { | { | ||||||
|     static __generic_error_category s; |     static __generic_error_category s; | ||||||
|     return s; |     return s; | ||||||
| @@ -82,13 +82,13 @@ class _LIBCPP_HIDDEN __system_error_category | |||||||
|     : public __do_message |     : public __do_message | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     virtual const char* name() const; |     virtual const char* name() const _NOEXCEPT; | ||||||
|     virtual string message(int ev) const; |     virtual string message(int ev) const; | ||||||
|     virtual error_condition default_error_condition(int ev) const; |     virtual error_condition default_error_condition(int ev) const _NOEXCEPT; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const char* | const char* | ||||||
| __system_error_category::name() const | __system_error_category::name() const _NOEXCEPT | ||||||
| { | { | ||||||
|     return "system"; |     return "system"; | ||||||
| } | } | ||||||
| @@ -104,7 +104,7 @@ __system_error_category::message(int ev) const | |||||||
| } | } | ||||||
|  |  | ||||||
| error_condition | error_condition | ||||||
| __system_error_category::default_error_condition(int ev) const | __system_error_category::default_error_condition(int ev) const _NOEXCEPT | ||||||
| { | { | ||||||
| #ifdef ELAST | #ifdef ELAST | ||||||
|     if (ev > ELAST) |     if (ev > ELAST) | ||||||
| @@ -114,7 +114,7 @@ __system_error_category::default_error_condition(int ev) const | |||||||
| } | } | ||||||
|  |  | ||||||
| const error_category& | const error_category& | ||||||
| system_category() | system_category() _NOEXCEPT | ||||||
| { | { | ||||||
|     static __system_error_category s; |     static __system_error_category s; | ||||||
|     return s; |     return s; | ||||||
| @@ -147,7 +147,7 @@ system_error::__init(const error_code& ec, string what_arg) | |||||||
|             what_arg += ": "; |             what_arg += ": "; | ||||||
|         what_arg += ec.message(); |         what_arg += ec.message(); | ||||||
|     } |     } | ||||||
|     return _STD::move(what_arg); |     return _VSTD::move(what_arg); | ||||||
| } | } | ||||||
|  |  | ||||||
| system_error::system_error(error_code ec, const string& what_arg) | system_error::system_error(error_code ec, const string& what_arg) | ||||||
| @@ -186,7 +186,7 @@ system_error::system_error(int ev, const error_category& ecat) | |||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| system_error::~system_error() throw() | system_error::~system_error() _NOEXCEPT | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -12,10 +12,7 @@ | |||||||
| #include "vector" | #include "vector" | ||||||
| #include "future" | #include "future" | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
| #ifdef __MINGW32__ |  | ||||||
| #else |  | ||||||
| #include <sys/sysctl.h> | #include <sys/sysctl.h> | ||||||
| #endif |  | ||||||
|  |  | ||||||
| _LIBCPP_BEGIN_NAMESPACE_STD | _LIBCPP_BEGIN_NAMESPACE_STD | ||||||
|  |  | ||||||
|   | |||||||
| @@ -13,30 +13,30 @@ | |||||||
|  |  | ||||||
| #include "typeinfo" | #include "typeinfo" | ||||||
|  |  | ||||||
| std::bad_cast::bad_cast() throw() | std::bad_cast::bad_cast() _NOEXCEPT | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| std::bad_cast::~bad_cast() throw() | std::bad_cast::~bad_cast() _NOEXCEPT | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| const char* | const char* | ||||||
| std::bad_cast::what() const throw() | std::bad_cast::what() const _NOEXCEPT | ||||||
| { | { | ||||||
|   return "std::bad_cast"; |   return "std::bad_cast"; | ||||||
| } | } | ||||||
|  |  | ||||||
| std::bad_typeid::bad_typeid() throw() | std::bad_typeid::bad_typeid() _NOEXCEPT | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| std::bad_typeid::~bad_typeid() throw() | std::bad_typeid::~bad_typeid() _NOEXCEPT | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| const char* | const char* | ||||||
| std::bad_typeid::what() const throw() | std::bad_typeid::what() const _NOEXCEPT | ||||||
| { | { | ||||||
|   return "std::bad_typeid"; |   return "std::bad_typeid"; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,15 +0,0 @@ | |||||||
| #include <windows.h> |  | ||||||
|  |  | ||||||
| namespace { |  | ||||||
|  |  | ||||||
|   class Win32ctor { |  | ||||||
|   public: |  | ||||||
|     Win32ctor() { |  | ||||||
|       SetErrorMode(SEM_FAILCRITICALERRORS | |  | ||||||
|                    SEM_NOGPFAULTERRORBOX | |  | ||||||
|                    SEM_NOOPENFILEERRORBOX); |  | ||||||
|     } |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   static Win32ctor ctor; |  | ||||||
| } |  | ||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user