3 * Purpose: Type-safe ANSI and Unicode builds compatible wrappers for
5 * Author: Joel Farley, Ove Kåven
6 * Modified by: Vadim Zeitlin, Robert Roebling, Ron Lee
9 * Copyright: (c) 1998-2006 wxWidgets dev team
10 * Licence: wxWindows licence
13 /* THIS IS A C FILE, DON'T USE C++ FEATURES (IN PARTICULAR COMMENTS) IN IT */
15 #ifndef _WX_WXCRTBASE_H_
16 #define _WX_WXCRTBASE_H_
18 /* -------------------------------------------------------------------------
19 headers and missing declarations
20 ------------------------------------------------------------------------- */
22 #include "wx/chartype.h"
25 Standard headers we need here.
27 NB: don't include any wxWidgets headers here because almost all of them
38 #if defined(HAVE_STRTOK_R) && defined(__DARWIN__) && defined(_MSL_USING_MW_C_HEADERS) && _MSL_USING_MW_C_HEADERS
39 char *strtok_r(char *, const char *, char **);
43 a few compilers don't have the (non standard but common) isascii function,
44 define it ourselves for them
47 #if defined(__MWERKS__)
48 #define wxNEED_ISASCII
49 #elif defined(_WIN32_WCE)
51 #define wxNEED_ISASCII
57 inline int isascii(int c
) { return (unsigned)c
< 0x80; }
62 #define isspace(c) ((c) == _T(' ') || (c) == _T('\t'))
64 #endif /* _WIN32_WCE */
66 /* string.h functions */
68 #if defined(__MWERKS__) && !defined(__MACH__) && (__MSL__ < 0x00008000)
70 #elif defined(__WXWINCE__)
78 WXDLLIMPEXP_BASE
char *strdup(const char* s
);
81 /* missing functions in some WinCE versions */
83 #if (_WIN32_WCE < 300)
84 WXDLLIMPEXP_BASE
void *calloc( size_t num
, size_t size
);
86 #endif /* _WIN32_WCE */
89 #if defined(__MWERKS__)
90 /* Metrowerks only has wide char support for OS X >= 10.3 */
91 #if !defined(__DARWIN__) || \
92 (MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_3)
93 #define wxHAVE_MWERKS_UNICODE
96 #ifdef wxHAVE_MWERKS_UNICODE
97 #define HAVE_WPRINTF 1
98 #define HAVE_WCSRTOMBS 1
99 #define HAVE_VSWPRINTF 1
101 #endif /* __MWERKS__ */
104 /* -------------------------------------------------------------------------
105 UTF-8 locale handling
106 ------------------------------------------------------------------------- */
109 #if wxUSE_UNICODE_UTF8
110 // flag indicating whether the current locale uses UTF-8 or not; must be
111 // updated every time the locale is changed!
112 #if wxUSE_UTF8_LOCALE_ONLY
113 #define wxLocaleIsUtf8 true
115 extern WXDLLIMPEXP_BASE
bool wxLocaleIsUtf8
;
117 // function used to update the flag:
118 extern WXDLLIMPEXP_BASE
void wxUpdateLocaleIsUtf8();
119 #else // !wxUSE_UNICODE_UTF8
120 inline void wxUpdateLocaleIsUtf8() {}
121 #endif // wxUSE_UNICODE_UTF8/!wxUSE_UNICODE_UTF8
122 #endif // __cplusplus
125 /* -------------------------------------------------------------------------
127 ------------------------------------------------------------------------- */
129 #define wxCRT_StrcatA strcat
130 #define wxCRT_StrchrA strchr
131 #define wxCRT_StrcmpA strcmp
132 #define wxCRT_StrcollA strcoll
133 #define wxCRT_StrcpyA strcpy
134 #define wxCRT_StrcspnA strcspn
135 #define wxCRT_StrlenA strlen
136 #define wxCRT_StrncatA strncat
137 #define wxCRT_StrncmpA strncmp
138 #define wxCRT_StrncpyA strncpy
139 #define wxCRT_StrpbrkA strpbrk
140 #define wxCRT_StrrchrA strrchr
141 #define wxCRT_StrspnA strspn
142 #define wxCRT_StrstrA strstr
143 #define wxCRT_StrxfrmA strxfrm
146 The system C library on Mac OS X 10.2 and below does not support unicode: in
147 other words all wide-character functions such as towupper et al. do simply
148 not exist so we need to provide our own in that context, except for the
149 wchar_t definition/typedef itself.
151 We need to do this for both project builder and CodeWarrior as the latter
152 uses the system C library in Mach builds for wide character support, which
153 as mentioned does not exist on 10.2 and below.
155 #if defined(__DARWIN__) && (MAC_OS_X_VERSION_MAX_ALLOWED < MAC_OS_X_VERSION_10_2)
156 #define wxHAS_NO_WCS_FUNCTIONS
159 #ifndef wxHAS_NO_WCS_FUNCTIONS
160 #define wxCRT_StrcatW wcscat
161 #define wxCRT_StrchrW wcschr
162 #define wxCRT_StrcmpW wcscmp
163 #define wxCRT_StrcollW wcscoll
164 #define wxCRT_StrcpyW wcscpy
165 #define wxCRT_StrcspnW wcscspn
166 #define wxCRT_StrncatW wcsncat
167 #define wxCRT_StrncmpW wcsncmp
168 #define wxCRT_StrncpyW wcsncpy
169 #define wxCRT_StrpbrkW wcspbrk
170 #define wxCRT_StrrchrW wcsrchr
171 #define wxCRT_StrspnW wcsspn
172 #define wxCRT_StrstrW wcsstr
173 #define wxCRT_StrxfrmW wcsxfrm
175 /* Almost all compiler have strdup(), but not quite all: CodeWarrior under
176 Mac and VC++ for Windows CE don't provide it */
177 #if defined(__VISUALC__) && __VISUALC__ >= 1400
178 #define wxCRT_StrdupA _strdup
179 #elif !(defined(__MWERKS__) && defined(__WXMAC__)) && !defined(__WXWINCE__)
180 #define wxCRT_StrdupA strdup
183 #define wxCRT_StrdupW _wcsdup
185 #define wxCRT_StrdupW wcsdup
188 #define wxCRT_StrdupA strdup
189 /* the rest is implemented in our code */
192 #ifdef wxHAVE_TCHAR_SUPPORT
193 /* we surely have wchar_t if we have TCHAR have wcslen() */
197 #endif /* wxHAVE_TCHAR_SUPPORT */
200 #define wxCRT_StrlenW wcslen
203 #define wxCRT_StrtodA strtod
204 #define wxCRT_StrtolA strtol
205 #define wxCRT_StrtoulA strtoul
206 #define wxCRT_StrtodW wcstod
207 #define wxCRT_StrtolW wcstol
208 #define wxCRT_StrtoulW wcstoul
211 #if __VISUALC__ >= 1300 && !defined(__WXWINCE__)
212 #define wxCRT_StrtollA _strtoi64
213 #define wxCRT_StrtoullA _strtoui64
214 #define wxCRT_StrtollW _wcstoi64
215 #define wxCRT_StrtoullW _wcstoui64
219 #define wxCRT_StrtollA strtoll
220 #define wxCRT_StrtoullA strtoull
221 #endif /* HAVE_STRTOULL */
223 /* assume that we have wcstoull(), which is also C99, too */
224 #define wxCRT_StrtollW wcstoll
225 #define wxCRT_StrtoullW wcstoull
226 #endif /* HAVE_WCSTOULL */
230 /* define wxCRT_StricmpA/W and wxCRT_StrnicmpA/W for various compilers */
232 /* note that we definitely are going to need our own version for widechar
234 #if !defined(wxCRT_StricmpA)
235 #if defined(__BORLANDC__) || defined(__WATCOMC__) || \
236 defined(__SALFORDC__) || defined(__VISAGECPP__) || \
237 defined(__EMX__) || defined(__DJGPP__)
238 #define wxCRT_StricmpA stricmp
239 #define wxCRT_StrnicmpA strnicmp
240 #elif defined(__WXPALMOS__)
241 /* FIXME: There is no equivalent to strnicmp in the Palm OS API. This
242 * quick hack should do until one can be written.
244 #define wxCRT_StricmpA StrCaselessCompare
245 #define wxCRT_StrnicmpA strnicmp
246 #elif defined(__SYMANTEC__) || defined(__VISUALC__) || \
247 (defined(__MWERKS__) && defined(__INTEL__))
248 #define wxCRT_StricmpA _stricmp
249 #define wxCRT_StrnicmpA _strnicmp
250 #elif defined(__UNIX__) || defined(__GNUWIN32__)
251 #define wxCRT_StricmpA strcasecmp
252 #define wxCRT_StrnicmpA strncasecmp
253 /* #else -- use wxWidgets implementation */
255 #endif /* !defined(wxCRT_StricmpA) */
256 /* FIXME-UTF8: use wcs(n)casecmp if available for *W versions */
259 #define wxCRT_StrtokA(str, sep, last) strtok_r(str, sep, last)
261 /* FIXME-UTF8: detect and use wcstok() if available for wxCRT_StrtokW */
263 /* these are extern "C" because they are used by regex lib: */
268 #ifndef wxCRT_StrlenW
269 WXDLLIMPEXP_BASE
size_t wxCRT_StrlenW(const wchar_t *s
);
272 #ifndef wxCRT_StrncmpW
273 WXDLLIMPEXP_BASE
int wxCRT_StrncmpW(const wchar_t *s1
, const wchar_t *s2
, size_t n
);
280 /* FIXME-UTF8: remove this once we are Unicode only */
282 #define wxCRT_StrlenNative wxCRT_StrlenW
283 #define wxCRT_StrncmpNative wxCRT_StrncmpW
284 #define wxCRT_ToupperNative wxCRT_ToupperW
285 #define wxCRT_TolowerNative wxCRT_TolowerW
287 #define wxCRT_StrlenNative wxCRT_StrlenA
288 #define wxCRT_StrncmpNative wxCRT_StrncmpA
289 #define wxCRT_ToupperNative toupper
290 #define wxCRT_TolowerNative tolower
293 #ifndef wxCRT_StrcatW
294 WXDLLIMPEXP_BASE
wchar_t *wxCRT_StrcatW(wchar_t *dest
, const wchar_t *src
);
297 #ifndef wxCRT_StrchrW
298 WXDLLIMPEXP_BASE
const wchar_t *wxCRT_StrchrW(const wchar_t *s
, wchar_t c
);
301 #ifndef wxCRT_StrcmpW
302 WXDLLIMPEXP_BASE
int wxCRT_StrcmpW(const wchar_t *s1
, const wchar_t *s2
);
305 #ifndef wxCRT_StrcollW
306 WXDLLIMPEXP_BASE
int wxCRT_StrcollW(const wchar_t *s1
, const wchar_t *s2
);
309 #ifndef wxCRT_StrcpyW
310 WXDLLIMPEXP_BASE
wchar_t *wxCRT_StrcpyW(wchar_t *dest
, const wchar_t *src
);
313 #ifndef wxCRT_StrcspnW
314 WXDLLIMPEXP_BASE
size_t wxCRT_StrcspnW(const wchar_t *s
, const wchar_t *reject
);
317 #ifndef wxCRT_StrncatW
318 WXDLLIMPEXP_BASE
wchar_t *wxCRT_StrncatW(wchar_t *dest
, const wchar_t *src
, size_t n
);
321 #ifndef wxCRT_StrncpyW
322 WXDLLIMPEXP_BASE
wchar_t *wxCRT_StrncpyW(wchar_t *dest
, const wchar_t *src
, size_t n
);
325 #ifndef wxCRT_StrpbrkW
326 WXDLLIMPEXP_BASE
const wchar_t *wxCRT_StrpbrkW(const wchar_t *s
, const wchar_t *accept
);
329 #ifndef wxCRT_StrrchrW
330 WXDLLIMPEXP_BASE
const wchar_t *wxCRT_StrrchrW(const wchar_t *s
, wchar_t c
);
333 #ifndef wxCRT_StrspnW
334 WXDLLIMPEXP_BASE
size_t wxCRT_StrspnW(const wchar_t *s
, const wchar_t *accept
);
337 #ifndef wxCRT_StrstrW
338 WXDLLIMPEXP_BASE
const wchar_t *wxCRT_StrstrW(const wchar_t *haystack
, const wchar_t *needle
);
341 #ifndef wxCRT_StrtodW
342 WXDLLIMPEXP_BASE
double wxCRT_StrtodW(const wchar_t *nptr
, wchar_t **endptr
);
345 #ifndef wxCRT_StrtolW
346 WXDLLIMPEXP_BASE
long int wxCRT_StrtolW(const wchar_t *nptr
, wchar_t **endptr
, int base
);
349 #ifndef wxCRT_StrtoulW
350 WXDLLIMPEXP_BASE
unsigned long int wxCRT_StrtoulW(const wchar_t *nptr
, wchar_t **endptr
, int base
);
353 #ifndef wxCRT_StrxfrmW
354 WXDLLIMPEXP_BASE
size_t wxCRT_StrxfrmW(wchar_t *dest
, const wchar_t *src
, size_t n
);
357 #ifndef wxCRT_StrdupA
358 WXDLLIMPEXP_BASE
char *wxCRT_StrdupA(const char *psz
);
361 #ifndef wxCRT_StrdupW
362 WXDLLIMPEXP_BASE
wchar_t *wxCRT_StrdupW(const wchar_t *pwz
);
365 #ifndef wxCRT_StricmpA
366 WXDLLIMPEXP_BASE
int wxCRT_StricmpA(const char *psz1
, const char *psz2
);
369 #ifndef wxCRT_StricmpW
370 WXDLLIMPEXP_BASE
int wxCRT_StricmpW(const wchar_t *psz1
, const wchar_t *psz2
);
373 #ifndef wxCRT_StrnicmpA
374 WXDLLIMPEXP_BASE
int wxCRT_StrnicmpA(const char *psz1
, const char *psz2
, size_t len
);
377 #ifndef wxCRT_StrnicmpW
378 WXDLLIMPEXP_BASE
int wxCRT_StrnicmpW(const wchar_t *psz1
, const wchar_t *psz2
, size_t len
);
381 #ifndef wxCRT_StrtokA
382 WXDLLIMPEXP_BASE
char *wxCRT_StrtokA(char *psz
, const char *delim
, char **save_ptr
);
385 #ifndef wxCRT_StrtokW
386 WXDLLIMPEXP_BASE
wchar_t *wxCRT_StrtokW(wchar_t *psz
, const wchar_t *delim
, wchar_t **save_ptr
);
389 /* supply strtoll and strtoull, if needed */
390 #ifndef wxCRT_StrtollA
391 WXDLLIMPEXP_BASE wxLongLong_t
wxCRT_StrtollA(const char* nptr
, char** endptr
, int base
);
392 WXDLLIMPEXP_BASE wxULongLong_t
wxCRT_StrtoullA(const char* nptr
, char** endptr
, int base
);
394 #ifndef wxCRT_StrtollW
395 WXDLLIMPEXP_BASE wxLongLong_t
wxCRT_StrtollW(const wchar_t* nptr
, wchar_t** endptr
, int base
);
396 WXDLLIMPEXP_BASE wxULongLong_t
wxCRT_StrtoullW(const wchar_t* nptr
, wchar_t** endptr
, int base
);
400 /* -------------------------------------------------------------------------
402 ------------------------------------------------------------------------- */
404 #if defined(__UNIX__) || defined(__WXMAC__)
411 /* these functions are only needed in the form used for filenames (i.e. char*
412 on Unix, wchar_t* on Windows), so we don't need to use A/W suffix: */
413 #if wxMBFILES || !wxUSE_UNICODE // ANSI filenames
415 #define wxCRT_Fopen fopen
416 #define wxCRT_Freopen freopen
417 #define wxCRT_Remove remove
418 #define wxCRT_Rename rename
420 #else // Unicode filenames
422 /* special case: these functions are missing under Win9x with Unicows so we
423 have to implement them ourselves */
424 #if wxUSE_UNICODE_MSLU
425 WXDLLIMPEXP_BASE
FILE* wxMSLU__wfopen(const wchar_t *name
, const wchar_t *mode
);
426 WXDLLIMPEXP_BASE
FILE* wxMSLU__wfreopen(const wchar_t *name
, const wchar_t *mode
, FILE *stream
);
427 WXDLLIMPEXP_BASE
int wxMSLU__wrename(const wchar_t *oldname
, const wchar_t *newname
);
428 WXDLLIMPEXP_BASE
int wxMSLU__wremove(const wchar_t *name
);
429 #define wxCRT_Fopen wxMSLU__wfopen
430 #define wxCRT_Remove wxMSLU__wremove
431 #define wxCRT_Rename wxMSLU__wrename
433 #define wxCRT_Rename _wrename
434 #define wxCRT_Fopen _wfopen
435 #define wxCRT_Freopen _wfreopen
437 /* carefully: wxCRT_Remove() must return 0 on success while
438 DeleteFile() returns 0 on error, so don't just define one as
440 int wxCRT_Remove(const wchar_t *path
);
442 #define wxCRT_Remove _wremove
446 #endif // wxMBFILES/!wxMBFILES
448 #define wxCRT_PutsA puts
449 #define wxCRT_FputsA fputs
450 #define wxCRT_FgetsA fgets
451 #define wxCRT_FputcA fputc
452 #define wxCRT_FgetcA fgetc
453 #define wxCRT_UngetcA ungetc
455 #ifndef wxHAS_NO_WCS_FUNCTIONS
456 #ifdef wxHAVE_TCHAR_SUPPORT
457 #define wxCRT_PutsW _putws
458 #define wxCRT_FputsW fputws
459 #define wxCRT_FputcW fputwc
462 #define wxCRT_FputsW fputws
465 #define wxCRT_PutsW putws
468 #define wxCRT_FputcW fputwc
470 #define wxCRT_FgetsW fgetws
471 #endif // !wxHAS_NO_WCS_FUNCTIONS
474 WXDLLIMPEXP_BASE
int wxCRT_PutsW(const wchar_t *ws
);
478 WXDLLIMPEXP_BASE
int wxCRT_FputsW(const wchar_t *ch
, FILE *stream
);
482 WXDLLIMPEXP_BASE
int wxCRT_FputcW(wchar_t wc
, FILE *stream
);
485 #define wxCRT_TmpnamA tmpnam
487 #define wxCRT_TmpnamW _wtmpnam
490 #ifndef wxCRT_TmpnamW
491 WXDLLIMPEXP_BASE
wchar_t *wxCRT_TmpnamW(wchar_t *s
);
494 #define wxCRT_PerrorA perror
495 #ifdef wxHAVE_TCHAR_SUPPORT
496 #define wxCRT_PerrorW _wperror
499 /* -------------------------------------------------------------------------
501 ------------------------------------------------------------------------- */
503 /* there are no env vars at all under CE, so no _tgetenv neither */
505 /* can't define as inline function as this is a C file... */
506 #define wxCRT_GetenvA(name) ((char*)NULL)
507 #define wxCRT_GetenvW(name) ((wchar_t*)NULL)
509 #define wxCRT_GetenvA getenv
511 #define wxCRT_GetenvW _wgetenv
515 #ifndef wxCRT_GetenvW
516 WXDLLIMPEXP_BASE
wchar_t * wxCRT_GetenvW(const wchar_t *name
);
520 #define wxCRT_SystemA system
521 /* mingw32 doesn't provide _tsystem() or _wsystem(): */
522 #if defined(_tsystem)
523 #define wxCRT_SystemW _wsystem
526 #define wxCRT_AtofA atof
527 #define wxCRT_AtoiA atoi
528 #define wxCRT_AtolA atol
530 #if defined(__MWERKS__)
532 #define wxCRT_AtofW watof
533 #define wxCRT_AtoiW watoi
534 #define wxCRT_AtolW watol
535 /* else: use ANSI versions */
537 #elif defined(wxHAVE_TCHAR_SUPPORT)
538 #define wxCRT_AtoiW _wtoi
539 #define wxCRT_AtolW _wtol
540 /* _wtof doesn't exist */
542 #define wxCRT_AtofW(s) wcstof(s, NULL)
543 #define wxCRT_AtolW(s) wcstol(s, NULL, 10)
544 /* wcstoi doesn't exist */
548 There are 2 unrelated problems with these functions under Mac:
549 a) Metrowerks MSL CRT implements them strictly in C99 sense and
550 doesn't support (very common) extension of allowing to call
551 mbstowcs(NULL, ...) which makes it pretty useless as you can't
552 know the size of the needed buffer
553 b) OS X <= 10.2 declares and even defined these functions but
554 doesn't really implement them -- they always return an error
556 So use our own replacements in both cases.
558 #if defined(__MWERKS__) && defined(__MSL__)
559 #define wxNEED_WX_MBSTOWCS
563 #if MAC_OS_X_VERSION_MAX_ALLOWED <= MAC_OS_X_VERSION_10_2
564 #define wxNEED_WX_MBSTOWCS
568 #ifdef wxNEED_WX_MBSTOWCS
569 /* even though they are defined and "implemented", they are bad and just
570 stubs so we need our own - we need these even in ANSI builds!! */
571 WXDLLIMPEXP_BASE
size_t wxMbstowcs(wchar_t *, const char *, size_t);
572 WXDLLIMPEXP_BASE
size_t wxWcstombs(char *, const wchar_t *, size_t);
574 #define wxMbstowcs mbstowcs
575 #define wxWcstombs wcstombs
580 /* -------------------------------------------------------------------------
582 ------------------------------------------------------------------------- */
584 #define wxCRT_StrftimeA strftime
585 /* FIXME-UTF8: when is this available? */
586 #define wxCRT_StrftimeW wcsftime
588 #ifndef wxCRT_StrftimeW
589 WXDLLIMPEXP_BASE
size_t wxCRT_StrftimeW(wchar_t *s
, size_t max
,
591 const struct tm
*tm
);
596 /* -------------------------------------------------------------------------
598 ------------------------------------------------------------------------- */
600 #ifdef wxHAS_NO_WCS_FUNCTIONS
601 #define wxNEED_WX_CTYPE_H
605 #define WXWCHAR_T_CAST(c) (wint_t)(c)
607 #define WXWCHAR_T_CAST(c) c
610 #ifdef wxNEED_WX_CTYPE_H
612 /* RN: Used only under OSX <= 10.2 currently */
613 WXDLLIMPEXP_BASE
int wxCRT_IsalnumW(wchar_t ch
);
614 WXDLLIMPEXP_BASE
int wxCRT_IsalphaW(wchar_t ch
);
615 WXDLLIMPEXP_BASE
int wxCRT_IscntrlW(wchar_t ch
);
616 WXDLLIMPEXP_BASE
int wxCRT_IsdigitW(wchar_t ch
);
617 WXDLLIMPEXP_BASE
int wxCRT_IsgraphW(wchar_t ch
);
618 WXDLLIMPEXP_BASE
int wxCRT_IslowerW(wchar_t ch
);
619 WXDLLIMPEXP_BASE
int wxCRT_IsprintW(wchar_t ch
);
620 WXDLLIMPEXP_BASE
int wxCRT_IspunctW(wchar_t ch
);
621 WXDLLIMPEXP_BASE
int wxCRT_IsspaceW(wchar_t ch
);
622 WXDLLIMPEXP_BASE
int wxCRT_IsupperW(wchar_t ch
);
623 WXDLLIMPEXP_BASE
int wxCRT_IsxdigitW(wchar_t ch
);
624 /* extern "C" because needed by regex code */
625 WXDLLIMPEXP_BASE
extern "C" int wxCRT_TolowerW(wchar_t ch
);
626 WXDLLIMPEXP_BASE
extern "C" int wxCRT_ToupperW(wchar_t ch
);
628 #else // !defined(wxNEED_WX_CTYPE_H)
630 #define wxCRT_IsalnumW(c) iswalnum(WXWCHAR_T_CAST(c))
631 #define wxCRT_IsalphaW(c) iswalpha(WXWCHAR_T_CAST(c))
632 #define wxCRT_IscntrlW(c) iswcntrl(WXWCHAR_T_CAST(c))
633 #define wxCRT_IsdigitW(c) iswdigit(WXWCHAR_T_CAST(c))
634 #define wxCRT_IsgraphW(c) iswgraph(WXWCHAR_T_CAST(c))
635 #define wxCRT_IslowerW(c) iswlower(WXWCHAR_T_CAST(c))
636 #define wxCRT_IsprintW(c) iswprint(WXWCHAR_T_CAST(c))
637 #define wxCRT_IspunctW(c) iswpunct(WXWCHAR_T_CAST(c))
638 #define wxCRT_IsspaceW(c) iswspace(WXWCHAR_T_CAST(c))
639 #define wxCRT_IsupperW(c) iswupper(WXWCHAR_T_CAST(c))
640 #define wxCRT_IsxdigitW(c) iswxdigit(WXWCHAR_T_CAST(c))
643 #if defined(__GLIBC__) && (__GLIBC__ == 2) && (__GLIBC_MINOR__ == 0)
644 /* /usr/include/wctype.h incorrectly declares translations */
645 /* tables which provokes tons of compile-time warnings -- try */
646 /* to correct this */
647 #define wxCRT_TolowerW(wc) towctrans((wc), (wctrans_t)__ctype_tolower)
648 #define wxCRT_ToupperW(wc) towctrans((wc), (wctrans_t)__ctype_toupper)
649 #else /* !glibc 2.0 */
650 #define wxCRT_TolowerW towlower
651 #define wxCRT_ToupperW towupper
654 /* There is a bug in VC6 C RTL: toxxx() functions dosn't do anything
655 with signed chars < 0, so "fix" it here. */
656 #define wxCRT_TolowerW(c) towlower((wxUChar)(wxChar)(c))
657 #define wxCRT_ToupperW(c) towupper((wxUChar)(wxChar)(c))
658 #endif // __GLIBC__/!__GLIBC__
659 #endif // !defined(wxNEED_WX_CTYPE_H)
665 /* -------------------------------------------------------------------------
666 wx wrappers for CRT functions in both char* and wchar_t* versions
667 ------------------------------------------------------------------------- */
671 /* NB: this belongs to wxcrt.h and not this header, but it makes life easier
672 * for buffer.h and stringimpl.h (both of which must be included before
673 * string.h, which is required by wxcrt.h) to have them here: */
675 /* safe version of strlen() (returns 0 if passed NULL pointer) */
676 inline size_t wxStrlen(const char *s
) { return s
? wxCRT_StrlenA(s
) : 0; }
677 inline size_t wxStrlen(const wchar_t *s
) { return s
? wxCRT_StrlenW(s
) : 0; }
678 #define wxWcslen wxCRT_StrlenW
680 #define wxStrdupA wxCRT_StrdupA
681 #define wxStrdupW wxCRT_StrdupW
682 inline char* wxStrdup(const char *s
) { return wxCRT_StrdupA(s
); }
683 inline wchar_t* wxStrdup(const wchar_t *s
) { return wxCRT_StrdupW(s
); }
685 #endif /* __cplusplus */
687 #endif /* _WX_WXCRTBASE_H_ */