]> git.saurik.com Git - wxWidgets.git/blame_incremental - include/wx/msw/gccpriv.h
use MSWCreateControl() instead of the old mess; implemented Get(Class)DefaultAttributes()
[wxWidgets.git] / include / wx / msw / gccpriv.h
... / ...
CommitLineData
1/* THIS IS A C FILE, DON'T USE C++ FEATURES (IN PARTICULAR COMMENTS) IN IT */
2/* MinGW w32api specific stuff */
3
4#ifndef _WX_MSW_GCCPRIV_H_
5#define _WX_MSW_GCCPRIV_H_
6
7#if defined(__MINGW32__) && !defined(__GNUWIN32__)
8 #define __GNUWIN32__
9#endif
10
11#if defined( __MINGW32__ ) && !defined(__WINE__) && !defined( HAVE_W32API_H )
12 #if ( __GNUC__ > 2 ) || ( ( __GNUC__ == 2 ) && ( __GNUC_MINOR__ >= 95 ) )
13 #include <_mingw.h>
14 #if __MINGW32_MAJOR_VERSION >= 1
15 #define HAVE_W32API_H
16 #endif
17 #endif
18#elif defined( __CYGWIN__ ) && !defined( HAVE_W32API_H )
19 #if ( __GNUC__ > 2 )
20 #define HAVE_W32API_H
21 #endif
22#endif
23
24#if (defined(__WATCOMC__) && __WATCOMC__ >= 1200)
25 #define HAVE_W32API_H
26#endif
27
28/* check for MinGW/Cygwin w32api version ( releases >= 0.5, only ) */
29#if defined( HAVE_W32API_H )
30#include <w32api.h>
31#endif
32
33/* Watcom can't handle defined(xxx) here: */
34#if defined(__W32API_MAJOR_VERSION) && defined(__W32API_MINOR_VERSION)
35 #define wxCHECK_W32API_VERSION( major, minor ) \
36 ( ( ( __W32API_MAJOR_VERSION > (major) ) \
37 || ( __W32API_MAJOR_VERSION == (major) && __W32API_MINOR_VERSION >= (minor) ) ) )
38#else
39 #define wxCHECK_W32API_VERSION( major, minor ) (0)
40#endif
41
42/* Cygwin / Mingw32 with gcc >= 2.95 use new windows headers which
43 are more ms-like (header author is Anders Norlander, hence the name) */
44#if (defined(__MINGW32__) || defined(__CYGWIN__) || defined(__WINE__)) && ((__GNUC__>2) || ((__GNUC__==2) && (__GNUC_MINOR__>=95)))
45 #ifndef wxUSE_NORLANDER_HEADERS
46 #define wxUSE_NORLANDER_HEADERS 1
47 #endif
48#else
49 #ifndef wxUSE_NORLANDER_HEADERS
50 #define wxUSE_NORLANDER_HEADERS 0
51 #endif
52#endif
53
54/* "old" GNUWIN32 is the one without Norlander's headers: it lacks the
55 standard Win32 headers and we define the used stuff ourselves for it
56 in wx/msw/gnuwin32/extra.h */
57#if defined(__GNUC__) && !wxUSE_NORLANDER_HEADERS
58 #define __GNUWIN32_OLD__
59#endif
60
61/* Cygwin 1.0 */
62#if defined(__CYGWIN__) && ((__GNUC__==2) && (__GNUC_MINOR__==9))
63 #define __CYGWIN10__
64#endif
65
66/* Mingw runtime 1.0-20010604 has some missing _tXXXX functions,
67 so let's define them ourselves: */
68#if defined(__GNUWIN32__) && wxCHECK_W32API_VERSION( 1, 0 ) \
69 && !wxCHECK_W32API_VERSION( 1, 1 )
70 #ifndef _tsetlocale
71 #if wxUSE_UNICODE
72 #define _tsetlocale _wsetlocale
73 #else
74 #define _tsetlocale setlocale
75 #endif
76 #endif
77 #ifndef _tgetenv
78 #if wxUSE_UNICODE
79 #define _tgetenv _wgetenv
80 #else
81 #define _tgetenv getenv
82 #endif
83 #endif
84 #ifndef _tfopen
85 #if wxUSE_UNICODE
86 #define _tfopen _wfopen
87 #else
88 #define _tfopen fopen
89 #endif
90 #endif
91#endif
92
93
94#endif
95 /* _WX_MSW_GCCPRIV_H_ */