Compare commits
	
		
			52 Commits
		
	
	
		
			svn-tags/l
			...
			w64
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | b13c5fc1a9 | ||
|   | 4e66976786 | ||
|   | 8074505c5d | ||
|   | efdce87766 | ||
|   | fd9aadef51 | ||
|   | 6d50da017f | ||
|   | ae185c2977 | ||
|   | 79356f49bd | ||
|   | 9117a0a174 | ||
|   | 591952787f | ||
|   | 8082261d2c | ||
|   | b101cb1408 | ||
|   | cb5181c5a2 | ||
|   | c3089afe8d | ||
|   | be2e6396c3 | ||
|   | 0428d2a325 | ||
|   | 5ee0769693 | ||
|   | 164d6b8bda | ||
|   | 117920302f | ||
|   | 16acf2ae93 | ||
|   | f9d6039245 | ||
|   | 4cf42dadd4 | ||
|   | 51ae55e510 | ||
|   | aeaeb51343 | ||
|   | b05cdf81ba | ||
|   | 4a796725e0 | ||
|   | 5a9ed2486b | ||
|   | beb21a0990 | ||
|   | 12f526f712 | ||
|   | bd94c33cc3 | ||
|   | 9dc188d64d | ||
|   | 9055a62ed4 | ||
|   | 17c8c462ae | ||
|   | ec97728ba0 | ||
|   | cb430f3a47 | ||
|   | d3665e1d9d | ||
|   | 6911fb59fd | ||
|   | a177c5da7b | ||
|   | 352c9e1a46 | ||
|   | 710f61ba2a | ||
|   | 469d419a17 | ||
|   | 7ac6af7027 | ||
|   | e14ea5835e | ||
|   | 75f7695c62 | ||
|   | ef3b2e2e34 | ||
|   | 9dbeff919b | ||
|   | 8c1aa2c24d | ||
|   | 506b36487c | ||
|   | a02851e8a2 | ||
|   | 3e93e96dff | ||
|   | b8a03c763a | ||
|   | d615e47bea | 
| @@ -13,6 +13,13 @@ | ||||
|  | ||||
| #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_ABI_VERSION 1 | ||||
| @@ -47,6 +54,11 @@ | ||||
| # endif  // _BYTE_ORDER == _LITTLE_ENDIAN | ||||
| #endif  // __FreeBSD__ | ||||
|  | ||||
| #if !defined(_LIBCPP_LITTLE_ENDIAN) && (defined(__i386__) || defined(__x86_64__)) | ||||
| #define _LIBCPP_LITTLE_ENDIAN 1 | ||||
| #define _LIBCPP_BIG_ENDIAN    0 | ||||
| #endif | ||||
|  | ||||
| #if !defined(_LIBCPP_LITTLE_ENDIAN) || !defined(_LIBCPP_BIG_ENDIAN) | ||||
| # include <endian.h> | ||||
| # if __BYTE_ORDER == __LITTLE_ENDIAN | ||||
| @@ -98,7 +110,7 @@ typedef __char32_t char32_t; | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #if !(__has_feature(cxx_exceptions)) | ||||
| #if !(__has_feature(cxx_exceptions)) || defined(__MINGW32__) | ||||
| #define _LIBCPP_NO_EXCEPTIONS | ||||
| #endif | ||||
|  | ||||
| @@ -184,10 +196,12 @@ namespace std { | ||||
| #define _LIBCPP_HAS_NO_UNICODE_CHARS | ||||
| #define _LIBCPP_HAS_NO_VARIADICS | ||||
| #define _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| #define _LIBCPP_HAS_NO_ALWAYS_INLINE_VARIADICS | ||||
|  | ||||
| #else  // __GXX_EXPERIMENTAL_CXX0X__ | ||||
|  | ||||
| #define _LIBCPP_HAS_NO_TRAILING_RETURN | ||||
| #define _LIBCPP_HAS_NO_ALWAYS_INLINE_VARIADICS | ||||
|  | ||||
| #if !(__GNUC__ >= 4 && __GNUC_MINOR__ >= 3) | ||||
| #define _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| @@ -207,7 +221,6 @@ namespace std { | ||||
| #endif  // !(__GNUC__ >= 4 && __GNUC_MINOR__ >= 4) | ||||
|  | ||||
| #if !(__GNUC__ >= 4 && __GNUC_MINOR__ >= 6) | ||||
| #define _LIBCPP_HAS_NO_ALWAYS_INLINE_VARIADICS | ||||
| #define _LIBCPP_HAS_NO_NULLPTR | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -19,7 +19,21 @@ | ||||
| #include <cstdint> | ||||
| #include <cctype> | ||||
| #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> | ||||
| #endif | ||||
|  | ||||
| #pragma GCC system_header | ||||
|  | ||||
| @@ -302,7 +316,7 @@ locale::operator()(const basic_string<_CharT, _Traits, _Allocator>& __x, | ||||
| class _LIBCPP_VISIBLE ctype_base | ||||
| { | ||||
| public: | ||||
|     typedef __uint32_t mask; | ||||
|     typedef std::uint32_t mask; | ||||
|  | ||||
| #if __APPLE__ | ||||
|     static const mask space  = _CTYPE_S; | ||||
| @@ -315,6 +329,17 @@ public: | ||||
|     static const mask punct  = _CTYPE_P; | ||||
|     static const mask xdigit = _CTYPE_X; | ||||
|     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__ | ||||
|     static const mask space  = _ISspace; | ||||
|     static const mask print  = _ISprint; | ||||
| @@ -451,7 +476,7 @@ public: | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     bool is(mask __m, char_type __c) const | ||||
|     { | ||||
|         return isascii(__c) ? __tab_[__c] & __m : false; | ||||
|         return isascii(__c) ? (__tab_ ? __tab_[__c] & __m : _isctype(__c, __m)) : false; | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|   | ||||
| @@ -14,7 +14,35 @@ | ||||
| #include <__config> | ||||
| #include <chrono> | ||||
| #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> | ||||
| #endif | ||||
|  | ||||
| #pragma GCC system_header | ||||
|  | ||||
|   | ||||
| @@ -288,12 +288,12 @@ __stdoutbuf<_CharT>::sync() | ||||
|         __r = __cv_->unshift(__st_, __extbuf, | ||||
|                                     __extbuf + sizeof(__extbuf), | ||||
|                                     __extbe); | ||||
|         if (__r == codecvt_base::error) | ||||
|             return -1; | ||||
|         size_t __nmemb = static_cast<size_t>(__extbe - __extbuf); | ||||
|         if (fwrite(__extbuf, 1, __nmemb, __file_) != __nmemb) | ||||
|             return -1; | ||||
|     } while (__r == codecvt_base::partial); | ||||
|     if (__r == codecvt_base::error) | ||||
|         return -1; | ||||
|     if (fflush(__file_)) | ||||
|         return -1; | ||||
|     return 0; | ||||
|   | ||||
| @@ -769,6 +769,7 @@ public: | ||||
|     typedef typename __alloc_traits::difference_type difference_type; | ||||
|  | ||||
|     typedef __tree_node<value_type, typename __alloc_traits::void_pointer> __node; | ||||
|     typedef __tree_node_base<typename __alloc_traits::void_pointer> __node_base; | ||||
|     typedef typename __alloc_traits::template | ||||
| #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
|             rebind_alloc<__node> | ||||
| @@ -779,10 +780,10 @@ public: | ||||
|     typedef allocator_traits<__node_allocator>       __node_traits; | ||||
|     typedef typename __node_traits::pointer          __node_pointer; | ||||
|     typedef typename __node_traits::const_pointer    __node_const_pointer; | ||||
|     typedef typename __node::base::pointer           __node_base_pointer; | ||||
|     typedef typename __node::base::const_pointer     __node_base_const_pointer; | ||||
|     typedef typename __node_base::pointer            __node_base_pointer; | ||||
|     typedef typename __node_base::const_pointer      __node_base_const_pointer; | ||||
| private: | ||||
|     typedef typename __node::base::base __end_node_t; | ||||
|     typedef typename __node_base::base __end_node_t; | ||||
|     typedef typename pointer_traits<__node_pointer>::template | ||||
| #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
|             rebind<__end_node_t> | ||||
| @@ -996,19 +997,19 @@ public: | ||||
|  | ||||
|     __node_holder remove(const_iterator __p); | ||||
| private: | ||||
|     typename __node::base::pointer& | ||||
|         __find_leaf_low(typename __node::base::pointer& __parent, const value_type& __v); | ||||
|     typename __node::base::pointer& | ||||
|         __find_leaf_high(typename __node::base::pointer& __parent, const value_type& __v); | ||||
|     typename __node::base::pointer& | ||||
|     typename __node_base::pointer& | ||||
|         __find_leaf_low(typename __node_base::pointer& __parent, const value_type& __v); | ||||
|     typename __node_base::pointer& | ||||
|         __find_leaf_high(typename __node_base::pointer& __parent, const value_type& __v); | ||||
|     typename __node_base::pointer& | ||||
|         __find_leaf(const_iterator __hint, | ||||
|                     typename __node::base::pointer& __parent, const value_type& __v); | ||||
|                     typename __node_base::pointer& __parent, const value_type& __v); | ||||
|     template <class _Key> | ||||
|         typename __node::base::pointer& | ||||
|         __find_equal(typename __node::base::pointer& __parent, const _Key& __v); | ||||
|         typename __node_base::pointer& | ||||
|         __find_equal(typename __node_base::pointer& __parent, const _Key& __v); | ||||
|     template <class _Key> | ||||
|         typename __node::base::pointer& | ||||
|         __find_equal(const_iterator __hint, typename __node::base::pointer& __parent, | ||||
|         typename __node_base::pointer& | ||||
|         __find_equal(const_iterator __hint, typename __node_base::pointer& __parent, | ||||
|                      const _Key& __v); | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | ||||
| @@ -1410,8 +1411,8 @@ __tree<_Tp, _Compare, _Allocator>::clear() | ||||
| // Set __parent to parent of null leaf | ||||
| // Return reference to null leaf | ||||
| template <class _Tp, class _Compare, class _Allocator> | ||||
| typename __tree<_Tp, _Compare, _Allocator>::__node::base::pointer& | ||||
| __tree<_Tp, _Compare, _Allocator>::__find_leaf_low(typename __node::base::pointer& __parent, | ||||
| typename __tree<_Tp, _Compare, _Allocator>::__node_base::pointer& | ||||
| __tree<_Tp, _Compare, _Allocator>::__find_leaf_low(typename __node_base::pointer& __parent, | ||||
|                                                    const value_type& __v) | ||||
| { | ||||
|     __node_pointer __nd = __root(); | ||||
| @@ -1449,8 +1450,8 @@ __tree<_Tp, _Compare, _Allocator>::__find_leaf_low(typename __node::base::pointe | ||||
| // Set __parent to parent of null leaf | ||||
| // Return reference to null leaf | ||||
| template <class _Tp, class _Compare, class _Allocator> | ||||
| typename __tree<_Tp, _Compare, _Allocator>::__node::base::pointer& | ||||
| __tree<_Tp, _Compare, _Allocator>::__find_leaf_high(typename __node::base::pointer& __parent, | ||||
| typename __tree<_Tp, _Compare, _Allocator>::__node_base::pointer& | ||||
| __tree<_Tp, _Compare, _Allocator>::__find_leaf_high(typename __node_base::pointer& __parent, | ||||
|                                                     const value_type& __v) | ||||
| { | ||||
|     __node_pointer __nd = __root(); | ||||
| @@ -1491,9 +1492,9 @@ __tree<_Tp, _Compare, _Allocator>::__find_leaf_high(typename __node::base::point | ||||
| // Set __parent to parent of null leaf | ||||
| // Return reference to null leaf | ||||
| template <class _Tp, class _Compare, class _Allocator> | ||||
| typename __tree<_Tp, _Compare, _Allocator>::__node::base::pointer& | ||||
| typename __tree<_Tp, _Compare, _Allocator>::__node_base::pointer& | ||||
| __tree<_Tp, _Compare, _Allocator>::__find_leaf(const_iterator __hint, | ||||
|                                                typename __node::base::pointer& __parent, | ||||
|                                                typename __node_base::pointer& __parent, | ||||
|                                                const value_type& __v) | ||||
| { | ||||
|     if (__hint == end() || !value_comp()(*__hint, __v))  // check before | ||||
| @@ -1527,8 +1528,8 @@ __tree<_Tp, _Compare, _Allocator>::__find_leaf(const_iterator __hint, | ||||
| // If __v exists, set parent to node of __v and return reference to node of __v | ||||
| template <class _Tp, class _Compare, class _Allocator> | ||||
| template <class _Key> | ||||
| typename __tree<_Tp, _Compare, _Allocator>::__node::base::pointer& | ||||
| __tree<_Tp, _Compare, _Allocator>::__find_equal(typename __node::base::pointer& __parent, | ||||
| typename __tree<_Tp, _Compare, _Allocator>::__node_base::pointer& | ||||
| __tree<_Tp, _Compare, _Allocator>::__find_equal(typename __node_base::pointer& __parent, | ||||
|                                                 const _Key& __v) | ||||
| { | ||||
|     __node_pointer __nd = __root(); | ||||
| @@ -1576,9 +1577,9 @@ __tree<_Tp, _Compare, _Allocator>::__find_equal(typename __node::base::pointer& | ||||
| // If __v exists, set parent to node of __v and return reference to node of __v | ||||
| template <class _Tp, class _Compare, class _Allocator> | ||||
| template <class _Key> | ||||
| typename __tree<_Tp, _Compare, _Allocator>::__node::base::pointer& | ||||
| typename __tree<_Tp, _Compare, _Allocator>::__node_base::pointer& | ||||
| __tree<_Tp, _Compare, _Allocator>::__find_equal(const_iterator __hint, | ||||
|                                                 typename __node::base::pointer& __parent, | ||||
|                                                 typename __node_base::pointer& __parent, | ||||
|                                                 const _Key& __v) | ||||
| { | ||||
|     if (__hint == end() || value_comp()(__v, *__hint))  // check before | ||||
| @@ -1608,7 +1609,7 @@ __tree<_Tp, _Compare, _Allocator>::__find_equal(const_iterator __hint, | ||||
|         const_iterator __next = _STD::next(__hint); | ||||
|         if (__next == end() || value_comp()(__v, *__next)) | ||||
|         { | ||||
|             // *__hint < __v < *next(__hint) | ||||
|             // *__hint < __v < *_STD::next(__hint) | ||||
|             if (__hint.__ptr_->__right_ == nullptr) | ||||
|             { | ||||
|                 __parent = const_cast<__node_pointer&>(__hint.__ptr_); | ||||
|   | ||||
| @@ -30,25 +30,43 @@ Macros: | ||||
|  | ||||
| #if !defined(EOWNERDEAD) || !defined(ENOTRECOVERABLE) | ||||
|  | ||||
| #ifdef ELAST | ||||
|  | ||||
| const int __elast1 = ELAST+1; | ||||
| const int __elast2 = ELAST+2; | ||||
| #undef ELAST | ||||
|  | ||||
| #else | ||||
|  | ||||
| const int __elast1 = 104; | ||||
| const int __elast2 = 105; | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #ifdef ENOTRECOVERABLE | ||||
|  | ||||
| #define EOWNERDEAD __elast1 | ||||
|  | ||||
| #ifdef ELAST | ||||
| #undef ELAST | ||||
| #define ELAST EOWNERDEAD | ||||
| #endif | ||||
|  | ||||
| #elif defined(EOWNERDEAD) | ||||
|  | ||||
| #define ENOTRECOVERABLE __elast1 | ||||
| #ifdef ELAST | ||||
| #undef ELAST | ||||
| #define ELAST ENOTRECOVERABLE | ||||
| #endif | ||||
|  | ||||
| #else  // defined(EOWNERDEAD) | ||||
|  | ||||
| #define EOWNERDEAD __elast1 | ||||
| #define ENOTRECOVERABLE __elast2 | ||||
| #ifdef ELAST | ||||
| #undef ELAST | ||||
| #define ELAST ENOTRECOVERABLE | ||||
| #endif | ||||
|  | ||||
| #endif  // defined(EOWNERDEAD) | ||||
|  | ||||
|   | ||||
| @@ -1787,7 +1787,7 @@ deque<_Tp, _Allocator>::insert(const_iterator __p, const value_type& __v) | ||||
|             --__base::__start_; | ||||
|             ++__base::size(); | ||||
|             if (__pos > 1) | ||||
|                 __b = __move_and_check(next(__b), __b + __pos, __b, __vt); | ||||
|                 __b = __move_and_check(_STD::next(__b), __b + __pos, __b, __vt); | ||||
|             *__b = *__vt; | ||||
|         } | ||||
|     } | ||||
| @@ -1847,7 +1847,7 @@ deque<_Tp, _Allocator>::insert(const_iterator __p, value_type&& __v) | ||||
|             --__base::__start_; | ||||
|             ++__base::size(); | ||||
|             if (__pos > 1) | ||||
|                 __b = _STD::move(next(__b), __b + __pos, __b); | ||||
|                 __b = _STD::move(_STD::next(__b), __b + __pos, __b); | ||||
|             *__b = _STD::move(__v); | ||||
|         } | ||||
|     } | ||||
| @@ -1905,7 +1905,7 @@ deque<_Tp, _Allocator>::emplace(const_iterator __p, _Args&&... __args) | ||||
|             --__base::__start_; | ||||
|             ++__base::size(); | ||||
|             if (__pos > 1) | ||||
|                 __b = _STD::move(next(__b), __b + __pos, __b); | ||||
|                 __b = _STD::move(_STD::next(__b), __b + __pos, __b); | ||||
|             *__b = value_type(_STD::forward<_Args>(__args)...); | ||||
|         } | ||||
|     } | ||||
| @@ -2621,7 +2621,7 @@ deque<_Tp, _Allocator>::erase(const_iterator __f) | ||||
|     } | ||||
|     else | ||||
|     {   // erase from back | ||||
|         iterator __i = _STD::move(next(__p), __base::end(), __p); | ||||
|         iterator __i = _STD::move(_STD::next(__p), __base::end(), __p); | ||||
|         __alloc_traits::destroy(__a, _STD::addressof(*__i)); | ||||
|         --__base::size(); | ||||
|         if (__back_spare() >= 2 * __base::__block_size) | ||||
|   | ||||
| @@ -173,6 +173,11 @@ typedef basic_fstream<wchar_t> wfstream; | ||||
|  | ||||
| #pragma GCC system_header | ||||
|  | ||||
| #ifdef _WIN32 | ||||
| #define fseeko fseek | ||||
| #define ftello ftell | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
|   | ||||
| @@ -186,7 +186,10 @@ template <class charT> class messages_byname; | ||||
| #endif | ||||
| #include <cstdlib> | ||||
| #include <ctime> | ||||
|  | ||||
| #ifndef _WIN32 | ||||
| #include <nl_types.h> | ||||
| #endif | ||||
|  | ||||
| #pragma GCC system_header | ||||
|  | ||||
| @@ -303,7 +306,14 @@ __nolocale_asprintf(char** __ret, | ||||
| { | ||||
|     va_list __ap; | ||||
|     va_start(__ap, __format); | ||||
|     int __result = vasprintf(__ret, __format, __ap); | ||||
| 	int __result; | ||||
| #ifdef _WIN32 | ||||
| 	*__ret = (char*)malloc(4096); | ||||
| 	__result = vsprintf(*__ret, __format, __ap); | ||||
| 	*__ret = (char*)realloc(*__ret, __result + 1); | ||||
| #else | ||||
| 	__result = vasprintf(__ret, __format, __ap); | ||||
| #endif | ||||
|     va_end(__ap); | ||||
|     return __result; | ||||
| } | ||||
| @@ -748,7 +758,12 @@ __num_get_signed_integral(const char* __a, const char* __a_end, | ||||
|         int __save_errno = errno; | ||||
|         errno = 0; | ||||
|         char *__p2; | ||||
|         long long __ll = strtoll_l(__a, &__p2, __base, 0); | ||||
|         long long __ll; | ||||
| #ifdef _WIN32 | ||||
|         __ll = _strtoi64_l(__a, &__p2, __base, 0); | ||||
| #else | ||||
|         __ll = strtoll_l(__a, &__p2, __base, 0); | ||||
| #endif | ||||
|         int __current_errno = errno; | ||||
|         if (__current_errno == 0) | ||||
|             errno = __save_errno; | ||||
| @@ -788,7 +803,12 @@ __num_get_unsigned_integral(const char* __a, const char* __a_end, | ||||
|         int __save_errno = errno; | ||||
|         errno = 0; | ||||
|         char *__p2; | ||||
|         unsigned long long __ll = strtoull_l(__a, &__p2, __base, 0); | ||||
|         unsigned long long __ll; | ||||
| #ifdef _WIN32 | ||||
|         __ll = _strtoui64_l(__a, &__p2, __base, 0); | ||||
| #else | ||||
|         __ll = strtoull_l(__a, &__p2, __base, 0); | ||||
| #endif | ||||
|         int __current_errno = errno; | ||||
|         if (__current_errno == 0) | ||||
|             errno = __save_errno; | ||||
| @@ -816,7 +836,13 @@ __num_get_float(const char* __a, const char* __a_end, ios_base::iostate& __err) | ||||
|     if (__a != __a_end) | ||||
|     { | ||||
|         char *__p2; | ||||
|         long double __ld = strtold_l(__a, &__p2, 0); | ||||
|         long double __ld; | ||||
| #ifdef _WIN32 | ||||
|         // Win32 does not use "long double". | ||||
|         __ld = _strtod_l(__a, &__p2, 0); | ||||
| #else | ||||
|         __ld = strtold_l(__a, &__p2, 0); | ||||
| #endif | ||||
|         if (__p2 != __a_end) | ||||
|         { | ||||
|             __err = ios_base::failbit; | ||||
| @@ -1676,11 +1702,17 @@ num_put<_CharT, _OutputIterator>::do_put(iter_type __s, ios_base& __iob, | ||||
| template <class _CharT, class _OutputIterator> | ||||
| _OutputIterator | ||||
| num_put<_CharT, _OutputIterator>::do_put(iter_type __s, ios_base& __iob, | ||||
|                                          char_type __fl, long double __v) const | ||||
|                                          char_type __fl, long double __lv) const | ||||
| { | ||||
|     // Stage 1 - Get number in narrow char | ||||
|     char __fmt[8] = {'%', 0}; | ||||
| #ifdef _WIN32 | ||||
|     const char* __len = ""; | ||||
|     double __v = __lv; | ||||
| #else | ||||
|     const char* __len = "L"; | ||||
|     long double __v = __lv; | ||||
| #endif | ||||
|     bool __specify_precision = this->__format_float(__fmt+1, __len, __iob.flags()); | ||||
|     const unsigned __nbuf = 30; | ||||
|     char __nar[__nbuf]; | ||||
| @@ -2346,6 +2378,12 @@ time_get<_CharT, _InputIterator>::do_get(iter_type __b, iter_type __e, | ||||
|         __b = get(__b, __e, __iob, __err, __tm, __fmt, __fmt + sizeof(__fmt)/sizeof(__fmt[0])); | ||||
|         } | ||||
|         break; | ||||
|     case 'F': | ||||
|         { | ||||
|         const char_type __fmt[] = {'%', 'Y', '-', '%', 'm', '-', '%', 'd'}; | ||||
|         __b = get(__b, __e, __iob, __err, __tm, __fmt, __fmt + sizeof(__fmt)/sizeof(__fmt[0])); | ||||
|         } | ||||
|         break; | ||||
|     case 'H': | ||||
|         __get_hour(__tm->tm_hour, __b, __e, __err, __ct); | ||||
|         break; | ||||
| @@ -3559,10 +3597,14 @@ template <class _CharT> | ||||
| typename messages<_CharT>::catalog | ||||
| 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)); | ||||
|     if (__cat != -1) | ||||
|         __cat = static_cast<catalog>((static_cast<size_t>(__cat) >> 1)); | ||||
|     return __cat; | ||||
| #endif | ||||
| } | ||||
|  | ||||
| template <class _CharT> | ||||
| @@ -3570,6 +3612,10 @@ typename messages<_CharT>::string_type | ||||
| messages<_CharT>::do_get(catalog __c, int __set, int __msgid, | ||||
|                          const string_type& __dflt) const | ||||
| { | ||||
| #ifdef __MINGW32__ | ||||
|     string_type __w; | ||||
| 	return __w; | ||||
| #else | ||||
|     string __ndflt; | ||||
|     __narrow_to_utf8<sizeof(char_type)*__CHAR_BIT__>()(back_inserter(__ndflt), | ||||
|                                                        __dflt.c_str(), | ||||
| @@ -3582,16 +3628,19 @@ messages<_CharT>::do_get(catalog __c, int __set, int __msgid, | ||||
|     __widen_from_utf8<sizeof(char_type)*__CHAR_BIT__>()(back_inserter(__w), | ||||
|                                                         __n, __n + strlen(__n)); | ||||
|     return __w; | ||||
| #endif | ||||
| } | ||||
|  | ||||
| template <class _CharT> | ||||
| void | ||||
| messages<_CharT>::do_close(catalog __c) const | ||||
| { | ||||
| #ifndef __MINGW32__ | ||||
|     if (__c != -1) | ||||
|         __c <<= 1; | ||||
|     nl_catd __cat = reinterpret_cast<nl_catd>(__c); | ||||
|     catclose(__cat); | ||||
| #endif | ||||
| } | ||||
|  | ||||
| extern template class messages<char>; | ||||
|   | ||||
| @@ -567,9 +567,9 @@ public: | ||||
|     typedef const value_type&                                    reference; | ||||
|     typedef typename __pointer_traits::template | ||||
| #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
|             rebind<value_type> | ||||
|             rebind<const value_type> | ||||
| #else | ||||
|             rebind<value_type>::other | ||||
|             rebind<const value_type>::other | ||||
| #endif | ||||
|                                                                  pointer; | ||||
|  | ||||
|   | ||||
							
								
								
									
										12
									
								
								include/new
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								include/new
									
									
									
									
									
								
							| @@ -90,6 +90,18 @@ _LIBCPP_VISIBLE new_handler get_new_handler() throw(); | ||||
|  | ||||
| }  // std | ||||
|  | ||||
| #if __APPLE__ | ||||
|     #include <cxxabi.h> | ||||
|     // On Darwin, there are two STL shared libraries and a lower level ABI | ||||
|     // 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 | ||||
|  | ||||
| _LIBCPP_VISIBLE void* operator new(std::size_t) throw(std::bad_alloc); | ||||
| _LIBCPP_VISIBLE void* operator new(std::size_t, const std::nothrow_t&) throw(); | ||||
| _LIBCPP_VISIBLE void  operator delete(void*) throw(); | ||||
|   | ||||
| @@ -1276,7 +1276,7 @@ operator<<(basic_ostream<_CharT, _Traits>& __os, shared_ptr<_Y> const& __p) | ||||
|  | ||||
| template <class _CharT, class _Traits, size_t _Size> | ||||
| basic_ostream<_CharT, _Traits>& | ||||
| operator<<(basic_ostream<_CharT, _Traits>& __os, bitset<_Size>& __x) | ||||
| operator<<(basic_ostream<_CharT, _Traits>& __os, const bitset<_Size>& __x) | ||||
| { | ||||
|     return __os << __x.template to_string<_CharT, _Traits> | ||||
|                         (use_facet<ctype<_CharT> >(__os.getloc()).widen('0'), | ||||
|   | ||||
| @@ -1650,6 +1650,16 @@ class piecewise_linear_distribution | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| // __is_seed_sequence | ||||
|  | ||||
| template <class _Sseq, class _Engine> | ||||
| struct __is_seed_sequence | ||||
| { | ||||
|     static const bool value = | ||||
|               !is_convertible<_Sseq, typename _Engine::result_type>::value && | ||||
|               !is_same<typename remove_cv<_Sseq>::type, _Engine>::value; | ||||
| }; | ||||
|  | ||||
| // linear_congruential_engine | ||||
|  | ||||
| template <unsigned long long __a, unsigned long long __c, | ||||
| @@ -1848,7 +1858,7 @@ public: | ||||
|         {seed(__s);} | ||||
|     template<class _Sseq> explicit linear_congruential_engine(_Sseq& __q, | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         typename enable_if<!is_convertible<_Sseq, result_type>::value>::type* = 0) | ||||
|         typename enable_if<__is_seed_sequence<_Sseq, linear_congruential_engine>::value>::type* = 0) | ||||
|         {seed(__q);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void seed(result_type __s = default_seed) | ||||
| @@ -1858,7 +1868,7 @@ public: | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         typename enable_if | ||||
|         < | ||||
|             !is_convertible<_Sseq, result_type>::value, | ||||
|             __is_seed_sequence<_Sseq, linear_congruential_engine>::value, | ||||
|             void | ||||
|         >::type | ||||
|         seed(_Sseq& __q) | ||||
| @@ -2104,14 +2114,14 @@ public: | ||||
|         {seed(__sd);} | ||||
|     template<class _Sseq> explicit mersenne_twister_engine(_Sseq& __q, | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         typename enable_if<!is_convertible<_Sseq, result_type>::value>::type* = 0) | ||||
|         typename enable_if<__is_seed_sequence<_Sseq, mersenne_twister_engine>::value>::type* = 0) | ||||
|         {seed(__q);} | ||||
|     void seed(result_type __sd = default_seed); | ||||
|     template<class _Sseq> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         typename enable_if | ||||
|         < | ||||
|             !is_convertible<_Sseq, result_type>::value, | ||||
|             __is_seed_sequence<_Sseq, mersenne_twister_engine>::value, | ||||
|             void | ||||
|         >::type | ||||
|         seed(_Sseq& __q) | ||||
| @@ -2473,7 +2483,7 @@ public: | ||||
|         {seed(__sd);} | ||||
|     template<class _Sseq> explicit subtract_with_carry_engine(_Sseq& __q, | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         typename enable_if<!is_convertible<_Sseq, result_type>::value>::type* = 0) | ||||
|         typename enable_if<__is_seed_sequence<_Sseq, subtract_with_carry_engine>::value>::type* = 0) | ||||
|         {seed(__q);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void seed(result_type __sd = default_seed) | ||||
| @@ -2482,7 +2492,7 @@ public: | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         typename enable_if | ||||
|         < | ||||
|             !is_convertible<_Sseq, result_type>::value, | ||||
|             __is_seed_sequence<_Sseq, subtract_with_carry_engine>::value, | ||||
|             void | ||||
|         >::type | ||||
|         seed(_Sseq& __q) | ||||
| @@ -2741,7 +2751,7 @@ public: | ||||
|     template<class _Sseq> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         explicit discard_block_engine(_Sseq& __q, | ||||
|         typename enable_if<!is_convertible<_Sseq, result_type>::value && | ||||
|         typename enable_if<__is_seed_sequence<_Sseq, discard_block_engine>::value && | ||||
|                            !is_convertible<_Sseq, _Engine>::value>::type* = 0) | ||||
|         : __e_(__q), __n_(0) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -2752,7 +2762,7 @@ public: | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         typename enable_if | ||||
|         < | ||||
|             !is_convertible<_Sseq, result_type>::value, | ||||
|             __is_seed_sequence<_Sseq, discard_block_engine>::value, | ||||
|             void | ||||
|         >::type | ||||
|         seed(_Sseq& __q) {__e_.seed(__q); __n_ = 0;} | ||||
| @@ -2940,7 +2950,7 @@ public: | ||||
|     explicit independent_bits_engine(result_type __sd) : __e_(__sd) {} | ||||
|     template<class _Sseq> explicit independent_bits_engine(_Sseq& __q, | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         typename enable_if<!is_convertible<_Sseq, result_type>::value && | ||||
|         typename enable_if<__is_seed_sequence<_Sseq, independent_bits_engine>::value && | ||||
|                            !is_convertible<_Sseq, _Engine>::value>::type* = 0) | ||||
|          : __e_(__q) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -2951,7 +2961,7 @@ public: | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         typename enable_if | ||||
|         < | ||||
|             !is_convertible<_Sseq, result_type>::value, | ||||
|             __is_seed_sequence<_Sseq, independent_bits_engine>::value, | ||||
|             void | ||||
|         >::type | ||||
|         seed(_Sseq& __q) {__e_.seed(__q);} | ||||
| @@ -3163,7 +3173,7 @@ public: | ||||
|     explicit shuffle_order_engine(result_type __sd) : __e_(__sd) {__init();} | ||||
|     template<class _Sseq> explicit shuffle_order_engine(_Sseq& __q, | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         typename enable_if<!is_convertible<_Sseq, result_type>::value && | ||||
|         typename enable_if<__is_seed_sequence<_Sseq, shuffle_order_engine>::value && | ||||
|                            !is_convertible<_Sseq, _Engine>::value>::type* = 0) | ||||
|          : __e_(__q) {__init();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -3174,7 +3184,7 @@ public: | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         typename enable_if | ||||
|         < | ||||
|             !is_convertible<_Sseq, result_type>::value, | ||||
|             __is_seed_sequence<_Sseq, shuffle_order_engine>::value, | ||||
|             void | ||||
|         >::type | ||||
|         seed(_Sseq& __q) {__e_.seed(__q); __init();} | ||||
| @@ -4467,7 +4477,7 @@ poisson_distribution<_IntType>::operator()(_URNG& __urng, const param_type& __pr | ||||
| { | ||||
|     result_type __x; | ||||
|     uniform_real_distribution<double> __urd; | ||||
|     if (__pr.__mean_ <= 10) | ||||
|     if (__pr.__mean_ < 10) | ||||
|     { | ||||
|          __x = 0; | ||||
|         for (double __p = __urd(__urng); __p > __pr.__l_; ++__x) | ||||
|   | ||||
| @@ -115,22 +115,22 @@ public: | ||||
|  | ||||
| enum class errc | ||||
| { | ||||
|     address_family_not_supported,       // EAFNOSUPPORT | ||||
|     address_in_use,                     // EADDRINUSE | ||||
|     address_not_available,              // EADDRNOTAVAIL | ||||
|     already_connected,                  // EISCONN | ||||
| //    address_family_not_supported,       // EAFNOSUPPORT | ||||
| //    address_in_use,                     // EADDRINUSE | ||||
| //    address_not_available,              // EADDRNOTAVAIL | ||||
| //    already_connected,                  // EISCONN | ||||
|     argument_list_too_long,             // E2BIG | ||||
|     argument_out_of_domain,             // EDOM | ||||
|     bad_address,                        // EFAULT | ||||
|     bad_file_descriptor,                // EBADF | ||||
|     bad_message,                        // EBADMSG | ||||
| //    bad_message,                        // EBADMSG | ||||
|     broken_pipe,                        // EPIPE | ||||
|     connection_aborted,                 // ECONNABORTED | ||||
|     connection_already_in_progress,     // EALREADY | ||||
|     connection_refused,                 // ECONNREFUSED | ||||
|     connection_reset,                   // ECONNRESET | ||||
| //    connection_aborted,                 // ECONNABORTED | ||||
| //    connection_already_in_progress,     // EALREADY | ||||
| //    connection_refused,                 // ECONNREFUSED | ||||
| //    connection_reset,                   // ECONNRESET | ||||
|     cross_device_link,                  // EXDEV | ||||
|     destination_address_required,       // EDESTADDRREQ | ||||
| //    destination_address_required,       // EDESTADDRREQ | ||||
|     device_or_resource_busy,            // EBUSY | ||||
|     directory_not_empty,                // ENOTEMPTY | ||||
|     executable_format_error,            // ENOEXEC | ||||
| @@ -138,8 +138,8 @@ enum class errc | ||||
|     file_too_large,                     // EFBIG | ||||
|     filename_too_long,                  // ENAMETOOLONG | ||||
|     function_not_supported,             // ENOSYS | ||||
|     host_unreachable,                   // EHOSTUNREACH | ||||
|     identifier_removed,                 // EIDRM | ||||
| //    host_unreachable,                   // EHOSTUNREACH | ||||
| //    identifier_removed,                 // EIDRM | ||||
|     illegal_byte_sequence,              // EILSEQ | ||||
|     inappropriate_io_control_operation, // ENOTTY | ||||
|     interrupted,                        // EINTR | ||||
| @@ -147,16 +147,16 @@ enum class errc | ||||
|     invalid_seek,                       // ESPIPE | ||||
|     io_error,                           // EIO | ||||
|     is_a_directory,                     // EISDIR | ||||
|     message_size,                       // EMSGSIZE | ||||
|     network_down,                       // ENETDOWN | ||||
|     network_reset,                      // ENETRESET | ||||
|     network_unreachable,                // ENETUNREACH | ||||
|     no_buffer_space,                    // ENOBUFS | ||||
| //    message_size,                       // EMSGSIZE | ||||
| //    network_down,                       // ENETDOWN | ||||
| //    network_reset,                      // ENETRESET | ||||
| //    network_unreachable,                // ENETUNREACH | ||||
| //    no_buffer_space,                    // ENOBUFS | ||||
|     no_child_process,                   // ECHILD | ||||
|     no_link,                            // ENOLINK | ||||
| //    no_link,                            // ENOLINK | ||||
|     no_lock_available,                  // ENOLCK | ||||
|     no_message_available,               // ENODATA | ||||
|     no_message,                         // ENOMSG | ||||
| //    no_message,                         // ENOMSG | ||||
|     no_protocol_option,                 // ENOPROTOOPT | ||||
|     no_space_on_device,                 // ENOSPC | ||||
|     no_stream_resources,                // ENOSR | ||||
| @@ -246,22 +246,42 @@ struct _LIBCPP_VISIBLE is_error_condition_enum | ||||
| struct errc | ||||
| { | ||||
| enum _ { | ||||
| #ifdef EAFNOSUPPORT | ||||
|     address_family_not_supported        = EAFNOSUPPORT, | ||||
| #endif | ||||
| #ifdef EADDRINUSE | ||||
|     address_in_use                      = EADDRINUSE, | ||||
| #endif | ||||
| #ifdef EADDRNOTAVAIL | ||||
|     address_not_available               = EADDRNOTAVAIL, | ||||
| #endif | ||||
| #ifdef EISCONN | ||||
|     already_connected                   = EISCONN, | ||||
| #endif | ||||
|     argument_list_too_long              = E2BIG, | ||||
|     argument_out_of_domain              = EDOM, | ||||
|     bad_address                         = EFAULT, | ||||
|     bad_file_descriptor                 = EBADF, | ||||
| #ifdef EBADMSG | ||||
|     bad_message                         = EBADMSG, | ||||
| #endif | ||||
|     broken_pipe                         = EPIPE, | ||||
| #ifdef ECONNABORTED | ||||
|     connection_aborted                  = ECONNABORTED, | ||||
| #endif | ||||
| #ifdef EALREADY | ||||
|     connection_already_in_progress      = EALREADY, | ||||
| #endif | ||||
| #ifdef ECONNREFUSED | ||||
|     connection_refused                  = ECONNREFUSED, | ||||
| #endif | ||||
| #ifdef ECONNRESET | ||||
|     connection_reset                    = ECONNRESET, | ||||
| #endif | ||||
|     cross_device_link                   = EXDEV, | ||||
| #ifdef EDESTADDRREQ | ||||
|     destination_address_required        = EDESTADDRREQ, | ||||
| #endif | ||||
|     device_or_resource_busy             = EBUSY, | ||||
|     directory_not_empty                 = ENOTEMPTY, | ||||
|     executable_format_error             = ENOEXEC, | ||||
| @@ -269,8 +289,12 @@ enum _ { | ||||
|     file_too_large                      = EFBIG, | ||||
|     filename_too_long                   = ENAMETOOLONG, | ||||
|     function_not_supported              = ENOSYS, | ||||
| #ifdef EHOSTUNREACH | ||||
|     host_unreachable                    = EHOSTUNREACH, | ||||
| #endif | ||||
| #ifdef EIDRM | ||||
|     identifier_removed                  = EIDRM, | ||||
| #endif | ||||
|     illegal_byte_sequence               = EILSEQ, | ||||
|     inappropriate_io_control_operation  = ENOTTY, | ||||
|     interrupted                         = EINTR, | ||||
| @@ -278,21 +302,37 @@ enum _ { | ||||
|     invalid_seek                        = ESPIPE, | ||||
|     io_error                            = EIO, | ||||
|     is_a_directory                      = EISDIR, | ||||
| #ifdef EMSGSIZE | ||||
|     message_size                        = EMSGSIZE, | ||||
| #endif | ||||
| #ifdef ENETDOWN | ||||
|     network_down                        = ENETDOWN, | ||||
| #endif | ||||
| #ifdef ENETRESET | ||||
|     network_reset                       = ENETRESET, | ||||
| #endif | ||||
| #ifdef ENETUNREACH | ||||
|     network_unreachable                 = ENETUNREACH, | ||||
| #endif | ||||
| #ifdef ENOBUFS | ||||
|     no_buffer_space                     = ENOBUFS, | ||||
| #endif | ||||
|     no_child_process                    = ECHILD, | ||||
| #ifdef ENOLINK | ||||
|     no_link                             = ENOLINK, | ||||
| #endif | ||||
|     no_lock_available                   = ENOLCK, | ||||
| #ifdef ENOMSG | ||||
| #ifdef ENODATA | ||||
|     no_message_available                = ENODATA, | ||||
| #else | ||||
|     no_message_available                = ENOMSG, | ||||
| #endif | ||||
|     no_message                          = ENOMSG, | ||||
| #endif | ||||
| #ifdef ENOPROTOOPT, | ||||
|     no_protocol_option                  = ENOPROTOOPT, | ||||
| #endif | ||||
|     no_space_on_device                  = ENOSPC, | ||||
| #ifdef ENOSR | ||||
|     no_stream_resources                 = ENOSR, | ||||
| @@ -304,24 +344,42 @@ enum _ { | ||||
|     no_such_file_or_directory           = ENOENT, | ||||
|     no_such_process                     = ESRCH, | ||||
|     not_a_directory                     = ENOTDIR, | ||||
| #ifdef ENOTSOCK | ||||
|     not_a_socket                        = ENOTSOCK, | ||||
| #endif | ||||
| #ifdef ENOSTR | ||||
|     not_a_stream                        = ENOSTR, | ||||
| #else | ||||
|     not_a_stream                        = EINVAL, | ||||
| #endif | ||||
| #ifdef ENOTCONN | ||||
|     not_connected                       = ENOTCONN, | ||||
| #endif | ||||
|     not_enough_memory                   = ENOMEM, | ||||
| #ifdef ENOTSUP | ||||
|     not_supported                       = ENOTSUP, | ||||
| #endif | ||||
| #ifdef ECANCELED | ||||
|     operation_canceled                  = ECANCELED, | ||||
| #endif | ||||
| #ifdef EINPROGRESS | ||||
|     operation_in_progress               = EINPROGRESS, | ||||
| #endif | ||||
|     operation_not_permitted             = EPERM, | ||||
| #ifdef EOPNOTSUPP | ||||
|     operation_not_supported             = EOPNOTSUPP, | ||||
| #endif | ||||
| #ifdef EWOULDBLOCK | ||||
|     operation_would_block               = EWOULDBLOCK, | ||||
| #endif | ||||
|     owner_dead                          = EOWNERDEAD, | ||||
|     permission_denied                   = EACCES, | ||||
| #ifdef EPROTO | ||||
|     protocol_error                      = EPROTO, | ||||
| #endif | ||||
| #ifdef EPROTONOSUPPORT | ||||
|     protocol_not_supported              = EPROTONOSUPPORT, | ||||
| #endif | ||||
|     read_only_file_system               = EROFS, | ||||
|     resource_deadlock_would_occur       = EDEADLK, | ||||
|     resource_unavailable_try_again      = EAGAIN, | ||||
| @@ -329,17 +387,27 @@ enum _ { | ||||
|     state_not_recoverable               = ENOTRECOVERABLE, | ||||
| #ifdef ETIME | ||||
|     stream_timeout                      = ETIME, | ||||
| #else | ||||
| #elif defined(ETIMEDOUT) | ||||
|     stream_timeout                      = ETIMEDOUT, | ||||
| #endif | ||||
| #ifdef ETXTBSY | ||||
|     text_file_busy                      = ETXTBSY, | ||||
| #endif | ||||
| #ifdef ETIMEDOUT | ||||
|     timed_out                           = ETIMEDOUT, | ||||
| #endif | ||||
|     too_many_files_open_in_system       = ENFILE, | ||||
|     too_many_files_open                 = EMFILE, | ||||
|     too_many_links                      = EMLINK, | ||||
| #ifdef ELOOP | ||||
|     too_many_symbolic_link_levels       = ELOOP, | ||||
| #endif | ||||
| #ifdef EOVERFLOW | ||||
|     value_too_large                     = EOVERFLOW, | ||||
|     wrong_protocol_type                 = EPROTOTYPE | ||||
| #endif | ||||
| #ifdef EPROTOTYPE | ||||
|     wrong_protocol_type                 = EPROTOTYPE, | ||||
| #endif | ||||
| }; | ||||
|  | ||||
|     _ __v_; | ||||
|   | ||||
| @@ -95,7 +95,15 @@ void sleep_for(const chrono::duration<Rep, Period>& rel_time); | ||||
| #include <system_error> | ||||
| #include <chrono> | ||||
| #include <__mutex_base> | ||||
| #ifdef __MINGW32__ | ||||
| #define pthread_key_delete(a) (-1) | ||||
| #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 | ||||
|  | ||||
| #pragma GCC system_header | ||||
|  | ||||
|   | ||||
| @@ -211,6 +211,13 @@ struct _LIBCPP_VISIBLE pair | ||||
|     _LIBCPP_INLINE_VISIBILITY pair(const _T1& __x, const _T2& __y) | ||||
|         : first(__x), second(__y) {} | ||||
|  | ||||
|     template<class _U1, class _U2> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         pair(const pair<_U1, _U2>& __p, | ||||
|                  typename enable_if<is_convertible<_U1, _T1>::value && | ||||
|                                     is_convertible<_U2, _T2>::value>::type* = 0) | ||||
|             : first(__p.first), second(__p.second) {} | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
|     template <class _U1, class _U2, | ||||
| @@ -222,6 +229,14 @@ struct _LIBCPP_VISIBLE pair | ||||
|               second(_STD::forward<_U2>(__u2)) | ||||
|             {} | ||||
|  | ||||
|     template<class _U1, class _U2> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         pair(pair<_U1, _U2>&& __p, | ||||
|                  typename enable_if<is_convertible<_U1, _T1>::value && | ||||
|                                     is_convertible<_U2, _T2>::value>::type* = 0) | ||||
|             : first(_STD::forward<_U1>(__p.first)), | ||||
|               second(_STD::forward<_U2>(__p.second)) {} | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||
|  | ||||
|     template<class _Tuple, | ||||
| @@ -261,10 +276,6 @@ struct _LIBCPP_VISIBLE pair | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||
|  | ||||
| #else  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     template<class _U1, class _U2> | ||||
|         _LIBCPP_INLINE_VISIBILITY pair(const pair<_U1, _U2>& __p) | ||||
|             : first(__p.first), second(__p.second) {} | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     void _LIBCPP_INLINE_VISIBILITY swap(pair& __p) {_STD::swap(*this, __p);} | ||||
| private: | ||||
|   | ||||
| @@ -32,7 +32,7 @@ append_if(libraries LIBCXX_HAS_GCC_S_LIB gcc_s) | ||||
| target_link_libraries(cxx ${libraries}) | ||||
|  | ||||
| # 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) | ||||
|  | ||||
| set_target_properties(cxx | ||||
|   | ||||
| @@ -116,10 +116,16 @@ steady_clock::now() | ||||
| steady_clock::time_point | ||||
| steady_clock::now() | ||||
| { | ||||
| #ifdef __MINGW32__ | ||||
|     timeval tv; | ||||
|     gettimeofday(&tv, 0); | ||||
|     return time_point(seconds(tv.tv_sec) + microseconds(tv.tv_usec)); | ||||
| #else | ||||
|     struct timespec tp; | ||||
|     if (0 != clock_gettime(CLOCK_MONOTONIC, &tp)) | ||||
|         __throw_system_error(errno, "clock_gettime(CLOCK_MONOTONIC) failed"); | ||||
|     return time_point(seconds(tp.tv_sec) + nanoseconds(tp.tv_nsec)); | ||||
| #endif | ||||
| } | ||||
| #endif  // __APPLE__ | ||||
|  | ||||
|   | ||||
| @@ -57,8 +57,10 @@ condition_variable::__do_timed_wait(unique_lock<mutex>& lk, | ||||
|     ts.tv_sec = static_cast<decltype(ts.tv_sec)>(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); | ||||
| #ifndef __MINGW32__ | ||||
|     if (ec != 0 && ec != ETIMEDOUT) | ||||
|         __throw_system_error(ec, "condition_variable timed_wait failed"); | ||||
| #endif | ||||
| } | ||||
|  | ||||
| void | ||||
|   | ||||
| @@ -77,6 +77,9 @@ std::terminate() | ||||
|  | ||||
| bool std::uncaught_exception() throw() | ||||
| { | ||||
| #ifdef _LIBCPP_NO_EXCEPTIONS | ||||
|     return false; | ||||
| #endif | ||||
| #if __APPLE__ | ||||
|     // on Darwin, there is a helper function so __cxa_get_globals is private | ||||
|     return __cxxabiapple::__cxa_uncaught_exception(); | ||||
|   | ||||
| @@ -18,7 +18,20 @@ | ||||
| #include "cstring" | ||||
| #include "cwctype" | ||||
| #include "__sso_allocator" | ||||
| #ifdef __MINGW32__ | ||||
| #define iswctype_l _iswctype_l | ||||
| #define strcoll_l _strcoll_l | ||||
| #define strftime_l(a,b,c,d,e) strftime(a,b,c,d) | ||||
| #define strxfrm_l _strxfrm_l | ||||
| #define tolower_l _tolower_l | ||||
| #define toupper_l _toupper_l | ||||
| #define towlower_l _towlower_l | ||||
| #define towupper_l _towupper_l | ||||
| #define wcscoll_l _wcscoll_l | ||||
| #define wcsxfrm_l _wcsxfrm_l | ||||
| #else | ||||
| #include <langinfo.h> | ||||
| #endif | ||||
| #include <stdlib.h> | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
| @@ -561,6 +574,22 @@ locale::id::__init() | ||||
|  | ||||
| // template <> class collate_byname<char> | ||||
|  | ||||
| static inline | ||||
| locale_t newlocale(int m, const char *l, locale_t b) { | ||||
| #if 0 | ||||
|   return _create_locale(LC_ALL, l); | ||||
| #else | ||||
|   return 0; | ||||
| #endif | ||||
| } | ||||
|  | ||||
| static inline | ||||
| void freelocale(locale_t p) { | ||||
| #if 0 // why! | ||||
|   _free_locale(p); | ||||
| #endif | ||||
| } | ||||
|  | ||||
| collate_byname<char>::collate_byname(const char* n, size_t refs) | ||||
|     : collate<char>(refs), | ||||
|       __l(newlocale(LC_ALL_MASK, n, 0)) | ||||
| @@ -1359,6 +1388,9 @@ codecvt<wchar_t, char, mbstate_t>::do_unshift(state_type& st, | ||||
|     for (extern_type* p = tmp; n; --n)  // write it | ||||
|         *to_nxt++ = *p++; | ||||
|     return ok; | ||||
| #elif defined(_WIN32) | ||||
|     to_nxt = to; | ||||
|     return noconv; | ||||
| #else | ||||
|     return error; | ||||
| #endif | ||||
|   | ||||
							
								
								
									
										102
									
								
								src/new.cpp
									
									
									
									
									
								
							
							
						
						
									
										102
									
								
								src/new.cpp
									
									
									
									
									
								
							| @@ -18,110 +18,16 @@ | ||||
|     // in the ABI library and named __cxa_new_handler. | ||||
|     #define __new_handler __cxxabiapple::__cxa_new_handler | ||||
| #else  // __APPLE__ | ||||
|     static std::new_handler __new_handler; | ||||
|     _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|         ::std::new_handler __new_handler; | ||||
|     _LIBCPP_END_NAMESPACE_STD | ||||
| #endif | ||||
|  | ||||
| #if 0 | ||||
| // Implement all new and delete operators as weak definitions | ||||
| // in this shared library, so that they can be overriden by programs | ||||
| // that define non-weak copies of the functions. | ||||
|  | ||||
| __attribute__((__weak__, __visibility__("default"))) | ||||
| 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; | ||||
| } | ||||
|  | ||||
| __attribute__((__weak__, __visibility__("default"))) | ||||
| 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; | ||||
| } | ||||
|  | ||||
| __attribute__((__weak__, __visibility__("default"))) | ||||
| void* | ||||
| operator new[](size_t size) throw (std::bad_alloc) | ||||
| { | ||||
|     return ::operator new(size); | ||||
| } | ||||
|  | ||||
| __attribute__((__weak__, __visibility__("default"))) | ||||
| 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; | ||||
| } | ||||
|  | ||||
| __attribute__((__weak__, __visibility__("default"))) | ||||
| void | ||||
| operator delete(void* ptr) throw () | ||||
| { | ||||
|     if (ptr) | ||||
|         ::free(ptr); | ||||
| } | ||||
|  | ||||
| __attribute__((__weak__, __visibility__("default"))) | ||||
| void | ||||
| operator delete(void* ptr, const std::nothrow_t&) throw () | ||||
| { | ||||
|     ::operator delete(ptr); | ||||
| } | ||||
|  | ||||
| __attribute__((__weak__, __visibility__("default"))) | ||||
| void | ||||
| operator delete[] (void* ptr) throw () | ||||
| { | ||||
|     ::operator delete (ptr); | ||||
| } | ||||
|  | ||||
| __attribute__((__weak__, __visibility__("default"))) | ||||
| void | ||||
| operator delete[] (void* ptr, const std::nothrow_t&) throw () | ||||
| { | ||||
|     ::operator delete[](ptr); | ||||
| } | ||||
|  | ||||
| namespace std | ||||
| { | ||||
|   | ||||
							
								
								
									
										7
									
								
								src/new_ZdaPv.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								src/new_ZdaPv.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| #include "new" | ||||
|  | ||||
| void | ||||
| operator delete[] (void* ptr) throw () | ||||
| { | ||||
|     ::operator delete (ptr); | ||||
| } | ||||
							
								
								
									
										7
									
								
								src/new_ZdaPvRKSt9nothrow_t.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								src/new_ZdaPvRKSt9nothrow_t.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| #include "new" | ||||
|  | ||||
| void | ||||
| operator delete[] (void* ptr, const std::nothrow_t&) throw () | ||||
| { | ||||
|     ::operator delete[](ptr); | ||||
| } | ||||
							
								
								
									
										10
									
								
								src/new_ZdlPv.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								src/new_ZdlPv.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | ||||
| #include <stdlib.h> | ||||
|  | ||||
| #include "new" | ||||
|  | ||||
| void | ||||
| operator delete(void* ptr) throw () | ||||
| { | ||||
|     if (ptr) | ||||
|         ::free(ptr); | ||||
| } | ||||
							
								
								
									
										7
									
								
								src/new_ZdlPvRKSt9nothrow_t.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								src/new_ZdlPvRKSt9nothrow_t.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| #include "new" | ||||
|  | ||||
| void | ||||
| operator delete(void* ptr, const std::nothrow_t&) throw () | ||||
| { | ||||
|     ::operator delete(ptr); | ||||
| } | ||||
							
								
								
									
										7
									
								
								src/new_Znay.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								src/new_Znay.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| #include "new" | ||||
|  | ||||
| void* | ||||
| operator new[](size_t size) throw (std::bad_alloc) | ||||
| { | ||||
|     return ::operator new(size); | ||||
| } | ||||
							
								
								
									
										19
									
								
								src/new_ZnayRKSt9nothrow_t.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								src/new_ZnayRKSt9nothrow_t.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | ||||
| #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; | ||||
| } | ||||
							
								
								
									
										26
									
								
								src/new_Znwy.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								src/new_Znwy.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| #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; | ||||
| } | ||||
							
								
								
									
										19
									
								
								src/new_ZnwyRKSt9nothrow_t.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								src/new_ZnwyRKSt9nothrow_t.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | ||||
| #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; | ||||
| } | ||||
| @@ -7,11 +7,17 @@ | ||||
| // | ||||
| //===----------------------------------------------------------------------===// | ||||
|  | ||||
| #define MINGW_HAS_SECURE_API | ||||
|  | ||||
| #include "string" | ||||
| #include "cstdlib" | ||||
| #include "cwchar" | ||||
| #include "cerrno" | ||||
|  | ||||
| #ifdef _WIN32 | ||||
| #define swprintf swprintf_s | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| template class __basic_string_common<true>; | ||||
|   | ||||
| @@ -12,7 +12,10 @@ | ||||
| #include "vector" | ||||
| #include "future" | ||||
| #include <sys/types.h> | ||||
| #ifdef __MINGW32__ | ||||
| #else | ||||
| #include <sys/sysctl.h> | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
|   | ||||
							
								
								
									
										15
									
								
								test/_win32_seterrormode.fail.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								test/_win32_seterrormode.fail.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | ||||
| #include <windows.h> | ||||
|  | ||||
| namespace { | ||||
|  | ||||
|   class Win32ctor { | ||||
|   public: | ||||
|     Win32ctor() { | ||||
|       SetErrorMode(SEM_FAILCRITICALERRORS | | ||||
|                    SEM_NOGPFAULTERRORBOX | | ||||
|                    SEM_NOOPENFILEERRORBOX); | ||||
|     } | ||||
|   }; | ||||
|  | ||||
|   static Win32ctor ctor; | ||||
| } | ||||
| @@ -7,15 +7,19 @@ | ||||
| //
 | ||||
| //===----------------------------------------------------------------------===//
 | ||||
| 
 | ||||
| // <mutex>
 | ||||
| // <map>
 | ||||
| 
 | ||||
| // class mutex;
 | ||||
| // class map
 | ||||
| 
 | ||||
| // mutex();
 | ||||
| // map();
 | ||||
| 
 | ||||
| #include <mutex> | ||||
| #include <map> | ||||
| 
 | ||||
| struct X | ||||
| { | ||||
|     std::multimap<int, X> m; | ||||
| }; | ||||
| 
 | ||||
| int main() | ||||
| { | ||||
|     std::mutex m; | ||||
| } | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user