X-Git-Url: https://wimlib.net/git/?a=blobdiff_plain;f=include%2Fwimlib_tchar.h;h=8acaee1e5b6109fc19000a640979ec93a4e10560;hb=292930754e68fa2ecee1be688efc2a90aa092112;hp=fefaabc491158d345191aba11bfc68905c8b8fe2;hpb=297e0855665e45708b114048e42befc4654cdbee;p=wimlib diff --git a/include/wimlib_tchar.h b/include/wimlib_tchar.h index fefaabc4..8acaee1e 100644 --- a/include/wimlib_tchar.h +++ b/include/wimlib_tchar.h @@ -15,12 +15,12 @@ typedef wchar_t tchar; # define T(text) _T(text) /* Make a string literal into a wide string */ # define TS "ls" /* Format a string of "tchar" */ # define TC "lc" /* Format a "tchar" */ -# define WS "ls" /* Format a UTF-16LE string (same as above) */ /* For Windows builds, the following definitions replace the "tchar" functions * with the "wide-character" functions. */ # define tmemchr wmemchr # define tmemcpy wmemcpy +# define tmemmove wmemmove # define tmempcpy wmempcpy # define tstrcpy wcscpy # define tprintf wprintf @@ -53,6 +53,8 @@ typedef wchar_t tchar; # define taccess _waccess # define tstrdup wcsdup # define ttempnam _wtempnam +# define tgetenv _wgetenv +# define totlower(c) towlower((wchar_t)(c)) /* The following "tchar" functions do not have exact wide-character equivalents * on Windows so require parameter rearrangement or redirection to a replacement * function defined ourselves. */ @@ -61,6 +63,7 @@ typedef wchar_t tchar; # define tstrerror_r win32_strerror_r_replacement # define trename win32_rename_replacement # define ttruncate win32_truncate_replacement +# define tglob win32_wglob #else /* __WIN32__ */ /* For non-Windows builds, the "tchar" type will be one byte and will specify a * string in the locale-dependent multibyte encoding. However, only UTF-8 is @@ -72,15 +75,11 @@ typedef char tchar; # define TS "s" /* Similarly, a string of "tchar" is printed just as a normal string. */ # define TC "c" /* Print a single character */ -# define WS "W" /* UTF-16LE strings must be printed using a special - extension implemented by wimlib itself. Note that - "ls" will not work here because a string of wide - characters on non-Windows systems is typically not - UTF-16LE. */ /* For non-Windows builds, replace the "tchar" functions with the regular old * string functions. */ # define tmemchr memchr # define tmemcpy memcpy +# define tmemmove memmove # define tmempcpy mempcpy # define tstrcpy strcpy # define tprintf printf @@ -113,11 +112,14 @@ typedef char tchar; # define tmkdir mkdir # define tstrdup strdup # define ttempnam tempnam +# define tgetenv getenv +# define totlower(c) tolower((unsigned char)(c)) # define TSTRDUP STRDUP # define tstrerror_r strerror_r # define trename rename # define ttruncate truncate # define taccess access +# define tglob glob #endif /* !__WIN32__ */ #endif /* _WIMLIB_TCHAR_H */