]> git.saurik.com Git - wxWidgets.git/blame - include/wx/platform.h
Correct bug with items without attributes in wxGTK wxDVC.
[wxWidgets.git] / include / wx / platform.h
CommitLineData
e0c749a7
RN
1/**
2* Name: wx/platform.h
3* Purpose: define the OS and compiler identification macros
4* Author: Vadim Zeitlin
5* Modified by:
6* Created: 29.10.01 (extracted from wx/defs.h)
7* RCS-ID: $Id$
99d80019 8* Copyright: (c) 1997-2001 Vadim Zeitlin
65571936 9* Licence: wxWindows licence
e0c749a7 10*/
78340847
VZ
11
12/* THIS IS A C FILE, DON'T USE C++ FEATURES (IN PARTICULAR COMMENTS) IN IT */
13
14#ifndef _WX_PLATFORM_H_
15#define _WX_PLATFORM_H_
16
a203834e
MB
17
18/*
19 Codewarrior doesn't define any Windows symbols until some headers
20 are included
21*/
498919dd 22#ifdef __MWERKS__
4b4e81ee 23# include <stddef.h>
e2fc40b4
VZ
24
25# if !defined(__WXMAC__) && !defined(__WINDOWS__) && !defined(WIN32) && !defined(_WIN32_WCE)
26# define __PALMOS__ 0x05000000
27# endif
4b4e81ee
VZ
28#endif
29
cf6fa9b9 30/*
712d087f
SC
31 WXOSX targets
32 __WXOSX_MAC__ means Mac OS X, non embedded
33 __WXOSX_IPHONE__ means OS X iPhone
cf6fa9b9 34*/
712d087f 35
17005cd7
VZ
36/*
37 Normally all of __WXOSX_XXX__, __WXOSX__ and __WXMAC__ are defined by
38 configure but ensure that we also define them if configure was not used for
39 whatever reason.
712d087f 40
17005cd7
VZ
41 The primare symbol remains __WXOSX_XXX__ one, __WXOSX__ exists to allow
42 checking for any OS X port (Carbon and Cocoa) and __WXMAC__ is an old name
43 for it.
44 */
03647350 45#if defined(__WXOSX_CARBON__) || defined(__WXOSX_COCOA__) || defined(__WXOSX_IPHONE__)
17005cd7
VZ
46# ifndef __WXOSX__
47# define __WXOSX__ 1
48# endif
0b6a49c2 49# ifndef __WXMAC__
2d14a14c 50# define __WXMAC__ 1
0b6a49c2 51# endif
17005cd7
VZ
52#endif
53
54#ifdef __WXOSX__
712d087f
SC
55/* setup precise defines according to sdk used */
56# include <TargetConditionals.h>
03647350 57# if defined(__WXOSX_IPHONE__)
0b6a49c2
SC
58# if !( defined(TARGET_OS_IPHONE) && TARGET_OS_IPHONE )
59# error "incorrect SDK for an iPhone build"
60# endif
61# elif defined(__WXOSX_CARBON__) || defined(__WXOSX_COCOA__)
62# if !( defined(TARGET_OS_MAC) && TARGET_OS_MAC )
63# error "incorrect SDK for a Mac OS X build"
64# endif
2d14a14c 65# define __WXOSX_MAC__ 1
2c6dbc21 66# else
0b6a49c2 67# error "one of __WXOSX_IPHONE__, __WXOSX_CARBON__ or __WXOSX_COCOA__ must be defined"
712d087f
SC
68# endif
69#endif
70
71#ifdef __WXOSX_MAC__
d80fc6df 72# if defined(__MACH__)
cdac585c 73# include <AvailabilityMacros.h>
c5e51452
SC
74# ifndef MAC_OS_X_VERSION_10_4
75# define MAC_OS_X_VERSION_10_4 1040
76# endif
77# ifndef MAC_OS_X_VERSION_10_5
78# define MAC_OS_X_VERSION_10_5 1050
79# endif
712d087f
SC
80# ifndef MAC_OS_X_VERSION_10_6
81# define MAC_OS_X_VERSION_10_6 1060
82# endif
d80fc6df 83# else
623633ee 84# error "only mach-o configurations are supported"
d80fc6df
VZ
85# endif
86#endif
87
88/*
0b6a49c2 89 __WXOSX_OR_COCOA__ is a common define to wxOSX (Carbon or Cocoa) and wxCocoa ports under OS X.
305142ad
DE
90
91 DO NOT use this define in base library code. Although wxMac has its own
0b6a49c2 92 private base library (and thus __WXOSX_OR_COCOA__,__WXMAC__ and related defines are
305142ad
DE
93 valid there), wxCocoa shares its library with other ports like wxGTK and wxX11.
94
0b6a49c2 95 To keep wx authors from screwing this up, only enable __WXOSX_OR_COCOA__ for wxCocoa when
305142ad
DE
96 not compiling the base library. We determine this by first checking if
97 wxUSE_BASE is not defined. If it is not defined, then we're not buildling
98 the base library, and possibly not building wx at all (but actually building
99 user code that's using wx). If it is defined then we must check to make sure
100 it is not true. If it is true, we're building base.
101
102 If you want it in the common darwin base library then use __DARWIN__. You
103 can use any Darwin-available libraries like CoreFoundation but please avoid
104 using OS X libraries like Carbon or CoreServices.
105
d80fc6df 106 */
0b6a49c2 107#if defined(__WXOSX__) || (defined(__WXCOCOA__) && (!defined(wxUSE_BASE) || !wxUSE_BASE))
2d14a14c 108# define __WXOSX_OR_COCOA__ 1
cf6fa9b9
SC
109#endif
110
0b6a49c2 111#ifdef __WXOSX_OR_COCOA__
dae17a47
SC
112# ifdef __WXMAC_XCODE__
113# include <unistd.h>
712d087f
SC
114# include <TargetConditionals.h>
115# include <AvailabilityMacros.h>
ef0e9220 116# include "wx/osx/config_xcode.h"
dae17a47
SC
117# endif
118#endif
78340847
VZ
119/*
120 first define Windows symbols if they're not defined on the command line: we
121 can autodetect everything we need if _WIN32 is defined
122 */
7275146d 123#if defined(__CYGWIN__) && defined(__WINDOWS__)
ef620df0
VZ
124# ifndef __WXMSW__
125# define __WXMSW__
126# endif
d66dcb60
MB
127#endif
128
4055ed82 129#if defined(__PALMOS__)
63ccc659 130# if __PALMOS__ == 0x06000000
e2fc40b4 131# define __WXPALMOS6__ 1
63ccc659
WS
132# endif
133# if __PALMOS__ == 0x05000000
e2fc40b4 134# define __WXPALMOS5__ 1
63ccc659 135# endif
4055ed82 136# ifndef __WXPALMOS__
e2fc40b4 137# define __WXPALMOS__ 1
4055ed82
WS
138# endif
139# ifdef __WXMSW__
140# undef __WXMSW__
141# endif
142# ifdef __WINDOWS__
143# undef __WINDOWS__
144# endif
145# ifdef __WIN32__
146# undef __WIN32__
147# endif
148# ifdef WIN32
149# undef WIN32
150# endif
151# ifdef _WIN32
152# undef _WIN32
153# endif
154#endif
155
ef620df0
VZ
156#if defined(_WIN64)
157# ifndef _WIN32
158 /*
159 a lot of code (mistakenly) uses #ifdef _WIN32 to either test for
160 Windows or to test for !__WIN16__, so we must define _WIN32 for
161 Win64 as well to ensure that the existing code continues to work.
162 */
163# define _WIN32
164# endif /* !_WIN32 */
165
166# ifndef __WIN64__
167# define __WIN64__
168# endif /* !__WIN64__ */
169#endif /* _WIN64 */
170
d5cd19b4
VZ
171#if (defined(_WIN32) || defined(WIN32) || defined(__NT__) || defined(__WXWINCE__)) \
172 && !defined(__WXMOTIF__) && !defined(__WXGTK__) && !defined(__WXX11__)
ef620df0
VZ
173# ifndef __WXMSW__
174# define __WXMSW__
175# endif
78340847
VZ
176#endif /* Win32 */
177
c65f4634 178#if defined(__WXMSW__)
9b141468
WS
179# if !defined(__WINDOWS__)
180# define __WINDOWS__
181# endif
c65f4634
VZ
182
183# ifndef _WIN32
184# define _WIN32
185# endif
186
187# ifndef WIN32
188# define WIN32
189# endif
190
191# ifndef __WIN32__
192# define __WIN32__
193# endif
194#endif /* __WXMSW__ */
78340847 195
9b141468 196/* detect MS SmartPhone */
f2aa588b 197#if defined( WIN32_PLATFORM_WFSP )
9b141468
WS
198# ifndef __SMARTPHONE__
199# define __SMARTPHONE__
200# endif
201# ifndef __WXWINCE__
202# define __WXWINCE__
203# endif
f2aa588b
VS
204#endif
205
a9928e9d
JS
206/* detect PocketPC */
207#if defined( WIN32_PLATFORM_PSPC )
9b141468
WS
208# ifndef __POCKETPC__
209# define __POCKETPC__
210# endif
211# ifndef __WXWINCE__
212# define __WXWINCE__
213# endif
a9928e9d
JS
214#endif
215
216/* detect Standard WinCE SDK */
217#if defined( WCE_PLATFORM_STANDARDSDK )
9b141468
WS
218# ifndef __WINCE_STANDARDSDK__
219# define __WINCE_STANDARDSDK__
220# endif
221# ifndef __WXWINCE__
222# define __WXWINCE__
223# endif
a9928e9d
JS
224#endif
225
daeb8330
RR
226#if defined(_WIN32_WCE) && !defined(WIN32_PLATFORM_WFSP) && !defined(WIN32_PLATFORM_PSPC)
227# if (_WIN32_WCE >= 400)
228# ifndef __WINCE_NET__
229# define __WINCE_NET__
230# endif
761fbb87 231# elif (_WIN32_WCE >= 200)
daeb8330
RR
232# ifndef __HANDHELDPC__
233# define __HANDHELDPC__
234# endif
235# endif
9b141468
WS
236# ifndef __WXWINCE__
237# define __WXWINCE__
238# endif
daeb8330
RR
239#endif
240
3795f11f
VZ
241#if defined(__WXWINCE__) && defined(_MSC_VER) && (_MSC_VER == 1201)
242 #define __EVC4__
243#endif
244
f1a4ca62
WS
245#if defined(__POCKETPC__) || defined(__SMARTPHONE__) || defined(__WXGPE__)
246# define __WXHANDHELD__
247#endif
248
592a7465
VZ
249/*
250 Include wx/setup.h for the Unix platform defines generated by configure and
251 the library compilation options
252
253 Note that it must be included before defining hardware symbols below as they
254 could be already defined by configure
255 */
601b9dfa
FM
256#include "wx/setup.h"
257
2f46438b
FM
258#ifdef __GCCXML__
259 /*
260 we're using gccxml to create an XML representation of the entire
601b9dfa
FM
261 wxWidgets interface; use a special setup_gccxml.h file to fix some
262 of the stuff #defined by the real setup.h
2f46438b
FM
263 */
264 #include "wx/setup_gccxml.h"
2f46438b 265#endif
592a7465 266
601b9dfa 267
748a4684
VZ
268/*
269 Hardware platform detection.
270
271 VC++ defines _M_xxx symbols.
272 */
273#if defined(_M_IX86) || defined(i386) || defined(__i386) || defined(__i386__)
274 #ifndef __INTEL__
275 #define __INTEL__
276 #endif
277#endif /* x86 */
278
279#if defined(_M_IA64)
280 #ifndef __IA64__
281 #define __IA64__
282 #endif
283#endif /* ia64 */
284
80da12bc 285#if defined(_M_MPPC) || defined(__PPC__) || defined(__ppc__)
748a4684
VZ
286 #ifndef __POWERPC__
287 #define __POWERPC__
288 #endif
289#endif /* alpha */
290
291#if defined(_M_ALPHA) || defined(__AXP__)
292 #ifndef __ALPHA__
293 #define __ALPHA__
294 #endif
295#endif /* alpha */
296
78340847 297
63e7198b
VZ
298/*
299 adjust the Unicode setting: wxUSE_UNICODE should be defined as 0 or 1
77ffb593 300 and is used by wxWidgets, _UNICODE and/or UNICODE may be defined or used by
63e7198b
VZ
301 the system headers so bring these settings in sync
302 */
303
304/* set wxUSE_UNICODE to 1 if UNICODE or _UNICODE is defined */
305#if defined(_UNICODE) || defined(UNICODE)
306# undef wxUSE_UNICODE
307# define wxUSE_UNICODE 1
308#else /* !UNICODE */
309# ifndef wxUSE_UNICODE
310# define wxUSE_UNICODE 0
311# endif
312#endif /* UNICODE/!UNICODE */
313
314/* and vice versa: define UNICODE and _UNICODE if wxUSE_UNICODE is 1 */
315#if wxUSE_UNICODE
316# ifndef _UNICODE
317# define _UNICODE
318# endif
319# ifndef UNICODE
320# define UNICODE
321# endif
322#endif /* wxUSE_UNICODE */
323
b3c35859 324#if defined( __MWERKS__ ) && !defined(__INTEL__)
3b2b40b4 325/* otherwise MSL headers bring in WIN32 dependant APIs */
b3c35859
SC
326#undef UNICODE
327#endif
79e70894
VZ
328
329
9eaadb1b
VZ
330/*
331 test for old versions of Borland C, normally need at least 5.82, Turbo
2f46438b 332 explorer, available for free at http://www.turboexplorer.com/downloads
6b73ac78 333*/
63ef7db3 334#if defined(__BORLANDC__) && (__BORLANDC__ < 0x550)
9eaadb1b 335# error "wxWidgets requires a newer version of Borland, we recommend upgrading to 5.82 (Turbo Explorer). You may at your own risk remove this line and try building but be prepared to get build errors."
63ef7db3
CE
336#endif /* __BORLANDC__ */
337
338#if defined(__BORLANDC__) && (__BORLANDC__ < 0x582) && (__BORLANDC__ > 0x559)
9eaadb1b
VZ
339# ifndef _USE_OLD_RW_STL
340# error "wxWidgets is incompatible with default Borland C++ 5.6 STL library, please add -D_USE_OLD_RW_STL to your bcc32.cfg to use RogueWave STL implementation."
341# endif
c266eff9 342#endif /* __BORLANDC__ */
6b73ac78
CE
343
344
6d3d756a 345/*
af588446 346 Define Watcom-specific macros.
6d3d756a
WS
347*/
348#ifndef __WATCOMC__
349# define wxWATCOM_VERSION(major,minor) 0
350# define wxCHECK_WATCOM_VERSION(major,minor) 0
351# define wxONLY_WATCOM_EARLIER_THAN(major,minor) 0
af588446 352# define WX_WATCOM_ONLY_CODE( x )
6d3d756a 353#else
af588446
VZ
354# if __WATCOMC__ < 1200
355# error "Only Open Watcom is supported in this release"
356# endif
357
6d3d756a
WS
358# define wxWATCOM_VERSION(major,minor) ( major * 100 + minor * 10 + 1100 )
359# define wxCHECK_WATCOM_VERSION(major,minor) ( __WATCOMC__ >= wxWATCOM_VERSION(major,minor) )
360# define wxONLY_WATCOM_EARLIER_THAN(major,minor) ( __WATCOMC__ < wxWATCOM_VERSION(major,minor) )
af588446 361# define WX_WATCOM_ONLY_CODE( x ) x
6d3d756a
WS
362#endif
363
78340847 364/*
865c589e
VS
365 OS: first of all, test for MS-DOS platform. We must do this before testing
366 for Unix, because DJGPP compiler defines __unix__ under MS-DOS
367 */
368#if defined(__GO32__) || defined(__DJGPP__) || defined(__DOS__)
ef620df0
VZ
369# ifndef __DOS__
370# define __DOS__
371# endif
865c589e
VS
372 /* size_t is the same as unsigned int for Watcom 11 compiler, */
373 /* so define it if it hadn't been done by configure yet */
ef620df0
VZ
374# if !defined(wxSIZE_T_IS_UINT) && !defined(wxSIZE_T_IS_ULONG)
375# ifdef __WATCOMC__
376# define wxSIZE_T_IS_UINT
377# endif
378# ifdef __DJGPP__
379# define wxSIZE_T_IS_ULONG
380# endif
381# endif
865c589e
VS
382
383/*
384 OS: then test for generic Unix defines, then for particular flavours and
78340847 385 finally for Unix-like systems
80da12bc 386 Mac OS X matches this case (__MACH__), prior Mac OS do not.
78340847 387 */
865c589e
VS
388#elif defined(__UNIX__) || defined(__unix) || defined(__unix__) || \
389 defined(____SVR4____) || defined(__LINUX__) || defined(__sgi) || \
390 defined(__hpux) || defined(sun) || defined(__SUN__) || defined(_AIX) || \
80da12bc 391 defined(__EMX__) || defined(__VMS) || defined(__BEOS__) || defined(__MACH__)
78340847 392
ef620df0 393# define __UNIX_LIKE__
78340847
VZ
394
395 /* Helps SGI compilation, apparently */
ef620df0
VZ
396# ifdef __SGI__
397# ifdef __GNUG__
398# define __need_wchar_t
399# else /* !gcc */
78340847
VZ
400 /*
401 Note I use the term __SGI_CC__ for both cc and CC, its not a good
402 idea to mix gcc and cc/CC, the name mangling is different
403 */
ef620df0
VZ
404# define __SGI_CC__
405# endif /* gcc/!gcc */
ae072480
VZ
406
407 /* system headers use this symbol and not __cplusplus in some places */
408# ifndef _LANGUAGE_C_PLUS_PLUS
409# define _LANGUAGE_C_PLUS_PLUS
410# endif
ef620df0
VZ
411# endif /* SGI */
412
2686d933
VZ
413# if defined(__SUNPRO_CC)
414# ifndef __SUNCC__
415# define __SUNCC__ __SUNPRO_CC
416# endif /* Sun CC */
417# endif /* Sun CC */
ef620df0
VZ
418
419# ifdef __EMX__
420# define OS2EMX_PLAIN_CHAR
421# endif
6d8978f0
SN
422# if defined(__INNOTEK_LIBC__)
423 /* Ensure visibility of strnlen declaration */
424# define _GNU_SOURCE
425# endif
78340847
VZ
426
427 /* define __HPUX__ for HP-UX where standard macro is __hpux */
ef620df0
VZ
428# if defined(__hpux) && !defined(__HPUX__)
429# define __HPUX__
430# endif /* HP-UX */
431
432# if defined(__CYGWIN__) || defined(__WINE__)
433# if !defined(wxSIZE_T_IS_UINT)
434# define wxSIZE_T_IS_UINT
435# endif
436# endif
80da12bc
DE
437
438 /* All of these should already be defined by including configure-
439 generated setup.h but we wish to support Xcode compilation without
440 requiring the user to define these himself.
441 */
442# if defined(__APPLE__) && defined(__MACH__)
443# ifndef __UNIX__
444# define __UNIX__ 1
445# endif
446# ifndef __BSD__
447# define __BSD__ 1
448# endif
449 /* __DARWIN__ is our own define to mean OS X or pure Darwin */
450# ifndef __DARWIN__
451# define __DARWIN__ 1
452# endif
453 /* NOTE: TARGET_CARBON is actually a 0/1 and must be 1 for OS X */
454# ifndef TARGET_CARBON
455# define TARGET_CARBON 1
456# endif
457 /* OS X uses unsigned long size_t for both ILP32 and LP64 modes. */
458# if !defined(wxSIZE_T_IS_UINT) && !defined(wxSIZE_T_IS_ULONG)
459# define wxSIZE_T_IS_ULONG
460# endif
461# endif
462
463/*
464 OS: Classic Mac OS
465 */
78340847
VZ
466#elif defined(applec) || \
467 defined(THINK_C) || \
468 (defined(__MWERKS__) && !defined(__INTEL__))
469 /* MacOS */
ef620df0
VZ
470# if !defined(wxSIZE_T_IS_UINT) && !defined(wxSIZE_T_IS_ULONG)
471# define wxSIZE_T_IS_ULONG
472# endif
78340847 473
80da12bc
DE
474/*
475 OS: OS/2
476 */
78340847 477#elif defined(__OS2__)
55034339
WS
478
479 /* wxOS2 vs. non wxOS2 ports on OS2 platform */
fbf618df 480# if !defined(__WXMOTIF__) && !defined(__WXGTK__) && !defined(__WXX11__)
55034339
WS
481# ifndef __WXPM__
482# define __WXPM__
483# endif
484# endif
485
ef620df0
VZ
486# if defined(__IBMCPP__)
487# define __VISAGEAVER__ __IBMCPP__
ef620df0 488# endif
78340847
VZ
489
490 /* Place other OS/2 compiler environment defines here */
ef620df0 491# if defined(__VISAGECPP__)
78340847 492 /* VisualAge is the only thing that understands _Optlink */
ef620df0
VZ
493# define LINKAGEMODE _Optlink
494# endif
495# define wxSIZE_T_IS_UINT
c427acc8 496
80da12bc
DE
497/*
498 OS: Palm OS
499 */
4055ed82
WS
500#elif defined(__PALMOS__)
501# ifdef __WIN32__
502# error "__WIN32__ should not be defined for PalmOS"
503# endif
504# ifdef __WINDOWS__
505# error "__WINDOWS__ should not be defined for PalmOS"
506# endif
507# ifdef __WXMSW__
508# error "__WXMSW__ should not be defined for PalmOS"
509# endif
510
80da12bc
DE
511/*
512 OS: Otherwise it must be Windows
513 */
78340847 514#else /* Windows */
ef620df0
VZ
515# ifndef __WINDOWS__
516# define __WINDOWS__
517# endif /* Windows */
78340847
VZ
518
519 /* to be changed for Win64! */
ef620df0 520# ifndef __WIN32__
3a5bcc4d 521# error "__WIN32__ should be defined for Win32 and Win64, Win16 is not supported"
ef620df0 522# endif
78340847
VZ
523
524 /*
525 define another standard symbol for Microsoft Visual C++: the standard
526 one (_MSC_VER) is also defined by Metrowerks compiler
527 */
ef620df0
VZ
528# if defined(_MSC_VER) && !defined(__MWERKS__)
529# define __VISUALC__ _MSC_VER
6b9c622a
VZ
530
531 /*
532 define special symbols for different VC version instead of writing tests
533 for magic numbers such as 1200, 1300 &c repeatedly
534 */
535# if __VISUALC__ < 1100
536# error "This Visual C++ version is too old and not supported any longer."
537# elif __VISUALC__ < 1200
538# define __VISUALC5__
539# elif __VISUALC__ < 1300
540# define __VISUALC6__
541# elif __VISUALC__ < 1400
542# define __VISUALC7__
543# elif __VISUALC__ < 1500
544# define __VISUALC8__
545# elif __VISUALC__ < 1600
546# define __VISUALC9__
547# else
548# pragma message("Please update this code for the next VC++ version")
549# endif
550
ef620df0
VZ
551# elif defined(__BCPLUSPLUS__) && !defined(__BORLANDC__)
552# define __BORLANDC__
6d3d756a 553# elif defined(__WATCOMC__)
ef620df0
VZ
554# elif defined(__SC__)
555# define __SYMANTECC__
556# endif /* compiler */
78340847
VZ
557
558 /* size_t is the same as unsigned int for all Windows compilers we know, */
559 /* so define it if it hadn't been done by configure yet */
3656eefc 560# if !defined(wxSIZE_T_IS_UINT) && !defined(wxSIZE_T_IS_ULONG) && !defined(__WIN64__)
ef620df0
VZ
561# define wxSIZE_T_IS_UINT
562# endif
78340847
VZ
563#endif /* OS */
564
565/*
566 if we're on a Unix system but didn't use configure (so that setup.h didn't
567 define __UNIX__), do define __UNIX__ now
568 */
569#if !defined(__UNIX__) && defined(__UNIX_LIKE__)
ef620df0 570# define __UNIX__
78340847
VZ
571#endif /* Unix */
572
f79bd02d 573#if defined(__WXMOTIF__) || defined(__WXX11__)
ef620df0 574# define __X__
78340847
VZ
575#endif
576
4b41ab26 577#ifdef __SC__
ef620df0
VZ
578# ifdef __DMC__
579# define __DIGITALMARS__
580# else
581# define __SYMANTEC__
582# endif
4b41ab26
VS
583#endif
584
17a1ebd1
VZ
585#ifdef __INTEL_COMPILER
586# define __INTELC__
587#endif
588
7eb00c80
VZ
589/*
590 We get "Large Files (ILP32) not supported in strict ANSI mode." #error
591 from HP-UX standard headers when compiling with g++ without this:
592 */
593#if defined(__HPUX__) && !defined(__STDC_EXT__)
594# define __STDC_EXT__ 1
595#endif
596
a84d5f9d 597/* Force linking against required libraries under Windows: */
eddb3250
VS
598#ifdef __WXWINCE__
599# include "wx/msw/wince/libraries.h"
a84d5f9d
MW
600#elif defined __WINDOWS__
601# include "wx/msw/libraries.h"
eddb3250
VS
602#endif
603
44893b87
VZ
604/*
605 This macro can be used to test the gcc version and can be used like this:
606
ef620df0 607# if wxCHECK_GCC_VERSION(3, 1)
44893b87 608 ... we have gcc 3.1 or later ...
ef620df0 609# else
44893b87 610 ... no gcc at all or gcc < 3.1 ...
ef620df0 611# endif
44893b87 612*/
49ca2a99
PC
613#if defined(__GNUC__) && defined(__GNUC_MINOR__)
614 #define wxCHECK_GCC_VERSION( major, minor ) \
615 ( ( __GNUC__ > (major) ) \
616 || ( __GNUC__ == (major) && __GNUC_MINOR__ >= (minor) ) )
617#else
618 #define wxCHECK_GCC_VERSION( major, minor ) 0
619#endif
44893b87 620
459f812b
SN
621#if defined(__BORLANDC__) || (defined(__GNUC__) && __GNUC__ < 3)
622#define wxNEEDS_CHARPP
623#endif
624
a38c9b43
VS
625/*
626 This macro can be used to test the Visual C++ version.
627*/
628#ifndef __VISUALC__
629# define wxVISUALC_VERSION(major) 0
630# define wxCHECK_VISUALC_VERSION(major) 0
631#else
632# define wxVISUALC_VERSION(major) ( (6 + major) * 100 )
633# define wxCHECK_VISUALC_VERSION(major) ( __VISUALC__ >= wxVISUALC_VERSION(major) )
634#endif
635
78340847
VZ
636/*
637 This macro can be used to check that the version of mingw32 compiler is
638 at least maj.min
639 */
a0be6908 640#if ( defined( __GNUWIN32__ ) || defined( __MINGW32__ ) || \
7275146d 641 ( defined( __CYGWIN__ ) && defined( __WINDOWS__ ) ) || \
6d3d756a 642 wxCHECK_WATCOM_VERSION(1,0) ) && \
a0be6908 643 !defined(__DOS__) && \
cb7d7375 644 !defined(__WXPM__) && \
a0be6908
WS
645 !defined(__WXMOTIF__) && \
646 !defined(__WXGTK__) && \
647 !defined(__WXX11__) && \
648 !defined(__WXPALMOS__)
ef620df0 649# include "wx/msw/gccpriv.h"
78340847 650#else
ef620df0
VZ
651# undef wxCHECK_W32API_VERSION
652# define wxCHECK_W32API_VERSION(maj, min) (0)
78340847
VZ
653#endif
654
2686d933
VZ
655/**
656 This is similar to wxCHECK_GCC_VERSION but for Sun CC compiler.
657 */
658#ifdef __SUNCC__
659 /*
660 __SUNCC__ is 0xVRP where V is major version, R release and P patch level
661 */
662 #define wxCHECK_SUNCC_VERSION(maj, min) (__SUNCC__ >= (((maj)<<8) | ((min)<<4)))
663#else
664 #define wxCHECK_SUNCC_VERSION(maj, min) (0)
665#endif
666
5ed63bf5
DE
667/*
668 Handle Darwin gcc universal compilation. Don't do this in an Apple-
669 specific case since no sane compiler should be defining either
670 __BIG_ENDIAN__ or __LITTLE_ENDIAN__ unless it really is generating
671 code that will be hosted on a machine with the appropriate endianness.
672 If a compiler defines neither, assume the user or configure set
673 WORDS_BIGENDIAN appropriately.
674 */
675#if defined(__BIG_ENDIAN__)
676# undef WORDS_BIGENDIAN
677# define WORDS_BIGENDIAN 1
678#elif defined(__LITTLE_ENDIAN__)
679# undef WORDS_BIGENDIAN
680#elif defined(__WXMAC__) && !defined(WORDS_BIGENDIAN)
681/* According to Stefan even ancient Mac compilers defined __BIG_ENDIAN__ */
682# warning "Compiling wxMac with probably wrong endianness"
01ebf752 683#endif
2f263517
SC
684/* also the 32/64 bit universal builds must be handled accordingly */
685#ifdef __DARWIN__
03647350
VZ
686# ifdef __LP64__
687# undef SIZEOF_VOID_P
688# undef SIZEOF_LONG
689# undef SIZEOF_SIZE_T
690# define SIZEOF_VOID_P 8
691# define SIZEOF_LONG 8
692# define SIZEOF_SIZE_T 8
693# else
694# undef SIZEOF_VOID_P
695# undef SIZEOF_LONG
696# undef SIZEOF_SIZE_T
697# define SIZEOF_VOID_P 4
698# define SIZEOF_LONG 4
699# define SIZEOF_SIZE_T 4
700# endif
2f263517 701#endif
d6f2a891
VZ
702/*
703 check the consistency of the settings in setup.h: note that this must be
704 done after setting wxUSE_UNICODE correctly as it is used in wx/chkconf.h
705 and after defining the compiler macros which are used in it too
706 */
707#include "wx/chkconf.h"
708
709
710/*
711 some compilers don't support iostream.h any longer, while some of theme
712 are not updated with <iostream> yet, so override the users setting here
713 in such case.
714 */
715#if defined(_MSC_VER) && (_MSC_VER >= 1310)
716# undef wxUSE_IOSTREAMH
717# define wxUSE_IOSTREAMH 0
718#elif defined(__DMC__) || defined(__WATCOMC__)
719# undef wxUSE_IOSTREAMH
720# define wxUSE_IOSTREAMH 1
721#elif defined(__MINGW32__)
722# undef wxUSE_IOSTREAMH
723# define wxUSE_IOSTREAMH 0
724#endif /* compilers with/without iostream.h */
725
726/*
727 old C++ headers (like <iostream.h>) declare classes in the global namespace
728 while the new, standard ones (like <iostream>) do it in std:: namespace,
729 unless it's an old gcc version.
730
731 using this macro allows constuctions like "wxSTD iostream" to work in
732 either case
733 */
734#if !wxUSE_IOSTREAMH && (!defined(__GNUC__) || ( __GNUC__ > 2 ) || (__GNUC__ == 2 && __GNUC_MINOR__ >= 95))
735# define wxSTD std::
736#else
737# define wxSTD
738#endif
739
b6937696
JJ
740/* On OpenVMS with the most recent HP C++ compiler some function (i.e. wscanf)
741 * are only available in the std-namespace. (BUG???)
742 */
743#if defined( __VMS ) && (__DECCXX_VER >= 70100000) && !defined(__STD_CFRONT) && !defined( __NONAMESPACE_STD )
744# define wxVMS_USE_STD std::
745#else
746# define wxVMS_USE_STD
747#endif
748
455f7c82
VZ
749#ifdef __VMS
750#define XtDisplay XTDISPLAY
751#ifdef __WXMOTIF__
752#define XtParent XTPARENT
753#define XtScreen XTSCREEN
754#define XtWindow XTWINDOW
755#endif
756#endif
757
0b30bb0b
JS
758/* Choose which method we will use for updating menus
759 * - in OnIdle, or when we receive a wxEVT_MENU_OPEN event.
760 * Presently, only Windows and GTK+ support wxEVT_MENU_OPEN.
761 */
762#ifndef wxUSE_IDLEMENUUPDATES
12c19488 763# if (defined(__WXMSW__) || defined(__WXGTK__)) && !defined(__WXUNIVERSAL__)
ef620df0
VZ
764# define wxUSE_IDLEMENUUPDATES 0
765# else
766# define wxUSE_IDLEMENUUPDATES 1
767# endif
0b30bb0b
JS
768#endif
769
5e967044
JS
770/*
771 * Define symbols that are not yet in
772 * configure or possibly some setup.h files.
773 * They will need to be added.
774 */
775
776#ifndef wxUSE_FILECONFIG
6502dc68 777# if wxUSE_CONFIG && wxUSE_TEXTFILE
ef620df0
VZ
778# define wxUSE_FILECONFIG 1
779# else
780# define wxUSE_FILECONFIG 0
781# endif
5e967044
JS
782#endif
783
784#ifndef wxUSE_HOTKEY
ef620df0 785# define wxUSE_HOTKEY 0
5e967044
JS
786#endif
787
086b3a5b 788#if !defined(wxUSE_WXDIB) && defined(__WXMSW__)
ef620df0 789# define wxUSE_WXDIB 1
086b3a5b
JS
790#endif
791
e40bae72 792/*
4055ed82 793 We need AvailabilityMacros.h for ifdefing out things that don't exist on
e40bae72
RN
794 OSX 10.2 and lower
795 FIXME: We need a better way to detect for 10.3 then including a system header
796*/
797#ifdef __DARWIN__
798 #include <AvailabilityMacros.h>
799#endif
800
e2fc40b4
VZ
801#if defined (__WXPALMOS__)
802#include "wx/palmos/missing.h"
803#endif // __WXPALMOS__
804
805#if !defined (__WXPALMOS5__)
806#define POSSEC_APPBASE
807#define POSSEC_ARCHIVE
808#define POSSEC_CLNTDATA
809#define POSSEC_CMDLINE
810#define POSSEC_CONFIG
811#define POSSEC_DATETIME
812#define POSSEC_DATETIME2
813#define POSSEC_DATSTRM
814#define POSSEC_DIRCMN
815#define POSSEC_DYNARRAY
816#define POSSEC_DYNLIB
817#define POSSEC_DYNLOAD
818#define POSSEC_ENCCONV
819#define POSSEC_EXTENDED
820#define POSSEC_FFILE
821#define POSSEC_FILE
822#define POSSEC_FILECONF
823#define POSSEC_FILEFN
824#endif // __WXPALMOS5__
825
78340847 826#endif /* _WX_PLATFORM_H_ */