diff -r 000000000000 -r bde4ae8d615e os/ossrv/stdcpp/include/config/stl_wince.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/os/ossrv/stdcpp/include/config/stl_wince.h Fri Jun 15 03:10:57 2012 +0200 @@ -0,0 +1,188 @@ +/* + * File to have Windows CE Toolkit for VC++ 5.0 working with STLport + * 09 - 03 - 1999 + * Origin : Giuseppe Govi - g.govi@iol.it + */ + +#ifndef _STLP_WINCE_H +#define _STLP_WINCE_H + +// this flag is being used by STLport +# define _STLP_WINCE + +#ifndef _MT // Always threaded in CE + #define _MT +#endif + +#define _STLP_NO_NATIVE_MBSTATE_T +#define _STLP_NO_TYPEINFO +#define _STLP_NO_BAD_ALLOC +#define _STLP_NO_NEW_NEW_HEADER +#define _STLP_OWN_IOSTREAMS + +// tell other parts no threads are there +# define _STLP_NO_THREADS 1 + +// not all new-style headers are available... +# define _STLP_HAS_NO_NEW_C_HEADERS + +# undef _STLP_HAS_NO_EXCEPTIONS +# define _STLP_HAS_NO_EXCEPTIONS +# undef _STLP_NO_EXCEPTION_HEADER +# define _STLP_NO_EXCEPTION_HEADER + +// we have to use malloc instead of new +# undef _STLP_USE_NEWALLOC +# define _STLP_USE_MALLOC + +//# ifdef _STLP_MSVC +//# pragma warning (disable: 4786) +//# endif + +#ifdef _STLP_WINCE_USE_OUTPUTDEBUGSTRING +#define _STLP_WINCE_TRACE(msg) OutputDebugString(msg) +#else +#define _STLP_WINCE_TRACE(msg) MessageBox(NULL,(msg),NULL,MB_OK) +#endif + +#ifndef __THROW_BAD_ALLOC +#define __THROW_BAD_ALLOC _STLP_WINCE_TRACE(L"out of memory"); ExitThread(1) +#endif + +#ifndef _SIZE_T_DEFINED +typedef unsigned int size_t; +#define _SIZE_T_DEFINED +#endif + +#ifndef _WCHAR_T_DEFINED +typedef unsigned short wchar_t; +#define _WCHAR_T_DEFINED +#endif + +#ifndef _TIME_T_DEFINED +typedef unsigned long time_t; +#define _TIME_T_DEFINED +#endif + +//ptrdiff_t is not defined in Windows CE SDK +#ifndef _PTRDIFF_T_DEFINED +typedef int ptrdiff_t; +#define _PTRDIFF_T_DEFINED +#endif + +//clock_t is not defined in Windows CE SDK +#ifndef _CLOCK_T_DEFINED +typedef long clock_t; +#define _CLOCK_T_DEFINED +#endif + +//struct tm is not defined in Windows CE SDK +#ifndef _TM_DEFINED +struct tm { + int tm_sec; /* seconds after the minute - [0,59] */ + int tm_min; /* minutes after the hour - [0,59] */ + int tm_hour; /* hours since midnight - [0,23] */ + int tm_mday; /* day of the month - [1,31] */ + int tm_mon; /* months since January - [0,11] */ + int tm_year; /* years since 1900 */ + int tm_wday; /* days since Sunday - [0,6] */ + int tm_yday; /* days since January 1 - [0,365] */ + int tm_isdst; /* daylight savings time flag */ + }; +#define _TM_DEFINED +#endif + +// Some useful routines that are missing in Windows CE SDK +#ifdef __cplusplus +extern "C" +{ +#endif + + char * __cdecl getenv(const char *); + struct tm * __cdecl gmtime(const time_t *); + int __cdecl remove(const char *); + int __cdecl rename(const char *, const char *); + time_t __cdecl time(time_t *); + + #if (_WIN32_WCE < 300) + char * __cdecl strrchr(const char *, int); + #endif + +#ifdef __cplusplus +} + +#ifndef __PLACEMENT_NEW_INLINE +inline void *__cdecl operator new(size_t, void *_P) { return (_P); } +#define __PLACEMENT_NEW_INLINE +#endif + +// Only defined as macros in Windows CE SDK +#include _STLP_NATIVE_C_HEADER(ctype.h) + +#if (_WIN32_WCE < 300) // Only wide chars for older versions +#define _isctype iswctype +#endif + +inline int (isalpha)(int c) { return _isctype(c, _ALPHA); } +inline int (isupper)(int c) { return _isctype(c, _UPPER); } +inline int (islower)(int c) { return _isctype(c, _LOWER); } +inline int (isdigit)(int c) { return _isctype(c, _DIGIT); } +inline int (isxdigit)(int c) { return _isctype(c, _HEX); } +inline int (isspace)(int c) { return _isctype(c, _SPACE); } +inline int (ispunct)(int c) { return _isctype(c, _PUNCT); } +inline int (isalnum)(int c) { return _isctype(c, _ALPHA|_DIGIT); } +inline int (isprint)(int c) { return _isctype(c, _BLANK|_PUNCT|_ALPHA|_DIGIT); } +inline int (isgraph)(int c) { return _isctype(c, _PUNCT|_ALPHA|_DIGIT); } +inline int (iscntrl)(int c) { return _isctype(c, _CONTROL); } +inline int (isascii)(int c) { return ((unsigned)(c) < 0x80); } + +#undef _isctype + +inline int (iswalpha)(int c) { return iswctype(c, _ALPHA); } +inline int (iswupper)(int c) { return iswctype(c, _UPPER); } +inline int (iswlower)(int c) { return iswctype(c, _LOWER); } +inline int (iswdigit)(int c) { return iswctype(c, _DIGIT); } +inline int (iswxdigit)(int c) { return iswctype(c, _HEX); } +inline int (iswspace)(int c) { return iswctype(c, _SPACE); } +inline int (iswpunct)(int c) { return iswctype(c, _PUNCT); } +inline int (iswalnum)(int c) { return iswctype(c, _ALPHA|_DIGIT); } +inline int (iswprint)(int c) { return iswctype(c, _BLANK|_PUNCT|_ALPHA|_DIGIT); } +inline int (iswgraph)(int c) { return iswctype(c, _PUNCT|_ALPHA|_DIGIT); } +inline int (iswcntrl)(int c) { return iswctype(c, _CONTROL); } +inline int (iswascii)(int c) { return ((unsigned)(c) < 0x80); } + +#endif /* __cplusplus */ + +#if !defined(WIN32_LEAN_AND_MEAN) // Minimise windows includes + #define WIN32_LEAN_AND_MEAN +#endif +#if !defined(VC_EXTRALEAN) + #define VC_EXTRALEAN +#endif +#if !defined(STRICT) + #define STRICT +#endif +#if !defined(NOMINMAX) + #define NOMINMAX +#endif + +#ifndef __WINDOWS__ +#include +#endif + +#ifndef _ABORT_DEFINED +# define _STLP_ABORT() TerminateProcess(GetCurrentProcess(), 0) +# define _ABORT_DEFINED +#endif + +#ifndef _ASSERT_DEFINED +# define assert(expr) _STLP_ASSERT(expr) +# define _ASSERT_DEFINED +#endif + +// they say it's needed +# include + +#endif /* _STLP_WCE_H */ + +