]>
git.saurik.com Git - wxWidgets.git/blob - include/wx/platform.h
3 * Purpose: define the OS and compiler identification macros
4 * Author: Vadim Zeitlin
6 * Created: 29.10.01 (extracted from wx/defs.h)
8 * Copyright: (c) 1997-2001 Vadim Zeitlin
9 * Licence: wxWindows licence
12 /* THIS IS A C FILE, DON'T USE C++ FEATURES (IN PARTICULAR COMMENTS) IN IT */
14 #ifndef _WX_PLATFORM_H_
15 #define _WX_PLATFORM_H_
19 Codewarrior doesn't define any Windows symbols until some headers
28 __WXMAC_CLASSIC__ means ppc non-carbon builds, __WXMAC_CARBON__ means
29 carbon API available (mach or cfm builds) , __WXMAC_OSX__ means mach-o
30 builds, running under 10.2 + only
33 # if defined(__MACH__)
34 # define __WXMAC_OSX__
35 # define __WXMAC_CARBON__
36 # ifdef __WXMAC_XCODE__
38 # include "wx/mac/carbon/config_xcode.h"
42 # define __WXMAC_CARBON__
44 # define __WXMAC_CLASSIC__
50 __WXOSX__ is a common define to wxMac (Carbon) and wxCocoa ports under OS X.
52 #if defined(__WXMAC_OSX__) || defined(__WXCOCOA__)
57 first define Windows symbols if they're not defined on the command line: we
58 can autodetect everything we need if _WIN32 is defined
60 #if defined(__CYGWIN32__) && !defined(__WXMOTIF__) && !defined(__WXGTK__) \
61 && !defined(__WXX11__)
62 /* for Cygwin, default to wxMSW unless otherwise specified */
76 #if defined(__PALMOS__)
100 a lot of code (mistakenly) uses #ifdef _WIN32 to either test for
101 Windows or to test for !__WIN16__, so we must define _WIN32 for
102 Win64 as well to ensure that the existing code continues to work.
105 # endif /* !_WIN32 */
109 # endif /* !__WIN64__ */
112 #if (defined(_WIN32) || defined(WIN32) || defined(__NT__) || defined(__WXWINCE__)) \
113 && !defined(__WXMOTIF__) && !defined(__WXGTK__) && !defined(__WXX11__)
123 The library user may override the default setting of WINVER by defining
124 it in his own makefile or project file -- if it is defined, we don't
127 It makes sense to define WINVER as:
128 - either some lowish value (e.g. 0x0302) to not even compile in the
129 features not available in Windows version lower than some given
131 - or to a higher value than the one used by default for the given
132 compiler if you updated its headers to newer version of Platform
133 SDK, e.g. VC6 ships with 0x0400 headers by default but may also
134 work with 0x0500 headers and beyond
137 # if defined(_MSC_VER) && _MSC_VER < 1300
139 VC6 defines some stuff in its default headers which is normally
140 only present if WINVER >= 0x0500 (FLASHW_XXX constants) which
141 means that our usual tests not involving WINVER sometimes fail
142 with it, hence explicitly define a lower WINVER value for it.
144 # define WINVER 0x0400
145 # elif defined(__DMC__)
147 Digital Mars is distributed with a little outdated headers.
149 # define WINVER 0x0400
152 see MSDN for the description of possible WINVER values, this one
153 is the highest one defined right now (Windows Server 2003) and
154 we use it unless it was explicitly overridden by the user to
155 disable recent features support as we check for all of the
156 features we use which could be not available on earlier Windows
157 systems during run-time anyhow, so there is almost no
158 disadvantage in using it.
160 # define WINVER 0x0502
161 # endif /* VC++ 6/!VC++6 */
164 /* Win95 means Win95-style UI, i.e. Win9x/NT 4+ */
165 # if !defined(__WIN95__) && (WINVER >= 0x0400)
170 #if defined(__WXMSW__) || defined(__WIN32__)
171 # if !defined(__WINDOWS__)
182 /* detect MS SmartPhone */
183 #if defined( WIN32_PLATFORM_WFSP )
184 # ifndef __SMARTPHONE__
185 # define __SMARTPHONE__
192 /* detect PocketPC */
193 #if defined( WIN32_PLATFORM_PSPC )
194 # ifndef __POCKETPC__
195 # define __POCKETPC__
202 /* detect Standard WinCE SDK */
203 #if defined( WCE_PLATFORM_STANDARDSDK )
204 # ifndef __WINCE_STANDARDSDK__
205 # define __WINCE_STANDARDSDK__
212 #if defined(_WIN32_WCE) && !defined(WIN32_PLATFORM_WFSP) && !defined(WIN32_PLATFORM_PSPC)
213 # if (_WIN32_WCE >= 400)
214 # ifndef __WINCE_NET__
215 # define __WINCE_NET__
217 # elif (_WIN32_WCE >= 200)
218 # ifndef __HANDHELDPC__
219 # define __HANDHELDPC__
228 Hardware platform detection.
230 VC++ defines _M_xxx symbols.
232 #if defined(_M_IX86) || defined(i386) || defined(__i386) || defined(__i386__)
244 #if defined(_M_MPPC) || defined(__PPC__)
250 #if defined(_M_ALPHA) || defined(__AXP__)
257 Include wx/setup.h for the Unix platform defines generated by configure and
258 the library compilation options
260 #include "wx/setup.h"
262 /* check the consistency of the settings in setup.h */
263 #include "wx/chkconf.h"
266 adjust the Unicode setting: wxUSE_UNICODE should be defined as 0 or 1
267 and is used by wxWidgets, _UNICODE and/or UNICODE may be defined or used by
268 the system headers so bring these settings in sync
271 /* set wxUSE_UNICODE to 1 if UNICODE or _UNICODE is defined */
272 #if defined(_UNICODE) || defined(UNICODE)
273 # undef wxUSE_UNICODE
274 # define wxUSE_UNICODE 1
276 # ifndef wxUSE_UNICODE
277 # define wxUSE_UNICODE 0
279 #endif /* UNICODE/!UNICODE */
281 /* and vice versa: define UNICODE and _UNICODE if wxUSE_UNICODE is 1 */
289 #endif /* wxUSE_UNICODE */
291 #if defined( __MWERKS__ ) && !defined(__INTEL__)
292 // otherwise MSL headers bring in WIN32 dependant APIs
296 some compilers don't support iostream.h any longer, while some of theme
297 are not updated with <iostream> yet, so override the users setting here
300 #if defined(_MSC_VER) && (_MSC_VER >= 1310)
301 # undef wxUSE_IOSTREAMH
302 # define wxUSE_IOSTREAMH 0
303 #elif defined(__DMC__) || defined(__WATCOMC__)
304 # undef wxUSE_IOSTREAMH
305 # define wxUSE_IOSTREAMH 1
306 #elif defined(__MINGW32__)
307 # undef wxUSE_IOSTREAMH
308 # define wxUSE_IOSTREAMH 0
309 #endif /* compilers with/without iostream.h */
312 old C++ headers (like <iostream.h>) declare classes in the global namespace
313 while the new, standard ones (like <iostream>) do it in std:: namespace,
314 unless it's an old gcc version.
316 using this macro allows constuctions like "wxSTD iostream" to work in
319 #if !wxUSE_IOSTREAMH && (!defined(__GNUC__) || ( __GNUC__ > 2 ) || (__GNUC__ == 2 && __GNUC_MINOR__ >= 95))
326 OS: first of all, test for MS-DOS platform. We must do this before testing
327 for Unix, because DJGPP compiler defines __unix__ under MS-DOS
329 #if defined(__GO32__) || defined(__DJGPP__) || defined(__DOS__)
333 /* size_t is the same as unsigned int for Watcom 11 compiler, */
334 /* so define it if it hadn't been done by configure yet */
335 # if !defined(wxSIZE_T_IS_UINT) && !defined(wxSIZE_T_IS_ULONG)
337 # define wxSIZE_T_IS_UINT
340 # define wxSIZE_T_IS_ULONG
345 OS: then test for generic Unix defines, then for particular flavours and
346 finally for Unix-like systems
348 #elif defined(__UNIX__) || defined(__unix) || defined(__unix__) || \
349 defined(____SVR4____) || defined(__LINUX__) || defined(__sgi) || \
350 defined(__hpux) || defined(sun) || defined(__SUN__) || defined(_AIX) || \
351 defined(__EMX__) || defined(__VMS) || defined(__BEOS__)
353 # define __UNIX_LIKE__
355 /* Helps SGI compilation, apparently */
358 # define __need_wchar_t
361 Note I use the term __SGI_CC__ for both cc and CC, its not a good
362 idea to mix gcc and cc/CC, the name mangling is different
365 # endif /* gcc/!gcc */
368 # if defined(sun) || defined(__SUN__)
377 # define OS2EMX_PLAIN_CHAR
380 /* define __HPUX__ for HP-UX where standard macro is __hpux */
381 # if defined(__hpux) && !defined(__HPUX__)
385 # if defined(__CYGWIN__) || defined(__WINE__)
386 # if !defined(wxSIZE_T_IS_UINT)
387 # define wxSIZE_T_IS_UINT
390 #elif defined(applec) || \
391 defined(THINK_C) || \
392 (defined(__MWERKS__) && !defined(__INTEL__))
394 # if !defined(wxSIZE_T_IS_UINT) && !defined(wxSIZE_T_IS_ULONG)
395 # define wxSIZE_T_IS_ULONG
397 #elif defined(__WXMAC__) && defined(__APPLE__)
399 # define __UNIX_LIKE__
402 These defines are needed when compiling using Project Builder
403 with a non generated setup0.h
412 # define __DARWIN__ 1
415 # define __POWERPC__ 1
417 # ifndef TARGET_CARBON
418 # define TARGET_CARBON 1
421 # if !defined(wxSIZE_T_IS_UINT) && !defined(wxSIZE_T_IS_ULONG)
422 # define wxSIZE_T_IS_ULONG
425 Some code has been added to workaround defects(?) in the
426 bundled gcc compiler. These corrections are identified by
427 __DARWIN__ for Darwin related corrections (wxMac, wxMotif)
429 #elif defined(__OS2__)
430 # if defined(__IBMCPP__)
431 # define __VISAGEAVER__ __IBMCPP__
440 /* Place other OS/2 compiler environment defines here */
441 # if defined(__VISAGECPP__)
442 /* VisualAge is the only thing that understands _Optlink */
443 # define LINKAGEMODE _Optlink
445 # define wxSIZE_T_IS_UINT
447 #elif defined(__PALMOS__)
449 # error "__WIN32__ should not be defined for PalmOS"
452 # error "__WINDOWS__ should not be defined for PalmOS"
455 # error "__WXMSW__ should not be defined for PalmOS"
461 # endif /* Windows */
463 /* to be changed for Win64! */
465 # error "__WIN32__ should be defined for Win32 and Win64, Win16 is not supported"
469 define another standard symbol for Microsoft Visual C++: the standard
470 one (_MSC_VER) is also defined by Metrowerks compiler
472 # if defined(_MSC_VER) && !defined(__MWERKS__)
473 # define __VISUALC__ _MSC_VER
474 # elif defined(__BCPLUSPLUS__) && !defined(__BORLANDC__)
475 # define __BORLANDC__
476 # elif defined(__WATCOMC__)
477 # elif defined(__SC__)
478 # define __SYMANTECC__
479 # endif /* compiler */
481 /* size_t is the same as unsigned int for all Windows compilers we know, */
482 /* so define it if it hadn't been done by configure yet */
483 # if !defined(wxSIZE_T_IS_UINT) && !defined(wxSIZE_T_IS_ULONG)
484 # define wxSIZE_T_IS_UINT
489 if we're on a Unix system but didn't use configure (so that setup.h didn't
490 define __UNIX__), do define __UNIX__ now
492 #if !defined(__UNIX__) && defined(__UNIX_LIKE__)
496 #if defined(__WXMOTIF__) || defined(__WXX11__)
502 # define __DIGITALMARS__
504 # define __SYMANTEC__
508 /* Force linking against required libraries under Windows CE: */
510 # include "wx/msw/wince/libraries.h"
513 /* Force inclusion of main PalmOS header: */
520 This macro can be used to test the gcc version and can be used like this:
522 # if wxCHECK_GCC_VERSION(3, 1)
523 ... we have gcc 3.1 or later ...
525 ... no gcc at all or gcc < 3.1 ...
528 #define wxCHECK_GCC_VERSION( major, minor ) \
529 ( defined(__GNUC__) && defined(__GNUC_MINOR__) \
530 && ( ( __GNUC__ > (major) ) \
531 || ( __GNUC__ == (major) && __GNUC_MINOR__ >= (minor) ) ) )
534 This macro can be used to check that the version of mingw32 compiler is
537 #if ( defined( __GNUWIN32__ ) || defined( __MINGW32__ ) || \
538 defined( __CYGWIN__ ) || \
539 (defined(__WATCOMC__) && __WATCOMC__ >= 1200) ) && \
540 !defined(__DOS__) && \
541 !defined(__WXMOTIF__) && \
542 !defined(__WXGTK__) && \
543 !defined(__WXX11__) && \
544 !defined(__WXPALMOS__)
545 # include "wx/msw/gccpriv.h"
547 # undef wxCHECK_W32API_VERSION
548 # define wxCHECK_W32API_VERSION(maj, min) (0)
551 #if defined (__WXMSW__)
552 # if !defined(__WATCOMC__)
553 # define wxHAVE_RAW_BITMAP
557 #if defined (__WXMAC__)
558 # ifndef WORDS_BIGENDIAN && ( !defined(__MACH__) || ( defined(__BIG_ENDIAN__) && __BIG_ENDIAN__ ) )
559 # define WORDS_BIGENDIAN 1
563 /* Choose which method we will use for updating menus
564 * - in OnIdle, or when we receive a wxEVT_MENU_OPEN event.
565 * Presently, only Windows and GTK+ support wxEVT_MENU_OPEN.
567 #ifndef wxUSE_IDLEMENUUPDATES
568 # if (defined(__WXMSW__) || defined(__WXGTK__)) && !defined(__WXUNIVERSAL__)
569 # define wxUSE_IDLEMENUUPDATES 0
571 # define wxUSE_IDLEMENUUPDATES 1
576 * Define symbols that are not yet in
577 * configure or possibly some setup.h files.
578 * They will need to be added.
581 #ifndef wxUSE_FILECONFIG
583 # define wxUSE_FILECONFIG 1
585 # define wxUSE_FILECONFIG 0
590 # define wxUSE_HOTKEY 0
593 #if !defined(wxUSE_WXDIB) && defined(__WXMSW__)
594 # define wxUSE_WXDIB 1
598 We need AvailabilityMacros.h for ifdefing out things that don't exist on
600 FIXME: We need a better way to detect for 10.3 then including a system header
603 #include <AvailabilityMacros.h>
606 #endif /* _WX_PLATFORM_H_ */