Compare commits
	
		
			40 Commits
		
	
	
		
			release_33
			...
			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 | 
| @@ -13,6 +13,13 @@ | |||||||
|  |  | ||||||
| #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 | ||||||
| @@ -47,6 +54,11 @@ | |||||||
| # endif  // _BYTE_ORDER == _LITTLE_ENDIAN | # endif  // _BYTE_ORDER == _LITTLE_ENDIAN | ||||||
| #endif  // __FreeBSD__ | #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) | #if !defined(_LIBCPP_LITTLE_ENDIAN) || !defined(_LIBCPP_BIG_ENDIAN) | ||||||
| # include <endian.h> | # include <endian.h> | ||||||
| # if __BYTE_ORDER == __LITTLE_ENDIAN | # if __BYTE_ORDER == __LITTLE_ENDIAN | ||||||
| @@ -98,7 +110,7 @@ typedef __char32_t char32_t; | |||||||
| #endif | #endif | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if !(__has_feature(cxx_exceptions)) | #if !(__has_feature(cxx_exceptions)) || defined(__MINGW32__) | ||||||
| #define _LIBCPP_NO_EXCEPTIONS | #define _LIBCPP_NO_EXCEPTIONS | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   | |||||||
| @@ -19,7 +19,21 @@ | |||||||
| #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 | ||||||
|  |  | ||||||
| @@ -302,7 +316,7 @@ locale::operator()(const basic_string<_CharT, _Traits, _Allocator>& __x, | |||||||
| class _LIBCPP_VISIBLE ctype_base | class _LIBCPP_VISIBLE ctype_base | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     typedef __uint32_t mask; |     typedef std::uint32_t mask; | ||||||
|  |  | ||||||
| #if __APPLE__ | #if __APPLE__ | ||||||
|     static const mask space  = _CTYPE_S; |     static const mask space  = _CTYPE_S; | ||||||
| @@ -315,6 +329,17 @@ 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; | ||||||
| @@ -451,7 +476,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_[__c] & __m : false; |         return isascii(__c) ? (__tab_ ? __tab_[__c] & __m : _isctype(__c, __m)) : false; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     _LIBCPP_ALWAYS_INLINE |     _LIBCPP_ALWAYS_INLINE | ||||||
|   | |||||||
| @@ -14,7 +14,35 @@ | |||||||
| #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 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -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; | ||||||
|   | |||||||
| @@ -173,6 +173,11 @@ 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> | ||||||
|   | |||||||
| @@ -186,7 +186,10 @@ 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 | ||||||
|  |  | ||||||
| @@ -303,7 +306,14 @@ __nolocale_asprintf(char** __ret, | |||||||
| { | { | ||||||
|     va_list __ap; |     va_list __ap; | ||||||
|     va_start(__ap, __format); |     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); |     va_end(__ap); | ||||||
|     return __result; |     return __result; | ||||||
| } | } | ||||||
| @@ -748,7 +758,12 @@ __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 = 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; |         int __current_errno = errno; | ||||||
|         if (__current_errno == 0) |         if (__current_errno == 0) | ||||||
|             errno = __save_errno; |             errno = __save_errno; | ||||||
| @@ -788,7 +803,12 @@ __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 = 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; |         int __current_errno = errno; | ||||||
|         if (__current_errno == 0) |         if (__current_errno == 0) | ||||||
|             errno = __save_errno; |             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) |     if (__a != __a_end) | ||||||
|     { |     { | ||||||
|         char *__p2; |         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) |         if (__p2 != __a_end) | ||||||
|         { |         { | ||||||
|             __err = ios_base::failbit; |             __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> | 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 __v) const |                                          char_type __fl, long double __lv) 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]; | ||||||
| @@ -3565,10 +3597,14 @@ 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> | ||||||
| @@ -3576,6 +3612,10 @@ 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(), | ||||||
| @@ -3588,16 +3628,19 @@ 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>; | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								include/new
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								include/new
									
									
									
									
									
								
							| @@ -90,6 +90,18 @@ _LIBCPP_VISIBLE new_handler get_new_handler() throw(); | |||||||
