Work on Windows port by Ruben Van Boxem
git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@140728 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -305,11 +305,11 @@ template <unsigned> struct __static_assert_check {}; | |||||||
| #define __has_feature(__x) 0 | #define __has_feature(__x) 0 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if __APPLE__ || __FreeBSD__ | #if __APPLE__ || __FreeBSD__ || _WIN32 | ||||||
| #define _LIBCPP_LOCALE__L_EXTENSIONS 1 | #define _LIBCPP_LOCALE__L_EXTENSIONS 1 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifdef __APPLE__ | #if __APPLE__ || _WIN32 | ||||||
| #define _LIBCPP_STABLE_APPLE_ABI | #define _LIBCPP_STABLE_APPLE_ABI | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   | |||||||
| @@ -106,6 +106,9 @@ size_t wcsrtombs(char* restrict dst, const wchar_t** restrict src, size_t len, | |||||||
| #include <__config> | #include <__config> | ||||||
| #include <cwctype> | #include <cwctype> | ||||||
| #include <wchar.h> | #include <wchar.h> | ||||||
|  | #if _WIN32 | ||||||
|  | #include <support/win32/support.h> // pull in *swprintf defines | ||||||
|  | #endif // _WIN32 | ||||||
|  |  | ||||||
| #pragma GCC system_header | #pragma GCC system_header | ||||||
|  |  | ||||||
|   | |||||||
| @@ -187,7 +187,8 @@ template <class charT> class messages_byname; | |||||||
| #include <cstdlib> | #include <cstdlib> | ||||||
| #include <ctime> | #include <ctime> | ||||||
| #if _WIN32 | #if _WIN32 | ||||||
| #include <support/win32/support.h> // vasprintf | #include <support/win32/support.h> | ||||||
|  | #include <support/win32/locale.h> | ||||||
| #else // _WIN32 | #else // _WIN32 | ||||||
| #include <nl_types.h> | #include <nl_types.h> | ||||||
| #endif  // !_WIN32 | #endif  // !_WIN32 | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| // -*- C++ -*- | // -*- C++ -*- | ||||||
| //===--------------------------- support/win32/locale.h --------------------------===// | //===------------------------ support/win32/locale.h ----------------------===// | ||||||
| // | // | ||||||
| //                     The LLVM Compiler Infrastructure | //                     The LLVM Compiler Infrastructure | ||||||
| // | // | ||||||
| @@ -8,10 +8,56 @@ | |||||||
| // | // | ||||||
| //===----------------------------------------------------------------------===// | //===----------------------------------------------------------------------===// | ||||||
|  |  | ||||||
| // Locale stuff | #ifndef _LIBCPP_SUPPORT_WIN32_LOCALE_H | ||||||
| // FIXME: the *_l functions are fairly new, only available on Vista?/7+ | #define _LIBCPP_SUPPORT_WIN32_LOCALE_H | ||||||
| #include <xlocinfo.h> //  |  | ||||||
|  | #include "support/win32/support.h" | ||||||
|  | #include <memory> | ||||||
|  | #include <xlocinfo.h> // _locale_t | ||||||
| #define locale_t _locale_t | #define locale_t _locale_t | ||||||
|  | #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 (  LC_COLLATE_MASK \ | ||||||
|  |                      | LC_CTYPE_MASK \ | ||||||
|  |                      | LC_MESSAGES_MASK \ | ||||||
|  |                      | LC_MONETARY_MASK \ | ||||||
|  |                      | LC_NUMERIC_MASK \ | ||||||
|  |                      | LC_TIME_MASK ) | ||||||
|  | #define freelocale _free_locale | ||||||
|  | // FIXME: base currently unused. Needs manual work to construct the new locale | ||||||
|  | locale_t newlocale( int mask, const char * locale, locale_t base ); | ||||||
|  | locale_t uselocale( locale_t newloc ); | ||||||
|  | lconv *localeconv_l( locale_t loc ); | ||||||
|  | size_t mbrlen_l( const char *__restrict__ s, size_t n, | ||||||
|  |                  mbstate_t *__restrict__ ps, locale_t loc); | ||||||
|  | size_t mbsrtowcs_l( wchar_t *__restrict__ dst, const char **__restrict__ src, | ||||||
|  |                     size_t len, mbstate_t *__restrict__ ps, locale_t loc ); | ||||||
|  | size_t wcrtomb_l( char *__restrict__ s, wchar_t wc, mbstate_t *__restrict__ ps, | ||||||
|  |                   locale_t loc); | ||||||
|  | size_t mbrtowc_l( wchar_t *__restrict__ pwc, const char *__restrict__ s, | ||||||
|  |                   size_t n, mbstate_t *__restrict__ ps, locale_t loc); | ||||||
|  | size_t mbsnrtowcs_l( wchar_t *__restrict__ dst, const char **__restrict__ src, | ||||||
|  |                      size_t nms, size_t len, mbstate_t *__restrict__ ps, locale_t loc); | ||||||
|  | size_t wcsnrtombs_l( char *__restrict__ dst, const wchar_t **__restrict__ src, | ||||||
|  |                      size_t nwc, size_t len, mbstate_t *__restrict__ ps, locale_t loc); | ||||||
|  | wint_t btowc_l( int c, locale_t loc ); | ||||||
|  | int wctob_l( wint_t c, locale_t loc ); | ||||||
|  | typedef _VSTD::remove_pointer<locale_t>::type __locale_struct; | ||||||
|  | typedef _VSTD::unique_ptr<__locale_struct, decltype(&uselocale)> __locale_raii; | ||||||
|  | _LIBCPP_ALWAYS_INLINE inline | ||||||
|  | decltype(MB_CUR_MAX) MB_CUR_MAX_L( locale_t __l ) | ||||||
|  | { | ||||||
|  |   __locale_raii __current( uselocale(__l), uselocale ); | ||||||
|  |   return MB_CUR_MAX; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // the *_l functions are prefixed on Windows, only available for msvcr80+, VS2005+ | ||||||
|  | #include <stdio.h> | ||||||
|  | #define mbtowc_l _mbtowc_l | ||||||
| #define strtoll_l _strtoi64_l | #define strtoll_l _strtoi64_l | ||||||
| #define strtoull_l _strtoui64_l | #define strtoull_l _strtoui64_l | ||||||
| // FIXME: current msvcrt does not know about long double | // FIXME: current msvcrt does not know about long double | ||||||
| @@ -36,6 +82,17 @@ | |||||||
| #define towupper_l _towupper_l | #define towupper_l _towupper_l | ||||||
| #define towlower_l _towlower_l | #define towlower_l _towlower_l | ||||||
| #define strftime_l _strftime_l | #define strftime_l _strftime_l | ||||||
|  | #define sscanf_l( __s, __l, __f, ...) _sscanf_l( __s, __f, __l, __VA_ARGS__ ) | ||||||
|  | #define vsscanf_l( __s, __l, __f, ...) _sscanf_l( __s, __f, __l, __VA_ARGS__ ) | ||||||
|  | #define sprintf_l( __s, __l, __f, ... ) _sprintf_l( __s, __f, __l, __VA_ARGS__ ) | ||||||
|  | #define snprintf_l( __s, __n, __l, __f, ... ) _snprintf_l( __s, __n, __f, __l, __VA_ARGS__ ) | ||||||
|  | #define vsprintf_l( __s, __l, __f, ... ) _vsprintf_l( __s, __f, __l, __VA_ARGS__ ) | ||||||
|  | #define vsnprintf_l( __s, __n, __l, __f, ... ) _vsnprintf_l( __s, __n, __f, __l, __VA_ARGS__ ) | ||||||
|  | int asprintf_l( char **ret, locale_t loc, const char *format, ... ); | ||||||
|  | int vasprintf_l( char **ret, locale_t loc, const char *format, va_list ap ); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // not-so-pressing FIXME: use locale to determine blank characters | ||||||
| inline int isblank_l( int c, locale_t /*loc*/ ) | inline int isblank_l( int c, locale_t /*loc*/ ) | ||||||
| { | { | ||||||
|     return ( c == ' ' || c == '\t' ); |     return ( c == ' ' || c == '\t' ); | ||||||
| @@ -44,29 +101,5 @@ inline int iswblank_l( wint_t c, locale_t /*loc*/ ) | |||||||
| { | { | ||||||
|     return ( c == L' ' || c == L'\t' ); |     return ( c == L' ' || c == L'\t' ); | ||||||
| } | } | ||||||
| #define freelocale _free_locale |  | ||||||
| // ignore base; it is always 0 in libc++ code |  | ||||||
| inline locale_t newlocale( int mask, const char * locale, locale_t /*base*/ ) |  | ||||||
| { |  | ||||||
|     return _create_locale( mask, locale ); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // FIXME: first call _configthreadlocale(_ENABLE_PER_THREAD_LOCALE) somewhere | #endif // _LIBCPP_SUPPORT_WIN32_LOCALE_H | ||||||
| // FIXME: return types are different, need to make locale_t from char* |  | ||||||
| inline locale_t uselocale(locale_t newloc) |  | ||||||
| { |  | ||||||
|     return _create_locale( LC_ALL, setlocale(LC_ALL, newloc->locinfo->lc_category[LC_ALL].locale) ); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #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 (  LC_COLLATE_MASK \ |  | ||||||
|                      | LC_CTYPE_MASK \ |  | ||||||
|                      | LC_MESSAGES_MASK \ |  | ||||||
|                      | LC_MONETARY_MASK \ |  | ||||||
|                      | LC_NUMERIC_MASK \ |  | ||||||
|                      | LC_TIME_MASK ) |  | ||||||
| @@ -1,5 +1,5 @@ | |||||||
| // -*- C++ -*- | // -*- C++ -*- | ||||||
| //===--------------------------- support/win32/support.h --------------------------===// | //===----------------------- support/win32/support.h ----------------------===// | ||||||
| // | // | ||||||
| //                     The LLVM Compiler Infrastructure | //                     The LLVM Compiler Infrastructure | ||||||
| // | // | ||||||
| @@ -8,16 +8,24 @@ | |||||||
| // | // | ||||||
| //===----------------------------------------------------------------------===// | //===----------------------------------------------------------------------===// | ||||||
|  |  | ||||||
|  | #ifndef _LIBCPP_SUPPORT_WIN32_SUPPORT_H | ||||||
|  | #define _LIBCPP_SUPPORT_WIN32_SUPPORT_H | ||||||
|  |  | ||||||
| /* | /* | ||||||
|    Functions and constants used in libc++ that are missing from the Windows C library. |    Functions and constants used in libc++ that are missing from the Windows C library. | ||||||
|   */ |   */ | ||||||
|  |  | ||||||
| #if __MINGW32__ | #include <wchar.h>  // mbstate_t | ||||||
| #include <stdio.h> | #include <stdio.h> // _snwprintf | ||||||
| #define swprintf snwprintf | #define swprintf _snwprintf | ||||||
| #endif // __MINGW32__ | #define vswprintf _vsnwprintf | ||||||
|  |  | ||||||
| int vasprintf( char **sptr, const char *__restrict__ fmt , va_list ap ); | int vasprintf( char **sptr, const char *__restrict__ fmt , va_list ap ); | ||||||
|  | int asprintf(char **sptr, const char *__restrict__ fmt, ...); | ||||||
|  |  | ||||||
| size_t mbsnrtowcs( wchar_t *__restrict__ dst, const char **__restrict__ src, | size_t mbsnrtowcs( wchar_t *__restrict__ dst, const char **__restrict__ src, | ||||||
|                    size_t nmc, size_t len, mbstate_t *__restrict__ ps ); |                    size_t nmc, size_t len, mbstate_t *__restrict__ ps ); | ||||||
| size_t wcsnrtombs( char *__restrict__ dst, const wchar_t **__restrict__ src, | size_t wcsnrtombs( char *__restrict__ dst, const wchar_t **__restrict__ src, | ||||||
|                    size_t nwc, size_t len, mbstate_t *__restrict__ ps ); |                    size_t nwc, size_t len, mbstate_t *__restrict__ ps ); | ||||||
|  |  | ||||||
|  | #endif // _LIBCPP_SUPPORT_WIN32_SUPPORT_H | ||||||
							
								
								
									
										16
									
								
								lib/buildit
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								lib/buildit
									
									
									
									
									
								
							| @@ -78,6 +78,13 @@ case $TRIPLE in | |||||||
| 			-Wl,-force_symbols_not_weak_list,notweak.exp " | 			-Wl,-force_symbols_not_weak_list,notweak.exp " | ||||||
| 	fi | 	fi | ||||||
|     ;; |     ;; | ||||||
|  |   *-*-mingw*) | ||||||
|  |     # FIXME: removing libgcc and libsupc++ dependencies means porting libcxxrt and LLVM/compiler-rt | ||||||
|  |     SOEXT=dll | ||||||
|  |     LDSHARED_FLAGS="-o libc++.dll \ | ||||||
|  |         -shared -nodefaultlibs -Wl,--export-all-symbols -Wl,--allow-multiple-definition -Wl,--out-implib,libc++.dll.a \ | ||||||
|  |         -lsupc++ -lpthread -lmingw32 -lgcc_s -lgcc -lmoldname -lmingwex -lmsvcr100 -ladvapi32 -lshell32 -luser32 -lkernel32 -lmingw32 -lgcc_s -lgcc -lmoldname -lmingwex -lmsvcrt" | ||||||
|  | 	;; | ||||||
|   *) |   *) | ||||||
|     RC_CFLAGS="-fPIC" |     RC_CFLAGS="-fPIC" | ||||||
|     SOEXT=so |     SOEXT=so | ||||||
| @@ -97,8 +104,13 @@ set -x | |||||||
| for FILE in ../src/*.cpp; do | for FILE in ../src/*.cpp; do | ||||||
| 	$CXX -c -g -Os $RC_CFLAGS $EXTRA_FLAGS -nostdinc++ -I../include $FILE | 	$CXX -c -g -Os $RC_CFLAGS $EXTRA_FLAGS -nostdinc++ -I../include $FILE | ||||||
| done | done | ||||||
|  | case $TRIPLE in | ||||||
|  |   *-*-mingw*) | ||||||
|  |   for FILE in ../src/support/win32/*.cpp; do | ||||||
|  |     $CXX -c -g -Os $RC_CFLAGS $EXTRA_FLAGS -nostdinc++ -I../include $FILE | ||||||
|  |   done | ||||||
|  |   ;; | ||||||
|  | esac | ||||||
| $CC *.o $RC_CFLAGS $LDSHARED_FLAGS $EXTRA_FLAGS | $CC *.o $RC_CFLAGS $LDSHARED_FLAGS $EXTRA_FLAGS | ||||||
|  |  | ||||||
| #libtool -static -o libc++.a *.o | #libtool -static -o libc++.a *.o | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| // -*- C++ -*- | // -*- C++ -*- | ||||||
| //===--------------------------- support/win32/support.h --------------------------===// | //===----------------------- support/win32/support.h ----------------------===// | ||||||
| // | // | ||||||
| //                     The LLVM Compiler Infrastructure | //                     The LLVM Compiler Infrastructure | ||||||
| // | // | ||||||
| @@ -8,12 +8,21 @@ | |||||||
| // | // | ||||||
| //===----------------------------------------------------------------------===// | //===----------------------------------------------------------------------===// | ||||||
|  |  | ||||||
|  | #include <support/win32/support.h> | ||||||
|  | #include <stdarg.h> // va_start, va_end | ||||||
| #include <stddef.h> // size_t | #include <stddef.h> // size_t | ||||||
| #include <stdlib.h> // malloc | #include <stdlib.h> // malloc | ||||||
| #include <stdio.h>  // vsprintf, vsnprintf | #include <stdio.h>  // vsprintf, vsnprintf | ||||||
| #include <string.h> // strcpy, wcsncpy | #include <string.h> // strcpy, wcsncpy | ||||||
| #include <wchar.h>  // mbstate_t |  | ||||||
|  |  | ||||||
|  | int asprintf(char **sptr, const char *__restrict__ fmt, ...) | ||||||
|  | { | ||||||
|  |     va_list ap; | ||||||
|  |     va_start(ap, fmt); | ||||||
|  |     int result = vasprintf(sptr, fmt, ap); | ||||||
|  |     va_end(ap); | ||||||
|  | 	return result; | ||||||
|  | } | ||||||
| int vasprintf( char **sptr, const char *__restrict__ fmt, va_list ap ) | int vasprintf( char **sptr, const char *__restrict__ fmt, va_list ap ) | ||||||
| { | { | ||||||
|     *sptr = NULL; |     *sptr = NULL; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Howard Hinnant
					Howard Hinnant