mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-15 18:49:11 +01:00
317e63e7ba
Note warnings may still be generated by code in Externals if it is included into warning-enabled code (this is the case for libusb). Also, quiet an intellisense warning in wxWidgets caused by using __w64 for an inapplicable type.
3538 lines
116 KiB
Objective-C
3538 lines
116 KiB
Objective-C
/*
|
|
* Name: wx/defs.h
|
|
* Purpose: Declarations/definitions common to all wx source files
|
|
* Author: Julian Smart and others
|
|
* Modified by: Ryan Norton (Converted to C)
|
|
* Created: 01/02/97
|
|
* Copyright: (c) Julian Smart
|
|
* Licence: wxWindows licence
|
|
*/
|
|
|
|
/* THIS IS A C FILE, DON'T USE C++ FEATURES (IN PARTICULAR COMMENTS) IN IT */
|
|
|
|
#ifndef _WX_DEFS_H_
|
|
#define _WX_DEFS_H_
|
|
|
|
/*
|
|
NOTE: this symbol will be replaced with "WXWIN_COMPATIBILITY_3_0" as soon
|
|
as the development branch for 3.1 is created
|
|
*/
|
|
#define FUTURE_WXWIN_COMPATIBILITY_3_0 1
|
|
#define wxDEPRECATED_FUTURE( x ) x
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* compiler and OS identification */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
#include "wx/platform.h"
|
|
|
|
#ifdef __cplusplus
|
|
/* Make sure the environment is set correctly */
|
|
# if defined(__WXMSW__) && defined(__X__)
|
|
# error "Target can't be both X and MSW"
|
|
# elif !defined(__WXMOTIF__) && \
|
|
!defined(__WXMSW__) && \
|
|
!defined(__WXGTK__) && \
|
|
!defined(__WXPM__) && \
|
|
!defined(__WXOSX_CARBON__) && \
|
|
!defined(__WXOSX_COCOA__) && \
|
|
!defined(__WXOSX_IPHONE__) && \
|
|
!defined(__WXCOCOA__) && \
|
|
!defined(__X__) && \
|
|
!defined(__WXDFB__) && \
|
|
!defined(__WXX11__) && \
|
|
wxUSE_GUI
|
|
# ifdef __UNIX__
|
|
# error "No Target! You should use wx-config program for compilation flags!"
|
|
# else /* !Unix */
|
|
# error "No Target! You should use supplied makefiles for compilation!"
|
|
# endif /* Unix/!Unix */
|
|
# endif
|
|
#endif /*__cplusplus*/
|
|
|
|
#ifndef __WXWINDOWS__
|
|
#define __WXWINDOWS__ 1
|
|
#endif
|
|
|
|
#ifndef wxUSE_BASE
|
|
/* by default consider that this is a monolithic build */
|
|
#define wxUSE_BASE 1
|
|
#endif
|
|
|
|
#if !wxUSE_GUI && !defined(__WXBASE__)
|
|
#define __WXBASE__
|
|
#endif
|
|
|
|
/* suppress some Visual C++ warnings */
|
|
#ifdef __VISUALC__
|
|
/* the only "real" warning here is 4244 but there are just too many of them */
|
|
/* in our code... one day someone should go and fix them but until then... */
|
|
# pragma warning(disable:4097) /* typedef used as class */
|
|
# pragma warning(disable:4201) /* nonstandard extension used: nameless struct/union */
|
|
# pragma warning(disable:4244) /* conversion from double to float */
|
|
# pragma warning(disable:4355) /* 'this' used in base member initializer list */
|
|
# pragma warning(disable:4511) /* copy ctor couldn't be generated */
|
|
# pragma warning(disable:4512) /* operator=() couldn't be generated */
|
|
# pragma warning(disable:4514) /* unreferenced inline func has been removed */
|
|
# pragma warning(disable:4710) /* function not inlined */
|
|
|
|
/*
|
|
TODO: this warning should really be enabled as it can be genuinely
|
|
useful, check where does it occur in wxWidgets
|
|
*/
|
|
#pragma warning(disable: 4127) /* conditional expression is constant */
|
|
|
|
/* There are too many false positivies for this one, particularly when
|
|
using templates like wxVector<T> */
|
|
/* class 'foo' needs to have dll-interface to be used by clients of
|
|
class 'bar'" */
|
|
# pragma warning(disable:4251)
|
|
|
|
/*
|
|
This is a similar warning which occurs when deriving from standard
|
|
containers. MSDN even mentions that it can be ignored in this case
|
|
(albeit only in debug build while the warning is the same in release
|
|
too and seems equally harmless).
|
|
*/
|
|
#if wxUSE_STD_CONTAINERS
|
|
# pragma warning(disable:4275)
|
|
#endif /* wxUSE_STD_CONTAINERS */
|
|
|
|
# ifdef __VISUALC5__
|
|
/* For VC++ 5.0 for release mode, the warning 'C4702: unreachable code */
|
|
/* is buggy, and occurs for code that does actually get executed */
|
|
# ifndef __WXDEBUG__
|
|
# pragma warning(disable:4702) /* unreachable code */
|
|
# endif
|
|
|
|
/* The VC++ 5.0 warning 'C4003: not enough actual parameters for macro'
|
|
* is incompatible with the wxWidgets headers since it is given when
|
|
* parameters are empty but not missing. */
|
|
# pragma warning(disable:4003) /* not enough actual parameters for macro */
|
|
# endif
|
|
|
|
/*
|
|
VC6 insists on complaining about
|
|
|
|
return type for 'wxVector<T>::reverse_iterator::operator ->' is 'T **'
|
|
(ie; not a UDT or reference to a UDT. Will produce errors if applied
|
|
using infix notation)
|
|
|
|
which is perfectly fine because template classes do routinely define
|
|
operators which don't make sense for all template parameter values
|
|
(besides this warning was removed in subsequent versions).
|
|
*/
|
|
#ifdef __VISUALC6__
|
|
#pragma warning(disable: 4284)
|
|
#endif /* VC6 */
|
|
|
|
/*
|
|
When compiling with VC++ 7 /Wp64 option we get thousands of warnings for
|
|
conversion from size_t to int or long. Some precious few of them might
|
|
be worth looking into but unfortunately it seems infeasible to fix all
|
|
the other, harmless ones (e.g. inserting static_cast<int>(s.length())
|
|
everywhere this method is used though we are quite sure that using >4GB
|
|
strings is a bad idea anyhow) so just disable it globally for now.
|
|
*/
|
|
#if wxCHECK_VISUALC_VERSION(7)
|
|
/* conversion from 'size_t' to 'unsigned long', possible loss of data */
|
|
#pragma warning(disable:4267)
|
|
#endif /* VC++ 7 or later */
|
|
|
|
/*
|
|
VC++ 8 gives a warning when using standard functions such as sprintf,
|
|
localtime, ... -- stop this madness, unless the user had already done it
|
|
*/
|
|
#if wxCHECK_VISUALC_VERSION(8)
|
|
#ifndef _CRT_SECURE_NO_DEPRECATE
|
|
#define _CRT_SECURE_NO_DEPRECATE 1
|
|
#endif
|
|
#ifndef _CRT_NON_CONFORMING_SWPRINTFS
|
|
#define _CRT_NON_CONFORMING_SWPRINTFS 1
|
|
#endif
|
|
#ifndef _SCL_SECURE_NO_WARNINGS
|
|
#define _SCL_SECURE_NO_WARNINGS 1
|
|
#endif
|
|
#endif /* VC++ 8 */
|
|
#endif /* __VISUALC__ */
|
|
|
|
/* suppress some Borland C++ warnings */
|
|
#ifdef __BORLANDC__
|
|
# pragma warn -inl /* Functions containing reserved words and certain constructs are not expanded inline */
|
|
#endif /* __BORLANDC__ */
|
|
|
|
/*
|
|
g++ gives a warning when a class has private dtor if it has no friends but
|
|
this is a perfectly valid situation for a ref-counted class which destroys
|
|
itself when its ref count drops to 0, so provide a macro to suppress this
|
|
warning
|
|
*/
|
|
#ifdef __GNUG__
|
|
# define wxSUPPRESS_GCC_PRIVATE_DTOR_WARNING(name) \
|
|
friend class wxDummyFriendFor ## name;
|
|
#else /* !g++ */
|
|
# define wxSUPPRESS_GCC_PRIVATE_DTOR_WARNING(name)
|
|
#endif
|
|
|
|
/*
|
|
Clang Support
|
|
*/
|
|
|
|
#ifndef WX_HAS_CLANG_FEATURE
|
|
# ifndef __has_feature
|
|
# define WX_HAS_CLANG_FEATURE(x) 0
|
|
# else
|
|
# define WX_HAS_CLANG_FEATURE(x) __has_feature(x)
|
|
# endif
|
|
#endif
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* wxWidgets version and compatibility defines */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
#include "wx/version.h"
|
|
|
|
/* ============================================================================ */
|
|
/* non portable C++ features */
|
|
/* ============================================================================ */
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* compiler defects workarounds */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
/*
|
|
Digital Unix C++ compiler only defines this symbol for .cxx and .hxx files,
|
|
so define it ourselves (newer versions do it for all files, though, and
|
|
don't allow it to be redefined)
|
|
*/
|
|
#if defined(__DECCXX) && !defined(__VMS) && !defined(__cplusplus)
|
|
#define __cplusplus
|
|
#endif /* __DECCXX */
|
|
|
|
/* Resolves linking problems under HP-UX when compiling with gcc/g++ */
|
|
#if defined(__HPUX__) && defined(__GNUG__)
|
|
#define va_list __gnuc_va_list
|
|
#endif /* HP-UX */
|
|
|
|
/* Prevents conflicts between sys/types.h and winsock.h with Cygwin, */
|
|
/* when using Windows sockets. */
|
|
#if defined(__CYGWIN__) && defined(__WXMSW__)
|
|
#define __USE_W32_SOCKETS
|
|
#endif
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* check for native bool type and TRUE/FALSE constants */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
/* for backwards compatibility, also define TRUE and FALSE */
|
|
/* */
|
|
/* note that these definitions should work both in C++ and C code, so don't */
|
|
/* use true/false below */
|
|
#ifndef TRUE
|
|
#define TRUE 1
|
|
#endif
|
|
|
|
#ifndef FALSE
|
|
#define FALSE 0
|
|
#endif
|
|
|
|
typedef short int WXTYPE;
|
|
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* other feature tests */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
/* Every ride down a slippery slope begins with a single step.. */
|
|
/* */
|
|
/* Yes, using nested classes is indeed against our coding standards in */
|
|
/* general, but there are places where you can use them to advantage */
|
|
/* without totally breaking ports that cannot use them. If you do, then */
|
|
/* wrap it in this guard, but such cases should still be relatively rare. */
|
|
#define wxUSE_NESTED_CLASSES 1
|
|
|
|
/* check for explicit keyword support */
|
|
#ifndef HAVE_EXPLICIT
|
|
#if defined(__VISUALC__) && (__VISUALC__ >= 1100)
|
|
/* VC++ 6.0 and 5.0 have explicit (what about earlier versions?) */
|
|
#define HAVE_EXPLICIT
|
|
#elif ( defined(__MINGW32__) || defined(__CYGWIN32__) ) \
|
|
&& wxCHECK_GCC_VERSION(2, 95)
|
|
/* GCC 2.95 has explicit, what about earlier versions? */
|
|
#define HAVE_EXPLICIT
|
|
#elif defined(__BORLANDC__) && (__BORLANDC__ >= 0x0520)
|
|
/* BC++ 4.52 doesn't support explicit, CBuilder 1 does */
|
|
#define HAVE_EXPLICIT
|
|
#elif defined(__DIGITALMARS__)
|
|
#define HAVE_EXPLICIT
|
|
#elif defined(__WATCOMC__)
|
|
#define HAVE_EXPLICIT
|
|
#endif
|
|
#endif /* !HAVE_EXPLICIT */
|
|
|
|
#ifdef HAVE_EXPLICIT
|
|
#define wxEXPLICIT explicit
|
|
#else /* !HAVE_EXPLICIT */
|
|
#define wxEXPLICIT
|
|
#endif /* HAVE_EXPLICIT/!HAVE_EXPLICIT */
|
|
|
|
/* these macros are obsolete, use the standard C++ casts directly now */
|
|
#define wx_static_cast(t, x) static_cast<t>(x)
|
|
#define wx_const_cast(t, x) const_cast<t>(x)
|
|
#define wx_reinterpret_cast(t, x) reinterpret_cast<t>(x)
|
|
|
|
/*
|
|
This one is a wx invention: like static cast but used when we intentionally
|
|
truncate from a larger to smaller type, static_cast<> can't be used for it
|
|
as it results in warnings when using some compilers (SGI mipspro for example)
|
|
*/
|
|
#if defined(__INTELC__) && defined(__cplusplus)
|
|
template <typename T, typename X>
|
|
inline T wx_truncate_cast_impl(X x)
|
|
{
|
|
#pragma warning(push)
|
|
/* implicit conversion of a 64-bit integral type to a smaller integral type */
|
|
#pragma warning(disable: 1682)
|
|
/* conversion from "X" to "T" may lose significant bits */
|
|
#pragma warning(disable: 810)
|
|
/* non-pointer conversion from "foo" to "bar" may lose significant bits */
|
|
#pragma warning(disable: 2259)
|
|
|
|
return x;
|
|
|
|
#pragma warning(pop)
|
|
}
|
|
|
|
#define wx_truncate_cast(t, x) wx_truncate_cast_impl<t>(x)
|
|
|
|
#elif defined(__cplusplus) && defined(__VISUALC__) && __VISUALC__ >= 1310
|
|
template <typename T, typename X>
|
|
inline T wx_truncate_cast_impl(X x)
|
|
{
|
|
#pragma warning(push)
|
|
/* conversion from 'size_t' to 'type', possible loss of data */
|
|
#pragma warning(disable: 4267)
|
|
/* conversion from 'type1' to 'type2', possible loss of data */
|
|
#pragma warning(disable: 4242)
|
|
|
|
return x;
|
|
|
|
#pragma warning(pop)
|
|
}
|
|
|
|
#define wx_truncate_cast(t, x) wx_truncate_cast_impl<t>(x)
|
|
#else
|
|
#define wx_truncate_cast(t, x) ((t)(x))
|
|
#endif
|
|
|
|
/* for consistency with wxStatic/DynamicCast defined in wx/object.h */
|
|
#define wxConstCast(obj, className) wx_const_cast(className *, obj)
|
|
|
|
#ifndef HAVE_STD_WSTRING
|
|
#if defined(__VISUALC__) && (__VISUALC__ >= 1100)
|
|
/* VC++ 6.0 and 5.0 have std::wstring (what about earlier versions?) */
|
|
#define HAVE_STD_WSTRING
|
|
#elif defined(__MINGW32__) && wxCHECK_GCC_VERSION(3, 3)
|
|
/* GCC 3.1 has std::wstring; 3.0 never was in MinGW, 2.95 hasn't it */
|
|
#define HAVE_STD_WSTRING
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef HAVE_STD_STRING_COMPARE
|
|
#if defined(__VISUALC__) && (__VISUALC__ >= 1100)
|
|
/* VC++ 6.0 and 5.0 have std::string::compare */
|
|
/* (what about earlier versions?) */
|
|
#define HAVE_STD_STRING_COMPARE
|
|
#elif ( defined(__MINGW32__) || defined(__CYGWIN32__) ) \
|
|
&& wxCHECK_GCC_VERSION(3, 1)
|
|
/* GCC 3.1 has std::string::compare; */
|
|
/* 3.0 never was in MinGW, 2.95 hasn't it */
|
|
#define HAVE_STD_STRING_COMPARE
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef HAVE_TR1_TYPE_TRAITS
|
|
#if defined(__VISUALC__) && (_MSC_FULL_VER >= 150030729)
|
|
#define HAVE_TR1_TYPE_TRAITS
|
|
#endif
|
|
#endif
|
|
|
|
#if defined(__has_include)
|
|
#if !defined(HAVE_TYPE_TRAITS) && __has_include(<type_traits>)
|
|
#define HAVE_TYPE_TRAITS
|
|
#endif
|
|
|
|
#if !defined(HAVE_TR1_TYPE_TRAITS) && __has_include(<tr1/type_traits>)
|
|
#define HAVE_TR1_TYPE_TRAITS
|
|
#endif
|
|
|
|
#if !defined(HAVE_STD_UNORDERED_MAP) && __has_include(<unordered_map>)
|
|
#define HAVE_STD_UNORDERED_MAP
|
|
#endif
|
|
|
|
#if !defined(HAVE_TR1_UNORDERED_MAP) && __has_include(<tr1/unordered_map>)
|
|
#define HAVE_TR1_UNORDERED_MAP
|
|
#endif
|
|
|
|
#if !defined(HAVE_STD_UNORDERED_SET) && __has_include(<unordered_set>)
|
|
#define HAVE_STD_UNORDERED_SET
|
|
#endif
|
|
|
|
#if !defined(HAVE_TR1_UNORDERED_SET) && __has_include(<tr1/unordered_set>)
|
|
#define HAVE_TR1_UNORDERED_SET
|
|
#endif
|
|
#endif // defined(__has_include)
|
|
|
|
/* provide replacement for C99 va_copy() if the compiler doesn't have it */
|
|
|
|
/* could be already defined by configure or the user */
|
|
#ifndef wxVaCopy
|
|
/* if va_copy is a macro or configure detected that we have it, use it */
|
|
#if defined(va_copy) || defined(HAVE_VA_COPY)
|
|
#define wxVaCopy va_copy
|
|
#else /* no va_copy, try to provide a replacement */
|
|
/*
|
|
configure tries to determine whether va_list is an array or struct
|
|
type, but it may not be used under Windows, so deal with a few
|
|
special cases.
|
|
*/
|
|
|
|
#ifdef __WATCOMC__
|
|
/* Watcom uses array type for va_list except for PPC and Alpha */
|
|
#if !defined(__PPC__) && !defined(__AXP__)
|
|
#define VA_LIST_IS_ARRAY
|
|
#endif
|
|
#endif /* __WATCOMC__ */
|
|
|
|
#if defined(__PPC__) && (defined(_CALL_SYSV) || defined (_WIN32))
|
|
/*
|
|
PPC using SysV ABI and NT/PPC are special in that they use an
|
|
extra level of indirection.
|
|
*/
|
|
#define VA_LIST_IS_POINTER
|
|
#endif /* SysV or Win32 on __PPC__ */
|
|
|
|
/*
|
|
note that we use memmove(), not memcpy(), in case anybody tries
|
|
to do wxVaCopy(ap, ap)
|
|
*/
|
|
#if defined(VA_LIST_IS_POINTER)
|
|
#define wxVaCopy(d, s) memmove(*(d), *(s), sizeof(va_list))
|
|
#elif defined(VA_LIST_IS_ARRAY)
|
|
#define wxVaCopy(d, s) memmove((d), (s), sizeof(va_list))
|
|
#else /* we can only hope that va_lists are simple lvalues */
|
|
#define wxVaCopy(d, s) ((d) = (s))
|
|
#endif
|
|
#endif /* va_copy/!va_copy */
|
|
#endif /* wxVaCopy */
|
|
|
|
#ifndef HAVE_WOSTREAM
|
|
/*
|
|
Mingw <= 3.4 and all versions of Cygwin don't have std::wostream
|
|
*/
|
|
#if (defined(__MINGW32__) && !wxCHECK_GCC_VERSION(4, 0)) || \
|
|
defined(__CYGWIN__)
|
|
#define wxNO_WOSTREAM
|
|
#endif
|
|
|
|
/* VC++ doesn't have it in the old iostream library */
|
|
#if defined(__VISUALC__) && wxUSE_IOSTREAMH
|
|
#define wxNO_WOSTREAM
|
|
#endif
|
|
|
|
#ifndef wxNO_WOSTREAM
|
|
#define HAVE_WOSTREAM
|
|
#endif
|
|
|
|
#undef wxNO_WOSTREAM
|
|
#endif /* HAVE_WOSTREAM */
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* other C++ features */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
#ifndef HAVE_PARTIAL_SPECIALIZATION
|
|
/* be optimistic by default */
|
|
#define HAVE_PARTIAL_SPECIALIZATION
|
|
#endif
|
|
|
|
#ifdef __VISUALC__
|
|
#if __VISUALC__ < 1310
|
|
#undef HAVE_PARTIAL_SPECIALIZATION
|
|
#endif
|
|
#endif /* __VISUALC__ */
|
|
|
|
|
|
#ifndef HAVE_TEMPLATE_OVERLOAD_RESOLUTION
|
|
/* assume the compiler can use type or const expressions as template
|
|
arguments if it supports partial specialization -- except if it's a
|
|
Borland one which can't */
|
|
#if defined(HAVE_PARTIAL_SPECIALIZATION) && !defined(__BORLANDC__)
|
|
#define HAVE_TEMPLATE_OVERLOAD_RESOLUTION
|
|
#endif /* (HAVE_PARTIAL_SPECIALIZATION) && !defined(__BORLANDC__) */
|
|
#endif /* !defined(HAVE_TEMPLATE_OVERLOAD_RESOLUTION) */
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* portable calling conventions macros */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
/* stdcall is used for all functions called by Windows under Windows */
|
|
#if defined(__WINDOWS__)
|
|
#if defined(__GNUWIN32__)
|
|
#define wxSTDCALL __attribute__((stdcall))
|
|
#else
|
|
/* both VC++ and Borland understand this */
|
|
#define wxSTDCALL _stdcall
|
|
#endif
|
|
|
|
#else /* Win */
|
|
/* no such stupidness under Unix */
|
|
#define wxSTDCALL
|
|
#endif /* platform */
|
|
|
|
/* LINKAGEMODE mode is empty for everything except OS/2 */
|
|
#ifndef LINKAGEMODE
|
|
#define LINKAGEMODE
|
|
#endif /* LINKAGEMODE */
|
|
|
|
/* wxCALLBACK should be used for the functions which are called back by */
|
|
/* Windows (such as compare function for wxListCtrl) */
|
|
#if defined(__WIN32__) && !defined(__WXMICROWIN__)
|
|
#define wxCALLBACK wxSTDCALL
|
|
#else
|
|
/* no stdcall under Unix nor Win16 */
|
|
#define wxCALLBACK
|
|
#endif /* platform */
|
|
|
|
/* generic calling convention for the extern "C" functions */
|
|
|
|
#if defined(__VISUALC__)
|
|
#define wxC_CALLING_CONV _cdecl
|
|
#elif defined(__VISAGECPP__)
|
|
#define wxC_CALLING_CONV _Optlink
|
|
#else /* !Visual C++ */
|
|
#define wxC_CALLING_CONV
|
|
#endif /* compiler */
|
|
|
|
/* callling convention for the qsort(3) callback */
|
|
#define wxCMPFUNC_CONV wxC_CALLING_CONV
|
|
|
|
/* compatibility :-( */
|
|
#define CMPFUNC_CONV wxCMPFUNC_CONV
|
|
|
|
/* DLL import/export declarations */
|
|
#include "wx/dlimpexp.h"
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* Very common macros */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
/* Printf-like attribute definitions to obtain warnings with GNU C/C++ */
|
|
#ifndef WX_ATTRIBUTE_PRINTF
|
|
# if defined(__GNUC__) && !wxUSE_UNICODE
|
|
# define WX_ATTRIBUTE_PRINTF(m, n) __attribute__ ((__format__ (__printf__, m, n)))
|
|
# else
|
|
# define WX_ATTRIBUTE_PRINTF(m, n)
|
|
# endif
|
|
|
|
# define WX_ATTRIBUTE_PRINTF_1 WX_ATTRIBUTE_PRINTF(1, 2)
|
|
# define WX_ATTRIBUTE_PRINTF_2 WX_ATTRIBUTE_PRINTF(2, 3)
|
|
# define WX_ATTRIBUTE_PRINTF_3 WX_ATTRIBUTE_PRINTF(3, 4)
|
|
# define WX_ATTRIBUTE_PRINTF_4 WX_ATTRIBUTE_PRINTF(4, 5)
|
|
# define WX_ATTRIBUTE_PRINTF_5 WX_ATTRIBUTE_PRINTF(5, 6)
|
|
#endif /* !defined(WX_ATTRIBUTE_PRINTF) */
|
|
|
|
#ifndef WX_ATTRIBUTE_NORETURN
|
|
# if WX_HAS_CLANG_FEATURE(attribute_analyzer_noreturn)
|
|
# define WX_ATTRIBUTE_NORETURN __attribute__((analyzer_noreturn))
|
|
# elif defined( __GNUC__ )
|
|
# define WX_ATTRIBUTE_NORETURN __attribute__ ((noreturn))
|
|
# elif wxCHECK_VISUALC_VERSION(7)
|
|
# define WX_ATTRIBUTE_NORETURN __declspec(noreturn)
|
|
# else
|
|
# define WX_ATTRIBUTE_NORETURN
|
|
# endif
|
|
#endif
|
|
|
|
#if defined(__GNUC__)
|
|
#define WX_ATTRIBUTE_UNUSED __attribute__ ((unused))
|
|
#else
|
|
#define WX_ATTRIBUTE_UNUSED
|
|
#endif
|
|
|
|
/*
|
|
Macros for marking functions as being deprecated.
|
|
|
|
The preferred macro in the new code is wxDEPRECATED_MSG() which allows to
|
|
explain why is the function deprecated. Almost all the existing code uses
|
|
the older wxDEPRECATED() or its variants currently, but this will hopefully
|
|
change in the future.
|
|
*/
|
|
|
|
/* The basic compiler-specific construct to generate a deprecation warning. */
|
|
#ifdef __clang__
|
|
#define wxDEPRECATED_DECL __attribute__((deprecated))
|
|
#elif wxCHECK_GCC_VERSION(3, 1)
|
|
#define wxDEPRECATED_DECL __attribute__((deprecated))
|
|
#elif defined(__VISUALC__) && (__VISUALC__ >= 1300)
|
|
#define wxDEPRECATED_DECL __declspec(deprecated)
|
|
#else
|
|
#define wxDEPRECATED_DECL
|
|
#endif
|
|
|
|
/*
|
|
Macro taking the deprecation message. It applies to the next declaration.
|
|
|
|
If the compiler doesn't support showing the message, this degrades to a
|
|
simple wxDEPRECATED(), i.e. at least gives a warning, if possible.
|
|
*/
|
|
#if defined(__clang__) && defined(__has_extension)
|
|
#if __has_extension(attribute_deprecated_with_message)
|
|
#define wxDEPRECATED_MSG(msg) __attribute__((deprecated(msg)))
|
|
#else
|
|
#define wxDEPRECATED_MSG(msg) __attribute__((deprecated))
|
|
#endif
|
|
#elif wxCHECK_GCC_VERSION(4, 5)
|
|
#define wxDEPRECATED_MSG(msg) __attribute__((deprecated(msg)))
|
|
#elif wxCHECK_VISUALC_VERSION(8)
|
|
#define wxDEPRECATED_MSG(msg) __declspec(deprecated("deprecated: " msg))
|
|
#else
|
|
#define wxDEPRECATED_MSG(msg) wxDEPRECATED_DECL
|
|
#endif
|
|
|
|
/*
|
|
Macro taking the declaration that it deprecates. Prefer to use
|
|
wxDEPRECATED_MSG() instead as it's simpler (wrapping the entire declaration
|
|
makes the code unclear) and allows to specify the explanation.
|
|
*/
|
|
#define wxDEPRECATED(x) wxDEPRECATED_DECL x
|
|
|
|
#if defined(__GNUC__) && !wxCHECK_GCC_VERSION(3, 4)
|
|
/*
|
|
We need to add dummy "inline" to allow gcc < 3.4 to handle the
|
|
deprecation attribute on the constructors.
|
|
*/
|
|
#define wxDEPRECATED_CONSTRUCTOR(x) wxDEPRECATED( inline x)
|
|
#else
|
|
#define wxDEPRECATED_CONSTRUCTOR(x) wxDEPRECATED(x)
|
|
#endif
|
|
|
|
/*
|
|
Macro which marks the function as being deprecated but also defines it
|
|
inline.
|
|
|
|
Currently it's defined in the same trivial way in all cases but it could
|
|
need a special definition with some other compilers in the future which
|
|
explains why do we have it.
|
|
*/
|
|
#define wxDEPRECATED_INLINE(func, body) wxDEPRECATED(func) { body }
|
|
|
|
/*
|
|
A macro to define a simple deprecated accessor.
|
|
*/
|
|
#define wxDEPRECATED_ACCESSOR(func, what) wxDEPRECATED_INLINE(func, return what;)
|
|
|
|
/*
|
|
Special variant of the macro above which should be used for the functions
|
|
which are deprecated but called by wx itself: this often happens with
|
|
deprecated virtual functions which are called by the library.
|
|
*/
|
|
#ifdef WXBUILDING
|
|
# define wxDEPRECATED_BUT_USED_INTERNALLY(x) x
|
|
#else
|
|
# define wxDEPRECATED_BUT_USED_INTERNALLY(x) wxDEPRECATED(x)
|
|
#endif
|
|
|
|
/*
|
|
Macros to suppress and restore gcc warnings, requires g++ >= 4.6 and don't
|
|
do anything otherwise.
|
|
|
|
Example of use:
|
|
|
|
wxGCC_WARNING_SUPPRESS(float-equal)
|
|
inline bool wxIsSameDouble(double x, double y) { return x == y; }
|
|
wxGCC_WARNING_RESTORE(float-equal)
|
|
*/
|
|
#if wxCHECK_GCC_VERSION(4, 6)
|
|
# define wxGCC_WARNING_SUPPRESS(x) \
|
|
_Pragma (wxSTRINGIZE(GCC diagnostic push)) \
|
|
_Pragma (wxSTRINGIZE(GCC diagnostic ignored wxSTRINGIZE(wxCONCAT(-W,x))))
|
|
# define wxGCC_WARNING_RESTORE(x) \
|
|
_Pragma (wxSTRINGIZE(GCC diagnostic pop))
|
|
#else /* gcc < 4.6 or not gcc at all */
|
|
# define wxGCC_WARNING_SUPPRESS(x)
|
|
# define wxGCC_WARNING_RESTORE(x)
|
|
#endif
|
|
|
|
/*
|
|
Combination of the two variants above: should be used for deprecated
|
|
functions which are defined inline and are used by wxWidgets itself.
|
|
*/
|
|
#ifdef WXBUILDING
|
|
# define wxDEPRECATED_BUT_USED_INTERNALLY_INLINE(func, body) func { body }
|
|
#else
|
|
# define wxDEPRECATED_BUT_USED_INTERNALLY_INLINE(func, body) \
|
|
wxDEPRECATED(func) { body }
|
|
#endif
|
|
|
|
/* NULL declaration: it must be defined as 0 for C++ programs (in particular, */
|
|
/* it must not be defined as "(void *)0" which is standard for C but completely */
|
|
/* breaks C++ code) */
|
|
#if !defined(__HANDHELDPC__)
|
|
#include <stddef.h>
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
|
|
// everybody gets the assert and other debug macros
|
|
#include "wx/debug.h"
|
|
|
|
// delete pointer if it is not NULL and NULL it afterwards
|
|
template <typename T>
|
|
inline void wxDELETE(T*& ptr)
|
|
{
|
|
typedef char TypeIsCompleteCheck[sizeof(T)] WX_ATTRIBUTE_UNUSED;
|
|
|
|
if ( ptr != NULL )
|
|
{
|
|
delete ptr;
|
|
ptr = NULL;
|
|
}
|
|
}
|
|
|
|
// delete an array and NULL it (see comments above)
|
|
template <typename T>
|
|
inline void wxDELETEA(T*& ptr)
|
|
{
|
|
typedef char TypeIsCompleteCheck[sizeof(T)] WX_ATTRIBUTE_UNUSED;
|
|
|
|
if ( ptr != NULL )
|
|
{
|
|
delete [] ptr;
|
|
ptr = NULL;
|
|
}
|
|
}
|
|
|
|
// trivial implementation of std::swap() for primitive types
|
|
template <typename T>
|
|
inline void wxSwap(T& first, T& second)
|
|
{
|
|
T tmp(first);
|
|
first = second;
|
|
second = tmp;
|
|
}
|
|
#endif /*__cplusplus*/
|
|
|
|
/* size of statically declared array */
|
|
#define WXSIZEOF(array) (sizeof(array)/sizeof(array[0]))
|
|
|
|
/* symbolic constant used by all Find()-like functions returning positive */
|
|
/* integer on success as failure indicator */
|
|
#define wxNOT_FOUND (-1)
|
|
|
|
/* the default value for some length parameters meaning that the string is */
|
|
/* NUL-terminated */
|
|
#define wxNO_LEN ((size_t)-1)
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* macros dealing with comparison operators */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
/*
|
|
Expands into m(op, args...) for each op in the set { ==, !=, <, <=, >, >= }.
|
|
*/
|
|
#define wxFOR_ALL_COMPARISONS(m) \
|
|
m(==) m(!=) m(>=) m(<=) m(>) m(<)
|
|
|
|
#define wxFOR_ALL_COMPARISONS_1(m, x) \
|
|
m(==,x) m(!=,x) m(>=,x) m(<=,x) m(>,x) m(<,x)
|
|
|
|
#define wxFOR_ALL_COMPARISONS_2(m, x, y) \
|
|
m(==,x,y) m(!=,x,y) m(>=,x,y) m(<=,x,y) m(>,x,y) m(<,x,y)
|
|
|
|
#define wxFOR_ALL_COMPARISONS_3(m, x, y, z) \
|
|
m(==,x,y,z) m(!=,x,y,z) m(>=,x,y,z) m(<=,x,y,z) m(>,x,y,z) m(<,x,y,z)
|
|
|
|
/*
|
|
These are only used with wxDEFINE_COMPARISON_[BY_]REV: they pass both the
|
|
normal and the reversed comparison operators to the macro.
|
|
*/
|
|
#define wxFOR_ALL_COMPARISONS_2_REV(m, x, y) \
|
|
m(==,x,y,==) m(!=,x,y,!=) m(>=,x,y,<=) \
|
|
m(<=,x,y,>=) m(>,x,y,<) m(<,x,y,>)
|
|
|
|
#define wxFOR_ALL_COMPARISONS_3_REV(m, x, y, z) \
|
|
m(==,x,y,z,==) m(!=,x,y,z,!=) m(>=,x,y,z,<=) \
|
|
m(<=,x,y,z,>=) m(>,x,y,z,<) m(<,x,y,z,>)
|
|
|
|
|
|
#define wxDEFINE_COMPARISON(op, T1, T2, cmp) \
|
|
inline bool operator op(T1 x, T2 y) { return cmp(x, y, op); }
|
|
|
|
#define wxDEFINE_COMPARISON_REV(op, T1, T2, cmp, oprev) \
|
|
inline bool operator op(T2 y, T1 x) { return cmp(x, y, oprev); }
|
|
|
|
#define wxDEFINE_COMPARISON_BY_REV(op, T1, T2, oprev) \
|
|
inline bool operator op(T1 x, T2 y) { return y oprev x; }
|
|
|
|
/*
|
|
Define all 6 comparison operators (==, !=, <, <=, >, >=) for the given
|
|
types in the specified order. The implementation is provided by the cmp
|
|
macro. Normally wxDEFINE_ALL_COMPARISONS should be used as comparison
|
|
operators are usually symmetric.
|
|
*/
|
|
#define wxDEFINE_COMPARISONS(T1, T2, cmp) \
|
|
wxFOR_ALL_COMPARISONS_3(wxDEFINE_COMPARISON, T1, T2, cmp)
|
|
|
|
/*
|
|
Define all 6 comparison operators (==, !=, <, <=, >, >=) for the given
|
|
types in the specified order, implemented in terms of existing operators
|
|
for the reverse order.
|
|
*/
|
|
#define wxDEFINE_COMPARISONS_BY_REV(T1, T2) \
|
|
wxFOR_ALL_COMPARISONS_2_REV(wxDEFINE_COMPARISON_BY_REV, T1, T2)
|
|
|
|
/*
|
|
This macro allows to define all 12 comparison operators (6 operators for
|
|
both orders of arguments) for the given types using the provided "cmp"
|
|
macro to implement the actual comparison: the macro is called with the 2
|
|
arguments names, the first of type T1 and the second of type T2, and the
|
|
comparison operator being implemented.
|
|
*/
|
|
#define wxDEFINE_ALL_COMPARISONS(T1, T2, cmp) \
|
|
wxFOR_ALL_COMPARISONS_3(wxDEFINE_COMPARISON, T1, T2, cmp) \
|
|
wxFOR_ALL_COMPARISONS_3_REV(wxDEFINE_COMPARISON_REV, T1, T2, cmp)
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* macros to avoid compiler warnings */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
/* Macro to cut down on compiler warnings. */
|
|
#if 1 /* there should be no more any compilers needing the "#else" version */
|
|
#define WXUNUSED(identifier) /* identifier */
|
|
#else /* stupid, broken compiler */
|
|
#define WXUNUSED(identifier) identifier
|
|
#endif
|
|
|
|
/* some arguments are not used in unicode mode */
|
|
#if wxUSE_UNICODE
|
|
#define WXUNUSED_IN_UNICODE(param) WXUNUSED(param)
|
|
#else
|
|
#define WXUNUSED_IN_UNICODE(param) param
|
|
#endif
|
|
|
|
/* some arguments are not used in WinCE build */
|
|
#ifdef __WXWINCE__
|
|
#define WXUNUSED_IN_WINCE(param) WXUNUSED(param)
|
|
#else
|
|
#define WXUNUSED_IN_WINCE(param) param
|
|
#endif
|
|
|
|
/* unused parameters in non stream builds */
|
|
#if wxUSE_STREAMS
|
|
#define WXUNUSED_UNLESS_STREAMS(param) param
|
|
#else
|
|
#define WXUNUSED_UNLESS_STREAMS(param) WXUNUSED(param)
|
|
#endif
|
|
|
|
/* some compilers give warning about a possibly unused variable if it is */
|
|
/* initialized in both branches of if/else and shut up if it is initialized */
|
|
/* when declared, but other compilers then give warnings about unused variable */
|
|
/* value -- this should satisfy both of them */
|
|
#if defined(__VISUALC__)
|
|
#define wxDUMMY_INITIALIZE(val) = val
|
|
#else
|
|
#define wxDUMMY_INITIALIZE(val)
|
|
#endif
|
|
|
|
/* sometimes the value of a variable is *really* not used, to suppress the */
|
|
/* resulting warning you may pass it to this function */
|
|
#ifdef __cplusplus
|
|
# ifdef __BORLANDC__
|
|
# define wxUnusedVar(identifier) identifier
|
|
# else
|
|
template <class T>
|
|
inline void wxUnusedVar(const T& WXUNUSED(t)) { }
|
|
# endif
|
|
#endif
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* compiler specific settings */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
#if wxONLY_WATCOM_EARLIER_THAN(1,4)
|
|
typedef short mode_t;
|
|
#endif
|
|
|
|
/* where should i put this? we need to make sure of this as it breaks */
|
|
/* the <iostream> code. */
|
|
#if !wxUSE_IOSTREAMH && defined(__WXDEBUG__)
|
|
# ifdef wxUSE_DEBUG_NEW_ALWAYS
|
|
# undef wxUSE_DEBUG_NEW_ALWAYS
|
|
# define wxUSE_DEBUG_NEW_ALWAYS 0
|
|
# endif
|
|
#endif
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* standard wxWidgets types */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
/* the type for screen and DC coordinates */
|
|
typedef int wxCoord;
|
|
|
|
enum { wxDefaultCoord = -1 };
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* define fixed length types */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
#if defined(__MINGW32__)
|
|
#include <sys/types.h>
|
|
#endif
|
|
|
|
/* chars are always one byte (by definition), shorts are always two (in */
|
|
/* practice) */
|
|
|
|
/* 8bit */
|
|
typedef signed char wxInt8;
|
|
typedef unsigned char wxUint8;
|
|
typedef wxUint8 wxByte;
|
|
|
|
|
|
/* 16bit */
|
|
#ifdef SIZEOF_SHORT
|
|
#if SIZEOF_SHORT != 2
|
|
#error "wxWidgets assumes sizeof(short) == 2, please fix the code"
|
|
#endif
|
|
#else
|
|
#define SIZEOF_SHORT 2
|
|
#endif
|
|
|
|
typedef signed short wxInt16;
|
|
typedef unsigned short wxUint16;
|
|
|
|
typedef wxUint16 wxWord;
|
|
|
|
/*
|
|
things are getting more interesting with ints, longs and pointers
|
|
|
|
there are several different standard data models described by this table:
|
|
|
|
+-----------+----------------------------+
|
|
|type\model | LP64 ILP64 LLP64 ILP32 LP32|
|
|
+-----------+----------------------------+
|
|
|char | 8 8 8 8 8 |
|
|
|short | 16 16 16 16 16 |
|
|
|int | 32 64 32 32 16 |
|
|
|long | 64 64 32 32 32 |
|
|
|long long | 64 64 64 -- -- |
|
|
|void * | 64 64 64 32 32 |
|
|
+-----------+----------------------------+
|
|
|
|
Win16 used LP32 (but we don't support it any longer), Win32 obviously used
|
|
ILP32 and Win64 uses LLP64 (a.k.a. P64)
|
|
|
|
Under Unix LP64 is the most widely used (the only I've ever seen, in fact)
|
|
*/
|
|
|
|
/* 32bit */
|
|
#if defined(__WINDOWS__)
|
|
#if defined(__WIN32__)
|
|
typedef int wxInt32;
|
|
typedef unsigned int wxUint32;
|
|
|
|
/*
|
|
Win64 uses LLP64 model and so ints and longs have the same size as
|
|
in Win32.
|
|
*/
|
|
#ifndef SIZEOF_INT
|
|
#define SIZEOF_INT 4
|
|
#endif
|
|
|
|
#ifndef SIZEOF_LONG
|
|
#define SIZEOF_LONG 4
|
|
#endif
|
|
|
|
#ifndef SIZEOF_LONG_LONG
|
|
#define SIZEOF_LONG_LONG 8
|
|
#endif
|
|
|
|
#ifndef SIZEOF_WCHAR_T
|
|
/* Windows uses UTF-16 */
|
|
#define SIZEOF_WCHAR_T 2
|
|
#endif
|
|
|
|
#ifndef SIZEOF_SIZE_T
|
|
/*
|
|
Under Win64 sizeof(size_t) == 8 and so it is neither unsigned
|
|
int nor unsigned long!
|
|
*/
|
|
#ifdef __WIN64__
|
|
#define SIZEOF_SIZE_T 8
|
|
|
|
#undef wxSIZE_T_IS_UINT
|
|
#else /* Win32 */
|
|
#define SIZEOF_SIZE_T 4
|
|
|
|
#define wxSIZE_T_IS_UINT
|
|
#endif
|
|
#undef wxSIZE_T_IS_ULONG
|
|
#endif
|
|
|
|
#ifndef SIZEOF_VOID_P
|
|
#ifdef __WIN64__
|
|
#define SIZEOF_VOID_P 8
|
|
#else /* Win32 */
|
|
#define SIZEOF_VOID_P 4
|
|
#endif /* Win64/32 */
|
|
#endif
|
|
#else
|
|
#error "Unsupported Windows version"
|
|
#endif
|
|
#else /* !Windows */
|
|
/* SIZEOF_XXX are normally defined by configure */
|
|
#ifdef SIZEOF_INT
|
|
#if SIZEOF_INT == 8
|
|
/* must be ILP64 data model, there is normally a special 32 bit */
|
|
/* type in it but we don't know what it is... */
|
|
#error "No 32bit int type on this platform"
|
|
#elif SIZEOF_INT == 4
|
|
typedef int wxInt32;
|
|
typedef unsigned int wxUint32;
|
|
#elif SIZEOF_INT == 2
|
|
/* must be LP32 */
|
|
#if SIZEOF_LONG != 4
|
|
#error "No 32bit int type on this platform"
|
|
#endif
|
|
|
|
typedef long wxInt32;
|
|
typedef unsigned long wxUint32;
|
|
#else
|
|
/* wxWidgets is not ready for 128bit systems yet... */
|
|
#error "Unknown sizeof(int) value, what are you compiling for?"
|
|
#endif
|
|
#else /* !defined(SIZEOF_INT) */
|
|
/* assume default 32bit machine -- what else can we do? */
|
|
wxCOMPILE_TIME_ASSERT( sizeof(int) == 4, IntMustBeExactly4Bytes);
|
|
wxCOMPILE_TIME_ASSERT( sizeof(size_t) == 4, SizeTMustBeExactly4Bytes);
|
|
wxCOMPILE_TIME_ASSERT( sizeof(void *) == 4, PtrMustBeExactly4Bytes);
|
|
|
|
#define SIZEOF_INT 4
|
|
#define SIZEOF_SIZE_T 4
|
|
#define SIZEOF_VOID_P 4
|
|
|
|
typedef int wxInt32;
|
|
typedef unsigned int wxUint32;
|
|
|
|
#if defined(__MACH__) && !defined(SIZEOF_WCHAR_T)
|
|
#define SIZEOF_WCHAR_T 4
|
|
#endif
|
|
#if !defined(SIZEOF_WCHAR_T)
|
|
/* also assume that sizeof(wchar_t) == 2 (under Unix the most */
|
|
/* common case is 4 but there configure would have defined */
|
|
/* SIZEOF_WCHAR_T for us) */
|
|
/* the most common case */
|
|
wxCOMPILE_TIME_ASSERT( sizeof(wchar_t) == 2,
|
|
Wchar_tMustBeExactly2Bytes);
|
|
|
|
#define SIZEOF_WCHAR_T 2
|
|
#endif /* !defined(SIZEOF_WCHAR_T) */
|
|
#endif
|
|
#endif /* Win/!Win */
|
|
|
|
#ifndef SIZEOF_WCHAR_T
|
|
#error "SIZEOF_WCHAR_T must be defined, but isn't"
|
|
#endif
|
|
|
|
/* also define C99-like sized MIN/MAX constants */
|
|
#define wxINT8_MIN CHAR_MIN
|
|
#define wxINT8_MAX CHAR_MAX
|
|
#define wxUINT8_MAX UCHAR_MAX
|
|
|
|
#define wxINT16_MIN SHRT_MIN
|
|
#define wxINT16_MAX SHRT_MAX
|
|
#define wxUINT16_MAX USHRT_MAX
|
|
|
|
#if SIZEOF_INT == 4
|
|
#define wxINT32_MIN INT_MIN
|
|
#define wxINT32_MAX INT_MAX
|
|
#define wxUINT32_MAX UINT_MAX
|
|
#elif SIZEOF_LONG == 4
|
|
#define wxINT32_MIN LONG_MIN
|
|
#define wxINT32_MAX LONG_MAX
|
|
#define wxUINT32_MAX ULONG_MAX
|
|
#else
|
|
#error "Unknown 32 bit type"
|
|
#endif
|
|
|
|
typedef wxUint32 wxDword;
|
|
|
|
#ifdef LLONG_MAX
|
|
#define wxINT64_MIN LLONG_MIN
|
|
#define wxINT64_MAX LLONG_MAX
|
|
#define wxUINT64_MAX ULLONG_MAX
|
|
#else
|
|
#define wxINT64_MIN (wxLL(-9223372036854775807)-1)
|
|
#define wxINT64_MAX wxLL(9223372036854775807)
|
|
#define wxUINT64_MAX wxULL(0xFFFFFFFFFFFFFFFF)
|
|
#endif
|
|
|
|
/* 64 bit */
|
|
|
|
/* NB: we #define and not typedef wxLongLong_t because we use "#ifdef */
|
|
/* wxLongLong_t" in wx/longlong.h */
|
|
|
|
/* wxULongLong_t is set later (usually to unsigned wxLongLong_t) */
|
|
|
|
/* to avoid compilation problems on 64bit machines with ambiguous method calls */
|
|
/* we will need to define this */
|
|
#undef wxLongLongIsLong
|
|
|
|
/*
|
|
First check for specific compilers which have known 64 bit integer types,
|
|
this avoids clashes with SIZEOF_LONG[_LONG] being defined incorrectly for
|
|
e.g. MSVC builds (Python.h defines it as 8 even for MSVC).
|
|
|
|
Also notice that we check for "long long" before checking for 64 bit long as
|
|
we still want to use "long long" and not "long" for wxLongLong_t on 64 bit
|
|
architectures to be able to pass wxLongLong_t to the standard functions
|
|
prototyped as taking "long long" such as strtoll().
|
|
*/
|
|
#if (defined(__VISUALC__) || defined(__INTELC__)) && defined(__WIN32__)
|
|
#define wxLongLong_t __int64
|
|
#define wxLongLongSuffix i64
|
|
#define wxLongLongFmtSpec "I64"
|
|
#elif defined(__BORLANDC__) && defined(__WIN32__) && (__BORLANDC__ >= 0x520)
|
|
#define wxLongLong_t __int64
|
|
#define wxLongLongSuffix i64
|
|
#define wxLongLongFmtSpec "L"
|
|
#elif (defined(__WATCOMC__) && (defined(__WIN32__) || defined(__DOS__) || defined(__OS2__)))
|
|
#define wxLongLong_t __int64
|
|
#define wxLongLongSuffix i64
|
|
#define wxLongLongFmtSpec "L"
|
|
#elif defined(__DIGITALMARS__)
|
|
#define wxLongLong_t __int64
|
|
#define wxLongLongSuffix LL
|
|
#define wxLongLongFmtSpec "ll"
|
|
#elif defined(__MINGW32__)
|
|
#define wxLongLong_t long long
|
|
#define wxLongLongSuffix ll
|
|
#define wxLongLongFmtSpec "I64"
|
|
#elif defined(__VISAGECPP__) && __IBMCPP__ >= 400
|
|
#define wxLongLong_t long long
|
|
#elif (defined(SIZEOF_LONG_LONG) && SIZEOF_LONG_LONG >= 8) || \
|
|
defined(__GNUC__) || \
|
|
defined(__CYGWIN__) || \
|
|
defined(__WXMICROWIN__) || \
|
|
(defined(__DJGPP__) && __DJGPP__ >= 2)
|
|
#define wxLongLong_t long long
|
|
#define wxLongLongSuffix ll
|
|
#define wxLongLongFmtSpec "ll"
|
|
#elif defined(SIZEOF_LONG) && (SIZEOF_LONG == 8)
|
|
#define wxLongLong_t long
|
|
#define wxLongLongSuffix l
|
|
#define wxLongLongFmtSpec "l"
|
|
#define wxLongLongIsLong
|
|
#endif
|
|
|
|
|
|
#ifdef wxLongLong_t
|
|
#define wxULongLong_t unsigned wxLongLong_t
|
|
|
|
/*
|
|
wxLL() and wxULL() macros allow to define 64 bit constants in a
|
|
portable way.
|
|
*/
|
|
#ifndef wxCOMPILER_BROKEN_CONCAT_OPER
|
|
#define wxLL(x) wxCONCAT(x, wxLongLongSuffix)
|
|
#define wxULL(x) wxCONCAT(x, wxCONCAT(u, wxLongLongSuffix))
|
|
#else
|
|
/*
|
|
Currently only Borland compiler has broken concatenation operator
|
|
and this compiler is known to use [u]i64 suffix.
|
|
*/
|
|
#define wxLL(x) wxAPPEND_i64(x)
|
|
#define wxULL(x) wxAPPEND_ui64(x)
|
|
#endif
|
|
|
|
typedef wxLongLong_t wxInt64;
|
|
typedef wxULongLong_t wxUint64;
|
|
|
|
#define wxHAS_INT64 1
|
|
|
|
#ifndef wxLongLongIsLong
|
|
#define wxHAS_LONG_LONG_T_DIFFERENT_FROM_LONG
|
|
#endif
|
|
#elif wxUSE_LONGLONG
|
|
/* these macros allow to define 64 bit constants in a portable way */
|
|
#define wxLL(x) wxLongLong(x)
|
|
#define wxULL(x) wxULongLong(x)
|
|
|
|
#define wxInt64 wxLongLong
|
|
#define wxUint64 wxULongLong
|
|
|
|
#define wxHAS_INT64 1
|
|
|
|
#else /* !wxUSE_LONGLONG */
|
|
|
|
#define wxHAS_INT64 0
|
|
|
|
#endif
|
|
|
|
/*
|
|
Helper macro for conditionally compiling some code only if wxLongLong_t is
|
|
available and is a type different from the other integer types (i.e. not
|
|
long).
|
|
*/
|
|
#ifdef wxHAS_LONG_LONG_T_DIFFERENT_FROM_LONG
|
|
#define wxIF_LONG_LONG_TYPE(x) x
|
|
#else
|
|
#define wxIF_LONG_LONG_TYPE(x)
|
|
#endif
|
|
|
|
|
|
/* Make sure ssize_t is defined (a signed type the same size as size_t). */
|
|
/* (HAVE_SSIZE_T is not already defined by configure) */
|
|
#ifndef HAVE_SSIZE_T
|
|
#ifdef __MINGW32__
|
|
#if defined(_SSIZE_T_) || defined(_SSIZE_T_DEFINED)
|
|
#define HAVE_SSIZE_T
|
|
#endif
|
|
#elif wxCHECK_WATCOM_VERSION(1,4)
|
|
#define HAVE_SSIZE_T
|
|
#endif
|
|
#endif /* !HAVE_SSIZE_T */
|
|
|
|
/* If we really don't have ssize_t, provide our own version. */
|
|
#ifdef HAVE_SSIZE_T
|
|
#ifdef __UNIX__
|
|
#include <sys/types.h>
|
|
#endif
|
|
#else /* !HAVE_SSIZE_T */
|
|
#if SIZEOF_SIZE_T == 4
|
|
typedef wxInt32 ssize_t;
|
|
#elif SIZEOF_SIZE_T == 8
|
|
typedef wxInt64 ssize_t;
|
|
#else
|
|
#error "error defining ssize_t, size_t is not 4 or 8 bytes"
|
|
#endif
|
|
|
|
/* prevent ssize_t redefinitions in other libraries */
|
|
#define HAVE_SSIZE_T
|
|
#endif
|
|
|
|
/*
|
|
We can't rely on Windows _W64 being defined as windows.h may not be
|
|
included so define our own equivalent: this should be used with types
|
|
like WXLPARAM or WXWPARAM which are 64 bit under Win64 to avoid warnings
|
|
each time we cast it to a pointer or a handle (which results in hundreds
|
|
of warnings as Win32 API often passes pointers in them)
|
|
*/
|
|
// (dolphin-emu) Just disable __w64 usage. It's not meant to be used anymore,
|
|
// even on 32bit builds.
|
|
#if 0
|
|
#define wxW64 __w64
|
|
#else
|
|
#define wxW64
|
|
#endif
|
|
|
|
/*
|
|
Define signed and unsigned integral types big enough to contain all of long,
|
|
size_t and void *.
|
|
*/
|
|
#if SIZEOF_LONG >= SIZEOF_VOID_P
|
|
/*
|
|
Normal case when long is the largest integral type.
|
|
*/
|
|
typedef long wxIntPtr;
|
|
typedef unsigned long wxUIntPtr;
|
|
#elif SIZEOF_SIZE_T >= SIZEOF_VOID_P
|
|
/*
|
|
Win64 case: size_t is the only integral type big enough for "void *".
|
|
|
|
Notice that we must use __w64 to avoid warnings about casting pointers
|
|
to wxIntPtr (which we do often as this is what it is defined for) in 32
|
|
bit build with MSVC.
|
|
*/
|
|
typedef wxW64 ssize_t wxIntPtr;
|
|
typedef size_t wxUIntPtr;
|
|
#else
|
|
/*
|
|
This should never happen for the current architectures but if you're
|
|
using one where it does, please contact wx-dev@lists.wxwidgets.org.
|
|
*/
|
|
#error "Pointers can't be stored inside integer types."
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
/* And also define a couple of simple functions to cast pointer to/from it. */
|
|
inline wxUIntPtr wxPtrToUInt(const void *p)
|
|
{
|
|
/*
|
|
VC++ 7.1 gives warnings about casts such as below even when they're
|
|
explicit with /Wp64 option, suppress them as we really know what we're
|
|
doing here. Same thing with icc with -Wall.
|
|
*/
|
|
#ifdef __VISUALC__
|
|
#if __VISUALC__ >= 1200
|
|
#pragma warning(push)
|
|
#endif
|
|
/* pointer truncation from '' to '' */
|
|
#pragma warning(disable: 4311)
|
|
#elif defined(__INTELC__)
|
|
#pragma warning(push)
|
|
/* conversion from pointer to same-sized integral type */
|
|
#pragma warning(disable: 1684)
|
|
#endif
|
|
|
|
return wx_reinterpret_cast(wxUIntPtr, p);
|
|
|
|
#if (defined(__VISUALC__) && __VISUALC__ >= 1200) || defined(__INTELC__)
|
|
#pragma warning(pop)
|
|
#endif
|
|
}
|
|
|
|
inline void *wxUIntToPtr(wxUIntPtr p)
|
|
{
|
|
#ifdef __VISUALC__
|
|
#if __VISUALC__ >= 1200
|
|
#pragma warning(push)
|
|
#endif
|
|
/* conversion to type of greater size */
|
|
#pragma warning(disable: 4312)
|
|
#elif defined(__INTELC__)
|
|
#pragma warning(push)
|
|
/* invalid type conversion: "wxUIntPtr={unsigned long}" to "void *" */
|
|
#pragma warning(disable: 171)
|
|
#endif
|
|
|
|
return wx_reinterpret_cast(void *, p);
|
|
|
|
#if (defined(__VISUALC__) && __VISUALC__ >= 1200) || defined(__INTELC__)
|
|
#pragma warning(pop)
|
|
#endif
|
|
}
|
|
#endif /*__cplusplus*/
|
|
|
|
|
|
|
|
/* base floating point types */
|
|
/* wxFloat32: 32 bit IEEE float ( 1 sign, 8 exponent bits, 23 fraction bits ) */
|
|
/* wxFloat64: 64 bit IEEE float ( 1 sign, 11 exponent bits, 52 fraction bits ) */
|
|
/* wxDouble: native fastest representation that has at least wxFloat64 */
|
|
/* precision, so use the IEEE types for storage, and this for */
|
|
/* calculations */
|
|
|
|
typedef float wxFloat32;
|
|
typedef double wxFloat64;
|
|
|
|
typedef double wxDouble;
|
|
|
|
/*
|
|
Some (non standard) compilers typedef wchar_t as an existing type instead
|
|
of treating it as a real fundamental type, set wxWCHAR_T_IS_REAL_TYPE to 0
|
|
for them and to 1 for all the others.
|
|
*/
|
|
#ifndef wxWCHAR_T_IS_REAL_TYPE
|
|
/*
|
|
VC++ typedefs wchar_t as unsigned short by default until VC8, that is
|
|
unless /Za or /Zc:wchar_t option is used in which case _WCHAR_T_DEFINED
|
|
is defined.
|
|
*/
|
|
# if defined(__VISUALC__) && !defined(_NATIVE_WCHAR_T_DEFINED)
|
|
# define wxWCHAR_T_IS_REAL_TYPE 0
|
|
# else /* compiler having standard-conforming wchar_t */
|
|
# define wxWCHAR_T_IS_REAL_TYPE 1
|
|
# endif
|
|
#endif /* !defined(wxWCHAR_T_IS_REAL_TYPE) */
|
|
|
|
/* Helper macro for doing something dependent on whether wchar_t is or isn't a
|
|
typedef inside another macro. */
|
|
#if wxWCHAR_T_IS_REAL_TYPE
|
|
#define wxIF_WCHAR_T_TYPE(x) x
|
|
#else /* !wxWCHAR_T_IS_REAL_TYPE */
|
|
#define wxIF_WCHAR_T_TYPE(x)
|
|
#endif /* wxWCHAR_T_IS_REAL_TYPE/!wxWCHAR_T_IS_REAL_TYPE */
|
|
|
|
/*
|
|
This constant should be used instead of NULL in vararg functions taking
|
|
wxChar* arguments: passing NULL (which is the same as 0, unless the compiler
|
|
defines it specially, e.g. like gcc does with its __null built-in) doesn't
|
|
work in this case as va_arg() wouldn't interpret the integer 0 correctly
|
|
when trying to convert it to a pointer on architectures where sizeof(int) is
|
|
strictly less than sizeof(void *).
|
|
|
|
Examples of places where this must be used include wxFileTypeInfo ctor.
|
|
*/
|
|
#define wxNullPtr ((void *)NULL)
|
|
|
|
|
|
/* Define wxChar16 and wxChar32 */
|
|
|
|
#if SIZEOF_WCHAR_T == 2
|
|
#define wxWCHAR_T_IS_WXCHAR16
|
|
typedef wchar_t wxChar16;
|
|
#else
|
|
typedef wxUint16 wxChar16;
|
|
#endif
|
|
|
|
#if SIZEOF_WCHAR_T == 4
|
|
#define wxWCHAR_T_IS_WXCHAR32
|
|
typedef wchar_t wxChar32;
|
|
#else
|
|
typedef wxUint32 wxChar32;
|
|
#endif
|
|
|
|
|
|
/*
|
|
Helper macro expanding into the given "m" macro invoked with each of the
|
|
integer types as parameter (notice that this does not include char/unsigned
|
|
char and bool but does include wchar_t).
|
|
*/
|
|
#define wxDO_FOR_INT_TYPES(m) \
|
|
m(short) \
|
|
m(unsigned short) \
|
|
m(int) \
|
|
m(unsigned int) \
|
|
m(long) \
|
|
m(unsigned long) \
|
|
wxIF_LONG_LONG_TYPE( m(wxLongLong_t) ) \
|
|
wxIF_LONG_LONG_TYPE( m(wxULongLong_t) ) \
|
|
wxIF_WCHAR_T_TYPE( m(wchar_t) )
|
|
|
|
/*
|
|
Same as wxDO_FOR_INT_TYPES() but does include char and unsigned char.
|
|
|
|
Notice that we use "char" and "unsigned char" here but not "signed char"
|
|
which would be more correct as "char" could be unsigned by default. But
|
|
wxWidgets code currently supposes that char is signed and we'd need to
|
|
clean up assumptions about it, notably in wx/unichar.h, to be able to use
|
|
"signed char" here.
|
|
*/
|
|
#define wxDO_FOR_CHAR_INT_TYPES(m) \
|
|
m(char) \
|
|
m(unsigned char) \
|
|
wxDO_FOR_INT_TYPES(m)
|
|
|
|
/*
|
|
Same as wxDO_FOR_INT_TYPES() above except that m macro takes the
|
|
type as the first argument and some extra argument, passed from this macro
|
|
itself, as the second one.
|
|
*/
|
|
#define wxDO_FOR_INT_TYPES_1(m, arg) \
|
|
m(short, arg) \
|
|
m(unsigned short, arg) \
|
|
m(int, arg) \
|
|
m(unsigned int, arg) \
|
|
m(long, arg) \
|
|
m(unsigned long, arg) \
|
|
wxIF_LONG_LONG_TYPE( m(wxLongLong_t, arg) ) \
|
|
wxIF_LONG_LONG_TYPE( m(wxULongLong_t, arg) ) \
|
|
wxIF_WCHAR_T_TYPE( m(wchar_t, arg) )
|
|
|
|
/*
|
|
Combination of wxDO_FOR_CHAR_INT_TYPES() and wxDO_FOR_INT_TYPES_1():
|
|
invokes the given macro with the specified argument as its second parameter
|
|
for all char and int types.
|
|
*/
|
|
#define wxDO_FOR_CHAR_INT_TYPES_1(m, arg) \
|
|
m(char, arg) \
|
|
m(unsigned char, arg) \
|
|
wxDO_FOR_INT_TYPES_1(m, arg)
|
|
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* byte ordering related definition and macros */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
/* byte sex */
|
|
|
|
#define wxBIG_ENDIAN 4321
|
|
#define wxLITTLE_ENDIAN 1234
|
|
#define wxPDP_ENDIAN 3412
|
|
|
|
#ifdef WORDS_BIGENDIAN
|
|
#define wxBYTE_ORDER wxBIG_ENDIAN
|
|
#else
|
|
#define wxBYTE_ORDER wxLITTLE_ENDIAN
|
|
#endif
|
|
|
|
/* byte swapping */
|
|
|
|
#define wxUINT16_SWAP_ALWAYS(val) \
|
|
((wxUint16) ( \
|
|
(((wxUint16) (val) & (wxUint16) 0x00ffU) << 8) | \
|
|
(((wxUint16) (val) & (wxUint16) 0xff00U) >> 8)))
|
|
|
|
#define wxINT16_SWAP_ALWAYS(val) \
|
|
((wxInt16) ( \
|
|
(((wxUint16) (val) & (wxUint16) 0x00ffU) << 8) | \
|
|
(((wxUint16) (val) & (wxUint16) 0xff00U) >> 8)))
|
|
|
|
#define wxUINT32_SWAP_ALWAYS(val) \
|
|
((wxUint32) ( \
|
|
(((wxUint32) (val) & (wxUint32) 0x000000ffU) << 24) | \
|
|
(((wxUint32) (val) & (wxUint32) 0x0000ff00U) << 8) | \
|
|
(((wxUint32) (val) & (wxUint32) 0x00ff0000U) >> 8) | \
|
|
(((wxUint32) (val) & (wxUint32) 0xff000000U) >> 24)))
|
|
|
|
#define wxINT32_SWAP_ALWAYS(val) \
|
|
((wxInt32) ( \
|
|
(((wxUint32) (val) & (wxUint32) 0x000000ffU) << 24) | \
|
|
(((wxUint32) (val) & (wxUint32) 0x0000ff00U) << 8) | \
|
|
(((wxUint32) (val) & (wxUint32) 0x00ff0000U) >> 8) | \
|
|
(((wxUint32) (val) & (wxUint32) 0xff000000U) >> 24)))
|
|
/* machine specific byte swapping */
|
|
|
|
#ifdef wxLongLong_t
|
|
#define wxUINT64_SWAP_ALWAYS(val) \
|
|
((wxUint64) ( \
|
|
(((wxUint64) (val) & (wxUint64) wxULL(0x00000000000000ff)) << 56) | \
|
|
(((wxUint64) (val) & (wxUint64) wxULL(0x000000000000ff00)) << 40) | \
|
|
(((wxUint64) (val) & (wxUint64) wxULL(0x0000000000ff0000)) << 24) | \
|
|
(((wxUint64) (val) & (wxUint64) wxULL(0x00000000ff000000)) << 8) | \
|
|
(((wxUint64) (val) & (wxUint64) wxULL(0x000000ff00000000)) >> 8) | \
|
|
(((wxUint64) (val) & (wxUint64) wxULL(0x0000ff0000000000)) >> 24) | \
|
|
(((wxUint64) (val) & (wxUint64) wxULL(0x00ff000000000000)) >> 40) | \
|
|
(((wxUint64) (val) & (wxUint64) wxULL(0xff00000000000000)) >> 56)))
|
|
|
|
#define wxINT64_SWAP_ALWAYS(val) \
|
|
((wxInt64) ( \
|
|
(((wxUint64) (val) & (wxUint64) wxULL(0x00000000000000ff)) << 56) | \
|
|
(((wxUint64) (val) & (wxUint64) wxULL(0x000000000000ff00)) << 40) | \
|
|
(((wxUint64) (val) & (wxUint64) wxULL(0x0000000000ff0000)) << 24) | \
|
|
(((wxUint64) (val) & (wxUint64) wxULL(0x00000000ff000000)) << 8) | \
|
|
(((wxUint64) (val) & (wxUint64) wxULL(0x000000ff00000000)) >> 8) | \
|
|
(((wxUint64) (val) & (wxUint64) wxULL(0x0000ff0000000000)) >> 24) | \
|
|
(((wxUint64) (val) & (wxUint64) wxULL(0x00ff000000000000)) >> 40) | \
|
|
(((wxUint64) (val) & (wxUint64) wxULL(0xff00000000000000)) >> 56)))
|
|
#elif wxUSE_LONGLONG /* !wxLongLong_t */
|
|
#define wxUINT64_SWAP_ALWAYS(val) \
|
|
((wxUint64) ( \
|
|
((wxULongLong(val) & wxULongLong(0L, 0x000000ffU)) << 56) | \
|
|
((wxULongLong(val) & wxULongLong(0L, 0x0000ff00U)) << 40) | \
|
|
((wxULongLong(val) & wxULongLong(0L, 0x00ff0000U)) << 24) | \
|
|
((wxULongLong(val) & wxULongLong(0L, 0xff000000U)) << 8) | \
|
|
((wxULongLong(val) & wxULongLong(0x000000ffL, 0U)) >> 8) | \
|
|
((wxULongLong(val) & wxULongLong(0x0000ff00L, 0U)) >> 24) | \
|
|
((wxULongLong(val) & wxULongLong(0x00ff0000L, 0U)) >> 40) | \
|
|
((wxULongLong(val) & wxULongLong(0xff000000L, 0U)) >> 56)))
|
|
|
|
#define wxINT64_SWAP_ALWAYS(val) \
|
|
((wxInt64) ( \
|
|
((wxLongLong(val) & wxLongLong(0L, 0x000000ffU)) << 56) | \
|
|
((wxLongLong(val) & wxLongLong(0L, 0x0000ff00U)) << 40) | \
|
|
((wxLongLong(val) & wxLongLong(0L, 0x00ff0000U)) << 24) | \
|
|
((wxLongLong(val) & wxLongLong(0L, 0xff000000U)) << 8) | \
|
|
((wxLongLong(val) & wxLongLong(0x000000ffL, 0U)) >> 8) | \
|
|
((wxLongLong(val) & wxLongLong(0x0000ff00L, 0U)) >> 24) | \
|
|
((wxLongLong(val) & wxLongLong(0x00ff0000L, 0U)) >> 40) | \
|
|
((wxLongLong(val) & wxLongLong(0xff000000L, 0U)) >> 56)))
|
|
#endif /* wxLongLong_t/!wxLongLong_t */
|
|
|
|
#ifdef WORDS_BIGENDIAN
|
|
#define wxUINT16_SWAP_ON_BE(val) wxUINT16_SWAP_ALWAYS(val)
|
|
#define wxINT16_SWAP_ON_BE(val) wxINT16_SWAP_ALWAYS(val)
|
|
#define wxUINT16_SWAP_ON_LE(val) (val)
|
|
#define wxINT16_SWAP_ON_LE(val) (val)
|
|
#define wxUINT32_SWAP_ON_BE(val) wxUINT32_SWAP_ALWAYS(val)
|
|
#define wxINT32_SWAP_ON_BE(val) wxINT32_SWAP_ALWAYS(val)
|
|
#define wxUINT32_SWAP_ON_LE(val) (val)
|
|
#define wxINT32_SWAP_ON_LE(val) (val)
|
|
#if wxHAS_INT64
|
|
#define wxUINT64_SWAP_ON_BE(val) wxUINT64_SWAP_ALWAYS(val)
|
|
#define wxUINT64_SWAP_ON_LE(val) (val)
|
|
#define wxINT64_SWAP_ON_BE(val) wxINT64_SWAP_ALWAYS(val)
|
|
#define wxINT64_SWAP_ON_LE(val) (val)
|
|
#endif
|
|
#else
|
|
#define wxUINT16_SWAP_ON_LE(val) wxUINT16_SWAP_ALWAYS(val)
|
|
#define wxINT16_SWAP_ON_LE(val) wxINT16_SWAP_ALWAYS(val)
|
|
#define wxUINT16_SWAP_ON_BE(val) (val)
|
|
#define wxINT16_SWAP_ON_BE(val) (val)
|
|
#define wxUINT32_SWAP_ON_LE(val) wxUINT32_SWAP_ALWAYS(val)
|
|
#define wxINT32_SWAP_ON_LE(val) wxINT32_SWAP_ALWAYS(val)
|
|
#define wxUINT32_SWAP_ON_BE(val) (val)
|
|
#define wxINT32_SWAP_ON_BE(val) (val)
|
|
#if wxHAS_INT64
|
|
#define wxUINT64_SWAP_ON_LE(val) wxUINT64_SWAP_ALWAYS(val)
|
|
#define wxUINT64_SWAP_ON_BE(val) (val)
|
|
#define wxINT64_SWAP_ON_LE(val) wxINT64_SWAP_ALWAYS(val)
|
|
#define wxINT64_SWAP_ON_BE(val) (val)
|
|
#endif
|
|
#endif
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* template workarounds for buggy compilers */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
#if defined(__GNUC__) && !wxCHECK_GCC_VERSION( 3, 4 )
|
|
/* GCC <= 3.4 has buggy template support */
|
|
# define wxUSE_MEMBER_TEMPLATES 0
|
|
#endif
|
|
|
|
#if defined(_MSC_VER) && _MSC_VER <= 1200
|
|
/* MSVC <= 6.0 has buggy template support */
|
|
# define wxUSE_MEMBER_TEMPLATES 0
|
|
# define wxUSE_FUNC_TEMPLATE_POINTER 0
|
|
#endif
|
|
|
|
#ifndef wxUSE_MEMBER_TEMPLATES
|
|
# define wxUSE_MEMBER_TEMPLATES 1
|
|
#endif
|
|
|
|
#ifndef wxUSE_FUNC_TEMPLATE_POINTER
|
|
# define wxUSE_FUNC_TEMPLATE_POINTER 1
|
|
#endif
|
|
|
|
#if wxUSE_MEMBER_TEMPLATES
|
|
# define wxTEMPLATED_MEMBER_CALL( method, type ) method<type>()
|
|
# define wxTEMPLATED_MEMBER_FIX( type )
|
|
#else
|
|
# define wxTEMPLATED_MEMBER_CALL( method, type ) method((type*)NULL)
|
|
# define wxTEMPLATED_MEMBER_FIX( type ) type* =NULL
|
|
#endif
|
|
|
|
#if defined(_MSC_VER) && _MSC_VER <= 1200
|
|
# define wxTEMPLATED_FUNCTION_FIX( type ), wxTEMPLATED_MEMBER_FIX(type)
|
|
# define wxINFUNC_CLASS_TYPE_FIX( type ) typedef type type;
|
|
#else
|
|
# define wxTEMPLATED_FUNCTION_FIX( type )
|
|
# define wxINFUNC_CLASS_TYPE_FIX( type )
|
|
#endif
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* Geometric flags */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
enum wxGeometryCentre
|
|
{
|
|
wxCENTRE = 0x0001,
|
|
wxCENTER = wxCENTRE
|
|
};
|
|
|
|
/* centering into frame rather than screen (obsolete) */
|
|
#define wxCENTER_FRAME 0x0000
|
|
/* centre on screen rather than parent */
|
|
#define wxCENTRE_ON_SCREEN 0x0002
|
|
#define wxCENTER_ON_SCREEN wxCENTRE_ON_SCREEN
|
|
|
|
enum wxOrientation
|
|
{
|
|
/* don't change the values of these elements, they are used elsewhere */
|
|
wxHORIZONTAL = 0x0004,
|
|
wxVERTICAL = 0x0008,
|
|
|
|
wxBOTH = wxVERTICAL | wxHORIZONTAL,
|
|
|
|
/* a mask to extract orientation from the combination of flags */
|
|
wxORIENTATION_MASK = wxBOTH
|
|
};
|
|
|
|
enum wxDirection
|
|
{
|
|
wxLEFT = 0x0010,
|
|
wxRIGHT = 0x0020,
|
|
wxUP = 0x0040,
|
|
wxDOWN = 0x0080,
|
|
|
|
wxTOP = wxUP,
|
|
wxBOTTOM = wxDOWN,
|
|
|
|
wxNORTH = wxUP,
|
|
wxSOUTH = wxDOWN,
|
|
wxWEST = wxLEFT,
|
|
wxEAST = wxRIGHT,
|
|
|
|
wxALL = (wxUP | wxDOWN | wxRIGHT | wxLEFT),
|
|
|
|
/* a mask to extract direction from the combination of flags */
|
|
wxDIRECTION_MASK = wxALL
|
|
};
|
|
|
|
enum wxAlignment
|
|
{
|
|
/*
|
|
0 is a valid wxAlignment value (both wxALIGN_LEFT and wxALIGN_TOP
|
|
use it) so define a symbolic name for an invalid alignment value
|
|
which can be assumed to be different from anything else
|
|
*/
|
|
wxALIGN_INVALID = -1,
|
|
|
|
wxALIGN_NOT = 0x0000,
|
|
wxALIGN_CENTER_HORIZONTAL = 0x0100,
|
|
wxALIGN_CENTRE_HORIZONTAL = wxALIGN_CENTER_HORIZONTAL,
|
|
wxALIGN_LEFT = wxALIGN_NOT,
|
|
wxALIGN_TOP = wxALIGN_NOT,
|
|
wxALIGN_RIGHT = 0x0200,
|
|
wxALIGN_BOTTOM = 0x0400,
|
|
wxALIGN_CENTER_VERTICAL = 0x0800,
|
|
wxALIGN_CENTRE_VERTICAL = wxALIGN_CENTER_VERTICAL,
|
|
|
|
wxALIGN_CENTER = (wxALIGN_CENTER_HORIZONTAL | wxALIGN_CENTER_VERTICAL),
|
|
wxALIGN_CENTRE = wxALIGN_CENTER,
|
|
|
|
/* a mask to extract alignment from the combination of flags */
|
|
wxALIGN_MASK = 0x0f00
|
|
};
|
|
|
|
/* misc. flags for wxSizer items */
|
|
enum wxSizerFlagBits
|
|
{
|
|
/*
|
|
wxADJUST_MINSIZE doesn't do anything any more but we still define
|
|
it for compatibility. Notice that it may be also predefined (as 0,
|
|
hopefully) in the user code in order to use it even in
|
|
!WXWIN_COMPATIBILITY_2_8 builds so don't redefine it in such case.
|
|
*/
|
|
#if WXWIN_COMPATIBILITY_2_8 && !defined(wxADJUST_MINSIZE)
|
|
wxADJUST_MINSIZE = 0,
|
|
#endif
|
|
wxFIXED_MINSIZE = 0x8000,
|
|
wxRESERVE_SPACE_EVEN_IF_HIDDEN = 0x0002,
|
|
|
|
/* a mask to extract wxSizerFlagBits from combination of flags */
|
|
wxSIZER_FLAG_BITS_MASK = 0x8002
|
|
};
|
|
|
|
enum wxStretch
|
|
{
|
|
wxSTRETCH_NOT = 0x0000,
|
|
wxSHRINK = 0x1000,
|
|
wxGROW = 0x2000,
|
|
wxEXPAND = wxGROW,
|
|
wxSHAPED = 0x4000,
|
|
wxTILE = wxSHAPED | wxFIXED_MINSIZE,
|
|
|
|
/* a mask to extract stretch from the combination of flags */
|
|
wxSTRETCH_MASK = 0x7000 /* sans wxTILE */
|
|
};
|
|
|
|
/* border flags: the values are chosen for backwards compatibility */
|
|
enum wxBorder
|
|
{
|
|
/* this is different from wxBORDER_NONE as by default the controls do have */
|
|
/* border */
|
|
wxBORDER_DEFAULT = 0,
|
|
|
|
wxBORDER_NONE = 0x00200000,
|
|
wxBORDER_STATIC = 0x01000000,
|
|
wxBORDER_SIMPLE = 0x02000000,
|
|
wxBORDER_RAISED = 0x04000000,
|
|
wxBORDER_SUNKEN = 0x08000000,
|
|
wxBORDER_DOUBLE = 0x10000000, /* deprecated */
|
|
wxBORDER_THEME = wxBORDER_DOUBLE,
|
|
|
|
/* a mask to extract border style from the combination of flags */
|
|
wxBORDER_MASK = 0x1f200000
|
|
};
|
|
|
|
/* This makes it easier to specify a 'normal' border for a control */
|
|
#if defined(__SMARTPHONE__) || defined(__POCKETPC__)
|
|
#define wxDEFAULT_CONTROL_BORDER wxBORDER_SIMPLE
|
|
#else
|
|
#define wxDEFAULT_CONTROL_BORDER wxBORDER_SUNKEN
|
|
#endif
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* Window style flags */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
/*
|
|
* Values are chosen so they can be |'ed in a bit list.
|
|
* Some styles are used across more than one group,
|
|
* so the values mustn't clash with others in the group.
|
|
* Otherwise, numbers can be reused across groups.
|
|
*/
|
|
|
|
/*
|
|
Summary of the bits used by various styles.
|
|
|
|
High word, containing styles which can be used with many windows:
|
|
|
|
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
|
|
|31|30|29|28|27|26|25|24|23|22|21|20|19|18|17|16|
|
|
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
|
|
| | | | | | | | | | | | | | | |
|
|
| | | | | | | | | | | | | | | \_ wxFULL_REPAINT_ON_RESIZE
|
|
| | | | | | | | | | | | | | \____ wxPOPUP_WINDOW
|
|
| | | | | | | | | | | | | \_______ wxWANTS_CHARS
|
|
| | | | | | | | | | | | \__________ wxTAB_TRAVERSAL
|
|
| | | | | | | | | | | \_____________ wxTRANSPARENT_WINDOW
|
|
| | | | | | | | | | \________________ wxBORDER_NONE
|
|
| | | | | | | | | \___________________ wxCLIP_CHILDREN
|
|
| | | | | | | | \______________________ wxALWAYS_SHOW_SB
|
|
| | | | | | | \_________________________ wxBORDER_STATIC
|
|
| | | | | | \____________________________ wxBORDER_SIMPLE
|
|
| | | | | \_______________________________ wxBORDER_RAISED
|
|
| | | | \__________________________________ wxBORDER_SUNKEN
|
|
| | | \_____________________________________ wxBORDER_{DOUBLE,THEME}
|
|
| | \________________________________________ wxCAPTION/wxCLIP_SIBLINGS
|
|
| \___________________________________________ wxHSCROLL
|
|
\______________________________________________ wxVSCROLL
|
|
|
|
|
|
Low word style bits is class-specific meaning that the same bit can have
|
|
different meanings for different controls (e.g. 0x10 is wxCB_READONLY
|
|
meaning that the control can't be modified for wxComboBox but wxLB_SORT
|
|
meaning that the control should be kept sorted for wxListBox, while
|
|
wxLB_SORT has a different value -- and this is just fine).
|
|
*/
|
|
|
|
/*
|
|
* Window (Frame/dialog/subwindow/panel item) style flags
|
|
*/
|
|
#define wxVSCROLL 0x80000000
|
|
#define wxHSCROLL 0x40000000
|
|
#define wxCAPTION 0x20000000
|
|
|
|
/* New styles (border styles are now in their own enum) */
|
|
#define wxDOUBLE_BORDER wxBORDER_DOUBLE
|
|
#define wxSUNKEN_BORDER wxBORDER_SUNKEN
|
|
#define wxRAISED_BORDER wxBORDER_RAISED
|
|
#define wxBORDER wxBORDER_SIMPLE
|
|
#define wxSIMPLE_BORDER wxBORDER_SIMPLE
|
|
#define wxSTATIC_BORDER wxBORDER_STATIC
|
|
#define wxNO_BORDER wxBORDER_NONE
|
|
|
|
/* wxALWAYS_SHOW_SB: instead of hiding the scrollbar when it is not needed, */
|
|
/* disable it - but still show (see also wxLB_ALWAYS_SB style) */
|
|
/* */
|
|
/* NB: as this style is only supported by wxUniversal and wxMSW so far */
|
|
#define wxALWAYS_SHOW_SB 0x00800000
|
|
|
|
/* Clip children when painting, which reduces flicker in e.g. frames and */
|
|
/* splitter windows, but can't be used in a panel where a static box must be */
|
|
/* 'transparent' (panel paints the background for it) */
|
|
#define wxCLIP_CHILDREN 0x00400000
|
|
|
|
/* Note we're reusing the wxCAPTION style because we won't need captions */
|
|
/* for subwindows/controls */
|
|
#define wxCLIP_SIBLINGS 0x20000000
|
|
|
|
#define wxTRANSPARENT_WINDOW 0x00100000
|
|
|
|
/* Add this style to a panel to get tab traversal working outside of dialogs */
|
|
/* (on by default for wxPanel, wxDialog, wxScrolledWindow) */
|
|
#define wxTAB_TRAVERSAL 0x00080000
|
|
|
|
/* Add this style if the control wants to get all keyboard messages (under */
|
|
/* Windows, it won't normally get the dialog navigation key events) */
|
|
#define wxWANTS_CHARS 0x00040000
|
|
|
|
/* Make window retained (Motif only, see src/generic/scrolwing.cpp)
|
|
* This is non-zero only under wxMotif, to avoid a clash with wxPOPUP_WINDOW
|
|
* on other platforms
|
|
*/
|
|
|
|
#ifdef __WXMOTIF__
|
|
#define wxRETAINED 0x00020000
|
|
#else
|
|
#define wxRETAINED 0x00000000
|
|
#endif
|
|
#define wxBACKINGSTORE wxRETAINED
|
|
|
|
/* set this flag to create a special popup window: it will be always shown on */
|
|
/* top of other windows, will capture the mouse and will be dismissed when the */
|
|
/* mouse is clicked outside of it or if it loses focus in any other way */
|
|
#define wxPOPUP_WINDOW 0x00020000
|
|
|
|
/* force a full repaint when the window is resized (instead of repainting just */
|
|
/* the invalidated area) */
|
|
#define wxFULL_REPAINT_ON_RESIZE 0x00010000
|
|
|
|
/* obsolete: now this is the default behaviour */
|
|
/* */
|
|
/* don't invalidate the whole window (resulting in a PAINT event) when the */
|
|
/* window is resized (currently, makes sense for wxMSW only) */
|
|
#define wxNO_FULL_REPAINT_ON_RESIZE 0
|
|
|
|
/* A mask which can be used to filter (out) all wxWindow-specific styles.
|
|
*/
|
|
#define wxWINDOW_STYLE_MASK \
|
|
(wxVSCROLL|wxHSCROLL|wxBORDER_MASK|wxALWAYS_SHOW_SB|wxCLIP_CHILDREN| \
|
|
wxCLIP_SIBLINGS|wxTRANSPARENT_WINDOW|wxTAB_TRAVERSAL|wxWANTS_CHARS| \
|
|
wxRETAINED|wxPOPUP_WINDOW|wxFULL_REPAINT_ON_RESIZE)
|
|
|
|
/*
|
|
* Extra window style flags (use wxWS_EX prefix to make it clear that they
|
|
* should be passed to wxWindow::SetExtraStyle(), not SetWindowStyle())
|
|
*/
|
|
|
|
/* by default, TransferDataTo/FromWindow() only work on direct children of the */
|
|
/* window (compatible behaviour), set this flag to make them recursively */
|
|
/* descend into all subwindows */
|
|
#define wxWS_EX_VALIDATE_RECURSIVELY 0x00000001
|
|
|
|
/* wxCommandEvents and the objects of the derived classes are forwarded to the */
|
|
/* parent window and so on recursively by default. Using this flag for the */
|
|
/* given window allows to block this propagation at this window, i.e. prevent */
|
|
/* the events from being propagated further upwards. The dialogs have this */
|
|
/* flag on by default. */
|
|
#define wxWS_EX_BLOCK_EVENTS 0x00000002
|
|
|
|
/* don't use this window as an implicit parent for the other windows: this must */
|
|
/* be used with transient windows as otherwise there is the risk of creating a */
|
|
/* dialog/frame with this window as a parent which would lead to a crash if the */
|
|
/* parent is destroyed before the child */
|
|
#define wxWS_EX_TRANSIENT 0x00000004
|
|
|
|
/* don't paint the window background, we'll assume it will */
|
|
/* be done by a theming engine. This is not yet used but could */
|
|
/* possibly be made to work in the future, at least on Windows */
|
|
#define wxWS_EX_THEMED_BACKGROUND 0x00000008
|
|
|
|
/* this window should always process idle events */
|
|
#define wxWS_EX_PROCESS_IDLE 0x00000010
|
|
|
|
/* this window should always process UI update events */
|
|
#define wxWS_EX_PROCESS_UI_UPDATES 0x00000020
|
|
|
|
/* Draw the window in a metal theme on Mac */
|
|
#define wxFRAME_EX_METAL 0x00000040
|
|
#define wxDIALOG_EX_METAL 0x00000040
|
|
|
|
/* Use this style to add a context-sensitive help to the window (currently for */
|
|
/* Win32 only and it doesn't work if wxMINIMIZE_BOX or wxMAXIMIZE_BOX are used) */
|
|
#define wxWS_EX_CONTEXTHELP 0x00000080
|
|
|
|
/* synonyms for wxWS_EX_CONTEXTHELP for compatibility */
|
|
#define wxFRAME_EX_CONTEXTHELP wxWS_EX_CONTEXTHELP
|
|
#define wxDIALOG_EX_CONTEXTHELP wxWS_EX_CONTEXTHELP
|
|
|
|
/* Create a window which is attachable to another top level window */
|
|
#define wxFRAME_DRAWER 0x0020
|
|
|
|
/*
|
|
* MDI parent frame style flags
|
|
* Can overlap with some of the above.
|
|
*/
|
|
|
|
#define wxFRAME_NO_WINDOW_MENU 0x0100
|
|
|
|
/*
|
|
* wxMenuBar style flags
|
|
*/
|
|
/* use native docking */
|
|
#define wxMB_DOCKABLE 0x0001
|
|
|
|
/*
|
|
* wxMenu style flags
|
|
*/
|
|
#define wxMENU_TEAROFF 0x0001
|
|
|
|
/*
|
|
* Apply to all panel items
|
|
*/
|
|
#define wxCOLOURED 0x0800
|
|
#define wxFIXED_LENGTH 0x0400
|
|
|
|
/*
|
|
* Styles for wxListBox
|
|
*/
|
|
#define wxLB_SORT 0x0010
|
|
#define wxLB_SINGLE 0x0020
|
|
#define wxLB_MULTIPLE 0x0040
|
|
#define wxLB_EXTENDED 0x0080
|
|
/* wxLB_OWNERDRAW is Windows-only */
|
|
#define wxLB_NEEDED_SB 0x0000
|
|
#define wxLB_OWNERDRAW 0x0100
|
|
#define wxLB_ALWAYS_SB 0x0200
|
|
#define wxLB_NO_SB 0x0400
|
|
#define wxLB_HSCROLL wxHSCROLL
|
|
/* always show an entire number of rows */
|
|
#define wxLB_INT_HEIGHT 0x0800
|
|
|
|
#if WXWIN_COMPATIBILITY_2_6
|
|
/* deprecated synonyms */
|
|
#define wxPROCESS_ENTER 0x0400 /* wxTE_PROCESS_ENTER */
|
|
#define wxPASSWORD 0x0800 /* wxTE_PASSWORD */
|
|
#endif
|
|
|
|
/*
|
|
* wxComboBox style flags
|
|
*/
|
|
#define wxCB_SIMPLE 0x0004
|
|
#define wxCB_SORT 0x0008
|
|
#define wxCB_READONLY 0x0010
|
|
#define wxCB_DROPDOWN 0x0020
|
|
|
|
/*
|
|
* wxRadioBox style flags
|
|
*/
|
|
/* should we number the items from left to right or from top to bottom in a 2d */
|
|
/* radiobox? */
|
|
#define wxRA_LEFTTORIGHT 0x0001
|
|
#define wxRA_TOPTOBOTTOM 0x0002
|
|
|
|
/* New, more intuitive names to specify majorDim argument */
|
|
#define wxRA_SPECIFY_COLS wxHORIZONTAL
|
|
#define wxRA_SPECIFY_ROWS wxVERTICAL
|
|
|
|
/* Old names for compatibility */
|
|
#define wxRA_HORIZONTAL wxHORIZONTAL
|
|
#define wxRA_VERTICAL wxVERTICAL
|
|
|
|
/*
|
|
* wxRadioButton style flag
|
|
*/
|
|
#define wxRB_GROUP 0x0004
|
|
#define wxRB_SINGLE 0x0008
|
|
|
|
/*
|
|
* wxScrollBar flags
|
|
*/
|
|
#define wxSB_HORIZONTAL wxHORIZONTAL
|
|
#define wxSB_VERTICAL wxVERTICAL
|
|
|
|
/*
|
|
* wxSpinButton flags.
|
|
* Note that a wxSpinCtrl is sometimes defined as a wxTextCtrl, and so the
|
|
* flags shouldn't overlap with wxTextCtrl flags that can be used for a single
|
|
* line controls (currently we reuse wxTE_CHARWRAP and wxTE_RICH2 neither of
|
|
* which makes sense for them).
|
|
*/
|
|
#define wxSP_HORIZONTAL wxHORIZONTAL /* 4 */
|
|
#define wxSP_VERTICAL wxVERTICAL /* 8 */
|
|
#define wxSP_ARROW_KEYS 0x4000
|
|
#define wxSP_WRAP 0x8000
|
|
|
|
/*
|
|
* wxTabCtrl flags
|
|
*/
|
|
#define wxTC_RIGHTJUSTIFY 0x0010
|
|
#define wxTC_FIXEDWIDTH 0x0020
|
|
#define wxTC_TOP 0x0000 /* default */
|
|
#define wxTC_LEFT 0x0020
|
|
#define wxTC_RIGHT 0x0040
|
|
#define wxTC_BOTTOM 0x0080
|
|
#define wxTC_MULTILINE 0x0200 /* == wxNB_MULTILINE */
|
|
#define wxTC_OWNERDRAW 0x0400
|
|
|
|
/*
|
|
* wxStaticBitmap flags
|
|
*/
|
|
#define wxBI_EXPAND wxEXPAND
|
|
|
|
/*
|
|
* wxStaticLine flags
|
|
*/
|
|
#define wxLI_HORIZONTAL wxHORIZONTAL
|
|
#define wxLI_VERTICAL wxVERTICAL
|
|
|
|
|
|
/*
|
|
* extended dialog specifiers. these values are stored in a different
|
|
* flag and thus do not overlap with other style flags. note that these
|
|
* values do not correspond to the return values of the dialogs (for
|
|
* those values, look at the wxID_XXX defines).
|
|
*/
|
|
|
|
/* wxCENTRE already defined as 0x00000001 */
|
|
#define wxYES 0x00000002
|
|
#define wxOK 0x00000004
|
|
#define wxNO 0x00000008
|
|
#define wxYES_NO (wxYES | wxNO)
|
|
#define wxCANCEL 0x00000010
|
|
#define wxAPPLY 0x00000020
|
|
#define wxCLOSE 0x00000040
|
|
|
|
#define wxOK_DEFAULT 0x00000000 /* has no effect (default) */
|
|
#define wxYES_DEFAULT 0x00000000 /* has no effect (default) */
|
|
#define wxNO_DEFAULT 0x00000080 /* only valid with wxYES_NO */
|
|
#define wxCANCEL_DEFAULT 0x80000000 /* only valid with wxCANCEL */
|
|
|
|
#define wxICON_EXCLAMATION 0x00000100
|
|
#define wxICON_HAND 0x00000200
|
|
#define wxICON_WARNING wxICON_EXCLAMATION
|
|
#define wxICON_ERROR wxICON_HAND
|
|
#define wxICON_QUESTION 0x00000400
|
|
#define wxICON_INFORMATION 0x00000800
|
|
#define wxICON_STOP wxICON_HAND
|
|
#define wxICON_ASTERISK wxICON_INFORMATION
|
|
|
|
#define wxHELP 0x00001000
|
|
#define wxFORWARD 0x00002000
|
|
#define wxBACKWARD 0x00004000
|
|
#define wxRESET 0x00008000
|
|
#define wxMORE 0x00010000
|
|
#define wxSETUP 0x00020000
|
|
#define wxICON_NONE 0x00040000
|
|
#define wxICON_AUTH_NEEDED 0x00080000
|
|
|
|
#define wxICON_MASK \
|
|
(wxICON_EXCLAMATION|wxICON_HAND|wxICON_QUESTION|wxICON_INFORMATION|wxICON_NONE|wxICON_AUTH_NEEDED)
|
|
|
|
/*
|
|
* Background styles. See wxWindow::SetBackgroundStyle
|
|
*/
|
|
enum wxBackgroundStyle
|
|
{
|
|
/*
|
|
background is erased in the EVT_ERASE_BACKGROUND handler or using
|
|
the system default background if no such handler is defined (this
|
|
is the default style)
|
|
*/
|
|
wxBG_STYLE_ERASE,
|
|
|
|
/*
|
|
background is erased by the system, no EVT_ERASE_BACKGROUND event
|
|
is generated at all
|
|
*/
|
|
wxBG_STYLE_SYSTEM,
|
|
|
|
/*
|
|
background is erased in EVT_PAINT handler and not erased at all
|
|
before it, this should be used if the paint handler paints over
|
|
the entire window to avoid flicker
|
|
*/
|
|
wxBG_STYLE_PAINT,
|
|
|
|
|
|
/* this is a Mac-only style, don't use in portable code */
|
|
wxBG_STYLE_TRANSPARENT,
|
|
|
|
/* this style is deprecated and doesn't do anything, don't use */
|
|
wxBG_STYLE_COLOUR,
|
|
|
|
/*
|
|
this style is deprecated and is synonymous with
|
|
wxBG_STYLE_PAINT, use the new name
|
|
*/
|
|
wxBG_STYLE_CUSTOM = wxBG_STYLE_PAINT
|
|
};
|
|
|
|
/*
|
|
* Key types used by (old style) lists and hashes.
|
|
*/
|
|
enum wxKeyType
|
|
{
|
|
wxKEY_NONE,
|
|
wxKEY_INTEGER,
|
|
wxKEY_STRING
|
|
};
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* standard IDs */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
/* Standard menu IDs */
|
|
enum wxStandardID
|
|
{
|
|
/*
|
|
These ids delimit the range used by automatically-generated ids
|
|
(i.e. those used when wxID_ANY is specified during construction).
|
|
*/
|
|
#if defined(__WXMSW__) || wxUSE_AUTOID_MANAGEMENT
|
|
/*
|
|
On MSW the range is always restricted no matter if id management
|
|
is used or not because the native window ids are limited to short
|
|
range. On other platforms the range is only restricted if id
|
|
management is used so the reference count buffer won't be so big.
|
|
*/
|
|
wxID_AUTO_LOWEST = -32000,
|
|
wxID_AUTO_HIGHEST = -2000,
|
|
#else
|
|
wxID_AUTO_LOWEST = -1000000,
|
|
wxID_AUTO_HIGHEST = -2000,
|
|
#endif
|
|
|
|
/* no id matches this one when compared to it */
|
|
wxID_NONE = -3,
|
|
|
|
/* id for a separator line in the menu (invalid for normal item) */
|
|
wxID_SEPARATOR = -2,
|
|
|
|
/* any id: means that we don't care about the id, whether when installing
|
|
* an event handler or when creating a new window */
|
|
wxID_ANY = -1,
|
|
|
|
|
|
/* all predefined ids are between wxID_LOWEST and wxID_HIGHEST */
|
|
wxID_LOWEST = 4999,
|
|
|
|
wxID_OPEN,
|
|
wxID_CLOSE,
|
|
wxID_NEW,
|
|
wxID_SAVE,
|
|
wxID_SAVEAS,
|
|
wxID_REVERT,
|
|
wxID_EXIT,
|
|
wxID_UNDO,
|
|
wxID_REDO,
|
|
wxID_HELP,
|
|
wxID_PRINT,
|
|
wxID_PRINT_SETUP,
|
|
wxID_PAGE_SETUP,
|
|
wxID_PREVIEW,
|
|
wxID_ABOUT,
|
|
wxID_HELP_CONTENTS,
|
|
wxID_HELP_INDEX,
|
|
wxID_HELP_SEARCH,
|
|
wxID_HELP_COMMANDS,
|
|
wxID_HELP_PROCEDURES,
|
|
wxID_HELP_CONTEXT,
|
|
wxID_CLOSE_ALL,
|
|
wxID_PREFERENCES,
|
|
|
|
wxID_EDIT = 5030,
|
|
wxID_CUT,
|
|
wxID_COPY,
|
|
wxID_PASTE,
|
|
wxID_CLEAR,
|
|
wxID_FIND,
|
|
wxID_DUPLICATE,
|
|
wxID_SELECTALL,
|
|
wxID_DELETE,
|
|
wxID_REPLACE,
|
|
wxID_REPLACE_ALL,
|
|
wxID_PROPERTIES,
|
|
|
|
wxID_VIEW_DETAILS,
|
|
wxID_VIEW_LARGEICONS,
|
|
wxID_VIEW_SMALLICONS,
|
|
wxID_VIEW_LIST,
|
|
wxID_VIEW_SORTDATE,
|
|
wxID_VIEW_SORTNAME,
|
|
wxID_VIEW_SORTSIZE,
|
|
wxID_VIEW_SORTTYPE,
|
|
|
|
wxID_FILE = 5050,
|
|
wxID_FILE1,
|
|
wxID_FILE2,
|
|
wxID_FILE3,
|
|
wxID_FILE4,
|
|
wxID_FILE5,
|
|
wxID_FILE6,
|
|
wxID_FILE7,
|
|
wxID_FILE8,
|
|
wxID_FILE9,
|
|
|
|
/* Standard button and menu IDs */
|
|
wxID_OK = 5100,
|
|
wxID_CANCEL,
|
|
wxID_APPLY,
|
|
wxID_YES,
|
|
wxID_NO,
|
|
wxID_STATIC,
|
|
wxID_FORWARD,
|
|
wxID_BACKWARD,
|
|
wxID_DEFAULT,
|
|
wxID_MORE,
|
|
wxID_SETUP,
|
|
wxID_RESET,
|
|
wxID_CONTEXT_HELP,
|
|
wxID_YESTOALL,
|
|
wxID_NOTOALL,
|
|
wxID_ABORT,
|
|
wxID_RETRY,
|
|
wxID_IGNORE,
|
|
wxID_ADD,
|
|
wxID_REMOVE,
|
|
|
|
wxID_UP,
|
|
wxID_DOWN,
|
|
wxID_HOME,
|
|
wxID_REFRESH,
|
|
wxID_STOP,
|
|
wxID_INDEX,
|
|
|
|
wxID_BOLD,
|
|
wxID_ITALIC,
|
|
wxID_JUSTIFY_CENTER,
|
|
wxID_JUSTIFY_FILL,
|
|
wxID_JUSTIFY_RIGHT,
|
|
wxID_JUSTIFY_LEFT,
|
|
wxID_UNDERLINE,
|
|
wxID_INDENT,
|
|
wxID_UNINDENT,
|
|
wxID_ZOOM_100,
|
|
wxID_ZOOM_FIT,
|
|
wxID_ZOOM_IN,
|
|
wxID_ZOOM_OUT,
|
|
wxID_UNDELETE,
|
|
wxID_REVERT_TO_SAVED,
|
|
wxID_CDROM,
|
|
wxID_CONVERT,
|
|
wxID_EXECUTE,
|
|
wxID_FLOPPY,
|
|
wxID_HARDDISK,
|
|
wxID_BOTTOM,
|
|
wxID_FIRST,
|
|
wxID_LAST,
|
|
wxID_TOP,
|
|
wxID_INFO,
|
|
wxID_JUMP_TO,
|
|
wxID_NETWORK,
|
|
wxID_SELECT_COLOR,
|
|
wxID_SELECT_FONT,
|
|
wxID_SORT_ASCENDING,
|
|
wxID_SORT_DESCENDING,
|
|
wxID_SPELL_CHECK,
|
|
wxID_STRIKETHROUGH,
|
|
|
|
/* System menu IDs (used by wxUniv): */
|
|
wxID_SYSTEM_MENU = 5200,
|
|
wxID_CLOSE_FRAME,
|
|
wxID_MOVE_FRAME,
|
|
wxID_RESIZE_FRAME,
|
|
wxID_MAXIMIZE_FRAME,
|
|
wxID_ICONIZE_FRAME,
|
|
wxID_RESTORE_FRAME,
|
|
|
|
/* MDI window menu ids */
|
|
wxID_MDI_WINDOW_FIRST = 5230,
|
|
wxID_MDI_WINDOW_CASCADE = wxID_MDI_WINDOW_FIRST,
|
|
wxID_MDI_WINDOW_TILE_HORZ,
|
|
wxID_MDI_WINDOW_TILE_VERT,
|
|
wxID_MDI_WINDOW_ARRANGE_ICONS,
|
|
wxID_MDI_WINDOW_PREV,
|
|
wxID_MDI_WINDOW_NEXT,
|
|
wxID_MDI_WINDOW_LAST = wxID_MDI_WINDOW_NEXT,
|
|
|
|
/* OS X system menu ids */
|
|
wxID_OSX_MENU_FIRST = 5250,
|
|
wxID_OSX_HIDE = wxID_OSX_MENU_FIRST,
|
|
wxID_OSX_HIDEOTHERS,
|
|
wxID_OSX_SHOWALL,
|
|
#if wxABI_VERSION >= 30001
|
|
wxID_OSX_SERVICES,
|
|
wxID_OSX_MENU_LAST = wxID_OSX_SERVICES,
|
|
#else
|
|
wxID_OSX_MENU_LAST = wxID_OSX_SHOWALL,
|
|
#endif
|
|
|
|
/* IDs used by generic file dialog (13 consecutive starting from this value) */
|
|
wxID_FILEDLGG = 5900,
|
|
|
|
/* IDs used by generic file ctrl (4 consecutive starting from this value) */
|
|
wxID_FILECTRL = 5950,
|
|
|
|
wxID_HIGHEST = 5999
|
|
};
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* wxWindowID type (after wxID_XYZ enum, platform detection, and dlimpexp.h) */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
/* special care should be taken with this type under Windows where the real */
|
|
/* window id is unsigned, so we must always do the cast before comparing them */
|
|
/* (or else they would be always different!). Using wxGetWindowId() which does */
|
|
/* the cast itself is recommended. Note that this type can't be unsigned */
|
|
/* because wxID_ANY == -1 is a valid (and largely used) value for window id. */
|
|
#if defined(__cplusplus) && wxUSE_GUI
|
|
#include "wx/windowid.h"
|
|
#endif
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* other constants */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
/* menu and toolbar item kinds */
|
|
enum wxItemKind
|
|
{
|
|
wxITEM_SEPARATOR = -1,
|
|
wxITEM_NORMAL,
|
|
wxITEM_CHECK,
|
|
wxITEM_RADIO,
|
|
wxITEM_DROPDOWN,
|
|
wxITEM_MAX
|
|
};
|
|
|
|
/*
|
|
* The possible states of a 3-state checkbox (Compatible
|
|
* with the 2-state checkbox).
|
|
*/
|
|
enum wxCheckBoxState
|
|
{
|
|
wxCHK_UNCHECKED,
|
|
wxCHK_CHECKED,
|
|
wxCHK_UNDETERMINED /* 3-state checkbox only */
|
|
};
|
|
|
|
|
|
/* hit test results */
|
|
enum wxHitTest
|
|
{
|
|
wxHT_NOWHERE,
|
|
|
|
/* scrollbar */
|
|
wxHT_SCROLLBAR_FIRST = wxHT_NOWHERE,
|
|
wxHT_SCROLLBAR_ARROW_LINE_1, /* left or upper arrow to scroll by line */
|
|
wxHT_SCROLLBAR_ARROW_LINE_2, /* right or down */
|
|
wxHT_SCROLLBAR_ARROW_PAGE_1, /* left or upper arrow to scroll by page */
|
|
wxHT_SCROLLBAR_ARROW_PAGE_2, /* right or down */
|
|
wxHT_SCROLLBAR_THUMB, /* on the thumb */
|
|
wxHT_SCROLLBAR_BAR_1, /* bar to the left/above the thumb */
|
|
wxHT_SCROLLBAR_BAR_2, /* bar to the right/below the thumb */
|
|
wxHT_SCROLLBAR_LAST,
|
|
|
|
/* window */
|
|
wxHT_WINDOW_OUTSIDE, /* not in this window at all */
|
|
wxHT_WINDOW_INSIDE, /* in the client area */
|
|
wxHT_WINDOW_VERT_SCROLLBAR, /* on the vertical scrollbar */
|
|
wxHT_WINDOW_HORZ_SCROLLBAR, /* on the horizontal scrollbar */
|
|
wxHT_WINDOW_CORNER, /* on the corner between 2 scrollbars */
|
|
|
|
wxHT_MAX
|
|
};
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* Possible SetSize flags */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
/* Use internally-calculated width if -1 */
|
|
#define wxSIZE_AUTO_WIDTH 0x0001
|
|
/* Use internally-calculated height if -1 */
|
|
#define wxSIZE_AUTO_HEIGHT 0x0002
|
|
/* Use internally-calculated width and height if each is -1 */
|
|
#define wxSIZE_AUTO (wxSIZE_AUTO_WIDTH|wxSIZE_AUTO_HEIGHT)
|
|
/* Ignore missing (-1) dimensions (use existing). */
|
|
/* For readability only: test for wxSIZE_AUTO_WIDTH/HEIGHT in code. */
|
|
#define wxSIZE_USE_EXISTING 0x0000
|
|
/* Allow -1 as a valid position */
|
|
#define wxSIZE_ALLOW_MINUS_ONE 0x0004
|
|
/* Don't do parent client adjustments (for implementation only) */
|
|
#define wxSIZE_NO_ADJUSTMENTS 0x0008
|
|
/* Change the window position even if it seems to be already correct */
|
|
#define wxSIZE_FORCE 0x0010
|
|
/* Emit size event even if size didn't change */
|
|
#define wxSIZE_FORCE_EVENT 0x0020
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* GDI descriptions */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
// Hatch styles used by both pen and brush styles.
|
|
//
|
|
// NB: Do not use these constants directly, they're for internal use only, use
|
|
// wxBRUSHSTYLE_XXX_HATCH and wxPENSTYLE_XXX_HATCH instead.
|
|
enum wxHatchStyle
|
|
{
|
|
wxHATCHSTYLE_INVALID = -1,
|
|
|
|
/*
|
|
The value of the first style is chosen to fit with
|
|
wxDeprecatedGUIConstants values below, don't change it.
|
|
*/
|
|
wxHATCHSTYLE_FIRST = 111,
|
|
wxHATCHSTYLE_BDIAGONAL = wxHATCHSTYLE_FIRST,
|
|
wxHATCHSTYLE_CROSSDIAG,
|
|
wxHATCHSTYLE_FDIAGONAL,
|
|
wxHATCHSTYLE_CROSS,
|
|
wxHATCHSTYLE_HORIZONTAL,
|
|
wxHATCHSTYLE_VERTICAL,
|
|
wxHATCHSTYLE_LAST = wxHATCHSTYLE_VERTICAL
|
|
};
|
|
|
|
/*
|
|
WARNING: the following styles are deprecated; use the
|
|
wxFontFamily, wxFontStyle, wxFontWeight, wxBrushStyle,
|
|
wxPenStyle, wxPenCap, wxPenJoin enum values instead!
|
|
*/
|
|
|
|
#if FUTURE_WXWIN_COMPATIBILITY_3_0
|
|
|
|
/* don't use any elements of this enum in the new code */
|
|
enum wxDeprecatedGUIConstants
|
|
{
|
|
/* Text font families */
|
|
wxDEFAULT = 70,
|
|
wxDECORATIVE,
|
|
wxROMAN,
|
|
wxSCRIPT,
|
|
wxSWISS,
|
|
wxMODERN,
|
|
wxTELETYPE, /* @@@@ */
|
|
|
|
/* Proportional or Fixed width fonts (not yet used) */
|
|
wxVARIABLE = 80,
|
|
wxFIXED,
|
|
|
|
wxNORMAL = 90,
|
|
wxLIGHT,
|
|
wxBOLD,
|
|
/* Also wxNORMAL for normal (non-italic text) */
|
|
wxITALIC,
|
|
wxSLANT,
|
|
|
|
/* Pen styles */
|
|
wxSOLID = 100,
|
|
wxDOT,
|
|
wxLONG_DASH,
|
|
wxSHORT_DASH,
|
|
wxDOT_DASH,
|
|
wxUSER_DASH,
|
|
|
|
wxTRANSPARENT,
|
|
|
|
/* Brush & Pen Stippling. Note that a stippled pen cannot be dashed!! */
|
|
/* Note also that stippling a Pen IS meaningful, because a Line is */
|
|
wxSTIPPLE_MASK_OPAQUE, /* mask is used for blitting monochrome using text fore and back ground colors */
|
|
wxSTIPPLE_MASK, /* mask is used for masking areas in the stipple bitmap (TO DO) */
|
|
/* drawn with a Pen, and without any Brush -- and it can be stippled. */
|
|
wxSTIPPLE = 110,
|
|
|
|
wxBDIAGONAL_HATCH = wxHATCHSTYLE_BDIAGONAL,
|
|
wxCROSSDIAG_HATCH = wxHATCHSTYLE_CROSSDIAG,
|
|
wxFDIAGONAL_HATCH = wxHATCHSTYLE_FDIAGONAL,
|
|
wxCROSS_HATCH = wxHATCHSTYLE_CROSS,
|
|
wxHORIZONTAL_HATCH = wxHATCHSTYLE_HORIZONTAL,
|
|
wxVERTICAL_HATCH = wxHATCHSTYLE_VERTICAL,
|
|
wxFIRST_HATCH = wxHATCHSTYLE_FIRST,
|
|
wxLAST_HATCH = wxHATCHSTYLE_LAST
|
|
};
|
|
#endif
|
|
|
|
/* ToolPanel in wxFrame (VZ: unused?) */
|
|
enum
|
|
{
|
|
wxTOOL_TOP = 1,
|
|
wxTOOL_BOTTOM,
|
|
wxTOOL_LEFT,
|
|
wxTOOL_RIGHT
|
|
};
|
|
|
|
/* the values of the format constants should be the same as corresponding */
|
|
/* CF_XXX constants in Windows API */
|
|
enum wxDataFormatId
|
|
{
|
|
wxDF_INVALID = 0,
|
|
wxDF_TEXT = 1, /* CF_TEXT */
|
|
wxDF_BITMAP = 2, /* CF_BITMAP */
|
|
wxDF_METAFILE = 3, /* CF_METAFILEPICT */
|
|
wxDF_SYLK = 4,
|
|
wxDF_DIF = 5,
|
|
wxDF_TIFF = 6,
|
|
wxDF_OEMTEXT = 7, /* CF_OEMTEXT */
|
|
wxDF_DIB = 8, /* CF_DIB */
|
|
wxDF_PALETTE = 9,
|
|
wxDF_PENDATA = 10,
|
|
wxDF_RIFF = 11,
|
|
wxDF_WAVE = 12,
|
|
wxDF_UNICODETEXT = 13,
|
|
wxDF_ENHMETAFILE = 14,
|
|
wxDF_FILENAME = 15, /* CF_HDROP */
|
|
wxDF_LOCALE = 16,
|
|
wxDF_PRIVATE = 20,
|
|
wxDF_HTML = 30, /* Note: does not correspond to CF_ constant */
|
|
wxDF_MAX
|
|
};
|
|
|
|
/* Key codes */
|
|
enum wxKeyCode
|
|
{
|
|
WXK_NONE = 0,
|
|
|
|
WXK_CONTROL_A = 1,
|
|
WXK_CONTROL_B,
|
|
WXK_CONTROL_C,
|
|
WXK_CONTROL_D,
|
|
WXK_CONTROL_E,
|
|
WXK_CONTROL_F,
|
|
WXK_CONTROL_G,
|
|
WXK_CONTROL_H,
|
|
WXK_CONTROL_I,
|
|
WXK_CONTROL_J,
|
|
WXK_CONTROL_K,
|
|
WXK_CONTROL_L,
|
|
WXK_CONTROL_M,
|
|
WXK_CONTROL_N,
|
|
WXK_CONTROL_O,
|
|
WXK_CONTROL_P,
|
|
WXK_CONTROL_Q,
|
|
WXK_CONTROL_R,
|
|
WXK_CONTROL_S,
|
|
WXK_CONTROL_T,
|
|
WXK_CONTROL_U,
|
|
WXK_CONTROL_V,
|
|
WXK_CONTROL_W,
|
|
WXK_CONTROL_X,
|
|
WXK_CONTROL_Y,
|
|
WXK_CONTROL_Z,
|
|
|
|
WXK_BACK = 8, /* backspace */
|
|
WXK_TAB = 9,
|
|
WXK_RETURN = 13,
|
|
WXK_ESCAPE = 27,
|
|
|
|
/* values from 33 to 126 are reserved for the standard ASCII characters */
|
|
|
|
WXK_SPACE = 32,
|
|
WXK_DELETE = 127,
|
|
|
|
/* values from 128 to 255 are reserved for ASCII extended characters
|
|
(note that there isn't a single fixed standard for the meaning
|
|
of these values; avoid them in portable apps!) */
|
|
|
|
/* These are not compatible with unicode characters.
|
|
If you want to get a unicode character from a key event, use
|
|
wxKeyEvent::GetUnicodeKey */
|
|
WXK_START = 300,
|
|
WXK_LBUTTON,
|
|
WXK_RBUTTON,
|
|
WXK_CANCEL,
|
|
WXK_MBUTTON,
|
|
WXK_CLEAR,
|
|
WXK_SHIFT,
|
|
WXK_ALT,
|
|
WXK_CONTROL,
|
|
WXK_MENU,
|
|
WXK_PAUSE,
|
|
WXK_CAPITAL,
|
|
WXK_END,
|
|
WXK_HOME,
|
|
WXK_LEFT,
|
|
WXK_UP,
|
|
WXK_RIGHT,
|
|
WXK_DOWN,
|
|
WXK_SELECT,
|
|
WXK_PRINT,
|
|
WXK_EXECUTE,
|
|
WXK_SNAPSHOT,
|
|
WXK_INSERT,
|
|
WXK_HELP,
|
|
WXK_NUMPAD0,
|
|
WXK_NUMPAD1,
|
|
WXK_NUMPAD2,
|
|
WXK_NUMPAD3,
|
|
WXK_NUMPAD4,
|
|
WXK_NUMPAD5,
|
|
WXK_NUMPAD6,
|
|
WXK_NUMPAD7,
|
|
WXK_NUMPAD8,
|
|
WXK_NUMPAD9,
|
|
WXK_MULTIPLY,
|
|
WXK_ADD,
|
|
WXK_SEPARATOR,
|
|
WXK_SUBTRACT,
|
|
WXK_DECIMAL,
|
|
WXK_DIVIDE,
|
|
WXK_F1,
|
|
WXK_F2,
|
|
WXK_F3,
|
|
WXK_F4,
|
|
WXK_F5,
|
|
WXK_F6,
|
|
WXK_F7,
|
|
WXK_F8,
|
|
WXK_F9,
|
|
WXK_F10,
|
|
WXK_F11,
|
|
WXK_F12,
|
|
WXK_F13,
|
|
WXK_F14,
|
|
WXK_F15,
|
|
WXK_F16,
|
|
WXK_F17,
|
|
WXK_F18,
|
|
WXK_F19,
|
|
WXK_F20,
|
|
WXK_F21,
|
|
WXK_F22,
|
|
WXK_F23,
|
|
WXK_F24,
|
|
WXK_NUMLOCK,
|
|
WXK_SCROLL,
|
|
WXK_PAGEUP,
|
|
WXK_PAGEDOWN,
|
|
#if WXWIN_COMPATIBILITY_2_6
|
|
WXK_PRIOR = WXK_PAGEUP,
|
|
WXK_NEXT = WXK_PAGEDOWN,
|
|
#endif
|
|
|
|
WXK_NUMPAD_SPACE,
|
|
WXK_NUMPAD_TAB,
|
|
WXK_NUMPAD_ENTER,
|
|
WXK_NUMPAD_F1,
|
|
WXK_NUMPAD_F2,
|
|
WXK_NUMPAD_F3,
|
|
WXK_NUMPAD_F4,
|
|
WXK_NUMPAD_HOME,
|
|
WXK_NUMPAD_LEFT,
|
|
WXK_NUMPAD_UP,
|
|
WXK_NUMPAD_RIGHT,
|
|
WXK_NUMPAD_DOWN,
|
|
WXK_NUMPAD_PAGEUP,
|
|
WXK_NUMPAD_PAGEDOWN,
|
|
#if WXWIN_COMPATIBILITY_2_6
|
|
WXK_NUMPAD_PRIOR = WXK_NUMPAD_PAGEUP,
|
|
WXK_NUMPAD_NEXT = WXK_NUMPAD_PAGEDOWN,
|
|
#endif
|
|
WXK_NUMPAD_END,
|
|
WXK_NUMPAD_BEGIN,
|
|
WXK_NUMPAD_INSERT,
|
|
WXK_NUMPAD_DELETE,
|
|
WXK_NUMPAD_EQUAL,
|
|
WXK_NUMPAD_MULTIPLY,
|
|
WXK_NUMPAD_ADD,
|
|
WXK_NUMPAD_SEPARATOR,
|
|
WXK_NUMPAD_SUBTRACT,
|
|
WXK_NUMPAD_DECIMAL,
|
|
WXK_NUMPAD_DIVIDE,
|
|
|
|
WXK_WINDOWS_LEFT,
|
|
WXK_WINDOWS_RIGHT,
|
|
WXK_WINDOWS_MENU ,
|
|
#ifdef __WXOSX__
|
|
WXK_RAW_CONTROL,
|
|
#else
|
|
WXK_RAW_CONTROL = WXK_CONTROL,
|
|
#endif
|
|
WXK_COMMAND = WXK_CONTROL,
|
|
|
|
/* Hardware-specific buttons */
|
|
WXK_SPECIAL1 = 193,
|
|
WXK_SPECIAL2,
|
|
WXK_SPECIAL3,
|
|
WXK_SPECIAL4,
|
|
WXK_SPECIAL5,
|
|
WXK_SPECIAL6,
|
|
WXK_SPECIAL7,
|
|
WXK_SPECIAL8,
|
|
WXK_SPECIAL9,
|
|
WXK_SPECIAL10,
|
|
WXK_SPECIAL11,
|
|
WXK_SPECIAL12,
|
|
WXK_SPECIAL13,
|
|
WXK_SPECIAL14,
|
|
WXK_SPECIAL15,
|
|
WXK_SPECIAL16,
|
|
WXK_SPECIAL17,
|
|
WXK_SPECIAL18,
|
|
WXK_SPECIAL19,
|
|
WXK_SPECIAL20
|
|
};
|
|
|
|
/* This enum contains bit mask constants used in wxKeyEvent */
|
|
enum wxKeyModifier
|
|
{
|
|
wxMOD_NONE = 0x0000,
|
|
wxMOD_ALT = 0x0001,
|
|
wxMOD_CONTROL = 0x0002,
|
|
wxMOD_ALTGR = wxMOD_ALT | wxMOD_CONTROL,
|
|
wxMOD_SHIFT = 0x0004,
|
|
wxMOD_META = 0x0008,
|
|
wxMOD_WIN = wxMOD_META,
|
|
#if defined(__WXMAC__) || defined(__WXCOCOA__)
|
|
wxMOD_RAW_CONTROL = 0x0010,
|
|
#else
|
|
wxMOD_RAW_CONTROL = wxMOD_CONTROL,
|
|
#endif
|
|
wxMOD_CMD = wxMOD_CONTROL,
|
|
wxMOD_ALL = 0xffff
|
|
};
|
|
|
|
/* Shortcut for easier dialog-unit-to-pixel conversion */
|
|
#define wxDLG_UNIT(parent, pt) parent->ConvertDialogToPixels(pt)
|
|
|
|
/* Paper types */
|
|
typedef enum
|
|
{
|
|
wxPAPER_NONE, /* Use specific dimensions */
|
|
wxPAPER_LETTER, /* Letter, 8 1/2 by 11 inches */
|
|
wxPAPER_LEGAL, /* Legal, 8 1/2 by 14 inches */
|
|
wxPAPER_A4, /* A4 Sheet, 210 by 297 millimeters */
|
|
wxPAPER_CSHEET, /* C Sheet, 17 by 22 inches */
|
|
wxPAPER_DSHEET, /* D Sheet, 22 by 34 inches */
|
|
wxPAPER_ESHEET, /* E Sheet, 34 by 44 inches */
|
|
wxPAPER_LETTERSMALL, /* Letter Small, 8 1/2 by 11 inches */
|
|
wxPAPER_TABLOID, /* Tabloid, 11 by 17 inches */
|
|
wxPAPER_LEDGER, /* Ledger, 17 by 11 inches */
|
|
wxPAPER_STATEMENT, /* Statement, 5 1/2 by 8 1/2 inches */
|
|
wxPAPER_EXECUTIVE, /* Executive, 7 1/4 by 10 1/2 inches */
|
|
wxPAPER_A3, /* A3 sheet, 297 by 420 millimeters */
|
|
wxPAPER_A4SMALL, /* A4 small sheet, 210 by 297 millimeters */
|
|
wxPAPER_A5, /* A5 sheet, 148 by 210 millimeters */
|
|
wxPAPER_B4, /* B4 sheet, 250 by 354 millimeters */
|
|
wxPAPER_B5, /* B5 sheet, 182-by-257-millimeter paper */
|
|
wxPAPER_FOLIO, /* Folio, 8-1/2-by-13-inch paper */
|
|
wxPAPER_QUARTO, /* Quarto, 215-by-275-millimeter paper */
|
|
wxPAPER_10X14, /* 10-by-14-inch sheet */
|
|
wxPAPER_11X17, /* 11-by-17-inch sheet */
|
|
wxPAPER_NOTE, /* Note, 8 1/2 by 11 inches */
|
|
wxPAPER_ENV_9, /* #9 Envelope, 3 7/8 by 8 7/8 inches */
|
|
wxPAPER_ENV_10, /* #10 Envelope, 4 1/8 by 9 1/2 inches */
|
|
wxPAPER_ENV_11, /* #11 Envelope, 4 1/2 by 10 3/8 inches */
|
|
wxPAPER_ENV_12, /* #12 Envelope, 4 3/4 by 11 inches */
|
|
wxPAPER_ENV_14, /* #14 Envelope, 5 by 11 1/2 inches */
|
|
wxPAPER_ENV_DL, /* DL Envelope, 110 by 220 millimeters */
|
|
wxPAPER_ENV_C5, /* C5 Envelope, 162 by 229 millimeters */
|
|
wxPAPER_ENV_C3, /* C3 Envelope, 324 by 458 millimeters */
|
|
wxPAPER_ENV_C4, /* C4 Envelope, 229 by 324 millimeters */
|
|
wxPAPER_ENV_C6, /* C6 Envelope, 114 by 162 millimeters */
|
|
wxPAPER_ENV_C65, /* C65 Envelope, 114 by 229 millimeters */
|
|
wxPAPER_ENV_B4, /* B4 Envelope, 250 by 353 millimeters */
|
|
wxPAPER_ENV_B5, /* B5 Envelope, 176 by 250 millimeters */
|
|
wxPAPER_ENV_B6, /* B6 Envelope, 176 by 125 millimeters */
|
|
wxPAPER_ENV_ITALY, /* Italy Envelope, 110 by 230 millimeters */
|
|
wxPAPER_ENV_MONARCH, /* Monarch Envelope, 3 7/8 by 7 1/2 inches */
|
|
wxPAPER_ENV_PERSONAL, /* 6 3/4 Envelope, 3 5/8 by 6 1/2 inches */
|
|
wxPAPER_FANFOLD_US, /* US Std Fanfold, 14 7/8 by 11 inches */
|
|
wxPAPER_FANFOLD_STD_GERMAN, /* German Std Fanfold, 8 1/2 by 12 inches */
|
|
wxPAPER_FANFOLD_LGL_GERMAN, /* German Legal Fanfold, 8 1/2 by 13 inches */
|
|
|
|
wxPAPER_ISO_B4, /* B4 (ISO) 250 x 353 mm */
|
|
wxPAPER_JAPANESE_POSTCARD, /* Japanese Postcard 100 x 148 mm */
|
|
wxPAPER_9X11, /* 9 x 11 in */
|
|
wxPAPER_10X11, /* 10 x 11 in */
|
|
wxPAPER_15X11, /* 15 x 11 in */
|
|
wxPAPER_ENV_INVITE, /* Envelope Invite 220 x 220 mm */
|
|
wxPAPER_LETTER_EXTRA, /* Letter Extra 9 \275 x 12 in */
|
|
wxPAPER_LEGAL_EXTRA, /* Legal Extra 9 \275 x 15 in */
|
|
wxPAPER_TABLOID_EXTRA, /* Tabloid Extra 11.69 x 18 in */
|
|
wxPAPER_A4_EXTRA, /* A4 Extra 9.27 x 12.69 in */
|
|
wxPAPER_LETTER_TRANSVERSE, /* Letter Transverse 8 \275 x 11 in */
|
|
wxPAPER_A4_TRANSVERSE, /* A4 Transverse 210 x 297 mm */
|
|
wxPAPER_LETTER_EXTRA_TRANSVERSE, /* Letter Extra Transverse 9\275 x 12 in */
|
|
wxPAPER_A_PLUS, /* SuperA/SuperA/A4 227 x 356 mm */
|
|
wxPAPER_B_PLUS, /* SuperB/SuperB/A3 305 x 487 mm */
|
|
wxPAPER_LETTER_PLUS, /* Letter Plus 8.5 x 12.69 in */
|
|
wxPAPER_A4_PLUS, /* A4 Plus 210 x 330 mm */
|
|
wxPAPER_A5_TRANSVERSE, /* A5 Transverse 148 x 210 mm */
|
|
wxPAPER_B5_TRANSVERSE, /* B5 (JIS) Transverse 182 x 257 mm */
|
|
wxPAPER_A3_EXTRA, /* A3 Extra 322 x 445 mm */
|
|
wxPAPER_A5_EXTRA, /* A5 Extra 174 x 235 mm */
|
|
wxPAPER_B5_EXTRA, /* B5 (ISO) Extra 201 x 276 mm */
|
|
wxPAPER_A2, /* A2 420 x 594 mm */
|
|
wxPAPER_A3_TRANSVERSE, /* A3 Transverse 297 x 420 mm */
|
|
wxPAPER_A3_EXTRA_TRANSVERSE, /* A3 Extra Transverse 322 x 445 mm */
|
|
|
|
wxPAPER_DBL_JAPANESE_POSTCARD,/* Japanese Double Postcard 200 x 148 mm */
|
|
wxPAPER_A6, /* A6 105 x 148 mm */
|
|
wxPAPER_JENV_KAKU2, /* Japanese Envelope Kaku #2 */
|
|
wxPAPER_JENV_KAKU3, /* Japanese Envelope Kaku #3 */
|
|
wxPAPER_JENV_CHOU3, /* Japanese Envelope Chou #3 */
|
|
wxPAPER_JENV_CHOU4, /* Japanese Envelope Chou #4 */
|
|
wxPAPER_LETTER_ROTATED, /* Letter Rotated 11 x 8 1/2 in */
|
|
wxPAPER_A3_ROTATED, /* A3 Rotated 420 x 297 mm */
|
|
wxPAPER_A4_ROTATED, /* A4 Rotated 297 x 210 mm */
|
|
wxPAPER_A5_ROTATED, /* A5 Rotated 210 x 148 mm */
|
|
wxPAPER_B4_JIS_ROTATED, /* B4 (JIS) Rotated 364 x 257 mm */
|
|
wxPAPER_B5_JIS_ROTATED, /* B5 (JIS) Rotated 257 x 182 mm */
|
|
wxPAPER_JAPANESE_POSTCARD_ROTATED,/* Japanese Postcard Rotated 148 x 100 mm */
|
|
wxPAPER_DBL_JAPANESE_POSTCARD_ROTATED,/* Double Japanese Postcard Rotated 148 x 200 mm */
|
|
wxPAPER_A6_ROTATED, /* A6 Rotated 148 x 105 mm */
|
|
wxPAPER_JENV_KAKU2_ROTATED, /* Japanese Envelope Kaku #2 Rotated */
|
|
wxPAPER_JENV_KAKU3_ROTATED, /* Japanese Envelope Kaku #3 Rotated */
|
|
wxPAPER_JENV_CHOU3_ROTATED, /* Japanese Envelope Chou #3 Rotated */
|
|
wxPAPER_JENV_CHOU4_ROTATED, /* Japanese Envelope Chou #4 Rotated */
|
|
wxPAPER_B6_JIS, /* B6 (JIS) 128 x 182 mm */
|
|
wxPAPER_B6_JIS_ROTATED, /* B6 (JIS) Rotated 182 x 128 mm */
|
|
wxPAPER_12X11, /* 12 x 11 in */
|
|
wxPAPER_JENV_YOU4, /* Japanese Envelope You #4 */
|
|
wxPAPER_JENV_YOU4_ROTATED, /* Japanese Envelope You #4 Rotated */
|
|
wxPAPER_P16K, /* PRC 16K 146 x 215 mm */
|
|
wxPAPER_P32K, /* PRC 32K 97 x 151 mm */
|
|
wxPAPER_P32KBIG, /* PRC 32K(Big) 97 x 151 mm */
|
|
wxPAPER_PENV_1, /* PRC Envelope #1 102 x 165 mm */
|
|
wxPAPER_PENV_2, /* PRC Envelope #2 102 x 176 mm */
|
|
wxPAPER_PENV_3, /* PRC Envelope #3 125 x 176 mm */
|
|
wxPAPER_PENV_4, /* PRC Envelope #4 110 x 208 mm */
|
|
wxPAPER_PENV_5, /* PRC Envelope #5 110 x 220 mm */
|
|
wxPAPER_PENV_6, /* PRC Envelope #6 120 x 230 mm */
|
|
wxPAPER_PENV_7, /* PRC Envelope #7 160 x 230 mm */
|
|
wxPAPER_PENV_8, /* PRC Envelope #8 120 x 309 mm */
|
|
wxPAPER_PENV_9, /* PRC Envelope #9 229 x 324 mm */
|
|
wxPAPER_PENV_10, /* PRC Envelope #10 324 x 458 mm */
|
|
wxPAPER_P16K_ROTATED, /* PRC 16K Rotated */
|
|
wxPAPER_P32K_ROTATED, /* PRC 32K Rotated */
|
|
wxPAPER_P32KBIG_ROTATED, /* PRC 32K(Big) Rotated */
|
|
wxPAPER_PENV_1_ROTATED, /* PRC Envelope #1 Rotated 165 x 102 mm */
|
|
wxPAPER_PENV_2_ROTATED, /* PRC Envelope #2 Rotated 176 x 102 mm */
|
|
wxPAPER_PENV_3_ROTATED, /* PRC Envelope #3 Rotated 176 x 125 mm */
|
|
wxPAPER_PENV_4_ROTATED, /* PRC Envelope #4 Rotated 208 x 110 mm */
|
|
wxPAPER_PENV_5_ROTATED, /* PRC Envelope #5 Rotated 220 x 110 mm */
|
|
wxPAPER_PENV_6_ROTATED, /* PRC Envelope #6 Rotated 230 x 120 mm */
|
|
wxPAPER_PENV_7_ROTATED, /* PRC Envelope #7 Rotated 230 x 160 mm */
|
|
wxPAPER_PENV_8_ROTATED, /* PRC Envelope #8 Rotated 309 x 120 mm */
|
|
wxPAPER_PENV_9_ROTATED, /* PRC Envelope #9 Rotated 324 x 229 mm */
|
|
wxPAPER_PENV_10_ROTATED, /* PRC Envelope #10 Rotated 458 x 324 m */
|
|
wxPAPER_A0, /* A0 Sheet 841 x 1189 mm */
|
|
wxPAPER_A1 /* A1 Sheet 594 x 841 mm */
|
|
} wxPaperSize;
|
|
|
|
/* Printing orientation */
|
|
enum wxPrintOrientation
|
|
{
|
|
wxPORTRAIT = 1,
|
|
wxLANDSCAPE
|
|
};
|
|
|
|
/* Duplex printing modes
|
|
*/
|
|
|
|
enum wxDuplexMode
|
|
{
|
|
wxDUPLEX_SIMPLEX, /* Non-duplex */
|
|
wxDUPLEX_HORIZONTAL,
|
|
wxDUPLEX_VERTICAL
|
|
};
|
|
|
|
/* Print quality.
|
|
*/
|
|
|
|
#define wxPRINT_QUALITY_HIGH -1
|
|
#define wxPRINT_QUALITY_MEDIUM -2
|
|
#define wxPRINT_QUALITY_LOW -3
|
|
#define wxPRINT_QUALITY_DRAFT -4
|
|
|
|
typedef int wxPrintQuality;
|
|
|
|
/* Print mode (currently PostScript only)
|
|
*/
|
|
|
|
enum wxPrintMode
|
|
{
|
|
wxPRINT_MODE_NONE = 0,
|
|
wxPRINT_MODE_PREVIEW = 1, /* Preview in external application */
|
|
wxPRINT_MODE_FILE = 2, /* Print to file */
|
|
wxPRINT_MODE_PRINTER = 3, /* Send to printer */
|
|
wxPRINT_MODE_STREAM = 4 /* Send postscript data into a stream */
|
|
};
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* UpdateWindowUI flags */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
enum wxUpdateUI
|
|
{
|
|
wxUPDATE_UI_NONE = 0x0000,
|
|
wxUPDATE_UI_RECURSE = 0x0001,
|
|
wxUPDATE_UI_FROMIDLE = 0x0002 /* Invoked from On(Internal)Idle */
|
|
};
|
|
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* wxList types */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
/* type of compare function for list sort operation (as in 'qsort'): it should
|
|
return a negative value, 0 or positive value if the first element is less
|
|
than, equal or greater than the second */
|
|
|
|
typedef int (* LINKAGEMODE wxSortCompareFunction)(const void *elem1, const void *elem2);
|
|
|
|
/* wxList iterator function */
|
|
typedef int (* LINKAGEMODE wxListIterateFunction)(void *current);
|
|
|
|
|
|
/* ---------------------------------------------------------------------------- */
|
|
/* miscellaneous */
|
|
/* ---------------------------------------------------------------------------- */
|
|
|
|
/* define this macro if font handling is done using the X font names */
|
|
#if (defined(__WXGTK__) && !defined(__WXGTK20__)) || defined(__X__)
|
|
#define _WX_X_FONTLIKE
|
|
#endif
|
|
|
|
/* macro to specify "All Files" on different platforms */
|
|
#if defined(__WXMSW__) || defined(__WXPM__)
|
|
# define wxALL_FILES_PATTERN wxT("*.*")
|
|
# define wxALL_FILES gettext_noop("All files (*.*)|*.*")
|
|
#else
|
|
# define wxALL_FILES_PATTERN wxT("*")
|
|
# define wxALL_FILES gettext_noop("All files (*)|*")
|
|
#endif
|
|
|
|
#if defined(__CYGWIN__) && defined(__WXMSW__)
|
|
# if wxUSE_STD_CONTAINERS || defined(wxUSE_STD_STRING)
|
|
/*
|
|
NASTY HACK because the gethostname in sys/unistd.h which the gnu
|
|
stl includes and wx builds with by default clash with each other
|
|
(windows version 2nd param is int, sys/unistd.h version is unsigned
|
|
int).
|
|
*/
|
|
# define gethostname gethostnameHACK
|
|
# include <unistd.h>
|
|
# undef gethostname
|
|
# endif
|
|
#endif
|
|
|
|
/* --------------------------------------------------------------------------- */
|
|
/* macros that enable wxWidgets apps to be compiled in absence of the */
|
|
/* system headers, although some platform specific types are used in the */
|
|
/* platform specific (implementation) parts of the headers */
|
|
/* --------------------------------------------------------------------------- */
|
|
|
|
#ifdef __DARWIN__
|
|
#define DECLARE_WXOSX_OPAQUE_CFREF( name ) typedef struct __##name* name##Ref;
|
|
#define DECLARE_WXOSX_OPAQUE_CONST_CFREF( name ) typedef const struct __##name* name##Ref;
|
|
#endif
|
|
|
|
#ifdef __WXMAC__
|
|
|
|
#define WX_OPAQUE_TYPE( name ) struct wxOpaque##name
|
|
|
|
typedef void* WXHBITMAP;
|
|
typedef void* WXHCURSOR;
|
|
typedef void* WXRECTPTR;
|
|
typedef void* WXPOINTPTR;
|
|
typedef void* WXHWND;
|
|
typedef void* WXEVENTREF;
|
|
typedef void* WXEVENTHANDLERREF;
|
|
typedef void* WXEVENTHANDLERCALLREF;
|
|
typedef void* WXAPPLEEVENTREF;
|
|
|
|
typedef unsigned int WXUINT;
|
|
typedef unsigned long WXDWORD;
|
|
typedef unsigned short WXWORD;
|
|
|
|
typedef WX_OPAQUE_TYPE(PicHandle ) * WXHMETAFILE ;
|
|
#if wxOSX_USE_CARBON
|
|
typedef struct OpaqueControlRef* WXWidget ;
|
|
typedef struct OpaqueWindowPtr* WXWindow ;
|
|
typedef struct __AGLPixelFormatRec *WXGLPixelFormat;
|
|
typedef struct __AGLContextRec *WXGLContext;
|
|
#endif
|
|
|
|
typedef void* WXDisplay;
|
|
|
|
/*
|
|
* core frameworks
|
|
*/
|
|
|
|
typedef const void * CFTypeRef;
|
|
|
|
/* typedef const struct __CFString * CFStringRef; */
|
|
|
|
DECLARE_WXOSX_OPAQUE_CONST_CFREF( CFString )
|
|
typedef struct __CFString * CFMutableStringRef;
|
|
|
|
DECLARE_WXOSX_OPAQUE_CFREF( CFRunLoopSource )
|
|
DECLARE_WXOSX_OPAQUE_CONST_CFREF( CTFont )
|
|
DECLARE_WXOSX_OPAQUE_CONST_CFREF( CTFontDescriptor )
|
|
|
|
#define DECLARE_WXOSX_OPAQUE_CGREF( name ) typedef struct name* name##Ref;
|
|
|
|
DECLARE_WXOSX_OPAQUE_CGREF( CGColor )
|
|
DECLARE_WXOSX_OPAQUE_CGREF( CGImage )
|
|
DECLARE_WXOSX_OPAQUE_CGREF( CGContext )
|
|
DECLARE_WXOSX_OPAQUE_CGREF( CGFont )
|
|
|
|
typedef CGColorRef WXCOLORREF;
|
|
typedef CGImageRef WXCGIMAGEREF;
|
|
typedef CGContextRef WXHDC;
|
|
|
|
/*
|
|
* carbon
|
|
*/
|
|
|
|
typedef const struct __HIShape * HIShapeRef;
|
|
typedef struct __HIShape * HIMutableShapeRef;
|
|
|
|
#define DECLARE_WXMAC_OPAQUE_REF( name ) typedef struct Opaque##name* name;
|
|
|
|
DECLARE_WXMAC_OPAQUE_REF( PasteboardRef )
|
|
DECLARE_WXMAC_OPAQUE_REF( IconRef )
|
|
DECLARE_WXMAC_OPAQUE_REF( MenuRef )
|
|
|
|
typedef IconRef WXHICON ;
|
|
typedef HIShapeRef WXHRGN;
|
|
#if wxOSX_USE_CARBON
|
|
typedef MenuRef WXHMENU;
|
|
#endif
|
|
|
|
#endif
|
|
|
|
#if defined( __WXCOCOA__ ) || defined(__WXMAC__)
|
|
|
|
/* Definitions of 32-bit/64-bit types
|
|
* These are typedef'd exactly the same way in newer OS X headers so
|
|
* redefinition when real headers are included should not be a problem. If
|
|
* it is, the types are being defined wrongly here.
|
|
* The purpose of these types is so they can be used from public wx headers.
|
|
* and also because the older (pre-Leopard) headers don't define them.
|
|
*/
|
|
|
|
/* NOTE: We don't pollute namespace with CGFLOAT_MIN/MAX/IS_DOUBLE macros
|
|
* since they are unlikely to be needed in a public header.
|
|
*/
|
|
#if defined(__LP64__) && __LP64__
|
|
typedef double CGFloat;
|
|
#else
|
|
typedef float CGFloat;
|
|
#endif
|
|
|
|
#if (defined(__LP64__) && __LP64__) || (defined(NS_BUILD_32_LIKE_64) && NS_BUILD_32_LIKE_64)
|
|
typedef long NSInteger;
|
|
typedef unsigned long NSUInteger;
|
|
#else
|
|
typedef int NSInteger;
|
|
typedef unsigned int NSUInteger;
|
|
#endif
|
|
|
|
/* Objective-C type declarations.
|
|
* These are to be used in public headers in lieu of NSSomething* because
|
|
* Objective-C class names are not available in C/C++ code.
|
|
*/
|
|
|
|
/* NOTE: This ought to work with other compilers too, but I'm being cautious */
|
|
#if (defined(__GNUC__) && defined(__APPLE__))
|
|
/* It's desirable to have type safety for Objective-C(++) code as it does
|
|
at least catch typos of method names among other things. However, it
|
|
is not possible to declare an Objective-C class from plain old C or C++
|
|
code. Furthermore, because of C++ name mangling, the type name must
|
|
be the same for both C++ and Objective-C++ code. Therefore, we define
|
|
what should be a pointer to an Objective-C class as a pointer to a plain
|
|
old C struct with the same name. Unfortunately, because the compiler
|
|
does not see a struct as an Objective-C class we cannot declare it
|
|
as a struct in Objective-C(++) mode.
|
|
*/
|
|
#if defined(__OBJC__)
|
|
#define DECLARE_WXCOCOA_OBJC_CLASS(klass) \
|
|
@class klass; \
|
|
typedef klass *WX_##klass
|
|
#else /* not defined(__OBJC__) */
|
|
#define DECLARE_WXCOCOA_OBJC_CLASS(klass) \
|
|
typedef struct klass *WX_##klass
|
|
#endif /* defined(__OBJC__) */
|
|
|
|
#else /* not Apple's gcc */
|
|
#warning "Objective-C types will not be checked by the compiler."
|
|
/* NOTE: typedef struct objc_object *id; */
|
|
/* IOW, we're declaring these using the id type without using that name, */
|
|
/* since "id" is used extensively not only within wxWidgets itself, but */
|
|
/* also in wxWidgets application code. The following works fine when */
|
|
/* compiling C(++) code, and works without typesafety for Obj-C(++) code */
|
|
#define DECLARE_WXCOCOA_OBJC_CLASS(klass) \
|
|
typedef struct objc_object *WX_##klass
|
|
|
|
#endif /* (defined(__GNUC__) && defined(__APPLE__)) */
|
|
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSApplication);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSBitmapImageRep);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSBox);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSButton);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSColor);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSColorPanel);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSControl);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSCursor);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSEvent);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSFont);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSFontDescriptor);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSFontPanel);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSImage);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSLayoutManager);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSMenu);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSMenuExtra);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSMenuItem);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSMutableArray);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSNotification);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSObject);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSPanel);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSResponder);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSScrollView);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSSound);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSStatusItem);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSTableColumn);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSTableView);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSTextContainer);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSTextField);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSTextStorage);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSThread);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSWindow);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSView);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSOpenGLContext);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSOpenGLPixelFormat);
|
|
DECLARE_WXCOCOA_OBJC_CLASS( NSPrintInfo );
|
|
#ifndef __WXMAC__
|
|
typedef WX_NSView WXWidget; /* wxWidgets BASE definition */
|
|
#endif
|
|
#endif /* __WXCOCOA__ || ( __WXMAC__ &__DARWIN__)*/
|
|
|
|
#ifdef __WXMAC__
|
|
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSString);
|
|
|
|
#if wxOSX_USE_COCOA
|
|
|
|
typedef WX_NSWindow WXWindow;
|
|
typedef WX_NSView WXWidget;
|
|
typedef WX_NSMenu WXHMENU;
|
|
typedef WX_NSOpenGLPixelFormat WXGLPixelFormat;
|
|
typedef WX_NSOpenGLContext WXGLContext;
|
|
|
|
#elif wxOSX_USE_IPHONE
|
|
|
|
DECLARE_WXCOCOA_OBJC_CLASS(UIWindow);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(UIView);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(UIFont);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(UIImage);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(UIEvent);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(NSSet);
|
|
DECLARE_WXCOCOA_OBJC_CLASS(EAGLContext);
|
|
|
|
typedef WX_UIWindow WXWindow;
|
|
typedef WX_UIView WXWidget;
|
|
typedef WX_EAGLContext WXGLContext;
|
|
typedef WX_NSString* WXGLPixelFormat;
|
|
|
|
#endif
|
|
|
|
#endif /* __WXMAC__ */
|
|
|
|
/* ABX: check __WIN32__ instead of __WXMSW__ for the same MSWBase in any Win32 port */
|
|
#if defined(__WIN32__)
|
|
|
|
/* Stand-ins for Windows types to avoid #including all of windows.h */
|
|
|
|
#ifndef NO_STRICT
|
|
#define WX_MSW_DECLARE_HANDLE(type) typedef struct type##__ * WX##type
|
|
#else
|
|
#define WX_MSW_DECLARE_HANDLE(type) typedef void * WX##type
|
|
#endif
|
|
|
|
typedef void* WXHANDLE;
|
|
WX_MSW_DECLARE_HANDLE(HWND);
|
|
WX_MSW_DECLARE_HANDLE(HICON);
|
|
WX_MSW_DECLARE_HANDLE(HFONT);
|
|
WX_MSW_DECLARE_HANDLE(HMENU);
|
|
WX_MSW_DECLARE_HANDLE(HPEN);
|
|
WX_MSW_DECLARE_HANDLE(HBRUSH);
|
|
WX_MSW_DECLARE_HANDLE(HPALETTE);
|
|
WX_MSW_DECLARE_HANDLE(HCURSOR);
|
|
WX_MSW_DECLARE_HANDLE(HRGN);
|
|
WX_MSW_DECLARE_HANDLE(RECTPTR);
|
|
WX_MSW_DECLARE_HANDLE(HACCEL);
|
|
WX_MSW_DECLARE_HANDLE(HINSTANCE);
|
|
WX_MSW_DECLARE_HANDLE(HBITMAP);
|
|
WX_MSW_DECLARE_HANDLE(HIMAGELIST);
|
|
WX_MSW_DECLARE_HANDLE(HGLOBAL);
|
|
WX_MSW_DECLARE_HANDLE(HDC);
|
|
typedef WXHINSTANCE WXHMODULE;
|
|
|
|
#undef WX_MSW_DECLARE_HANDLE
|
|
|
|
typedef unsigned int WXUINT;
|
|
typedef unsigned long WXDWORD;
|
|
typedef unsigned short WXWORD;
|
|
|
|
typedef unsigned long WXCOLORREF;
|
|
typedef void * WXRGNDATA;
|
|
typedef struct tagMSG WXMSG;
|
|
typedef void * WXHCONV;
|
|
typedef void * WXHKEY;
|
|
typedef void * WXHTREEITEM;
|
|
|
|
typedef void * WXDRAWITEMSTRUCT;
|
|
typedef void * WXMEASUREITEMSTRUCT;
|
|
typedef void * WXLPCREATESTRUCT;
|
|
|
|
#ifdef __WXMSW__
|
|
typedef WXHWND WXWidget;
|
|
#endif
|
|
|
|
#ifdef __WIN64__
|
|
typedef unsigned __int64 WXWPARAM;
|
|
typedef __int64 WXLPARAM;
|
|
typedef __int64 WXLRESULT;
|
|
#else
|
|
typedef wxW64 unsigned int WXWPARAM;
|
|
typedef wxW64 long WXLPARAM;
|
|
typedef wxW64 long WXLRESULT;
|
|
#endif
|
|
|
|
#if defined(__GNUWIN32__) || defined(__WXMICROWIN__)
|
|
typedef int (*WXFARPROC)();
|
|
#else
|
|
typedef int (__stdcall *WXFARPROC)();
|
|
#endif
|
|
#endif /* __WIN32__ */
|
|
|
|
|
|
#if defined(__OS2__)
|
|
typedef unsigned long DWORD;
|
|
typedef unsigned short WORD;
|
|
#endif
|
|
|
|
#if defined(__WXPM__) || defined(__EMX__)
|
|
#ifdef __WXPM__
|
|
/* Stand-ins for OS/2 types, to avoid #including all of os2.h */
|
|
typedef unsigned long WXHWND;
|
|
typedef unsigned long WXHANDLE;
|
|
typedef unsigned long WXHICON;
|
|
typedef unsigned long WXHFONT;
|
|
typedef unsigned long WXHMENU;
|
|
typedef unsigned long WXHPEN;
|
|
typedef unsigned long WXHBRUSH;
|
|
typedef unsigned long WXHPALETTE;
|
|
typedef unsigned long WXHCURSOR;
|
|
typedef unsigned long WXHRGN;
|
|
typedef unsigned long WXHACCEL;
|
|
typedef unsigned long WXHINSTANCE;
|
|
typedef unsigned long WXHMODULE;
|
|
typedef unsigned long WXHBITMAP;
|
|
typedef unsigned long WXHDC;
|
|
typedef unsigned int WXUINT;
|
|
typedef unsigned long WXDWORD;
|
|
typedef unsigned short WXWORD;
|
|
|
|
typedef unsigned long WXCOLORREF;
|
|
typedef void * WXMSG;
|
|
typedef unsigned long WXHTREEITEM;
|
|
|
|
typedef void * WXDRAWITEMSTRUCT;
|
|
typedef void * WXMEASUREITEMSTRUCT;
|
|
typedef void * WXLPCREATESTRUCT;
|
|
|
|
typedef WXHWND WXWidget;
|
|
#endif
|
|
#ifdef __EMX__
|
|
/* Need a well-known type for WXFARPROC
|
|
below. MPARAM is typedef'ed too late. */
|
|
#define WXWPARAM void *
|
|
#define WXLPARAM void *
|
|
#else
|
|
#define WXWPARAM MPARAM
|
|
#define WXLPARAM MPARAM
|
|
#endif
|
|
#define RECT RECTL
|
|
#define LOGFONT FATTRS
|
|
#define LOWORD SHORT1FROMMP
|
|
#define HIWORD SHORT2FROMMP
|
|
|
|
typedef unsigned long WXMPARAM;
|
|
typedef unsigned long WXMSGID;
|
|
typedef void* WXRESULT;
|
|
/* typedef int (*WXFARPROC)(); */
|
|
/* some windows handles not defined by PM */
|
|
typedef unsigned long HANDLE;
|
|
typedef unsigned long HICON;
|
|
typedef unsigned long HFONT;
|
|
typedef unsigned long HMENU;
|
|
typedef unsigned long HPEN;
|
|
typedef unsigned long HBRUSH;
|
|
typedef unsigned long HPALETTE;
|
|
typedef unsigned long HCURSOR;
|
|
typedef unsigned long HINSTANCE;
|
|
typedef unsigned long HIMAGELIST;
|
|
typedef unsigned long HGLOBAL;
|
|
#endif /* WXPM || EMX */
|
|
|
|
#if defined (__WXPM__)
|
|
/* WIN32 graphics types for OS/2 GPI */
|
|
|
|
/* RGB under OS2 is more like a PALETTEENTRY struct under Windows so we need a real RGB def */
|
|
#define OS2RGB(r,g,b) ((DWORD)((unsigned char)(b) | ((unsigned char)(g) << 8)) | ((unsigned char)(r) << 16))
|
|
|
|
typedef unsigned long COLORREF;
|
|
#define GetRValue(rgb) ((unsigned char)((rgb) >> 16))
|
|
#define GetGValue(rgb) ((unsigned char)(((unsigned short)(rgb)) >> 8))
|
|
#define GetBValue(rgb) ((unsigned char)(rgb))
|
|
#define PALETTEINDEX(i) ((COLORREF)(0x01000000 | (DWORD)(WORD)(i)))
|
|
#define PALETTERGB(r,g,b) (0x02000000 | OS2RGB(r,g,b))
|
|
/* OS2's RGB/RGB2 is backwards from this */
|
|
typedef struct tagPALETTEENTRY
|
|
{
|
|
char bRed;
|
|
char bGreen;
|
|
char bBlue;
|
|
char bFlags;
|
|
} PALETTEENTRY;
|
|
typedef struct tagLOGPALETTE
|
|
{
|
|
WORD palVersion;
|
|
WORD palNumentries;
|
|
WORD PALETTEENTRY[1];
|
|
} LOGPALETTE;
|
|
|
|
#if (defined(__VISAGECPP__) && (__IBMCPP__ < 400)) || defined (__WATCOMC__)
|
|
/* VA 3.0 for some reason needs base data types when typedefing a proc proto??? */
|
|
typedef void* (_System *WXFARPROC)(unsigned long, unsigned long, void*, void*);
|
|
#else
|
|
#if defined(__EMX__) && !defined(_System)
|
|
#define _System
|
|
#endif
|
|
typedef WXRESULT (_System *WXFARPROC)(WXHWND, WXMSGID, WXWPARAM, WXLPARAM);
|
|
#endif
|
|
|
|
#endif /* __WXPM__ */
|
|
|
|
|
|
#if defined(__WXMOTIF__) || defined(__WXX11__)
|
|
/* Stand-ins for X/Xt/Motif types */
|
|
typedef void* WXWindow;
|
|
typedef void* WXWidget;
|
|
typedef void* WXAppContext;
|
|
typedef void* WXColormap;
|
|
typedef void* WXColor;
|
|
typedef void WXDisplay;
|
|
typedef void WXEvent;
|
|
typedef void* WXCursor;
|
|
typedef void* WXPixmap;
|
|
typedef void* WXFontStructPtr;
|
|
typedef void* WXGC;
|
|
typedef void* WXRegion;
|
|
typedef void* WXFont;
|
|
typedef void* WXImage;
|
|
typedef void* WXFontList;
|
|
typedef void* WXFontSet;
|
|
typedef void* WXRendition;
|
|
typedef void* WXRenderTable;
|
|
typedef void* WXFontType; /* either a XmFontList or XmRenderTable */
|
|
typedef void* WXString;
|
|
|
|
typedef unsigned long Atom; /* this might fail on a few architectures */
|
|
typedef long WXPixel; /* safety catch in src/motif/colour.cpp */
|
|
|
|
#endif /* Motif */
|
|
|
|
#ifdef __WXGTK__
|
|
|
|
/* Stand-ins for GLIB types */
|
|
typedef struct _GSList GSList;
|
|
|
|
/* Stand-ins for GDK types */
|
|
typedef struct _GdkColor GdkColor;
|
|
typedef struct _GdkCursor GdkCursor;
|
|
typedef struct _GdkDragContext GdkDragContext;
|
|
|
|
#if defined(__WXGTK20__)
|
|
typedef struct _GdkAtom* GdkAtom;
|
|
#else
|
|
typedef unsigned long GdkAtom;
|
|
#endif
|
|
|
|
#if !defined(__WXGTK3__)
|
|
typedef struct _GdkColormap GdkColormap;
|
|
typedef struct _GdkFont GdkFont;
|
|
typedef struct _GdkGC GdkGC;
|
|
typedef struct _GdkRegion GdkRegion;
|
|
#endif
|
|
|
|
#if defined(__WXGTK3__)
|
|
typedef struct _GdkWindow GdkWindow;
|
|
#elif defined(__WXGTK20__)
|
|
typedef struct _GdkDrawable GdkWindow;
|
|
typedef struct _GdkDrawable GdkPixmap;
|
|
#else
|
|
typedef struct _GdkWindow GdkWindow;
|
|
typedef struct _GdkWindow GdkBitmap;
|
|
typedef struct _GdkWindow GdkPixmap;
|
|
#endif
|
|
|
|
/* Stand-ins for GTK types */
|
|
typedef struct _GtkWidget GtkWidget;
|
|
typedef struct _GtkRcStyle GtkRcStyle;
|
|
typedef struct _GtkAdjustment GtkAdjustment;
|
|
typedef struct _GtkToolbar GtkToolbar;
|
|
typedef struct _GtkNotebook GtkNotebook;
|
|
typedef struct _GtkNotebookPage GtkNotebookPage;
|
|
typedef struct _GtkAccelGroup GtkAccelGroup;
|
|
typedef struct _GtkSelectionData GtkSelectionData;
|
|
typedef struct _GtkTextBuffer GtkTextBuffer;
|
|
typedef struct _GtkRange GtkRange;
|
|
typedef struct _GtkCellRenderer GtkCellRenderer;
|
|
|
|
typedef GtkWidget *WXWidget;
|
|
|
|
#ifndef __WXGTK20__
|
|
#define GTK_OBJECT_GET_CLASS(object) (GTK_OBJECT(object)->klass)
|
|
#define GTK_CLASS_TYPE(klass) ((klass)->type)
|
|
#endif
|
|
|
|
#endif /* __WXGTK__ */
|
|
|
|
#if defined(__WXGTK20__) || (defined(__WXX11__) && wxUSE_UNICODE)
|
|
#define wxUSE_PANGO 1
|
|
#else
|
|
#define wxUSE_PANGO 0
|
|
#endif
|
|
|
|
#if wxUSE_PANGO
|
|
/* Stand-ins for Pango types */
|
|
typedef struct _PangoContext PangoContext;
|
|
typedef struct _PangoLayout PangoLayout;
|
|
typedef struct _PangoFontDescription PangoFontDescription;
|
|
#endif
|
|
|
|
#ifdef __WXDFB__
|
|
/* DirectFB doesn't have the concept of non-TLW window, so use
|
|
something arbitrary */
|
|
typedef const void* WXWidget;
|
|
#endif /* DFB */
|
|
|
|
/* This is required because of clashing macros in windows.h, which may be */
|
|
/* included before or after wxWidgets classes, and therefore must be */
|
|
/* disabled here before any significant wxWidgets headers are included. */
|
|
#ifdef __cplusplus
|
|
#ifdef __WINDOWS__
|
|
#include "wx/msw/winundef.h"
|
|
#endif /* __WINDOWS__ */
|
|
#endif /* __cplusplus */
|
|
|
|
|
|
/* include the feature test macros */
|
|
#include "wx/features.h"
|
|
|
|
/* --------------------------------------------------------------------------- */
|
|
/* macros to define a class without copy ctor nor assignment operator */
|
|
/* --------------------------------------------------------------------------- */
|
|
|
|
#define wxDECLARE_NO_COPY_CLASS(classname) \
|
|
private: \
|
|
classname(const classname&); \
|
|
classname& operator=(const classname&)
|
|
|
|
#define wxDECLARE_NO_COPY_TEMPLATE_CLASS(classname, arg) \
|
|
private: \
|
|
classname(const classname<arg>&); \
|
|
classname& operator=(const classname<arg>&)
|
|
|
|
#define wxDECLARE_NO_COPY_TEMPLATE_CLASS_2(classname, arg1, arg2) \
|
|
private: \
|
|
classname(const classname<arg1, arg2>&); \
|
|
classname& operator=(const classname<arg1, arg2>&)
|
|
|
|
#define wxDECLARE_NO_ASSIGN_CLASS(classname) \
|
|
private: \
|
|
classname& operator=(const classname&)
|
|
|
|
/* deprecated variants _not_ requiring a semicolon after them */
|
|
#define DECLARE_NO_COPY_CLASS(classname) \
|
|
wxDECLARE_NO_COPY_CLASS(classname);
|
|
#define DECLARE_NO_COPY_TEMPLATE_CLASS(classname, arg) \
|
|
wxDECLARE_NO_COPY_TEMPLATE_CLASS(classname, arg);
|
|
#define DECLARE_NO_ASSIGN_CLASS(classname) \
|
|
wxDECLARE_NO_ASSIGN_CLASS(classname);
|
|
|
|
/* --------------------------------------------------------------------------- */
|
|
/* If a manifest is being automatically generated, add common controls 6 to it */
|
|
/* --------------------------------------------------------------------------- */
|
|
|
|
#if wxUSE_GUI && \
|
|
(!defined wxUSE_NO_MANIFEST || wxUSE_NO_MANIFEST == 0 ) && \
|
|
( defined _MSC_FULL_VER && _MSC_FULL_VER >= 140040130 )
|
|
|
|
#define WX_CC_MANIFEST(cpu) \
|
|
"/manifestdependency:\"type='win32' \
|
|
name='Microsoft.Windows.Common-Controls' \
|
|
version='6.0.0.0' \
|
|
processorArchitecture='" cpu "' \
|
|
publicKeyToken='6595b64144ccf1df' \
|
|
language='*'\""
|
|
|
|
#if defined _M_IX86
|
|
#pragma comment(linker, WX_CC_MANIFEST("x86"))
|
|
#elif defined _M_X64
|
|
#pragma comment(linker, WX_CC_MANIFEST("amd64"))
|
|
#elif defined _M_IA64
|
|
#pragma comment(linker, WX_CC_MANIFEST("ia64"))
|
|
#else
|
|
#pragma comment(linker, WX_CC_MANIFEST("*"))
|
|
#endif
|
|
|
|
#endif /* !wxUSE_NO_MANIFEST && _MSC_FULL_VER >= 140040130 */
|
|
|
|
/* wxThread and wxProcess priorities */
|
|
enum
|
|
{
|
|
wxPRIORITY_MIN = 0u, /* lowest possible priority */
|
|
wxPRIORITY_DEFAULT = 50u, /* normal priority */
|
|
wxPRIORITY_MAX = 100u /* highest possible priority */
|
|
};
|
|
|
|
#endif
|
|
/* _WX_DEFS_H_ */
|