|  |  | ||||||
| }  // std | }  // 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) throw(std::bad_alloc); | ||||||
| _LIBCPP_VISIBLE void* operator new(std::size_t, const std::nothrow_t&) throw(); | _LIBCPP_VISIBLE void* operator new(std::size_t, const std::nothrow_t&) throw(); | ||||||
| _LIBCPP_VISIBLE void  operator delete(void*) throw(); | _LIBCPP_VISIBLE void  operator delete(void*) throw(); | ||||||
|   | |||||||
| @@ -115,22 +115,22 @@ public: | |||||||
|  |  | ||||||
| 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 | ||||||
| @@ -246,22 +246,42 @@ 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, | ||||||
| @@ -269,8 +289,12 @@ 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, | ||||||
| @@ -278,21 +302,37 @@ 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, | ||||||
| @@ -304,24 +344,42 @@ 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, | ||||||
| @@ -329,17 +387,27 @@ enum _ { | |||||||
|     state_not_recoverable               = ENOTRECOVERABLE, |     state_not_recoverable               = ENOTRECOVERABLE, | ||||||
| #ifdef ETIME | #ifdef ETIME | ||||||
|     stream_timeout                      = ETIME, |     stream_timeout                      = ETIME, | ||||||
| #else | #elif defined(ETIMEDOUT) | ||||||
|     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, | ||||||
|     wrong_protocol_type                 = EPROTOTYPE | #endif | ||||||
|  | #ifdef EPROTOTYPE | ||||||
|  |     wrong_protocol_type                 = EPROTOTYPE, | ||||||
|  | #endif | ||||||
| }; | }; | ||||||
|  |  | ||||||
|     _ __v_; |     _ __v_; | ||||||
|   | |||||||
| @@ -95,7 +95,15 @@ 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__ | ||||||
|  | #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> | #include <pthread.h> | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #pragma GCC system_header | #pragma GCC system_header | ||||||
|  |  | ||||||
|   | |||||||
| @@ -32,7 +32,7 @@ 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 | ||||||
|   | |||||||
| @@ -116,10 +116,16 @@ steady_clock::now() | |||||||
| steady_clock::time_point | steady_clock::time_point | ||||||
| steady_clock::now() | 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; |     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,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_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 | ||||||
|   | |||||||
| @@ -77,6 +77,9 @@ std::terminate() | |||||||
|  |  | ||||||
| bool std::uncaught_exception() throw() | bool std::uncaught_exception() throw() | ||||||
| { | { | ||||||
|  | #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(); | ||||||
|   | |||||||
| @@ -18,7 +18,20 @@ | |||||||
| #include "cstring" | #include "cstring" | ||||||
| #include "cwctype" | #include "cwctype" | ||||||
| #include "__sso_allocator" | #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> | #include <langinfo.h> | ||||||
|  | #endif | ||||||
| #include <stdlib.h> | #include <stdlib.h> | ||||||
|  |  | ||||||
| _LIBCPP_BEGIN_NAMESPACE_STD | _LIBCPP_BEGIN_NAMESPACE_STD | ||||||
| @@ -561,6 +574,22 @@ locale::id::__init() | |||||||
|  |  | ||||||
| // template <> class collate_byname<char> | // 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_byname<char>::collate_byname(const char* n, size_t refs) | ||||||
|     : collate<char>(refs), |     : collate<char>(refs), | ||||||
|       __l(newlocale(LC_ALL_MASK, n, 0)) |       __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 |     for (extern_type* p = tmp; n; --n)  // write it | ||||||
|         *to_nxt++ = *p++; |         *to_nxt++ = *p++; | ||||||
|     return ok; |     return ok; | ||||||
|  | #elif defined(_WIN32) | ||||||
|  |     to_nxt = to; | ||||||
|  |     return noconv; | ||||||
| #else | #else | ||||||
|     return error; |     return error; | ||||||
| #endif | #endif | ||||||
|   | |||||||
							
								
								
									
										102
									
								
								src/new.cpp
									
									
									
									
									
								
							
							
						
						
									
										102
									
								
								src/new.cpp
									
									
									
									
									
								
							| @@ -18,110 +18,16 @@ | |||||||
|     // 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__ | ||||||
|     static std::new_handler __new_handler; |     _LIBCPP_BEGIN_NAMESPACE_STD | ||||||
|  |         ::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) 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 | #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 | 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 "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>; | ||||||
|   | |||||||
| @@ -12,7 +12,10 @@ | |||||||
| #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 | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										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; | ||||||
|  | } | ||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user