added Win64 detection

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@23816 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin 2003-09-22 12:43:36 +00:00
parent 014c5a64b5
commit ef620df011

View File

@ -20,7 +20,7 @@
are included
*/
#if __MWERKS__
#include <stddef.h>
# include <stddef.h>
#endif
/*
@ -30,53 +30,68 @@
#if defined(__CYGWIN32__) && !defined(__WXMOTIF__) && !defined(__WXGTK__) \
&& !defined(__WXX11__)
/* for Cygwin, default to wxMSW unless otherwise specified */
#ifndef __WXMSW__
#define __WXMSW__
#endif
# ifndef __WXMSW__
# define __WXMSW__
# endif
#ifndef _WIN32
#define _WIN32
#endif
# ifndef _WIN32
# define _WIN32
# endif
#ifndef WIN32
#define WIN32
#endif
# ifndef WIN32
# define WIN32
# endif
#endif
#if defined(_WIN32) || defined(WIN32) || defined(__NT__) || defined(__WXWINCE__)
#ifndef __WXMSW__
#define __WXMSW__
#endif
#if defined(_WIN64)
# ifndef _WIN32
/*
a lot of code (mistakenly) uses #ifdef _WIN32 to either test for
Windows or to test for !__WIN16__, so we must define _WIN32 for
Win64 as well to ensure that the existing code continues to work.
*/
# define _WIN32
# endif /* !_WIN32 */
#ifndef __WIN32__
#define __WIN32__
#endif
# ifndef __WIN64__
# define __WIN64__
# endif /* !__WIN64__ */
#endif /* _WIN64 */
#if defined(_WIN32) || defined(WIN32) || defined(__NT__) || defined(__WXWINCE__)
# ifndef __WXMSW__
# define __WXMSW__
# endif
# ifndef __WIN32__
# define __WIN32__
# endif
/*
see MSDN for the description of possible WINVER values, this one is a
good default and, anyhow, we check for most of the features we use
during run-time.
*/
#ifndef WINVER
#define WINVER 0x0400
#endif
# ifndef WINVER
# define WINVER 0x0400
# endif
/* Win95 means Win95-style UI, i.e. Win9x/NT 4+ */
#if !defined(__WIN95__) && (WINVER >= 0x0400)
#define __WIN95__
#endif
# if !defined(__WIN95__) && (WINVER >= 0x0400)
# define __WIN95__
# endif
#endif /* Win32 */
#if defined(__WXMSW__) || defined(__WIN32__)
#if !defined(__WINDOWS__)
#define __WINDOWS__
#endif
# if !defined(__WINDOWS__)
# define __WINDOWS__
# endif
#endif
#ifdef __WINE__
#ifndef __WIN95__
#define __WIN95__
#endif
# ifndef __WIN95__
# define __WIN95__
# endif
#endif /* WINE */
/*
@ -93,8 +108,8 @@
setting here in such case.
*/
#if defined(_MSC_VER) && (_MSC_VER >= 1310)
#undef wxUSE_IOSTREAMH
#define wxUSE_IOSTREAMH 0
# undef wxUSE_IOSTREAMH
# define wxUSE_IOSTREAMH 0
#endif /* compilers not supporting iostream.h */
/*
@ -105,9 +120,9 @@
either case
*/
#if !wxUSE_IOSTREAMH
#define wxSTD std::
# define wxSTD std::
#else
#define wxSTD
# define wxSTD
#endif
/*
@ -115,19 +130,19 @@
for Unix, because DJGPP compiler defines __unix__ under MS-DOS
*/
#if defined(__GO32__) || defined(__DJGPP__) || defined(__DOS__)
#ifndef __DOS__
#define __DOS__
#endif
# ifndef __DOS__
# define __DOS__
# endif
/* size_t is the same as unsigned int for Watcom 11 compiler, */
/* so define it if it hadn't been done by configure yet */
#if !defined(wxSIZE_T_IS_UINT) && !defined(wxSIZE_T_IS_ULONG)
#ifdef __WATCOMC__
#define wxSIZE_T_IS_UINT
#endif
#ifdef __DJGPP__
#define wxSIZE_T_IS_ULONG
#endif
#endif
# if !defined(wxSIZE_T_IS_UINT) && !defined(wxSIZE_T_IS_ULONG)
# ifdef __WATCOMC__
# define wxSIZE_T_IS_UINT
# endif
# ifdef __DJGPP__
# define wxSIZE_T_IS_ULONG
# endif
# endif
/*
OS: then test for generic Unix defines, then for particular flavours and
@ -138,128 +153,128 @@
defined(__hpux) || defined(sun) || defined(__SUN__) || defined(_AIX) || \
defined(__EMX__) || defined(__VMS) || defined(__BEOS__)
#define __UNIX_LIKE__
# define __UNIX_LIKE__
/* Helps SGI compilation, apparently */
#ifdef __SGI__
#ifdef __GNUG__
#define __need_wchar_t
#else /* !gcc */
# ifdef __SGI__
# ifdef __GNUG__
# define __need_wchar_t
# else /* !gcc */
/*
Note I use the term __SGI_CC__ for both cc and CC, its not a good
idea to mix gcc and cc/CC, the name mangling is different
*/
#define __SGI_CC__
#endif /* gcc/!gcc */
#endif /* SGI */
# define __SGI_CC__
# endif /* gcc/!gcc */
# endif /* SGI */
#if defined(sun) || defined(__SUN__)
#ifndef __GNUG__
#ifndef __SUNCC__
#define __SUNCC__
#endif /* Sun CC */
#endif
#endif /* Sun */
# if defined(sun) || defined(__SUN__)
# ifndef __GNUG__
# ifndef __SUNCC__
# define __SUNCC__
# endif /* Sun CC */
# endif
# endif /* Sun */
#ifdef __EMX__
#define OS2EMX_PLAIN_CHAR
#endif
# ifdef __EMX__
# define OS2EMX_PLAIN_CHAR
# endif
/* define __HPUX__ for HP-UX where standard macro is __hpux */
#if defined(__hpux) && !defined(__HPUX__)
#define __HPUX__
#endif /* HP-UX */
# if defined(__hpux) && !defined(__HPUX__)
# define __HPUX__
# endif /* HP-UX */
#if defined(__CYGWIN__) || defined(__WINE__)
#if !defined(wxSIZE_T_IS_UINT)
#define wxSIZE_T_IS_UINT
#endif
#endif
# if defined(__CYGWIN__) || defined(__WINE__)
# if !defined(wxSIZE_T_IS_UINT)
# define wxSIZE_T_IS_UINT
# endif
# endif
#elif defined(applec) || \
defined(THINK_C) || \
(defined(__MWERKS__) && !defined(__INTEL__))
/* MacOS */
#if !defined(wxSIZE_T_IS_UINT) && !defined(wxSIZE_T_IS_ULONG)
#define wxSIZE_T_IS_ULONG
#endif
# if !defined(wxSIZE_T_IS_UINT) && !defined(wxSIZE_T_IS_ULONG)
# define wxSIZE_T_IS_ULONG
# endif
#elif defined(__WXMAC__) && defined(__APPLE__)
/* Mac OS X */
#define __UNIX_LIKE__
# define __UNIX_LIKE__
/*
These defines are needed when compiling using Project Builder
with a non generated setup0.h
*/
#ifndef __UNIX__
#define __UNIX__ 1
#endif
#ifndef __BSD__
#define __BSD__ 1
#endif
#ifndef __DARWIN__
#define __DARWIN__ 1
#endif
#ifndef __POWERPC__
#define __POWERPC__ 1
#endif
#ifndef TARGET_CARBON
#define TARGET_CARBON 1
#endif
# ifndef __UNIX__
# define __UNIX__ 1
# endif
# ifndef __BSD__
# define __BSD__ 1
# endif
# ifndef __DARWIN__
# define __DARWIN__ 1
# endif
# ifndef __POWERPC__
# define __POWERPC__ 1
# endif
# ifndef TARGET_CARBON
# define TARGET_CARBON 1
# endif
#if !defined(wxSIZE_T_IS_UINT) && !defined(wxSIZE_T_IS_ULONG)
#define wxSIZE_T_IS_ULONG
#endif
# if !defined(wxSIZE_T_IS_UINT) && !defined(wxSIZE_T_IS_ULONG)
# define wxSIZE_T_IS_ULONG
# endif
/*
Some code has been added to workaround defects(?) in the
bundled gcc compiler. These corrections are identified by
__DARWIN__ for Darwin related corrections (wxMac, wxMotif)
*/
#elif defined(__OS2__)
#if defined(__IBMCPP__)
#define __VISAGEAVER__ __IBMCPP__
#endif
#ifndef __WXOS2__
#define __WXOS2__
#endif
#ifndef __WXPM__
#define __WXPM__
#endif
# if defined(__IBMCPP__)
# define __VISAGEAVER__ __IBMCPP__
# endif
# ifndef __WXOS2__
# define __WXOS2__
# endif
# ifndef __WXPM__
# define __WXPM__
# endif
/* Place other OS/2 compiler environment defines here */
#if defined(__VISAGECPP__)
# if defined(__VISAGECPP__)
/* VisualAge is the only thing that understands _Optlink */
#define LINKAGEMODE _Optlink
#endif
#define wxSIZE_T_IS_UINT
# define LINKAGEMODE _Optlink
# endif
# define wxSIZE_T_IS_UINT
#else /* Windows */
#ifndef __WINDOWS__
#define __WINDOWS__
#endif /* Windows */
# ifndef __WINDOWS__
# define __WINDOWS__
# endif /* Windows */
/* to be changed for Win64! */
#ifndef __WIN32__
#define __WIN16__
#endif
# ifndef __WIN32__
# define __WIN16__
# endif
/*
define another standard symbol for Microsoft Visual C++: the standard
one (_MSC_VER) is also defined by Metrowerks compiler
*/
#if defined(_MSC_VER) && !defined(__MWERKS__)
#define __VISUALC__ _MSC_VER
#elif defined(__BCPLUSPLUS__) && !defined(__BORLANDC__)
#define __BORLANDC__
#elif defined(__WATCOMC__)
#elif defined(__SC__)
#define __SYMANTECC__
#endif /* compiler */
# if defined(_MSC_VER) && !defined(__MWERKS__)
# define __VISUALC__ _MSC_VER
# elif defined(__BCPLUSPLUS__) && !defined(__BORLANDC__)
# define __BORLANDC__
# elif defined(__WATCOMC__)
# elif defined(__SC__)
# define __SYMANTECC__
# endif /* compiler */
/* size_t is the same as unsigned int for all Windows compilers we know, */
/* so define it if it hadn't been done by configure yet */
#if !defined(wxSIZE_T_IS_UINT) && !defined(wxSIZE_T_IS_ULONG)
#define wxSIZE_T_IS_UINT
#endif
# if !defined(wxSIZE_T_IS_UINT) && !defined(wxSIZE_T_IS_ULONG)
# define wxSIZE_T_IS_UINT
# endif
#endif /* OS */
/*
@ -267,35 +282,35 @@
define __UNIX__), do define __UNIX__ now
*/
#if !defined(__UNIX__) && defined(__UNIX_LIKE__)
#define __UNIX__
# define __UNIX__
#endif /* Unix */
#if defined(__HPUX__) && !defined(__WXGTK__)
#ifndef __WXMOTIF__
#define __WXMOTIF__
#endif /* __WXMOTIF__ */
# ifndef __WXMOTIF__
# define __WXMOTIF__
# endif /* __WXMOTIF__ */
#endif
#if defined(__WXMOTIF__) || defined(__WXX11__)
#define __X__
# define __X__
#endif
#ifdef __SC__
#ifdef __DMC__
#define __DIGITALMARS__
#else
#define __SYMANTEC__
#endif
# ifdef __DMC__
# define __DIGITALMARS__
# else
# define __SYMANTEC__
# endif
#endif
/*
This macro can be used to test the gcc version and can be used like this:
#if wxCHECK_GCC_VERSION(3, 1)
# if wxCHECK_GCC_VERSION(3, 1)
... we have gcc 3.1 or later ...
#else
# else
... no gcc at all or gcc < 3.1 ...
#endif
# endif
*/
#define wxCHECK_GCC_VERSION( major, minor ) \
( defined(__GNUC__) && defined(__GNUC_MINOR__) \
@ -309,22 +324,22 @@
#if defined( __GNUWIN32__ ) || defined( __MINGW32__ ) || \
defined( __CYGWIN__ ) || \
(defined(__WATCOMC__) && __WATCOMC__ >= 1200)
#include "wx/msw/gccpriv.h"
# include "wx/msw/gccpriv.h"
#else
#undef wxCHECK_W32API_VERSION
#define wxCHECK_W32API_VERSION(maj, min) (0)
# undef wxCHECK_W32API_VERSION
# define wxCHECK_W32API_VERSION(maj, min) (0)
#endif
#if defined (__WXMSW__)
#if !defined(__WATCOMC__)
#define wxHAVE_RAW_BITMAP
#endif
# if !defined(__WATCOMC__)
# define wxHAVE_RAW_BITMAP
# endif
#endif
#if defined (__WXMAC__)
#ifndef WORDS_BIGENDIAN
#define WORDS_BIGENDIAN 1
#endif
# ifndef WORDS_BIGENDIAN
# define WORDS_BIGENDIAN 1
# endif
#endif
/* Choose which method we will use for updating menus
@ -332,11 +347,11 @@
* Presently, only Windows and GTK+ support wxEVT_MENU_OPEN.
*/
#ifndef wxUSE_IDLEMENUUPDATES
#if defined(__WXMSW__) || defined(__WXGTK__)
#define wxUSE_IDLEMENUUPDATES 0
#else
#define wxUSE_IDLEMENUUPDATES 1
#endif
# if defined(__WXMSW__) || defined(__WXGTK__)
# define wxUSE_IDLEMENUUPDATES 0
# else
# define wxUSE_IDLEMENUUPDATES 1
# endif
#endif
/*
@ -346,19 +361,19 @@
*/
#ifndef wxUSE_FILECONFIG
#if wxUSE_CONFIG
#define wxUSE_FILECONFIG 1
#else
#define wxUSE_FILECONFIG 0
#endif
# if wxUSE_CONFIG
# define wxUSE_FILECONFIG 1
# else
# define wxUSE_FILECONFIG 0
# endif
#endif
#ifndef wxUSE_HOTKEY
#define wxUSE_HOTKEY 0
# define wxUSE_HOTKEY 0
#endif
#if !defined(wxUSE_WXDIB) && defined(__WXMSW__)
#define wxUSE_WXDIB 1
# define wxUSE_WXDIB 1
#endif
#endif /* _WX_PLATFORM_H_ */