3 * Purpose: Declarations/definitions common to all wx source files
4 * Author: Julian Smart and others
5 * Modified by: Ryan Norton (Converted to C)
8 * Copyright: (c) Julian Smart
9 * Licence: wxWindows licence
12 /* THIS IS A C FILE, DON'T USE C++ FEATURES (IN PARTICULAR COMMENTS) IN IT */
18 NOTE: this symbol will be replaced with "WXWIN_COMPATIBILITY_3_0" as soon
19 as the development branch for 3.1 is created
21 #define FUTURE_WXWIN_COMPATIBILITY_3_0 1
22 #define wxDEPRECATED_FUTURE( x ) x
24 /* ---------------------------------------------------------------------------- */
25 /* compiler and OS identification */
26 /* ---------------------------------------------------------------------------- */
28 #include "wx/platform.h"
31 /* Make sure the environment is set correctly */
32 # if defined(__WXMSW__) && defined(__X__)
33 # error "Target can't be both X and MSW"
34 # elif !defined(__WXMOTIF__) && \
35 !defined(__WXMSW__) && \
36 !defined(__WXGTK__) && \
37 !defined(__WXPM__) && \
38 !defined(__WXOSX_CARBON__) && \
39 !defined(__WXOSX_COCOA__) && \
40 !defined(__WXOSX_IPHONE__) && \
41 !defined(__WXCOCOA__) && \
43 !defined(__WXDFB__) && \
44 !defined(__WXX11__) && \
47 # error "No Target! You should use wx-config program for compilation flags!"
49 # error "No Target! You should use supplied makefiles for compilation!"
50 # endif /* Unix/!Unix */
52 #endif /*__cplusplus*/
55 #define __WXWINDOWS__ 1
59 /* by default consider that this is a monolithic build */
63 #if !wxUSE_GUI && !defined(__WXBASE__)
67 /* suppress some Visual C++ warnings */
69 /* the only "real" warning here is 4244 but there are just too many of them */
70 /* in our code... one day someone should go and fix them but until then... */
71 # pragma warning(disable:4097) /* typedef used as class */
72 # pragma warning(disable:4201) /* nonstandard extension used: nameless struct/union */
73 # pragma warning(disable:4244) /* conversion from double to float */
74 # pragma warning(disable:4355) /* 'this' used in base member initializer list */
75 # pragma warning(disable:4511) /* copy ctor couldn't be generated */
76 # pragma warning(disable:4512) /* operator=() couldn't be generated */
77 # pragma warning(disable:4514) /* unreferenced inline func has been removed */
78 # pragma warning(disable:4710) /* function not inlined */
81 TODO: this warning should really be enabled as it can be genuinely
82 useful, check where does it occur in wxWidgets
84 #pragma warning(disable: 4127) /* conditional expression is constant */
86 /* There are too many false positivies for this one, particularly when
87 using templates like wxVector<T> */
88 /* class 'foo' needs to have dll-interface to be used by clients of
90 # pragma warning(disable:4251)
93 This is a similar warning which occurs when deriving from standard
94 containers. MSDN even mentions that it can be ignored in this case
95 (albeit only in debug build while the warning is the same in release
96 too and seems equally harmless).
98 #if wxUSE_STD_CONTAINERS
99 # pragma warning(disable:4275)
100 #endif /* wxUSE_STD_CONTAINERS */
103 /* For VC++ 5.0 for release mode, the warning 'C4702: unreachable code */
104 /* is buggy, and occurs for code that does actually get executed */
106 # pragma warning(disable:4702) /* unreachable code */
109 /* The VC++ 5.0 warning 'C4003: not enough actual parameters for macro'
110 * is incompatible with the wxWidgets headers since it is given when
111 * parameters are empty but not missing. */
112 # pragma warning(disable:4003) /* not enough actual parameters for macro */
116 VC6 insists on complaining about
118 return type for 'wxVector<T>::reverse_iterator::operator ->' is 'T **'
119 (ie; not a UDT or reference to a UDT. Will produce errors if applied
120 using infix notation)
122 which is perfectly fine because template classes do routinely define
123 operators which don't make sense for all template parameter values
124 (besides this warning was removed in subsequent versions).
127 #pragma warning(disable: 4284)
131 When compiling with VC++ 7 /Wp64 option we get thousands of warnings for
132 conversion from size_t to int or long. Some precious few of them might
133 be worth looking into but unfortunately it seems infeasible to fix all
134 the other, harmless ones (e.g. inserting static_cast<int>(s.length())
135 everywhere this method is used though we are quite sure that using >4GB
136 strings is a bad idea anyhow) so just disable it globally for now.
138 #if wxCHECK_VISUALC_VERSION(7)
139 /* conversion from 'size_t' to 'unsigned long', possible loss of data */
140 #pragma warning(disable:4267)
141 #endif /* VC++ 7 or later */
144 VC++ 8 gives a warning when using standard functions such as sprintf,
145 localtime, ... -- stop this madness, unless the user had already done it
147 #if wxCHECK_VISUALC_VERSION(8)
148 #ifndef _CRT_SECURE_NO_DEPRECATE
149 #define _CRT_SECURE_NO_DEPRECATE 1
151 #ifndef _CRT_NON_CONFORMING_SWPRINTFS
152 #define _CRT_NON_CONFORMING_SWPRINTFS 1
154 #ifndef _SCL_SECURE_NO_WARNINGS
155 #define _SCL_SECURE_NO_WARNINGS 1
158 #endif /* __VISUALC__ */
160 /* suppress some Borland C++ warnings */
162 # pragma warn -inl /* Functions containing reserved words and certain constructs are not expanded inline */
163 #endif /* __BORLANDC__ */
166 g++ gives a warning when a class has private dtor if it has no friends but
167 this is a perfectly valid situation for a ref-counted class which destroys
168 itself when its ref count drops to 0, so provide a macro to suppress this
172 # define wxSUPPRESS_GCC_PRIVATE_DTOR_WARNING(name) \
173 friend class wxDummyFriendFor ## name;
175 # define wxSUPPRESS_GCC_PRIVATE_DTOR_WARNING(name)
182 #ifndef WX_HAS_CLANG_FEATURE
183 # ifndef __has_feature
184 # define WX_HAS_CLANG_FEATURE(x) 0
186 # define WX_HAS_CLANG_FEATURE(x) __has_feature(x)
190 /* ---------------------------------------------------------------------------- */
191 /* wxWidgets version and compatibility defines */
192 /* ---------------------------------------------------------------------------- */
194 #include "wx/version.h"
196 /* ============================================================================ */
197 /* non portable C++ features */
198 /* ============================================================================ */
200 /* ---------------------------------------------------------------------------- */
201 /* compiler defects workarounds */
202 /* ---------------------------------------------------------------------------- */
205 Digital Unix C++ compiler only defines this symbol for .cxx and .hxx files,
206 so define it ourselves (newer versions do it for all files, though, and
207 don't allow it to be redefined)
209 #if defined(__DECCXX) && !defined(__VMS) && !defined(__cplusplus)
211 #endif /* __DECCXX */
213 /* Resolves linking problems under HP-UX when compiling with gcc/g++ */
214 #if defined(__HPUX__) && defined(__GNUG__)
215 #define va_list __gnuc_va_list
218 /* Prevents conflicts between sys/types.h and winsock.h with Cygwin, */
219 /* when using Windows sockets. */
220 #if defined(__CYGWIN__) && defined(__WXMSW__)
221 #define __USE_W32_SOCKETS
224 /* ---------------------------------------------------------------------------- */
225 /* check for native bool type and TRUE/FALSE constants */
226 /* ---------------------------------------------------------------------------- */
228 /* for backwards compatibility, also define TRUE and FALSE */
230 /* note that these definitions should work both in C++ and C code, so don't */
231 /* use true/false below */
240 typedef short int WXTYPE
;
243 /* ---------------------------------------------------------------------------- */
244 /* other feature tests */
245 /* ---------------------------------------------------------------------------- */
247 /* Every ride down a slippery slope begins with a single step.. */
249 /* Yes, using nested classes is indeed against our coding standards in */
250 /* general, but there are places where you can use them to advantage */
251 /* without totally breaking ports that cannot use them. If you do, then */
252 /* wrap it in this guard, but such cases should still be relatively rare. */
253 #define wxUSE_NESTED_CLASSES 1
255 /* check for explicit keyword support */
256 #ifndef HAVE_EXPLICIT
257 #if defined(__VISUALC__) && (__VISUALC__ >= 1100)
258 /* VC++ 6.0 and 5.0 have explicit (what about earlier versions?) */
259 #define HAVE_EXPLICIT
260 #elif ( defined(__MINGW32__) || defined(__CYGWIN32__) ) \
261 && wxCHECK_GCC_VERSION(2, 95)
262 /* GCC 2.95 has explicit, what about earlier versions? */
263 #define HAVE_EXPLICIT
264 #elif defined(__BORLANDC__) && (__BORLANDC__ >= 0x0520)
265 /* BC++ 4.52 doesn't support explicit, CBuilder 1 does */
266 #define HAVE_EXPLICIT
267 #elif defined(__DIGITALMARS__)
268 #define HAVE_EXPLICIT
269 #elif defined(__WATCOMC__)
270 #define HAVE_EXPLICIT
272 #endif /* !HAVE_EXPLICIT */
275 #define wxEXPLICIT explicit
276 #else /* !HAVE_EXPLICIT */
278 #endif /* HAVE_EXPLICIT/!HAVE_EXPLICIT */
280 /* these macros are obsolete, use the standard C++ casts directly now */
281 #define wx_static_cast(t, x) static_cast<t>(x)
282 #define wx_const_cast(t, x) const_cast<t>(x)
283 #define wx_reinterpret_cast(t, x) reinterpret_cast<t>(x)
286 This one is a wx invention: like static cast but used when we intentionally
287 truncate from a larger to smaller type, static_cast<> can't be used for it
288 as it results in warnings when using some compilers (SGI mipspro for example)
290 #if defined(__INTELC__) && defined(__cplusplus)
291 template <typename T
, typename X
>
292 inline T
wx_truncate_cast_impl(X x
)
294 #pragma warning(push)
295 /* implicit conversion of a 64-bit integral type to a smaller integral type */
296 #pragma warning(disable: 1682)
297 /* conversion from "X" to "T" may lose significant bits */
298 #pragma warning(disable: 810)
299 /* non-pointer conversion from "foo" to "bar" may lose significant bits */
300 #pragma warning(disable: 2259)
307 #define wx_truncate_cast(t, x) wx_truncate_cast_impl<t>(x)
309 #elif defined(__cplusplus) && defined(__VISUALC__) && __VISUALC__ >= 1310
310 template <typename T
, typename X
>
311 inline T
wx_truncate_cast_impl(X x
)
313 #pragma warning(push)
314 /* conversion from 'X' to 'T', possible loss of data */
315 #pragma warning(disable: 4267)
322 #define wx_truncate_cast(t, x) wx_truncate_cast_impl<t>(x)
324 #define wx_truncate_cast(t, x) ((t)(x))
327 /* for consistency with wxStatic/DynamicCast defined in wx/object.h */
328 #define wxConstCast(obj, className) wx_const_cast(className *, obj)
330 #ifndef HAVE_STD_WSTRING
331 #if defined(__VISUALC__) && (__VISUALC__ >= 1100)
332 /* VC++ 6.0 and 5.0 have std::wstring (what about earlier versions?) */
333 #define HAVE_STD_WSTRING
334 #elif defined(__MINGW32__) && wxCHECK_GCC_VERSION(3, 3)
335 /* GCC 3.1 has std::wstring; 3.0 never was in MinGW, 2.95 hasn't it */
336 #define HAVE_STD_WSTRING
340 #ifndef HAVE_STD_STRING_COMPARE
341 #if defined(__VISUALC__) && (__VISUALC__ >= 1100)
342 /* VC++ 6.0 and 5.0 have std::string::compare */
343 /* (what about earlier versions?) */
344 #define HAVE_STD_STRING_COMPARE
345 #elif ( defined(__MINGW32__) || defined(__CYGWIN32__) ) \
346 && wxCHECK_GCC_VERSION(3, 1)
347 /* GCC 3.1 has std::string::compare; */
348 /* 3.0 never was in MinGW, 2.95 hasn't it */
349 #define HAVE_STD_STRING_COMPARE
353 #ifndef HAVE_TYPE_TRAITS
354 #if defined(__has_include) && __has_include(<type_traits>)
355 #define HAVE_TYPE_TRAITS
359 #ifndef HAVE_TR1_TYPE_TRAITS
360 #if defined(__has_include) && __has_include(<tr1/type_traits>)
361 #define HAVE_TR1_TYPE_TRAITS
362 #elif defined(__VISUALC__) && (_MSC_FULL_VER >= 150030729)
363 #define HAVE_TR1_TYPE_TRAITS
367 #ifndef HAVE_STD_UNORDERED_MAP
368 #if defined(__has_include) && __has_include(<unordered_map>)
369 #define HAVE_STD_UNORDERED_MAP
373 #ifndef HAVE_TR1_UNORDERED_MAP
374 #if defined(__has_include) && __has_include(<tr1/unordered_map>)
375 #define HAVE_TR1_UNORDERED_MAP
379 #ifndef HAVE_STD_UNORDERED_SET
380 #if defined(__has_include) && __has_include(<unordered_set>)
381 #define HAVE_STD_UNORDERED_SET
385 #ifndef HAVE_TR1_UNORDERED_SET
386 #if defined(__has_include) && __has_include(<tr1/unordered_set>)
387 #define HAVE_TR1_UNORDERED_SET
391 /* provide replacement for C99 va_copy() if the compiler doesn't have it */
393 /* could be already defined by configure or the user */
395 /* if va_copy is a macro or configure detected that we have it, use it */
396 #if defined(va_copy) || defined(HAVE_VA_COPY)
397 #define wxVaCopy va_copy
398 #else /* no va_copy, try to provide a replacement */
400 configure tries to determine whether va_list is an array or struct
401 type, but it may not be used under Windows, so deal with a few
406 /* Watcom uses array type for va_list except for PPC and Alpha */
407 #if !defined(__PPC__) && !defined(__AXP__)
408 #define VA_LIST_IS_ARRAY
410 #endif /* __WATCOMC__ */
412 #if defined(__PPC__) && (defined(_CALL_SYSV) || defined (_WIN32))
414 PPC using SysV ABI and NT/PPC are special in that they use an
415 extra level of indirection.
417 #define VA_LIST_IS_POINTER
418 #endif /* SysV or Win32 on __PPC__ */
421 note that we use memmove(), not memcpy(), in case anybody tries
422 to do wxVaCopy(ap, ap)
424 #if defined(VA_LIST_IS_POINTER)
425 #define wxVaCopy(d, s) memmove(*(d), *(s), sizeof(va_list))
426 #elif defined(VA_LIST_IS_ARRAY)
427 #define wxVaCopy(d, s) memmove((d), (s), sizeof(va_list))
428 #else /* we can only hope that va_lists are simple lvalues */
429 #define wxVaCopy(d, s) ((d) = (s))
431 #endif /* va_copy/!va_copy */
432 #endif /* wxVaCopy */
434 #ifndef HAVE_VARIADIC_MACROS
435 #if wxCHECK_WATCOM_VERSION(1,2)
436 #define HAVE_VARIADIC_MACROS
439 #if wxCHECK_VISUALC_VERSION(9)
440 #define HAVE_VARIADIC_MACROS
442 #endif /* HAVE_VARIADIC_MACROS */
445 #ifndef HAVE_WOSTREAM
447 Mingw <= 3.4 and all versions of Cygwin don't have std::wostream
449 #if (defined(__MINGW32__) && !wxCHECK_GCC_VERSION(4, 0)) || \
451 #define wxNO_WOSTREAM
454 /* VC++ doesn't have it in the old iostream library */
455 #if defined(__VISUALC__) && wxUSE_IOSTREAMH
456 #define wxNO_WOSTREAM
459 #ifndef wxNO_WOSTREAM
460 #define HAVE_WOSTREAM
464 #endif /* HAVE_WOSTREAM */
466 /* ---------------------------------------------------------------------------- */
467 /* other C++ features */
468 /* ---------------------------------------------------------------------------- */
470 #ifndef HAVE_PARTIAL_SPECIALIZATION
471 /* be optimistic by default */
472 #define HAVE_PARTIAL_SPECIALIZATION
476 #if __VISUALC__ < 1310
477 #undef HAVE_PARTIAL_SPECIALIZATION
479 #endif /* __VISUALC__ */
482 #ifndef HAVE_TEMPLATE_OVERLOAD_RESOLUTION
483 /* assume the compiler can use type or const expressions as template
484 arguments if it supports partial specialization -- except if it's a
485 Borland one which can't */
486 #if defined(HAVE_PARTIAL_SPECIALIZATION) && !defined(__BORLANDC__)
487 #define HAVE_TEMPLATE_OVERLOAD_RESOLUTION
488 #endif /* (HAVE_PARTIAL_SPECIALIZATION) && !defined(__BORLANDC__) */
489 #endif /* !defined(HAVE_TEMPLATE_OVERLOAD_RESOLUTION) */
491 /* ---------------------------------------------------------------------------- */
492 /* portable calling conventions macros */
493 /* ---------------------------------------------------------------------------- */
495 /* stdcall is used for all functions called by Windows under Windows */
496 #if defined(__WINDOWS__)
497 #if defined(__GNUWIN32__)
498 #define wxSTDCALL __attribute__((stdcall))
500 /* both VC++ and Borland understand this */
501 #define wxSTDCALL _stdcall
505 /* no such stupidness under Unix */
507 #endif /* platform */
509 /* LINKAGEMODE mode is empty for everything except OS/2 */
512 #endif /* LINKAGEMODE */
514 /* wxCALLBACK should be used for the functions which are called back by */
515 /* Windows (such as compare function for wxListCtrl) */
516 #if defined(__WIN32__) && !defined(__WXMICROWIN__)
517 #define wxCALLBACK wxSTDCALL
519 /* no stdcall under Unix nor Win16 */
521 #endif /* platform */
523 /* generic calling convention for the extern "C" functions */
525 #if defined(__VISUALC__)
526 #define wxC_CALLING_CONV _cdecl
527 #elif defined(__VISAGECPP__)
528 #define wxC_CALLING_CONV _Optlink
529 #else /* !Visual C++ */
530 #define wxC_CALLING_CONV
531 #endif /* compiler */
533 /* callling convention for the qsort(3) callback */
534 #define wxCMPFUNC_CONV wxC_CALLING_CONV
536 /* compatibility :-( */
537 #define CMPFUNC_CONV wxCMPFUNC_CONV
539 /* DLL import/export declarations */
540 #include "wx/dlimpexp.h"
542 /* ---------------------------------------------------------------------------- */
543 /* Very common macros */
544 /* ---------------------------------------------------------------------------- */
546 /* Printf-like attribute definitions to obtain warnings with GNU C/C++ */
547 #ifndef WX_ATTRIBUTE_PRINTF
548 # if defined(__GNUC__) && !wxUSE_UNICODE
549 # define WX_ATTRIBUTE_PRINTF(m, n) __attribute__ ((__format__ (__printf__, m, n)))
551 # define WX_ATTRIBUTE_PRINTF(m, n)
554 # define WX_ATTRIBUTE_PRINTF_1 WX_ATTRIBUTE_PRINTF(1, 2)
555 # define WX_ATTRIBUTE_PRINTF_2 WX_ATTRIBUTE_PRINTF(2, 3)
556 # define WX_ATTRIBUTE_PRINTF_3 WX_ATTRIBUTE_PRINTF(3, 4)
557 # define WX_ATTRIBUTE_PRINTF_4 WX_ATTRIBUTE_PRINTF(4, 5)
558 # define WX_ATTRIBUTE_PRINTF_5 WX_ATTRIBUTE_PRINTF(5, 6)
559 #endif /* !defined(WX_ATTRIBUTE_PRINTF) */
561 #ifndef WX_ATTRIBUTE_NORETURN
562 # if WX_HAS_CLANG_FEATURE(attribute_analyzer_noreturn)
563 # define WX_ATTRIBUTE_NORETURN __attribute__((analyzer_noreturn))
564 # elif defined( __GNUC__ )
565 # define WX_ATTRIBUTE_NORETURN __attribute__ ((noreturn))
566 # elif wxCHECK_VISUALC_VERSION(7)
567 # define WX_ATTRIBUTE_NORETURN __declspec(noreturn)
569 # define WX_ATTRIBUTE_NORETURN
573 #if defined(__GNUC__)
574 #define WX_ATTRIBUTE_UNUSED __attribute__ ((unused))
576 #define WX_ATTRIBUTE_UNUSED
579 /* Macro to issue warning when using deprecated functions with gcc3 or MSVC7: */
580 #if wxCHECK_GCC_VERSION(3, 1)
581 #define wxDEPRECATED(x) __attribute__((deprecated)) x
582 #elif defined(__VISUALC__) && (__VISUALC__ >= 1300)
583 #define wxDEPRECATED(x) __declspec(deprecated) x
585 #define wxDEPRECATED(x) x
588 #if defined(__GNUC__) && !wxCHECK_GCC_VERSION(3, 4)
590 We need to add dummy "inline" to allow gcc < 3.4 to handle the
591 deprecation attribute on the constructors.
593 #define wxDEPRECATED_CONSTRUCTOR(x) wxDEPRECATED( inline x)
595 #define wxDEPRECATED_CONSTRUCTOR(x) wxDEPRECATED(x)
599 Macro which marks the function as being deprecated but also defines it
602 Currently it's defined in the same trivial way in all cases but it could
603 need a special definition with some other compilers in the future which
604 explains why do we have it.
606 #define wxDEPRECATED_INLINE(func, body) wxDEPRECATED(func) { body }
609 A macro to define a simple deprecated accessor.
611 #define wxDEPRECATED_ACCESSOR(func, what) wxDEPRECATED_INLINE(func, return what;)
614 Special variant of the macro above which should be used for the functions
615 which are deprecated but called by wx itself: this often happens with
616 deprecated virtual functions which are called by the library.
619 # define wxDEPRECATED_BUT_USED_INTERNALLY(x) x
621 # define wxDEPRECATED_BUT_USED_INTERNALLY(x) wxDEPRECATED(x)
625 Macros to suppress and restore gcc warnings, requires g++ >= 4.6 and don't
626 do anything otherwise.
630 wxGCC_WARNING_SUPPRESS(float-equal)
631 inline bool wxIsSameDouble(double x, double y) { return x == y; }
632 wxGCC_WARNING_RESTORE(float-equal)
634 #if wxCHECK_GCC_VERSION(4, 6)
635 # define wxGCC_WARNING_SUPPRESS(x) \
636 _Pragma (wxSTRINGIZE(GCC diagnostic push)) \
637 _Pragma (wxSTRINGIZE(GCC diagnostic ignored wxSTRINGIZE(wxCONCAT(-W,x))))
638 # define wxGCC_WARNING_RESTORE(x) \
639 _Pragma (wxSTRINGIZE(GCC diagnostic pop))
640 #else /* gcc < 4.6 or not gcc at all */
641 # define wxGCC_WARNING_SUPPRESS(x)
642 # define wxGCC_WARNING_RESTORE(x)
646 Combination of the two variants above: should be used for deprecated
647 functions which are defined inline and are used by wxWidgets itself.
650 # define wxDEPRECATED_BUT_USED_INTERNALLY_INLINE(func, body) func { body }
652 # define wxDEPRECATED_BUT_USED_INTERNALLY_INLINE(func, body) \
653 wxDEPRECATED(func) { body }
656 /* NULL declaration: it must be defined as 0 for C++ programs (in particular, */
657 /* it must not be defined as "(void *)0" which is standard for C but completely */
658 /* breaks C++ code) */
659 #if !defined(__HANDHELDPC__)
665 // everybody gets the assert and other debug macros
666 #include "wx/debug.h"
668 // delete pointer if it is not NULL and NULL it afterwards
669 template <typename T
>
670 inline void wxDELETE(T
*& ptr
)
672 typedef char TypeIsCompleteCheck
[sizeof(T
)] WX_ATTRIBUTE_UNUSED
;
681 // delete an array and NULL it (see comments above)
682 template <typename T
>
683 inline void wxDELETEA(T
*& ptr
)
685 typedef char TypeIsCompleteCheck
[sizeof(T
)] WX_ATTRIBUTE_UNUSED
;
694 // trivial implementation of std::swap() for primitive types
695 template <typename T
>
696 inline void wxSwap(T
& first
, T
& second
)
702 #endif /*__cplusplus*/
704 /* size of statically declared array */
705 #define WXSIZEOF(array) (sizeof(array)/sizeof(array[0]))
707 /* symbolic constant used by all Find()-like functions returning positive */
708 /* integer on success as failure indicator */
709 #define wxNOT_FOUND (-1)
711 /* the default value for some length parameters meaning that the string is */
713 #define wxNO_LEN ((size_t)-1)
715 /* ---------------------------------------------------------------------------- */
716 /* macros dealing with comparison operators */
717 /* ---------------------------------------------------------------------------- */
720 Expands into m(op, args...) for each op in the set { ==, !=, <, <=, >, >= }.
722 #define wxFOR_ALL_COMPARISONS(m) \
723 m(==) m(!=) m(>=) m(<=) m(>) m(<)
725 #define wxFOR_ALL_COMPARISONS_1(m, x) \
726 m(==,x) m(!=,x) m(>=,x) m(<=,x) m(>,x) m(<,x)
728 #define wxFOR_ALL_COMPARISONS_2(m, x, y) \
729 m(==,x,y) m(!=,x,y) m(>=,x,y) m(<=,x,y) m(>,x,y) m(<,x,y)
731 #define wxFOR_ALL_COMPARISONS_3(m, x, y, z) \
732 m(==,x,y,z) m(!=,x,y,z) m(>=,x,y,z) m(<=,x,y,z) m(>,x,y,z) m(<,x,y,z)
735 These are only used with wxDEFINE_COMPARISON_[BY_]REV: they pass both the
736 normal and the reversed comparison operators to the macro.
738 #define wxFOR_ALL_COMPARISONS_2_REV(m, x, y) \
739 m(==,x,y,==) m(!=,x,y,!=) m(>=,x,y,<=) \
740 m(<=,x,y,>=) m(>,x,y,<) m(<,x,y,>)
742 #define wxFOR_ALL_COMPARISONS_3_REV(m, x, y, z) \
743 m(==,x,y,z,==) m(!=,x,y,z,!=) m(>=,x,y,z,<=) \
744 m(<=,x,y,z,>=) m(>,x,y,z,<) m(<,x,y,z,>)
747 #define wxDEFINE_COMPARISON(op, T1, T2, cmp) \
748 inline bool operator op(T1 x, T2 y) { return cmp(x, y, op); }
750 #define wxDEFINE_COMPARISON_REV(op, T1, T2, cmp, oprev) \
751 inline bool operator op(T2 y, T1 x) { return cmp(x, y, oprev); }
753 #define wxDEFINE_COMPARISON_BY_REV(op, T1, T2, oprev) \
754 inline bool operator op(T1 x, T2 y) { return y oprev x; }
757 Define all 6 comparison operators (==, !=, <, <=, >, >=) for the given
758 types in the specified order. The implementation is provided by the cmp
759 macro. Normally wxDEFINE_ALL_COMPARISONS should be used as comparison
760 operators are usually symmetric.
762 #define wxDEFINE_COMPARISONS(T1, T2, cmp) \
763 wxFOR_ALL_COMPARISONS_3(wxDEFINE_COMPARISON, T1, T2, cmp)
766 Define all 6 comparison operators (==, !=, <, <=, >, >=) for the given
767 types in the specified order, implemented in terms of existing operators
768 for the reverse order.
770 #define wxDEFINE_COMPARISONS_BY_REV(T1, T2) \
771 wxFOR_ALL_COMPARISONS_2_REV(wxDEFINE_COMPARISON_BY_REV, T1, T2)
774 This macro allows to define all 12 comparison operators (6 operators for
775 both orders of arguments) for the given types using the provided "cmp"
776 macro to implement the actual comparison: the macro is called with the 2
777 arguments names, the first of type T1 and the second of type T2, and the
778 comparison operator being implemented.
780 #define wxDEFINE_ALL_COMPARISONS(T1, T2, cmp) \
781 wxFOR_ALL_COMPARISONS_3(wxDEFINE_COMPARISON, T1, T2, cmp) \
782 wxFOR_ALL_COMPARISONS_3_REV(wxDEFINE_COMPARISON_REV, T1, T2, cmp)
784 /* ---------------------------------------------------------------------------- */
785 /* macros to avoid compiler warnings */
786 /* ---------------------------------------------------------------------------- */
788 /* Macro to cut down on compiler warnings. */
789 #if 1 /* there should be no more any compilers needing the "#else" version */
790 #define WXUNUSED(identifier) /* identifier */
791 #else /* stupid, broken compiler */
792 #define WXUNUSED(identifier) identifier
795 /* some arguments are not used in unicode mode */
797 #define WXUNUSED_IN_UNICODE(param) WXUNUSED(param)
799 #define WXUNUSED_IN_UNICODE(param) param
802 /* some arguments are not used in WinCE build */
804 #define WXUNUSED_IN_WINCE(param) WXUNUSED(param)
806 #define WXUNUSED_IN_WINCE(param) param
809 /* unused parameters in non stream builds */
811 #define WXUNUSED_UNLESS_STREAMS(param) param
813 #define WXUNUSED_UNLESS_STREAMS(param) WXUNUSED(param)
816 /* some compilers give warning about a possibly unused variable if it is */
817 /* initialized in both branches of if/else and shut up if it is initialized */
818 /* when declared, but other compilers then give warnings about unused variable */
819 /* value -- this should satisfy both of them */
820 #if defined(__VISUALC__)
821 #define wxDUMMY_INITIALIZE(val) = val
823 #define wxDUMMY_INITIALIZE(val)
826 /* sometimes the value of a variable is *really* not used, to suppress the */
827 /* resulting warning you may pass it to this function */
830 # define wxUnusedVar(identifier) identifier
833 inline void wxUnusedVar(const T
& WXUNUSED(t
)) { }
837 /* ---------------------------------------------------------------------------- */
838 /* compiler specific settings */
839 /* ---------------------------------------------------------------------------- */
841 #if wxONLY_WATCOM_EARLIER_THAN(1,4)
842 typedef short mode_t
;
845 /* where should i put this? we need to make sure of this as it breaks */
846 /* the <iostream> code. */
847 #if !wxUSE_IOSTREAMH && defined(__WXDEBUG__)
848 # ifdef wxUSE_DEBUG_NEW_ALWAYS
849 # undef wxUSE_DEBUG_NEW_ALWAYS
850 # define wxUSE_DEBUG_NEW_ALWAYS 0
854 /* ---------------------------------------------------------------------------- */
855 /* standard wxWidgets types */
856 /* ---------------------------------------------------------------------------- */
858 /* the type for screen and DC coordinates */
861 enum { wxDefaultCoord
= -1 };
863 /* ---------------------------------------------------------------------------- */
864 /* define fixed length types */
865 /* ---------------------------------------------------------------------------- */
867 #if defined(__MINGW32__)
868 #include <sys/types.h>
871 /* chars are always one byte (by definition), shorts are always two (in */
875 typedef signed char wxInt8
;
876 typedef unsigned char wxUint8
;
877 typedef wxUint8 wxByte
;
882 #if SIZEOF_SHORT != 2
883 #error "wxWidgets assumes sizeof(short) == 2, please fix the code"
886 #define SIZEOF_SHORT 2
889 typedef signed short wxInt16
;
890 typedef unsigned short wxUint16
;
892 typedef wxUint16 wxWord
;
895 things are getting more interesting with ints, longs and pointers
897 there are several different standard data models described by this table:
899 +-----------+----------------------------+
900 |type\model | LP64 ILP64 LLP64 ILP32 LP32|
901 +-----------+----------------------------+
903 |short | 16 16 16 16 16 |
904 |int | 32 64 32 32 16 |
905 |long | 64 64 32 32 32 |
906 |long long | 64 64 64 -- -- |
907 |void * | 64 64 64 32 32 |
908 +-----------+----------------------------+
910 Win16 used LP32 (but we don't support it any longer), Win32 obviously used
911 ILP32 and Win64 uses LLP64 (a.k.a. P64)
913 Under Unix LP64 is the most widely used (the only I've ever seen, in fact)
917 #if defined(__WINDOWS__)
918 #if defined(__WIN32__)
920 typedef unsigned int wxUint32
;
923 Win64 uses LLP64 model and so ints and longs have the same size as
931 #define SIZEOF_LONG 4
934 #ifndef SIZEOF_WCHAR_T
935 /* Windows uses UTF-16 */
936 #define SIZEOF_WCHAR_T 2
939 #ifndef SIZEOF_SIZE_T
941 Under Win64 sizeof(size_t) == 8 and so it is neither unsigned
942 int nor unsigned long!
945 #define SIZEOF_SIZE_T 8
947 #undef wxSIZE_T_IS_UINT
949 #define SIZEOF_SIZE_T 4
951 #define wxSIZE_T_IS_UINT
953 #undef wxSIZE_T_IS_ULONG
956 #ifndef SIZEOF_VOID_P
958 #define SIZEOF_VOID_P 8
960 #define SIZEOF_VOID_P 4
961 #endif /* Win64/32 */
964 #error "Unsupported Windows version"
967 /* SIZEOF_XXX are normally defined by configure */
970 /* must be ILP64 data model, there is normally a special 32 bit */
971 /* type in it but we don't know what it is... */
972 #error "No 32bit int type on this platform"
973 #elif SIZEOF_INT == 4
975 typedef unsigned int wxUint32
;
976 #elif SIZEOF_INT == 2
979 #error "No 32bit int type on this platform"
982 typedef long wxInt32
;
983 typedef unsigned long wxUint32
;
985 /* wxWidgets is not ready for 128bit systems yet... */
986 #error "Unknown sizeof(int) value, what are you compiling for?"
988 #else /* !defined(SIZEOF_INT) */
989 /* assume default 32bit machine -- what else can we do? */
990 wxCOMPILE_TIME_ASSERT( sizeof(int) == 4, IntMustBeExactly4Bytes
);
991 wxCOMPILE_TIME_ASSERT( sizeof(size_t) == 4, SizeTMustBeExactly4Bytes
);
992 wxCOMPILE_TIME_ASSERT( sizeof(void *) == 4, PtrMustBeExactly4Bytes
);
995 #define SIZEOF_SIZE_T 4
996 #define SIZEOF_VOID_P 4
999 typedef unsigned int wxUint32
;
1001 #if defined(__MACH__) && !defined(SIZEOF_WCHAR_T)
1002 #define SIZEOF_WCHAR_T 4
1004 #if !defined(SIZEOF_WCHAR_T)
1005 /* also assume that sizeof(wchar_t) == 2 (under Unix the most */
1006 /* common case is 4 but there configure would have defined */
1007 /* SIZEOF_WCHAR_T for us) */
1008 /* the most common case */
1009 wxCOMPILE_TIME_ASSERT( sizeof(wchar_t) == 2,
1010 Wchar_tMustBeExactly2Bytes
);
1012 #define SIZEOF_WCHAR_T 2
1013 #endif /* !defined(SIZEOF_WCHAR_T) */
1015 #endif /* Win/!Win */
1017 #ifndef SIZEOF_WCHAR_T
1018 #error "SIZEOF_WCHAR_T must be defined, but isn't"
1021 /* also define C99-like sized MIN/MAX constants */
1022 #define wxINT8_MIN CHAR_MIN
1023 #define wxINT8_MAX CHAR_MAX
1024 #define wxUINT8_MAX UCHAR_MAX
1026 #define wxINT16_MIN SHRT_MIN
1027 #define wxINT16_MAX SHRT_MAX
1028 #define wxUINT16_MAX USHRT_MAX
1031 #define wxINT32_MIN INT_MIN
1032 #define wxINT32_MAX INT_MAX
1033 #define wxUINT32_MAX UINT_MAX
1034 #elif SIZEOF_LONG == 4
1035 #define wxINT32_MIN LONG_MIN
1036 #define wxINT32_MAX LONG_MAX
1037 #define wxUINT32_MAX ULONG_MAX
1039 #error "Unknown 32 bit type"
1042 typedef wxUint32 wxDword
;
1045 #define wxINT64_MIN LLONG_MIN
1046 #define wxINT64_MAX LLONG_MAX
1047 #define wxUINT64_MAX ULLONG_MAX
1049 #define wxINT64_MIN (wxLL(-9223372036854775807)-1)
1050 #define wxINT64_MAX wxLL(9223372036854775807)
1051 #define wxUINT64_MAX wxULL(0xFFFFFFFFFFFFFFFF)
1056 /* NB: we #define and not typedef wxLongLong_t because we use "#ifdef */
1057 /* wxLongLong_t" in wx/longlong.h */
1059 /* wxULongLong_t is set later (usually to unsigned wxLongLong_t) */
1061 /* to avoid compilation problems on 64bit machines with ambiguous method calls */
1062 /* we will need to define this */
1063 #undef wxLongLongIsLong
1066 First check for specific compilers which have known 64 bit integer types,
1067 this avoids clashes with SIZEOF_LONG[_LONG] being defined incorrectly for
1068 e.g. MSVC builds (Python.h defines it as 8 even for MSVC).
1070 Also notice that we check for "long long" before checking for 64 bit long as
1071 we still want to use "long long" and not "long" for wxLongLong_t on 64 bit
1072 architectures to be able to pass wxLongLong_t to the standard functions
1073 prototyped as taking "long long" such as strtoll().
1075 #if (defined(__VISUALC__) && defined(__WIN32__))
1076 #define wxLongLong_t __int64
1077 #define wxLongLongSuffix i64
1078 #define wxLongLongFmtSpec "I64"
1079 #elif defined(__BORLANDC__) && defined(__WIN32__) && (__BORLANDC__ >= 0x520)
1080 #define wxLongLong_t __int64
1081 #define wxLongLongSuffix i64
1082 #define wxLongLongFmtSpec "L"
1083 #elif (defined(__WATCOMC__) && (defined(__WIN32__) || defined(__DOS__) || defined(__OS2__)))
1084 #define wxLongLong_t __int64
1085 #define wxLongLongSuffix i64
1086 #define wxLongLongFmtSpec "L"
1087 #elif defined(__DIGITALMARS__)
1088 #define wxLongLong_t __int64
1089 #define wxLongLongSuffix LL
1090 #define wxLongLongFmtSpec "ll"
1091 #elif defined(__MINGW32__)
1092 #define wxLongLong_t long long
1093 #define wxLongLongSuffix ll
1094 #define wxLongLongFmtSpec "I64"
1095 #elif defined(__VISAGECPP__) && __IBMCPP__ >= 400
1096 #define wxLongLong_t long long
1097 #elif (defined(SIZEOF_LONG_LONG) && SIZEOF_LONG_LONG >= 8) || \
1098 defined(__GNUC__) || \
1099 defined(__CYGWIN__) || \
1100 defined(__WXMICROWIN__) || \
1101 (defined(__DJGPP__) && __DJGPP__ >= 2)
1102 #define wxLongLong_t long long
1103 #define wxLongLongSuffix ll
1104 #define wxLongLongFmtSpec "ll"
1105 #elif defined(SIZEOF_LONG) && (SIZEOF_LONG == 8)
1106 #define wxLongLong_t long
1107 #define wxLongLongSuffix l
1108 #define wxLongLongFmtSpec "l"
1109 #define wxLongLongIsLong
1114 #define wxULongLong_t unsigned wxLongLong_t
1117 wxLL() and wxULL() macros allow to define 64 bit constants in a
1120 #ifndef wxCOMPILER_BROKEN_CONCAT_OPER
1121 #define wxLL(x) wxCONCAT(x, wxLongLongSuffix)
1122 #define wxULL(x) wxCONCAT(x, wxCONCAT(u, wxLongLongSuffix))
1125 Currently only Borland compiler has broken concatenation operator
1126 and this compiler is known to use [u]i64 suffix.
1128 #define wxLL(x) wxAPPEND_i64(x)
1129 #define wxULL(x) wxAPPEND_ui64(x)
1132 typedef wxLongLong_t wxInt64
;
1133 typedef wxULongLong_t wxUint64
;
1135 #define wxHAS_INT64 1
1137 #ifndef wxLongLongIsLong
1138 #define wxHAS_LONG_LONG_T_DIFFERENT_FROM_LONG
1140 #elif wxUSE_LONGLONG
1141 /* these macros allow to define 64 bit constants in a portable way */
1142 #define wxLL(x) wxLongLong(x)
1143 #define wxULL(x) wxULongLong(x)
1145 #define wxInt64 wxLongLong
1146 #define wxUint64 wxULongLong
1148 #define wxHAS_INT64 1
1150 #else /* !wxUSE_LONGLONG */
1152 #define wxHAS_INT64 0
1157 Helper macro for conditionally compiling some code only if wxLongLong_t is
1158 available and is a type different from the other integer types (i.e. not
1161 #ifdef wxHAS_LONG_LONG_T_DIFFERENT_FROM_LONG
1162 #define wxIF_LONG_LONG_TYPE(x) x
1164 #define wxIF_LONG_LONG_TYPE(x)
1168 /* Make sure ssize_t is defined (a signed type the same size as size_t). */
1169 /* (HAVE_SSIZE_T is not already defined by configure) */
1170 #ifndef HAVE_SSIZE_T
1172 #if defined(_SSIZE_T_) || defined(_SSIZE_T_DEFINED)
1173 #define HAVE_SSIZE_T
1175 #elif wxCHECK_WATCOM_VERSION(1,4)
1176 #define HAVE_SSIZE_T
1178 #endif /* !HAVE_SSIZE_T */
1180 /* If we really don't have ssize_t, provide our own version. */
1183 #include <sys/types.h>
1185 #else /* !HAVE_SSIZE_T */
1186 #if SIZEOF_SIZE_T == 4
1187 typedef wxInt32 ssize_t
;
1188 #elif SIZEOF_SIZE_T == 8
1189 typedef wxInt64 ssize_t
;
1191 #error "error defining ssize_t, size_t is not 4 or 8 bytes"
1194 /* prevent ssize_t redefinitions in other libraries */
1195 #define HAVE_SSIZE_T
1199 We can't rely on Windows _W64 being defined as windows.h may not be
1200 included so define our own equivalent: this should be used with types
1201 like WXLPARAM or WXWPARAM which are 64 bit under Win64 to avoid warnings
1202 each time we cast it to a pointer or a handle (which results in hundreds
1203 of warnings as Win32 API often passes pointers in them)
1205 #if wxCHECK_VISUALC_VERSION(7)
1212 Define signed and unsigned integral types big enough to contain all of long,
1215 #if SIZEOF_LONG >= SIZEOF_VOID_P
1217 Normal case when long is the largest integral type.
1219 typedef long wxIntPtr
;
1220 typedef unsigned long wxUIntPtr
;
1221 #elif SIZEOF_SIZE_T >= SIZEOF_VOID_P
1223 Win64 case: size_t is the only integral type big enough for "void *".
1225 Notice that we must use __w64 to avoid warnings about casting pointers
1226 to wxIntPtr (which we do often as this is what it is defined for) in 32
1227 bit build with MSVC.
1229 typedef wxW64 ssize_t wxIntPtr
;
1230 typedef size_t wxUIntPtr
;
1233 This should never happen for the current architectures but if you're
1234 using one where it does, please contact wx-dev@lists.wxwidgets.org.
1236 #error "Pointers can't be stored inside integer types."
1240 /* And also define a couple of simple functions to cast pointer to/from it. */
1241 inline wxUIntPtr
wxPtrToUInt(const void *p
)
1244 VC++ 7.1 gives warnings about casts such as below even when they're
1245 explicit with /Wp64 option, suppress them as we really know what we're
1246 doing here. Same thing with icc with -Wall.
1249 #if __VISUALC__ >= 1200
1250 #pragma warning(push)
1252 /* pointer truncation from '' to '' */
1253 #pragma warning(disable: 4311)
1254 #elif defined(__INTELC__)
1255 #pragma warning(push)
1256 /* conversion from pointer to same-sized integral type */
1257 #pragma warning(disable: 1684)
1260 return wx_reinterpret_cast(wxUIntPtr
, p
);
1262 #if (defined(__VISUALC__) && __VISUALC__ >= 1200) || defined(__INTELC__)
1263 #pragma warning(pop)
1267 inline void *wxUIntToPtr(wxUIntPtr p
)
1270 #if __VISUALC__ >= 1200
1271 #pragma warning(push)
1273 /* conversion to type of greater size */
1274 #pragma warning(disable: 4312)
1275 #elif defined(__INTELC__)
1276 #pragma warning(push)
1277 /* invalid type conversion: "wxUIntPtr={unsigned long}" to "void *" */
1278 #pragma warning(disable: 171)
1281 return wx_reinterpret_cast(void *, p
);
1283 #if (defined(__VISUALC__) && __VISUALC__ >= 1200) || defined(__INTELC__)
1284 #pragma warning(pop)
1287 #endif /*__cplusplus*/
1291 /* base floating point types */
1292 /* wxFloat32: 32 bit IEEE float ( 1 sign, 8 exponent bits, 23 fraction bits ) */
1293 /* wxFloat64: 64 bit IEEE float ( 1 sign, 11 exponent bits, 52 fraction bits ) */
1294 /* wxDouble: native fastest representation that has at least wxFloat64 */
1295 /* precision, so use the IEEE types for storage, and this for */
1298 typedef float wxFloat32
;
1299 typedef double wxFloat64
;
1301 typedef double wxDouble
;
1304 Some (non standard) compilers typedef wchar_t as an existing type instead
1305 of treating it as a real fundamental type, set wxWCHAR_T_IS_REAL_TYPE to 0
1306 for them and to 1 for all the others.
1308 #ifndef wxWCHAR_T_IS_REAL_TYPE
1310 VC++ typedefs wchar_t as unsigned short by default until VC8, that is
1311 unless /Za or /Zc:wchar_t option is used in which case _WCHAR_T_DEFINED
1314 # if defined(__VISUALC__) && !defined(_NATIVE_WCHAR_T_DEFINED)
1315 # define wxWCHAR_T_IS_REAL_TYPE 0
1316 # else /* compiler having standard-conforming wchar_t */
1317 # define wxWCHAR_T_IS_REAL_TYPE 1
1319 #endif /* !defined(wxWCHAR_T_IS_REAL_TYPE) */
1321 /* Helper macro for doing something dependent on whether wchar_t is or isn't a
1322 typedef inside another macro. */
1323 #if wxWCHAR_T_IS_REAL_TYPE
1324 #define wxIF_WCHAR_T_TYPE(x) x
1325 #else /* !wxWCHAR_T_IS_REAL_TYPE */
1326 #define wxIF_WCHAR_T_TYPE(x)
1327 #endif /* wxWCHAR_T_IS_REAL_TYPE/!wxWCHAR_T_IS_REAL_TYPE */
1330 This constant should be used instead of NULL in vararg functions taking
1331 wxChar* arguments: passing NULL (which is the same as 0, unless the compiler
1332 defines it specially, e.g. like gcc does with its __null built-in) doesn't
1333 work in this case as va_arg() wouldn't interpret the integer 0 correctly
1334 when trying to convert it to a pointer on architectures where sizeof(int) is
1335 strictly less than sizeof(void *).
1337 Examples of places where this must be used include wxFileTypeInfo ctor.
1339 #define wxNullPtr ((void *)NULL)
1342 /* Define wxChar16 and wxChar32 */
1344 #if SIZEOF_WCHAR_T == 2
1345 #define wxWCHAR_T_IS_WXCHAR16
1346 typedef wchar_t wxChar16
;
1348 typedef wxUint16 wxChar16
;
1351 #if SIZEOF_WCHAR_T == 4
1352 #define wxWCHAR_T_IS_WXCHAR32
1353 typedef wchar_t wxChar32
;
1355 typedef wxUint32 wxChar32
;
1360 Helper macro expanding into the given "m" macro invoked with each of the
1361 integer types as parameter (notice that this does not include char/unsigned
1362 char and bool but does include wchar_t).
1364 #define wxDO_FOR_INT_TYPES(m) \
1371 wxIF_LONG_LONG_TYPE( m(wxLongLong_t) ) \
1372 wxIF_LONG_LONG_TYPE( m(wxULongLong_t) ) \
1373 wxIF_WCHAR_T_TYPE( m(wchar_t) )
1376 Same as wxDO_FOR_INT_TYPES() but does include char and unsigned char.
1378 Notice that we use "char" and "unsigned char" here but not "signed char"
1379 which would be more correct as "char" could be unsigned by default. But
1380 wxWidgets code currently supposes that char is signed and we'd need to
1381 clean up assumptions about it, notably in wx/unichar.h, to be able to use
1384 #define wxDO_FOR_CHAR_INT_TYPES(m) \
1387 wxDO_FOR_INT_TYPES(m)
1390 Same as wxDO_FOR_INT_TYPES() above except that m macro takes the
1391 type as the first argument and some extra argument, passed from this macro
1392 itself, as the second one.
1394 #define wxDO_FOR_INT_TYPES_1(m, arg) \
1396 m(unsigned short, arg) \
1398 m(unsigned int, arg) \
1400 m(unsigned long, arg) \
1401 wxIF_LONG_LONG_TYPE( m(wxLongLong_t, arg) ) \
1402 wxIF_LONG_LONG_TYPE( m(wxULongLong_t, arg) ) \
1403 wxIF_WCHAR_T_TYPE( m(wchar_t, arg) )
1406 Combination of wxDO_FOR_CHAR_INT_TYPES() and wxDO_FOR_INT_TYPES_1():
1407 invokes the given macro with the specified argument as its second parameter
1408 for all char and int types.
1410 #define wxDO_FOR_CHAR_INT_TYPES_1(m, arg) \
1412 m(unsigned char, arg) \
1413 wxDO_FOR_INT_TYPES_1(m, arg)
1416 /* ---------------------------------------------------------------------------- */
1417 /* byte ordering related definition and macros */
1418 /* ---------------------------------------------------------------------------- */
1422 #define wxBIG_ENDIAN 4321
1423 #define wxLITTLE_ENDIAN 1234
1424 #define wxPDP_ENDIAN 3412
1426 #ifdef WORDS_BIGENDIAN
1427 #define wxBYTE_ORDER wxBIG_ENDIAN
1429 #define wxBYTE_ORDER wxLITTLE_ENDIAN
1434 #define wxUINT16_SWAP_ALWAYS(val) \
1436 (((wxUint16) (val) & (wxUint16) 0x00ffU) << 8) | \
1437 (((wxUint16) (val) & (wxUint16) 0xff00U) >> 8)))
1439 #define wxINT16_SWAP_ALWAYS(val) \
1441 (((wxUint16) (val) & (wxUint16) 0x00ffU) << 8) | \
1442 (((wxUint16) (val) & (wxUint16) 0xff00U) >> 8)))
1444 #define wxUINT32_SWAP_ALWAYS(val) \
1446 (((wxUint32) (val) & (wxUint32) 0x000000ffU) << 24) | \
1447 (((wxUint32) (val) & (wxUint32) 0x0000ff00U) << 8) | \
1448 (((wxUint32) (val) & (wxUint32) 0x00ff0000U) >> 8) | \
1449 (((wxUint32) (val) & (wxUint32) 0xff000000U) >> 24)))
1451 #define wxINT32_SWAP_ALWAYS(val) \
1453 (((wxUint32) (val) & (wxUint32) 0x000000ffU) << 24) | \
1454 (((wxUint32) (val) & (wxUint32) 0x0000ff00U) << 8) | \
1455 (((wxUint32) (val) & (wxUint32) 0x00ff0000U) >> 8) | \
1456 (((wxUint32) (val) & (wxUint32) 0xff000000U) >> 24)))
1457 /* machine specific byte swapping */
1460 #define wxUINT64_SWAP_ALWAYS(val) \
1462 (((wxUint64) (val) & (wxUint64) wxULL(0x00000000000000ff)) << 56) | \
1463 (((wxUint64) (val) & (wxUint64) wxULL(0x000000000000ff00)) << 40) | \
1464 (((wxUint64) (val) & (wxUint64) wxULL(0x0000000000ff0000)) << 24) | \
1465 (((wxUint64) (val) & (wxUint64) wxULL(0x00000000ff000000)) << 8) | \
1466 (((wxUint64) (val) & (wxUint64) wxULL(0x000000ff00000000)) >> 8) | \
1467 (((wxUint64) (val) & (wxUint64) wxULL(0x0000ff0000000000)) >> 24) | \
1468 (((wxUint64) (val) & (wxUint64) wxULL(0x00ff000000000000)) >> 40) | \
1469 (((wxUint64) (val) & (wxUint64) wxULL(0xff00000000000000)) >> 56)))
1471 #define wxINT64_SWAP_ALWAYS(val) \
1473 (((wxUint64) (val) & (wxUint64) wxULL(0x00000000000000ff)) << 56) | \
1474 (((wxUint64) (val) & (wxUint64) wxULL(0x000000000000ff00)) << 40) | \
1475 (((wxUint64) (val) & (wxUint64) wxULL(0x0000000000ff0000)) << 24) | \
1476 (((wxUint64) (val) & (wxUint64) wxULL(0x00000000ff000000)) << 8) | \
1477 (((wxUint64) (val) & (wxUint64) wxULL(0x000000ff00000000)) >> 8) | \
1478 (((wxUint64) (val) & (wxUint64) wxULL(0x0000ff0000000000)) >> 24) | \
1479 (((wxUint64) (val) & (wxUint64) wxULL(0x00ff000000000000)) >> 40) | \
1480 (((wxUint64) (val) & (wxUint64) wxULL(0xff00000000000000)) >> 56)))
1481 #elif wxUSE_LONGLONG /* !wxLongLong_t */
1482 #define wxUINT64_SWAP_ALWAYS(val) \
1484 ((wxULongLong(val) & wxULongLong(0L, 0x000000ffU)) << 56) | \
1485 ((wxULongLong(val) & wxULongLong(0L, 0x0000ff00U)) << 40) | \
1486 ((wxULongLong(val) & wxULongLong(0L, 0x00ff0000U)) << 24) | \
1487 ((wxULongLong(val) & wxULongLong(0L, 0xff000000U)) << 8) | \
1488 ((wxULongLong(val) & wxULongLong(0x000000ffL, 0U)) >> 8) | \
1489 ((wxULongLong(val) & wxULongLong(0x0000ff00L, 0U)) >> 24) | \
1490 ((wxULongLong(val) & wxULongLong(0x00ff0000L, 0U)) >> 40) | \
1491 ((wxULongLong(val) & wxULongLong(0xff000000L, 0U)) >> 56)))
1493 #define wxINT64_SWAP_ALWAYS(val) \
1495 ((wxLongLong(val) & wxLongLong(0L, 0x000000ffU)) << 56) | \
1496 ((wxLongLong(val) & wxLongLong(0L, 0x0000ff00U)) << 40) | \
1497 ((wxLongLong(val) & wxLongLong(0L, 0x00ff0000U)) << 24) | \
1498 ((wxLongLong(val) & wxLongLong(0L, 0xff000000U)) << 8) | \
1499 ((wxLongLong(val) & wxLongLong(0x000000ffL, 0U)) >> 8) | \
1500 ((wxLongLong(val) & wxLongLong(0x0000ff00L, 0U)) >> 24) | \
1501 ((wxLongLong(val) & wxLongLong(0x00ff0000L, 0U)) >> 40) | \
1502 ((wxLongLong(val) & wxLongLong(0xff000000L, 0U)) >> 56)))
1503 #endif /* wxLongLong_t/!wxLongLong_t */
1505 #ifdef WORDS_BIGENDIAN
1506 #define wxUINT16_SWAP_ON_BE(val) wxUINT16_SWAP_ALWAYS(val)
1507 #define wxINT16_SWAP_ON_BE(val) wxINT16_SWAP_ALWAYS(val)
1508 #define wxUINT16_SWAP_ON_LE(val) (val)
1509 #define wxINT16_SWAP_ON_LE(val) (val)
1510 #define wxUINT32_SWAP_ON_BE(val) wxUINT32_SWAP_ALWAYS(val)
1511 #define wxINT32_SWAP_ON_BE(val) wxINT32_SWAP_ALWAYS(val)
1512 #define wxUINT32_SWAP_ON_LE(val) (val)
1513 #define wxINT32_SWAP_ON_LE(val) (val)
1515 #define wxUINT64_SWAP_ON_BE(val) wxUINT64_SWAP_ALWAYS(val)
1516 #define wxUINT64_SWAP_ON_LE(val) (val)
1517 #define wxINT64_SWAP_ON_BE(val) wxINT64_SWAP_ALWAYS(val)
1518 #define wxINT64_SWAP_ON_LE(val) (val)
1521 #define wxUINT16_SWAP_ON_LE(val) wxUINT16_SWAP_ALWAYS(val)
1522 #define wxINT16_SWAP_ON_LE(val) wxINT16_SWAP_ALWAYS(val)
1523 #define wxUINT16_SWAP_ON_BE(val) (val)
1524 #define wxINT16_SWAP_ON_BE(val) (val)
1525 #define wxUINT32_SWAP_ON_LE(val) wxUINT32_SWAP_ALWAYS(val)
1526 #define wxINT32_SWAP_ON_LE(val) wxINT32_SWAP_ALWAYS(val)
1527 #define wxUINT32_SWAP_ON_BE(val) (val)
1528 #define wxINT32_SWAP_ON_BE(val) (val)
1530 #define wxUINT64_SWAP_ON_LE(val) wxUINT64_SWAP_ALWAYS(val)
1531 #define wxUINT64_SWAP_ON_BE(val) (val)
1532 #define wxINT64_SWAP_ON_LE(val) wxINT64_SWAP_ALWAYS(val)
1533 #define wxINT64_SWAP_ON_BE(val) (val)
1537 /* ---------------------------------------------------------------------------- */
1538 /* template workarounds for buggy compilers */
1539 /* ---------------------------------------------------------------------------- */
1541 #if defined(__GNUC__) && !wxCHECK_GCC_VERSION( 3, 4 )
1542 /* GCC <= 3.4 has buggy template support */
1543 # define wxUSE_MEMBER_TEMPLATES 0
1546 #if defined(_MSC_VER) && _MSC_VER <= 1200
1547 /* MSVC <= 6.0 has buggy template support */
1548 # define wxUSE_MEMBER_TEMPLATES 0
1549 # define wxUSE_FUNC_TEMPLATE_POINTER 0
1552 #ifndef wxUSE_MEMBER_TEMPLATES
1553 # define wxUSE_MEMBER_TEMPLATES 1
1556 #ifndef wxUSE_FUNC_TEMPLATE_POINTER
1557 # define wxUSE_FUNC_TEMPLATE_POINTER 1
1560 #if wxUSE_MEMBER_TEMPLATES
1561 # define wxTEMPLATED_MEMBER_CALL( method, type ) method<type>()
1562 # define wxTEMPLATED_MEMBER_FIX( type )
1564 # define wxTEMPLATED_MEMBER_CALL( method, type ) method((type*)NULL)
1565 # define wxTEMPLATED_MEMBER_FIX( type ) type* =NULL
1568 #if defined(_MSC_VER) && _MSC_VER <= 1200
1569 # define wxTEMPLATED_FUNCTION_FIX( type ), wxTEMPLATED_MEMBER_FIX(type)
1570 # define wxINFUNC_CLASS_TYPE_FIX( type ) typedef type type;
1572 # define wxTEMPLATED_FUNCTION_FIX( type )
1573 # define wxINFUNC_CLASS_TYPE_FIX( type )
1576 /* ---------------------------------------------------------------------------- */
1577 /* Geometric flags */
1578 /* ---------------------------------------------------------------------------- */
1580 enum wxGeometryCentre
1586 /* centering into frame rather than screen (obsolete) */
1587 #define wxCENTER_FRAME 0x0000
1588 /* centre on screen rather than parent */
1589 #define wxCENTRE_ON_SCREEN 0x0002
1590 #define wxCENTER_ON_SCREEN wxCENTRE_ON_SCREEN
1594 /* don't change the values of these elements, they are used elsewhere */
1595 wxHORIZONTAL
= 0x0004,
1596 wxVERTICAL
= 0x0008,
1598 wxBOTH
= wxVERTICAL
| wxHORIZONTAL
,
1600 /* a mask to extract orientation from the combination of flags */
1601 wxORIENTATION_MASK
= wxBOTH
1619 wxALL
= (wxUP
| wxDOWN
| wxRIGHT
| wxLEFT
),
1621 /* a mask to extract direction from the combination of flags */
1622 wxDIRECTION_MASK
= wxALL
1628 0 is a valid wxAlignment value (both wxALIGN_LEFT and wxALIGN_TOP
1629 use it) so define a symbolic name for an invalid alignment value
1630 which can be assumed to be different from anything else
1632 wxALIGN_INVALID
= -1,
1634 wxALIGN_NOT
= 0x0000,
1635 wxALIGN_CENTER_HORIZONTAL
= 0x0100,
1636 wxALIGN_CENTRE_HORIZONTAL
= wxALIGN_CENTER_HORIZONTAL
,
1637 wxALIGN_LEFT
= wxALIGN_NOT
,
1638 wxALIGN_TOP
= wxALIGN_NOT
,
1639 wxALIGN_RIGHT
= 0x0200,
1640 wxALIGN_BOTTOM
= 0x0400,
1641 wxALIGN_CENTER_VERTICAL
= 0x0800,
1642 wxALIGN_CENTRE_VERTICAL
= wxALIGN_CENTER_VERTICAL
,
1644 wxALIGN_CENTER
= (wxALIGN_CENTER_HORIZONTAL
| wxALIGN_CENTER_VERTICAL
),
1645 wxALIGN_CENTRE
= wxALIGN_CENTER
,
1647 /* a mask to extract alignment from the combination of flags */
1648 wxALIGN_MASK
= 0x0f00
1651 /* misc. flags for wxSizer items */
1652 enum wxSizerFlagBits
1655 wxADJUST_MINSIZE doesn't do anything any more but we still define
1656 it for compatibility. Notice that it may be also predefined (as 0,
1657 hopefully) in the user code in order to use it even in
1658 !WXWIN_COMPATIBILITY_2_8 builds so don't redefine it in such case.
1660 #if WXWIN_COMPATIBILITY_2_8 && !defined(wxADJUST_MINSIZE)
1661 wxADJUST_MINSIZE
= 0,
1663 wxFIXED_MINSIZE
= 0x8000,
1664 wxRESERVE_SPACE_EVEN_IF_HIDDEN
= 0x0002,
1666 /* a mask to extract wxSizerFlagBits from combination of flags */
1667 wxSIZER_FLAG_BITS_MASK
= 0x8002
1672 wxSTRETCH_NOT
= 0x0000,
1677 wxTILE
= wxSHAPED
| wxFIXED_MINSIZE
,
1679 /* a mask to extract stretch from the combination of flags */
1680 wxSTRETCH_MASK
= 0x7000 /* sans wxTILE */
1683 /* border flags: the values are chosen for backwards compatibility */
1686 /* this is different from wxBORDER_NONE as by default the controls do have */
1688 wxBORDER_DEFAULT
= 0,
1690 wxBORDER_NONE
= 0x00200000,
1691 wxBORDER_STATIC
= 0x01000000,
1692 wxBORDER_SIMPLE
= 0x02000000,
1693 wxBORDER_RAISED
= 0x04000000,
1694 wxBORDER_SUNKEN
= 0x08000000,
1695 wxBORDER_DOUBLE
= 0x10000000, /* deprecated */
1696 wxBORDER_THEME
= wxBORDER_DOUBLE
,
1698 /* a mask to extract border style from the combination of flags */
1699 wxBORDER_MASK
= 0x1f200000
1702 /* This makes it easier to specify a 'normal' border for a control */
1703 #if defined(__SMARTPHONE__) || defined(__POCKETPC__)
1704 #define wxDEFAULT_CONTROL_BORDER wxBORDER_SIMPLE
1706 #define wxDEFAULT_CONTROL_BORDER wxBORDER_SUNKEN
1709 /* ---------------------------------------------------------------------------- */
1710 /* Window style flags */
1711 /* ---------------------------------------------------------------------------- */
1714 * Values are chosen so they can be |'ed in a bit list.
1715 * Some styles are used across more than one group,
1716 * so the values mustn't clash with others in the group.
1717 * Otherwise, numbers can be reused across groups.
1721 Summary of the bits used by various styles.
1723 High word, containing styles which can be used with many windows:
1725 +--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
1726 |31|30|29|28|27|26|25|24|23|22|21|20|19|18|17|16|
1727 +--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
1728 | | | | | | | | | | | | | | | |
1729 | | | | | | | | | | | | | | | \_ wxFULL_REPAINT_ON_RESIZE
1730 | | | | | | | | | | | | | | \____ wxPOPUP_WINDOW
1731 | | | | | | | | | | | | | \_______ wxWANTS_CHARS
1732 | | | | | | | | | | | | \__________ wxTAB_TRAVERSAL
1733 | | | | | | | | | | | \_____________ wxTRANSPARENT_WINDOW
1734 | | | | | | | | | | \________________ wxBORDER_NONE
1735 | | | | | | | | | \___________________ wxCLIP_CHILDREN
1736 | | | | | | | | \______________________ wxALWAYS_SHOW_SB
1737 | | | | | | | \_________________________ wxBORDER_STATIC
1738 | | | | | | \____________________________ wxBORDER_SIMPLE
1739 | | | | | \_______________________________ wxBORDER_RAISED
1740 | | | | \__________________________________ wxBORDER_SUNKEN
1741 | | | \_____________________________________ wxBORDER_{DOUBLE,THEME}
1742 | | \________________________________________ wxCAPTION/wxCLIP_SIBLINGS
1743 | \___________________________________________ wxHSCROLL
1744 \______________________________________________ wxVSCROLL
1747 Low word style bits is class-specific meaning that the same bit can have
1748 different meanings for different controls (e.g. 0x10 is wxCB_READONLY
1749 meaning that the control can't be modified for wxComboBox but wxLB_SORT
1750 meaning that the control should be kept sorted for wxListBox, while
1751 wxLB_SORT has a different value -- and this is just fine).
1755 * Window (Frame/dialog/subwindow/panel item) style flags
1757 #define wxVSCROLL 0x80000000
1758 #define wxHSCROLL 0x40000000
1759 #define wxCAPTION 0x20000000
1761 /* New styles (border styles are now in their own enum) */
1762 #define wxDOUBLE_BORDER wxBORDER_DOUBLE
1763 #define wxSUNKEN_BORDER wxBORDER_SUNKEN
1764 #define wxRAISED_BORDER wxBORDER_RAISED
1765 #define wxBORDER wxBORDER_SIMPLE
1766 #define wxSIMPLE_BORDER wxBORDER_SIMPLE
1767 #define wxSTATIC_BORDER wxBORDER_STATIC
1768 #define wxNO_BORDER wxBORDER_NONE
1770 /* wxALWAYS_SHOW_SB: instead of hiding the scrollbar when it is not needed, */
1771 /* disable it - but still show (see also wxLB_ALWAYS_SB style) */
1773 /* NB: as this style is only supported by wxUniversal and wxMSW so far */
1774 #define wxALWAYS_SHOW_SB 0x00800000
1776 /* Clip children when painting, which reduces flicker in e.g. frames and */
1777 /* splitter windows, but can't be used in a panel where a static box must be */
1778 /* 'transparent' (panel paints the background for it) */
1779 #define wxCLIP_CHILDREN 0x00400000
1781 /* Note we're reusing the wxCAPTION style because we won't need captions */
1782 /* for subwindows/controls */
1783 #define wxCLIP_SIBLINGS 0x20000000
1785 #define wxTRANSPARENT_WINDOW 0x00100000
1787 /* Add this style to a panel to get tab traversal working outside of dialogs */
1788 /* (on by default for wxPanel, wxDialog, wxScrolledWindow) */
1789 #define wxTAB_TRAVERSAL 0x00080000
1791 /* Add this style if the control wants to get all keyboard messages (under */
1792 /* Windows, it won't normally get the dialog navigation key events) */
1793 #define wxWANTS_CHARS 0x00040000
1795 /* Make window retained (Motif only, see src/generic/scrolwing.cpp)
1796 * This is non-zero only under wxMotif, to avoid a clash with wxPOPUP_WINDOW
1797 * on other platforms
1801 #define wxRETAINED 0x00020000
1803 #define wxRETAINED 0x00000000
1805 #define wxBACKINGSTORE wxRETAINED
1807 /* set this flag to create a special popup window: it will be always shown on */
1808 /* top of other windows, will capture the mouse and will be dismissed when the */
1809 /* mouse is clicked outside of it or if it loses focus in any other way */
1810 #define wxPOPUP_WINDOW 0x00020000
1812 /* force a full repaint when the window is resized (instead of repainting just */
1813 /* the invalidated area) */
1814 #define wxFULL_REPAINT_ON_RESIZE 0x00010000
1816 /* obsolete: now this is the default behaviour */
1818 /* don't invalidate the whole window (resulting in a PAINT event) when the */
1819 /* window is resized (currently, makes sense for wxMSW only) */
1820 #define wxNO_FULL_REPAINT_ON_RESIZE 0
1822 /* A mask which can be used to filter (out) all wxWindow-specific styles.
1824 #define wxWINDOW_STYLE_MASK \
1825 (wxVSCROLL|wxHSCROLL|wxBORDER_MASK|wxALWAYS_SHOW_SB|wxCLIP_CHILDREN| \
1826 wxCLIP_SIBLINGS|wxTRANSPARENT_WINDOW|wxTAB_TRAVERSAL|wxWANTS_CHARS| \
1827 wxRETAINED|wxPOPUP_WINDOW|wxFULL_REPAINT_ON_RESIZE)
1830 * Extra window style flags (use wxWS_EX prefix to make it clear that they
1831 * should be passed to wxWindow::SetExtraStyle(), not SetWindowStyle())
1834 /* by default, TransferDataTo/FromWindow() only work on direct children of the */
1835 /* window (compatible behaviour), set this flag to make them recursively */
1836 /* descend into all subwindows */
1837 #define wxWS_EX_VALIDATE_RECURSIVELY 0x00000001
1839 /* wxCommandEvents and the objects of the derived classes are forwarded to the */
1840 /* parent window and so on recursively by default. Using this flag for the */
1841 /* given window allows to block this propagation at this window, i.e. prevent */
1842 /* the events from being propagated further upwards. The dialogs have this */
1843 /* flag on by default. */
1844 #define wxWS_EX_BLOCK_EVENTS 0x00000002
1846 /* don't use this window as an implicit parent for the other windows: this must */
1847 /* be used with transient windows as otherwise there is the risk of creating a */
1848 /* dialog/frame with this window as a parent which would lead to a crash if the */
1849 /* parent is destroyed before the child */
1850 #define wxWS_EX_TRANSIENT 0x00000004
1852 /* don't paint the window background, we'll assume it will */
1853 /* be done by a theming engine. This is not yet used but could */
1854 /* possibly be made to work in the future, at least on Windows */
1855 #define wxWS_EX_THEMED_BACKGROUND 0x00000008
1857 /* this window should always process idle events */
1858 #define wxWS_EX_PROCESS_IDLE 0x00000010
1860 /* this window should always process UI update events */
1861 #define wxWS_EX_PROCESS_UI_UPDATES 0x00000020
1863 /* Draw the window in a metal theme on Mac */
1864 #define wxFRAME_EX_METAL 0x00000040
1865 #define wxDIALOG_EX_METAL 0x00000040
1867 /* Use this style to add a context-sensitive help to the window (currently for */
1868 /* Win32 only and it doesn't work if wxMINIMIZE_BOX or wxMAXIMIZE_BOX are used) */
1869 #define wxWS_EX_CONTEXTHELP 0x00000080
1871 /* synonyms for wxWS_EX_CONTEXTHELP for compatibility */
1872 #define wxFRAME_EX_CONTEXTHELP wxWS_EX_CONTEXTHELP
1873 #define wxDIALOG_EX_CONTEXTHELP wxWS_EX_CONTEXTHELP
1875 /* Create a window which is attachable to another top level window */
1876 #define wxFRAME_DRAWER 0x0020
1879 * MDI parent frame style flags
1880 * Can overlap with some of the above.
1883 #define wxFRAME_NO_WINDOW_MENU 0x0100
1886 * wxMenuBar style flags
1888 /* use native docking */
1889 #define wxMB_DOCKABLE 0x0001
1892 * wxMenu style flags
1894 #define wxMENU_TEAROFF 0x0001
1897 * Apply to all panel items
1899 #define wxCOLOURED 0x0800
1900 #define wxFIXED_LENGTH 0x0400
1903 * Styles for wxListBox
1905 #define wxLB_SORT 0x0010
1906 #define wxLB_SINGLE 0x0020
1907 #define wxLB_MULTIPLE 0x0040
1908 #define wxLB_EXTENDED 0x0080
1909 /* wxLB_OWNERDRAW is Windows-only */
1910 #define wxLB_NEEDED_SB 0x0000
1911 #define wxLB_OWNERDRAW 0x0100
1912 #define wxLB_ALWAYS_SB 0x0200
1913 #define wxLB_NO_SB 0x0400
1914 #define wxLB_HSCROLL wxHSCROLL
1915 /* always show an entire number of rows */
1916 #define wxLB_INT_HEIGHT 0x0800
1918 #if WXWIN_COMPATIBILITY_2_6
1919 /* deprecated synonyms */
1920 #define wxPROCESS_ENTER 0x0400 /* wxTE_PROCESS_ENTER */
1921 #define wxPASSWORD 0x0800 /* wxTE_PASSWORD */
1925 * wxComboBox style flags
1927 #define wxCB_SIMPLE 0x0004
1928 #define wxCB_SORT 0x0008
1929 #define wxCB_READONLY 0x0010
1930 #define wxCB_DROPDOWN 0x0020
1933 * wxRadioBox style flags
1935 /* should we number the items from left to right or from top to bottom in a 2d */
1937 #define wxRA_LEFTTORIGHT 0x0001
1938 #define wxRA_TOPTOBOTTOM 0x0002
1940 /* New, more intuitive names to specify majorDim argument */
1941 #define wxRA_SPECIFY_COLS wxHORIZONTAL
1942 #define wxRA_SPECIFY_ROWS wxVERTICAL
1944 /* Old names for compatibility */
1945 #define wxRA_HORIZONTAL wxHORIZONTAL
1946 #define wxRA_VERTICAL wxVERTICAL
1949 * wxRadioButton style flag
1951 #define wxRB_GROUP 0x0004
1952 #define wxRB_SINGLE 0x0008
1957 #define wxSB_HORIZONTAL wxHORIZONTAL
1958 #define wxSB_VERTICAL wxVERTICAL
1961 * wxSpinButton flags.
1962 * Note that a wxSpinCtrl is sometimes defined as a wxTextCtrl, and so the
1963 * flags shouldn't overlap with wxTextCtrl flags that can be used for a single
1964 * line controls (currently we reuse wxTE_CHARWRAP and wxTE_RICH2 neither of
1965 * which makes sense for them).
1967 #define wxSP_HORIZONTAL wxHORIZONTAL /* 4 */
1968 #define wxSP_VERTICAL wxVERTICAL /* 8 */
1969 #define wxSP_ARROW_KEYS 0x4000
1970 #define wxSP_WRAP 0x8000
1975 #define wxTC_RIGHTJUSTIFY 0x0010
1976 #define wxTC_FIXEDWIDTH 0x0020
1977 #define wxTC_TOP 0x0000 /* default */
1978 #define wxTC_LEFT 0x0020
1979 #define wxTC_RIGHT 0x0040
1980 #define wxTC_BOTTOM 0x0080
1981 #define wxTC_MULTILINE 0x0200 /* == wxNB_MULTILINE */
1982 #define wxTC_OWNERDRAW 0x0400
1985 * wxStaticBitmap flags
1987 #define wxBI_EXPAND wxEXPAND
1990 * wxStaticLine flags
1992 #define wxLI_HORIZONTAL wxHORIZONTAL
1993 #define wxLI_VERTICAL wxVERTICAL
1997 * extended dialog specifiers. these values are stored in a different
1998 * flag and thus do not overlap with other style flags. note that these
1999 * values do not correspond to the return values of the dialogs (for
2000 * those values, look at the wxID_XXX defines).
2003 /* wxCENTRE already defined as 0x00000001 */
2004 #define wxYES 0x00000002
2005 #define wxOK 0x00000004
2006 #define wxNO 0x00000008
2007 #define wxYES_NO (wxYES | wxNO)
2008 #define wxCANCEL 0x00000010
2009 #define wxAPPLY 0x00000020
2010 #define wxCLOSE 0x00000040
2012 #define wxOK_DEFAULT 0x00000000 /* has no effect (default) */
2013 #define wxYES_DEFAULT 0x00000000 /* has no effect (default) */
2014 #define wxNO_DEFAULT 0x00000080 /* only valid with wxYES_NO */
2015 #define wxCANCEL_DEFAULT 0x80000000 /* only valid with wxCANCEL */
2017 #define wxICON_EXCLAMATION 0x00000100
2018 #define wxICON_HAND 0x00000200
2019 #define wxICON_WARNING wxICON_EXCLAMATION
2020 #define wxICON_ERROR wxICON_HAND
2021 #define wxICON_QUESTION 0x00000400
2022 #define wxICON_INFORMATION 0x00000800
2023 #define wxICON_STOP wxICON_HAND
2024 #define wxICON_ASTERISK wxICON_INFORMATION
2026 #define wxHELP 0x00001000
2027 #define wxFORWARD 0x00002000
2028 #define wxBACKWARD 0x00004000
2029 #define wxRESET 0x00008000
2030 #define wxMORE 0x00010000
2031 #define wxSETUP 0x00020000
2032 #define wxICON_NONE 0x00040000
2033 #define wxICON_AUTH_NEEDED 0x00080000
2035 #define wxICON_MASK \
2036 (wxICON_EXCLAMATION|wxICON_HAND|wxICON_QUESTION|wxICON_INFORMATION|wxICON_NONE|wxICON_AUTH_NEEDED)
2039 * Background styles. See wxWindow::SetBackgroundStyle
2041 enum wxBackgroundStyle
2044 background is erased in the EVT_ERASE_BACKGROUND handler or using
2045 the system default background if no such handler is defined (this
2046 is the default style)
2051 background is erased by the system, no EVT_ERASE_BACKGROUND event
2057 background is erased in EVT_PAINT handler and not erased at all
2058 before it, this should be used if the paint handler paints over
2059 the entire window to avoid flicker
2064 /* this is a Mac-only style, don't use in portable code */
2065 wxBG_STYLE_TRANSPARENT
,
2067 /* this style is deprecated and doesn't do anything, don't use */
2071 this style is deprecated and is synonymous with
2072 wxBG_STYLE_PAINT, use the new name
2074 wxBG_STYLE_CUSTOM
= wxBG_STYLE_PAINT
2078 * Key types used by (old style) lists and hashes.
2087 /* ---------------------------------------------------------------------------- */
2089 /* ---------------------------------------------------------------------------- */
2091 /* Standard menu IDs */
2095 These ids delimit the range used by automatically-generated ids
2096 (i.e. those used when wxID_ANY is specified during construction).
2098 #if defined(__WXMSW__) || wxUSE_AUTOID_MANAGEMENT
2100 On MSW the range is always restricted no matter if id management
2101 is used or not because the native window ids are limited to short
2102 range. On other platforms the range is only restricted if id
2103 management is used so the reference count buffer won't be so big.
2105 wxID_AUTO_LOWEST
= -32000,
2106 wxID_AUTO_HIGHEST
= -2000,
2108 wxID_AUTO_LOWEST
= -1000000,
2109 wxID_AUTO_HIGHEST
= -2000,
2112 /* no id matches this one when compared to it */
2115 /* id for a separator line in the menu (invalid for normal item) */
2116 wxID_SEPARATOR
= -2,
2118 /* any id: means that we don't care about the id, whether when installing
2119 * an event handler or when creating a new window */
2123 /* all predefined ids are between wxID_LOWEST and wxID_HIGHEST */
2145 wxID_HELP_PROCEDURES
,
2164 wxID_VIEW_LARGEICONS
,
2165 wxID_VIEW_SMALLICONS
,
2183 /* Standard button and menu IDs */
2214 wxID_JUSTIFY_CENTER
,
2226 wxID_REVERT_TO_SAVED
,
2241 wxID_SORT_ASCENDING
,
2242 wxID_SORT_DESCENDING
,
2246 /* System menu IDs (used by wxUniv): */
2247 wxID_SYSTEM_MENU
= 5200,
2251 wxID_MAXIMIZE_FRAME
,
2255 /* MDI window menu ids */
2256 wxID_MDI_WINDOW_FIRST
= 5230,
2257 wxID_MDI_WINDOW_CASCADE
= wxID_MDI_WINDOW_FIRST
,
2258 wxID_MDI_WINDOW_TILE_HORZ
,
2259 wxID_MDI_WINDOW_TILE_VERT
,
2260 wxID_MDI_WINDOW_ARRANGE_ICONS
,
2261 wxID_MDI_WINDOW_PREV
,
2262 wxID_MDI_WINDOW_NEXT
,
2263 wxID_MDI_WINDOW_LAST
= wxID_MDI_WINDOW_NEXT
,
2265 /* OS X system menu ids */
2266 wxID_OSX_MENU_FIRST
= 5250,
2267 wxID_OSX_HIDE
= wxID_OSX_MENU_FIRST
,
2268 wxID_OSX_HIDEOTHERS
,
2270 wxID_OSX_MENU_LAST
= wxID_OSX_SHOWALL
,
2272 /* IDs used by generic file dialog (13 consecutive starting from this value) */
2273 wxID_FILEDLGG
= 5900,
2275 /* IDs used by generic file ctrl (4 consecutive starting from this value) */
2276 wxID_FILECTRL
= 5950,
2281 /* ---------------------------------------------------------------------------- */
2282 /* wxWindowID type (after wxID_XYZ enum, platform detection, and dlimpexp.h) */
2283 /* ---------------------------------------------------------------------------- */
2285 /* special care should be taken with this type under Windows where the real */
2286 /* window id is unsigned, so we must always do the cast before comparing them */
2287 /* (or else they would be always different!). Using wxGetWindowId() which does */
2288 /* the cast itself is recommended. Note that this type can't be unsigned */
2289 /* because wxID_ANY == -1 is a valid (and largely used) value for window id. */
2290 #if defined(__cplusplus) && wxUSE_GUI
2291 #include "wx/windowid.h"
2294 /* ---------------------------------------------------------------------------- */
2295 /* other constants */
2296 /* ---------------------------------------------------------------------------- */
2298 /* menu and toolbar item kinds */
2301 wxITEM_SEPARATOR
= -1,
2310 * The possible states of a 3-state checkbox (Compatible
2311 * with the 2-state checkbox).
2313 enum wxCheckBoxState
2317 wxCHK_UNDETERMINED
/* 3-state checkbox only */
2321 /* hit test results */
2327 wxHT_SCROLLBAR_FIRST
= wxHT_NOWHERE
,
2328 wxHT_SCROLLBAR_ARROW_LINE_1
, /* left or upper arrow to scroll by line */
2329 wxHT_SCROLLBAR_ARROW_LINE_2
, /* right or down */
2330 wxHT_SCROLLBAR_ARROW_PAGE_1
, /* left or upper arrow to scroll by page */
2331 wxHT_SCROLLBAR_ARROW_PAGE_2
, /* right or down */
2332 wxHT_SCROLLBAR_THUMB
, /* on the thumb */
2333 wxHT_SCROLLBAR_BAR_1
, /* bar to the left/above the thumb */
2334 wxHT_SCROLLBAR_BAR_2
, /* bar to the right/below the thumb */
2335 wxHT_SCROLLBAR_LAST
,
2338 wxHT_WINDOW_OUTSIDE
, /* not in this window at all */
2339 wxHT_WINDOW_INSIDE
, /* in the client area */
2340 wxHT_WINDOW_VERT_SCROLLBAR
, /* on the vertical scrollbar */
2341 wxHT_WINDOW_HORZ_SCROLLBAR
, /* on the horizontal scrollbar */
2342 wxHT_WINDOW_CORNER
, /* on the corner between 2 scrollbars */
2347 /* ---------------------------------------------------------------------------- */
2348 /* Possible SetSize flags */
2349 /* ---------------------------------------------------------------------------- */
2351 /* Use internally-calculated width if -1 */
2352 #define wxSIZE_AUTO_WIDTH 0x0001
2353 /* Use internally-calculated height if -1 */
2354 #define wxSIZE_AUTO_HEIGHT 0x0002
2355 /* Use internally-calculated width and height if each is -1 */
2356 #define wxSIZE_AUTO (wxSIZE_AUTO_WIDTH|wxSIZE_AUTO_HEIGHT)
2357 /* Ignore missing (-1) dimensions (use existing). */
2358 /* For readability only: test for wxSIZE_AUTO_WIDTH/HEIGHT in code. */
2359 #define wxSIZE_USE_EXISTING 0x0000
2360 /* Allow -1 as a valid position */
2361 #define wxSIZE_ALLOW_MINUS_ONE 0x0004
2362 /* Don't do parent client adjustments (for implementation only) */
2363 #define wxSIZE_NO_ADJUSTMENTS 0x0008
2364 /* Change the window position even if it seems to be already correct */
2365 #define wxSIZE_FORCE 0x0010
2366 /* Emit size event even if size didn't change */
2367 #define wxSIZE_FORCE_EVENT 0x0020
2369 /* ---------------------------------------------------------------------------- */
2370 /* GDI descriptions */
2371 /* ---------------------------------------------------------------------------- */
2373 // Hatch styles used by both pen and brush styles.
2375 // NB: Do not use these constants directly, they're for internal use only, use
2376 // wxBRUSHSTYLE_XXX_HATCH and wxPENSTYLE_XXX_HATCH instead.
2379 wxHATCHSTYLE_INVALID
= -1,
2382 The value of the first style is chosen to fit with
2383 wxDeprecatedGUIConstants values below, don't change it.
2385 wxHATCHSTYLE_FIRST
= 111,
2386 wxHATCHSTYLE_BDIAGONAL
= wxHATCHSTYLE_FIRST
,
2387 wxHATCHSTYLE_CROSSDIAG
,
2388 wxHATCHSTYLE_FDIAGONAL
,
2390 wxHATCHSTYLE_HORIZONTAL
,
2391 wxHATCHSTYLE_VERTICAL
,
2392 wxHATCHSTYLE_LAST
= wxHATCHSTYLE_VERTICAL
2396 WARNING: the following styles are deprecated; use the
2397 wxFontFamily, wxFontStyle, wxFontWeight, wxBrushStyle,
2398 wxPenStyle, wxPenCap, wxPenJoin enum values instead!
2401 #if FUTURE_WXWIN_COMPATIBILITY_3_0
2403 /* don't use any elements of this enum in the new code */
2404 enum wxDeprecatedGUIConstants
2406 /* Text font families */
2413 wxTELETYPE
, /* @@@@ */
2415 /* Proportional or Fixed width fonts (not yet used) */
2422 /* Also wxNORMAL for normal (non-italic text) */
2436 /* Brush & Pen Stippling. Note that a stippled pen cannot be dashed!! */
2437 /* Note also that stippling a Pen IS meaningful, because a Line is */
2438 wxSTIPPLE_MASK_OPAQUE
, /* mask is used for blitting monochrome using text fore and back ground colors */
2439 wxSTIPPLE_MASK
, /* mask is used for masking areas in the stipple bitmap (TO DO) */
2440 /* drawn with a Pen, and without any Brush -- and it can be stippled. */
2443 wxBDIAGONAL_HATCH
= wxHATCHSTYLE_BDIAGONAL
,
2444 wxCROSSDIAG_HATCH
= wxHATCHSTYLE_CROSSDIAG
,
2445 wxFDIAGONAL_HATCH
= wxHATCHSTYLE_FDIAGONAL
,
2446 wxCROSS_HATCH
= wxHATCHSTYLE_CROSS
,
2447 wxHORIZONTAL_HATCH
= wxHATCHSTYLE_HORIZONTAL
,
2448 wxVERTICAL_HATCH
= wxHATCHSTYLE_VERTICAL
,
2449 wxFIRST_HATCH
= wxHATCHSTYLE_FIRST
,
2450 wxLAST_HATCH
= wxHATCHSTYLE_LAST
2454 /* ToolPanel in wxFrame (VZ: unused?) */
2463 /* the values of the format constants should be the same as corresponding */
2464 /* CF_XXX constants in Windows API */
2468 wxDF_TEXT
= 1, /* CF_TEXT */
2469 wxDF_BITMAP
= 2, /* CF_BITMAP */
2470 wxDF_METAFILE
= 3, /* CF_METAFILEPICT */
2474 wxDF_OEMTEXT
= 7, /* CF_OEMTEXT */
2475 wxDF_DIB
= 8, /* CF_DIB */
2480 wxDF_UNICODETEXT
= 13,
2481 wxDF_ENHMETAFILE
= 14,
2482 wxDF_FILENAME
= 15, /* CF_HDROP */
2485 wxDF_HTML
= 30, /* Note: does not correspond to CF_ constant */
2521 WXK_BACK
= 8, /* backspace */
2526 /* values from 33 to 126 are reserved for the standard ASCII characters */
2531 /* values from 128 to 255 are reserved for ASCII extended characters
2532 (note that there isn't a single fixed standard for the meaning
2533 of these values; avoid them in portable apps!) */
2535 /* These are not compatible with unicode characters.
2536 If you want to get a unicode character from a key event, use
2537 wxKeyEvent::GetUnicodeKey */
2606 #if WXWIN_COMPATIBILITY_2_6
2607 WXK_PRIOR
= WXK_PAGEUP
,
2608 WXK_NEXT
= WXK_PAGEDOWN
,
2624 WXK_NUMPAD_PAGEDOWN
,
2625 #if WXWIN_COMPATIBILITY_2_6
2626 WXK_NUMPAD_PRIOR
= WXK_NUMPAD_PAGEUP
,
2627 WXK_NUMPAD_NEXT
= WXK_NUMPAD_PAGEDOWN
,
2634 WXK_NUMPAD_MULTIPLY
,
2636 WXK_NUMPAD_SEPARATOR
,
2637 WXK_NUMPAD_SUBTRACT
,
2647 WXK_RAW_CONTROL
= WXK_CONTROL
,
2649 WXK_COMMAND
= WXK_CONTROL
,
2651 /* Hardware-specific buttons */
2674 /* This enum contains bit mask constants used in wxKeyEvent */
2677 wxMOD_NONE
= 0x0000,
2679 wxMOD_CONTROL
= 0x0002,
2680 wxMOD_ALTGR
= wxMOD_ALT
| wxMOD_CONTROL
,
2681 wxMOD_SHIFT
= 0x0004,
2682 wxMOD_META
= 0x0008,
2683 wxMOD_WIN
= wxMOD_META
,
2684 #if defined(__WXMAC__) || defined(__WXCOCOA__)
2685 wxMOD_RAW_CONTROL
= 0x0010,
2687 wxMOD_RAW_CONTROL
= wxMOD_CONTROL
,
2689 wxMOD_CMD
= wxMOD_CONTROL
,
2693 /* Shortcut for easier dialog-unit-to-pixel conversion */
2694 #define wxDLG_UNIT(parent, pt) parent->ConvertDialogToPixels(pt)
2699 wxPAPER_NONE
, /* Use specific dimensions */
2700 wxPAPER_LETTER
, /* Letter, 8 1/2 by 11 inches */
2701 wxPAPER_LEGAL
, /* Legal, 8 1/2 by 14 inches */
2702 wxPAPER_A4
, /* A4 Sheet, 210 by 297 millimeters */
2703 wxPAPER_CSHEET
, /* C Sheet, 17 by 22 inches */
2704 wxPAPER_DSHEET
, /* D Sheet, 22 by 34 inches */
2705 wxPAPER_ESHEET
, /* E Sheet, 34 by 44 inches */
2706 wxPAPER_LETTERSMALL
, /* Letter Small, 8 1/2 by 11 inches */
2707 wxPAPER_TABLOID
, /* Tabloid, 11 by 17 inches */
2708 wxPAPER_LEDGER
, /* Ledger, 17 by 11 inches */
2709 wxPAPER_STATEMENT
, /* Statement, 5 1/2 by 8 1/2 inches */
2710 wxPAPER_EXECUTIVE
, /* Executive, 7 1/4 by 10 1/2 inches */
2711 wxPAPER_A3
, /* A3 sheet, 297 by 420 millimeters */
2712 wxPAPER_A4SMALL
, /* A4 small sheet, 210 by 297 millimeters */
2713 wxPAPER_A5
, /* A5 sheet, 148 by 210 millimeters */
2714 wxPAPER_B4
, /* B4 sheet, 250 by 354 millimeters */
2715 wxPAPER_B5
, /* B5 sheet, 182-by-257-millimeter paper */
2716 wxPAPER_FOLIO
, /* Folio, 8-1/2-by-13-inch paper */
2717 wxPAPER_QUARTO
, /* Quarto, 215-by-275-millimeter paper */
2718 wxPAPER_10X14
, /* 10-by-14-inch sheet */
2719 wxPAPER_11X17
, /* 11-by-17-inch sheet */
2720 wxPAPER_NOTE
, /* Note, 8 1/2 by 11 inches */
2721 wxPAPER_ENV_9
, /* #9 Envelope, 3 7/8 by 8 7/8 inches */
2722 wxPAPER_ENV_10
, /* #10 Envelope, 4 1/8 by 9 1/2 inches */
2723 wxPAPER_ENV_11
, /* #11 Envelope, 4 1/2 by 10 3/8 inches */
2724 wxPAPER_ENV_12
, /* #12 Envelope, 4 3/4 by 11 inches */
2725 wxPAPER_ENV_14
, /* #14 Envelope, 5 by 11 1/2 inches */
2726 wxPAPER_ENV_DL
, /* DL Envelope, 110 by 220 millimeters */
2727 wxPAPER_ENV_C5
, /* C5 Envelope, 162 by 229 millimeters */
2728 wxPAPER_ENV_C3
, /* C3 Envelope, 324 by 458 millimeters */
2729 wxPAPER_ENV_C4
, /* C4 Envelope, 229 by 324 millimeters */
2730 wxPAPER_ENV_C6
, /* C6 Envelope, 114 by 162 millimeters */
2731 wxPAPER_ENV_C65
, /* C65 Envelope, 114 by 229 millimeters */
2732 wxPAPER_ENV_B4
, /* B4 Envelope, 250 by 353 millimeters */
2733 wxPAPER_ENV_B5
, /* B5 Envelope, 176 by 250 millimeters */
2734 wxPAPER_ENV_B6
, /* B6 Envelope, 176 by 125 millimeters */
2735 wxPAPER_ENV_ITALY
, /* Italy Envelope, 110 by 230 millimeters */
2736 wxPAPER_ENV_MONARCH
, /* Monarch Envelope, 3 7/8 by 7 1/2 inches */
2737 wxPAPER_ENV_PERSONAL
, /* 6 3/4 Envelope, 3 5/8 by 6 1/2 inches */
2738 wxPAPER_FANFOLD_US
, /* US Std Fanfold, 14 7/8 by 11 inches */
2739 wxPAPER_FANFOLD_STD_GERMAN
, /* German Std Fanfold, 8 1/2 by 12 inches */
2740 wxPAPER_FANFOLD_LGL_GERMAN
, /* German Legal Fanfold, 8 1/2 by 13 inches */
2742 wxPAPER_ISO_B4
, /* B4 (ISO) 250 x 353 mm */
2743 wxPAPER_JAPANESE_POSTCARD
, /* Japanese Postcard 100 x 148 mm */
2744 wxPAPER_9X11
, /* 9 x 11 in */
2745 wxPAPER_10X11
, /* 10 x 11 in */
2746 wxPAPER_15X11
, /* 15 x 11 in */
2747 wxPAPER_ENV_INVITE
, /* Envelope Invite 220 x 220 mm */
2748 wxPAPER_LETTER_EXTRA
, /* Letter Extra 9 \275 x 12 in */
2749 wxPAPER_LEGAL_EXTRA
, /* Legal Extra 9 \275 x 15 in */
2750 wxPAPER_TABLOID_EXTRA
, /* Tabloid Extra 11.69 x 18 in */
2751 wxPAPER_A4_EXTRA
, /* A4 Extra 9.27 x 12.69 in */
2752 wxPAPER_LETTER_TRANSVERSE
, /* Letter Transverse 8 \275 x 11 in */
2753 wxPAPER_A4_TRANSVERSE
, /* A4 Transverse 210 x 297 mm */
2754 wxPAPER_LETTER_EXTRA_TRANSVERSE
, /* Letter Extra Transverse 9\275 x 12 in */
2755 wxPAPER_A_PLUS
, /* SuperA/SuperA/A4 227 x 356 mm */
2756 wxPAPER_B_PLUS
, /* SuperB/SuperB/A3 305 x 487 mm */
2757 wxPAPER_LETTER_PLUS
, /* Letter Plus 8.5 x 12.69 in */
2758 wxPAPER_A4_PLUS
, /* A4 Plus 210 x 330 mm */
2759 wxPAPER_A5_TRANSVERSE
, /* A5 Transverse 148 x 210 mm */
2760 wxPAPER_B5_TRANSVERSE
, /* B5 (JIS) Transverse 182 x 257 mm */
2761 wxPAPER_A3_EXTRA
, /* A3 Extra 322 x 445 mm */
2762 wxPAPER_A5_EXTRA
, /* A5 Extra 174 x 235 mm */
2763 wxPAPER_B5_EXTRA
, /* B5 (ISO) Extra 201 x 276 mm */
2764 wxPAPER_A2
, /* A2 420 x 594 mm */
2765 wxPAPER_A3_TRANSVERSE
, /* A3 Transverse 297 x 420 mm */
2766 wxPAPER_A3_EXTRA_TRANSVERSE
, /* A3 Extra Transverse 322 x 445 mm */
2768 wxPAPER_DBL_JAPANESE_POSTCARD
,/* Japanese Double Postcard 200 x 148 mm */
2769 wxPAPER_A6
, /* A6 105 x 148 mm */
2770 wxPAPER_JENV_KAKU2
, /* Japanese Envelope Kaku #2 */
2771 wxPAPER_JENV_KAKU3
, /* Japanese Envelope Kaku #3 */
2772 wxPAPER_JENV_CHOU3
, /* Japanese Envelope Chou #3 */
2773 wxPAPER_JENV_CHOU4
, /* Japanese Envelope Chou #4 */
2774 wxPAPER_LETTER_ROTATED
, /* Letter Rotated 11 x 8 1/2 in */
2775 wxPAPER_A3_ROTATED
, /* A3 Rotated 420 x 297 mm */
2776 wxPAPER_A4_ROTATED
, /* A4 Rotated 297 x 210 mm */
2777 wxPAPER_A5_ROTATED
, /* A5 Rotated 210 x 148 mm */
2778 wxPAPER_B4_JIS_ROTATED
, /* B4 (JIS) Rotated 364 x 257 mm */
2779 wxPAPER_B5_JIS_ROTATED
, /* B5 (JIS) Rotated 257 x 182 mm */
2780 wxPAPER_JAPANESE_POSTCARD_ROTATED
,/* Japanese Postcard Rotated 148 x 100 mm */
2781 wxPAPER_DBL_JAPANESE_POSTCARD_ROTATED
,/* Double Japanese Postcard Rotated 148 x 200 mm */
2782 wxPAPER_A6_ROTATED
, /* A6 Rotated 148 x 105 mm */
2783 wxPAPER_JENV_KAKU2_ROTATED
, /* Japanese Envelope Kaku #2 Rotated */
2784 wxPAPER_JENV_KAKU3_ROTATED
, /* Japanese Envelope Kaku #3 Rotated */
2785 wxPAPER_JENV_CHOU3_ROTATED
, /* Japanese Envelope Chou #3 Rotated */
2786 wxPAPER_JENV_CHOU4_ROTATED
, /* Japanese Envelope Chou #4 Rotated */
2787 wxPAPER_B6_JIS
, /* B6 (JIS) 128 x 182 mm */
2788 wxPAPER_B6_JIS_ROTATED
, /* B6 (JIS) Rotated 182 x 128 mm */
2789 wxPAPER_12X11
, /* 12 x 11 in */
2790 wxPAPER_JENV_YOU4
, /* Japanese Envelope You #4 */
2791 wxPAPER_JENV_YOU4_ROTATED
, /* Japanese Envelope You #4 Rotated */
2792 wxPAPER_P16K
, /* PRC 16K 146 x 215 mm */
2793 wxPAPER_P32K
, /* PRC 32K 97 x 151 mm */
2794 wxPAPER_P32KBIG
, /* PRC 32K(Big) 97 x 151 mm */
2795 wxPAPER_PENV_1
, /* PRC Envelope #1 102 x 165 mm */
2796 wxPAPER_PENV_2
, /* PRC Envelope #2 102 x 176 mm */
2797 wxPAPER_PENV_3
, /* PRC Envelope #3 125 x 176 mm */
2798 wxPAPER_PENV_4
, /* PRC Envelope #4 110 x 208 mm */
2799 wxPAPER_PENV_5
, /* PRC Envelope #5 110 x 220 mm */
2800 wxPAPER_PENV_6
, /* PRC Envelope #6 120 x 230 mm */
2801 wxPAPER_PENV_7
, /* PRC Envelope #7 160 x 230 mm */
2802 wxPAPER_PENV_8
, /* PRC Envelope #8 120 x 309 mm */
2803 wxPAPER_PENV_9
, /* PRC Envelope #9 229 x 324 mm */
2804 wxPAPER_PENV_10
, /* PRC Envelope #10 324 x 458 mm */
2805 wxPAPER_P16K_ROTATED
, /* PRC 16K Rotated */
2806 wxPAPER_P32K_ROTATED
, /* PRC 32K Rotated */
2807 wxPAPER_P32KBIG_ROTATED
, /* PRC 32K(Big) Rotated */
2808 wxPAPER_PENV_1_ROTATED
, /* PRC Envelope #1 Rotated 165 x 102 mm */
2809 wxPAPER_PENV_2_ROTATED
, /* PRC Envelope #2 Rotated 176 x 102 mm */
2810 wxPAPER_PENV_3_ROTATED
, /* PRC Envelope #3 Rotated 176 x 125 mm */
2811 wxPAPER_PENV_4_ROTATED
, /* PRC Envelope #4 Rotated 208 x 110 mm */
2812 wxPAPER_PENV_5_ROTATED
, /* PRC Envelope #5 Rotated 220 x 110 mm */
2813 wxPAPER_PENV_6_ROTATED
, /* PRC Envelope #6 Rotated 230 x 120 mm */
2814 wxPAPER_PENV_7_ROTATED
, /* PRC Envelope #7 Rotated 230 x 160 mm */
2815 wxPAPER_PENV_8_ROTATED
, /* PRC Envelope #8 Rotated 309 x 120 mm */
2816 wxPAPER_PENV_9_ROTATED
, /* PRC Envelope #9 Rotated 324 x 229 mm */
2817 wxPAPER_PENV_10_ROTATED
, /* PRC Envelope #10 Rotated 458 x 324 m */
2818 wxPAPER_A0
, /* A0 Sheet 841 x 1189 mm */
2819 wxPAPER_A1
/* A1 Sheet 594 x 841 mm */
2822 /* Printing orientation */
2823 enum wxPrintOrientation
2829 /* Duplex printing modes
2834 wxDUPLEX_SIMPLEX
, /* Non-duplex */
2835 wxDUPLEX_HORIZONTAL
,
2842 #define wxPRINT_QUALITY_HIGH -1
2843 #define wxPRINT_QUALITY_MEDIUM -2
2844 #define wxPRINT_QUALITY_LOW -3
2845 #define wxPRINT_QUALITY_DRAFT -4
2847 typedef int wxPrintQuality
;
2849 /* Print mode (currently PostScript only)
2854 wxPRINT_MODE_NONE
= 0,
2855 wxPRINT_MODE_PREVIEW
= 1, /* Preview in external application */
2856 wxPRINT_MODE_FILE
= 2, /* Print to file */
2857 wxPRINT_MODE_PRINTER
= 3, /* Send to printer */
2858 wxPRINT_MODE_STREAM
= 4 /* Send postscript data into a stream */
2861 /* ---------------------------------------------------------------------------- */
2862 /* UpdateWindowUI flags */
2863 /* ---------------------------------------------------------------------------- */
2867 wxUPDATE_UI_NONE
= 0x0000,
2868 wxUPDATE_UI_RECURSE
= 0x0001,
2869 wxUPDATE_UI_FROMIDLE
= 0x0002 /* Invoked from On(Internal)Idle */
2873 /* ---------------------------------------------------------------------------- */
2875 /* ---------------------------------------------------------------------------- */
2877 /* type of compare function for list sort operation (as in 'qsort'): it should
2878 return a negative value, 0 or positive value if the first element is less
2879 than, equal or greater than the second */
2881 typedef int (* LINKAGEMODE wxSortCompareFunction
)(const void *elem1
, const void *elem2
);
2883 /* wxList iterator function */
2884 typedef int (* LINKAGEMODE wxListIterateFunction
)(void *current
);
2887 /* ---------------------------------------------------------------------------- */
2889 /* ---------------------------------------------------------------------------- */
2891 /* define this macro if font handling is done using the X font names */
2892 #if (defined(__WXGTK__) && !defined(__WXGTK20__)) || defined(__X__)
2893 #define _WX_X_FONTLIKE
2896 /* macro to specify "All Files" on different platforms */
2897 #if defined(__WXMSW__) || defined(__WXPM__)
2898 # define wxALL_FILES_PATTERN wxT("*.*")
2899 # define wxALL_FILES gettext_noop("All files (*.*)|*.*")
2901 # define wxALL_FILES_PATTERN wxT("*")
2902 # define wxALL_FILES gettext_noop("All files (*)|*")
2905 #if defined(__CYGWIN__) && defined(__WXMSW__)
2906 # if wxUSE_STD_CONTAINERS || defined(wxUSE_STD_STRING)
2908 NASTY HACK because the gethostname in sys/unistd.h which the gnu
2909 stl includes and wx builds with by default clash with each other
2910 (windows version 2nd param is int, sys/unistd.h version is unsigned
2913 # define gethostname gethostnameHACK
2914 # include <unistd.h>
2919 /* --------------------------------------------------------------------------- */
2920 /* macros that enable wxWidgets apps to be compiled in absence of the */
2921 /* system headers, although some platform specific types are used in the */
2922 /* platform specific (implementation) parts of the headers */
2923 /* --------------------------------------------------------------------------- */
2926 #define DECLARE_WXOSX_OPAQUE_CFREF( name ) typedef struct __##name* name##Ref;
2927 #define DECLARE_WXOSX_OPAQUE_CONST_CFREF( name ) typedef const struct __##name* name##Ref;
2932 #define WX_OPAQUE_TYPE( name ) struct wxOpaque##name
2934 typedef void* WXHBITMAP
;
2935 typedef void* WXHCURSOR
;
2936 typedef void* WXRECTPTR
;
2937 typedef void* WXPOINTPTR
;
2938 typedef void* WXHWND
;
2939 typedef void* WXEVENTREF
;
2940 typedef void* WXEVENTHANDLERREF
;
2941 typedef void* WXEVENTHANDLERCALLREF
;
2942 typedef void* WXAPPLEEVENTREF
;
2944 typedef unsigned int WXUINT
;
2945 typedef unsigned long WXDWORD
;
2946 typedef unsigned short WXWORD
;
2948 typedef WX_OPAQUE_TYPE(PicHandle
) * WXHMETAFILE
;
2949 #if wxOSX_USE_CARBON
2950 typedef struct OpaqueControlRef
* WXWidget
;
2951 typedef struct OpaqueWindowPtr
* WXWindow
;
2952 typedef struct __AGLPixelFormatRec
*WXGLPixelFormat
;
2953 typedef struct __AGLContextRec
*WXGLContext
;
2956 typedef void* WXDisplay
;
2962 typedef const void * CFTypeRef
;
2964 /* typedef const struct __CFString * CFStringRef; */
2966 DECLARE_WXOSX_OPAQUE_CONST_CFREF( CFString
)
2967 typedef struct __CFString
* CFMutableStringRef
;
2969 DECLARE_WXOSX_OPAQUE_CFREF( CFRunLoopSource
)
2970 DECLARE_WXOSX_OPAQUE_CONST_CFREF( CTFont
)
2971 DECLARE_WXOSX_OPAQUE_CONST_CFREF( CTFontDescriptor
)
2973 #define DECLARE_WXOSX_OPAQUE_CGREF( name ) typedef struct name* name##Ref;
2975 DECLARE_WXOSX_OPAQUE_CGREF( CGColor
)
2976 DECLARE_WXOSX_OPAQUE_CGREF( CGImage
)
2977 DECLARE_WXOSX_OPAQUE_CGREF( CGContext
)
2978 DECLARE_WXOSX_OPAQUE_CGREF( CGFont
)
2980 typedef CGColorRef WXCOLORREF
;
2981 typedef CGImageRef WXCGIMAGEREF
;
2982 typedef CGContextRef WXHDC
;
2988 typedef const struct __HIShape
* HIShapeRef
;
2989 typedef struct __HIShape
* HIMutableShapeRef
;
2991 #define DECLARE_WXMAC_OPAQUE_REF( name ) typedef struct Opaque##name* name;
2993 DECLARE_WXMAC_OPAQUE_REF( PasteboardRef
)
2994 DECLARE_WXMAC_OPAQUE_REF( IconRef
)
2995 DECLARE_WXMAC_OPAQUE_REF( MenuRef
)
2997 typedef IconRef WXHICON
;
2998 typedef HIShapeRef WXHRGN
;
2999 #if wxOSX_USE_CARBON
3000 typedef MenuRef WXHMENU
;
3005 #if defined( __WXCOCOA__ ) || defined(__WXMAC__)
3007 /* Definitions of 32-bit/64-bit types
3008 * These are typedef'd exactly the same way in newer OS X headers so
3009 * redefinition when real headers are included should not be a problem. If
3010 * it is, the types are being defined wrongly here.
3011 * The purpose of these types is so they can be used from public wx headers.
3012 * and also because the older (pre-Leopard) headers don't define them.
3015 /* NOTE: We don't pollute namespace with CGFLOAT_MIN/MAX/IS_DOUBLE macros
3016 * since they are unlikely to be needed in a public header.
3018 #if defined(__LP64__) && __LP64__
3019 typedef double CGFloat
;
3021 typedef float CGFloat
;
3024 #if (defined(__LP64__) && __LP64__) || (defined(NS_BUILD_32_LIKE_64) && NS_BUILD_32_LIKE_64)
3025 typedef long NSInteger
;
3026 typedef unsigned long NSUInteger
;
3028 typedef int NSInteger
;
3029 typedef unsigned int NSUInteger
;
3032 /* Objective-C type declarations.
3033 * These are to be used in public headers in lieu of NSSomething* because
3034 * Objective-C class names are not available in C/C++ code.
3037 /* NOTE: This ought to work with other compilers too, but I'm being cautious */
3038 #if (defined(__GNUC__) && defined(__APPLE__))
3039 /* It's desirable to have type safety for Objective-C(++) code as it does
3040 at least catch typos of method names among other things. However, it
3041 is not possible to declare an Objective-C class from plain old C or C++
3042 code. Furthermore, because of C++ name mangling, the type name must
3043 be the same for both C++ and Objective-C++ code. Therefore, we define
3044 what should be a pointer to an Objective-C class as a pointer to a plain
3045 old C struct with the same name. Unfortunately, because the compiler
3046 does not see a struct as an Objective-C class we cannot declare it
3047 as a struct in Objective-C(++) mode.
3049 #if defined(__OBJC__)
3050 #define DECLARE_WXCOCOA_OBJC_CLASS(klass) \
3052 typedef klass *WX_##klass
3053 #else /* not defined(__OBJC__) */
3054 #define DECLARE_WXCOCOA_OBJC_CLASS(klass) \
3055 typedef struct klass *WX_##klass
3056 #endif /* defined(__OBJC__) */
3058 #else /* not Apple's gcc */
3059 #warning "Objective-C types will not be checked by the compiler."
3060 /* NOTE: typedef struct objc_object *id; */
3061 /* IOW, we're declaring these using the id type without using that name, */
3062 /* since "id" is used extensively not only within wxWidgets itself, but */
3063 /* also in wxWidgets application code. The following works fine when */
3064 /* compiling C(++) code, and works without typesafety for Obj-C(++) code */
3065 #define DECLARE_WXCOCOA_OBJC_CLASS(klass) \
3066 typedef struct objc_object *WX_##klass
3068 #endif /* (defined(__GNUC__) && defined(__APPLE__)) */
3070 DECLARE_WXCOCOA_OBJC_CLASS(NSApplication
);
3071 DECLARE_WXCOCOA_OBJC_CLASS(NSBitmapImageRep
);
3072 DECLARE_WXCOCOA_OBJC_CLASS(NSBox
);
3073 DECLARE_WXCOCOA_OBJC_CLASS(NSButton
);
3074 DECLARE_WXCOCOA_OBJC_CLASS(NSColor
);
3075 DECLARE_WXCOCOA_OBJC_CLASS(NSColorPanel
);
3076 DECLARE_WXCOCOA_OBJC_CLASS(NSControl
);
3077 DECLARE_WXCOCOA_OBJC_CLASS(NSCursor
);
3078 DECLARE_WXCOCOA_OBJC_CLASS(NSEvent
);
3079 DECLARE_WXCOCOA_OBJC_CLASS(NSFont
);
3080 DECLARE_WXCOCOA_OBJC_CLASS(NSFontDescriptor
);
3081 DECLARE_WXCOCOA_OBJC_CLASS(NSFontPanel
);
3082 DECLARE_WXCOCOA_OBJC_CLASS(NSImage
);
3083 DECLARE_WXCOCOA_OBJC_CLASS(NSLayoutManager
);
3084 DECLARE_WXCOCOA_OBJC_CLASS(NSMenu
);
3085 DECLARE_WXCOCOA_OBJC_CLASS(NSMenuExtra
);
3086 DECLARE_WXCOCOA_OBJC_CLASS(NSMenuItem
);
3087 DECLARE_WXCOCOA_OBJC_CLASS(NSMutableArray
);
3088 DECLARE_WXCOCOA_OBJC_CLASS(NSNotification
);
3089 DECLARE_WXCOCOA_OBJC_CLASS(NSObject
);
3090 DECLARE_WXCOCOA_OBJC_CLASS(NSPanel
);
3091 DECLARE_WXCOCOA_OBJC_CLASS(NSResponder
);
3092 DECLARE_WXCOCOA_OBJC_CLASS(NSScrollView
);
3093 DECLARE_WXCOCOA_OBJC_CLASS(NSSound
);
3094 DECLARE_WXCOCOA_OBJC_CLASS(NSStatusItem
);
3095 DECLARE_WXCOCOA_OBJC_CLASS(NSTableColumn
);
3096 DECLARE_WXCOCOA_OBJC_CLASS(NSTableView
);
3097 DECLARE_WXCOCOA_OBJC_CLASS(NSTextContainer
);
3098 DECLARE_WXCOCOA_OBJC_CLASS(NSTextField
);
3099 DECLARE_WXCOCOA_OBJC_CLASS(NSTextStorage
);
3100 DECLARE_WXCOCOA_OBJC_CLASS(NSThread
);
3101 DECLARE_WXCOCOA_OBJC_CLASS(NSWindow
);
3102 DECLARE_WXCOCOA_OBJC_CLASS(NSView
);
3103 DECLARE_WXCOCOA_OBJC_CLASS(NSOpenGLContext
);
3104 DECLARE_WXCOCOA_OBJC_CLASS(NSOpenGLPixelFormat
);
3105 DECLARE_WXCOCOA_OBJC_CLASS( NSPrintInfo
);
3107 typedef WX_NSView WXWidget
; /* wxWidgets BASE definition */
3109 #endif /* __WXCOCOA__ || ( __WXMAC__ &__DARWIN__)*/
3113 DECLARE_WXCOCOA_OBJC_CLASS(NSString
);
3117 typedef WX_NSWindow WXWindow
;
3118 typedef WX_NSView WXWidget
;
3119 typedef WX_NSMenu WXHMENU
;
3120 typedef WX_NSOpenGLPixelFormat WXGLPixelFormat
;
3121 typedef WX_NSOpenGLContext WXGLContext
;
3123 #elif wxOSX_USE_IPHONE
3125 DECLARE_WXCOCOA_OBJC_CLASS(UIWindow
);
3126 DECLARE_WXCOCOA_OBJC_CLASS(UIView
);
3127 DECLARE_WXCOCOA_OBJC_CLASS(UIFont
);
3128 DECLARE_WXCOCOA_OBJC_CLASS(UIImage
);
3129 DECLARE_WXCOCOA_OBJC_CLASS(UIEvent
);
3130 DECLARE_WXCOCOA_OBJC_CLASS(NSSet
);
3131 DECLARE_WXCOCOA_OBJC_CLASS(EAGLContext
);
3133 typedef WX_UIWindow WXWindow
;
3134 typedef WX_UIView WXWidget
;
3135 typedef WX_EAGLContext WXGLContext
;
3136 typedef WX_NSString
* WXGLPixelFormat
;
3140 #endif /* __WXMAC__ */
3142 /* ABX: check __WIN32__ instead of __WXMSW__ for the same MSWBase in any Win32 port */
3143 #if defined(__WIN32__)
3145 /* Stand-ins for Windows types to avoid #including all of windows.h */
3148 #define WX_MSW_DECLARE_HANDLE(type) typedef struct type##__ * WX##type
3150 #define WX_MSW_DECLARE_HANDLE(type) typedef void * WX##type
3153 typedef void* WXHANDLE
;
3154 WX_MSW_DECLARE_HANDLE(HWND
);
3155 WX_MSW_DECLARE_HANDLE(HICON
);
3156 WX_MSW_DECLARE_HANDLE(HFONT
);
3157 WX_MSW_DECLARE_HANDLE(HMENU
);
3158 WX_MSW_DECLARE_HANDLE(HPEN
);
3159 WX_MSW_DECLARE_HANDLE(HBRUSH
);
3160 WX_MSW_DECLARE_HANDLE(HPALETTE
);
3161 WX_MSW_DECLARE_HANDLE(HCURSOR
);
3162 WX_MSW_DECLARE_HANDLE(HRGN
);
3163 WX_MSW_DECLARE_HANDLE(RECTPTR
);
3164 WX_MSW_DECLARE_HANDLE(HACCEL
);
3165 WX_MSW_DECLARE_HANDLE(HINSTANCE
);
3166 WX_MSW_DECLARE_HANDLE(HBITMAP
);
3167 WX_MSW_DECLARE_HANDLE(HIMAGELIST
);
3168 WX_MSW_DECLARE_HANDLE(HGLOBAL
);
3169 WX_MSW_DECLARE_HANDLE(HDC
);
3170 typedef WXHINSTANCE WXHMODULE
;
3172 #undef WX_MSW_DECLARE_HANDLE
3174 typedef unsigned int WXUINT
;
3175 typedef unsigned long WXDWORD
;
3176 typedef unsigned short WXWORD
;
3178 typedef unsigned long WXCOLORREF
;
3179 typedef void * WXRGNDATA
;
3180 typedef struct tagMSG WXMSG
;
3181 typedef void * WXHCONV
;
3182 typedef void * WXHKEY
;
3183 typedef void * WXHTREEITEM
;
3185 typedef void * WXDRAWITEMSTRUCT
;
3186 typedef void * WXMEASUREITEMSTRUCT
;
3187 typedef void * WXLPCREATESTRUCT
;
3190 typedef WXHWND WXWidget
;
3194 typedef unsigned __int64 WXWPARAM
;
3195 typedef __int64 WXLPARAM
;
3196 typedef __int64 WXLRESULT
;
3198 typedef wxW64
unsigned int WXWPARAM
;
3199 typedef wxW64
long WXLPARAM
;
3200 typedef wxW64
long WXLRESULT
;
3203 #if defined(__GNUWIN32__) || defined(__WXMICROWIN__)
3204 typedef int (*WXFARPROC
)();
3206 typedef int (__stdcall
*WXFARPROC
)();
3208 #endif /* __WIN32__ */
3211 #if defined(__OS2__)
3212 typedef unsigned long DWORD
;
3213 typedef unsigned short WORD
;
3216 #if defined(__WXPM__) || defined(__EMX__)
3218 /* Stand-ins for OS/2 types, to avoid #including all of os2.h */
3219 typedef unsigned long WXHWND
;
3220 typedef unsigned long WXHANDLE
;
3221 typedef unsigned long WXHICON
;
3222 typedef unsigned long WXHFONT
;
3223 typedef unsigned long WXHMENU
;
3224 typedef unsigned long WXHPEN
;
3225 typedef unsigned long WXHBRUSH
;
3226 typedef unsigned long WXHPALETTE
;
3227 typedef unsigned long WXHCURSOR
;
3228 typedef unsigned long WXHRGN
;
3229 typedef unsigned long WXHACCEL
;
3230 typedef unsigned long WXHINSTANCE
;
3231 typedef unsigned long WXHMODULE
;
3232 typedef unsigned long WXHBITMAP
;
3233 typedef unsigned long WXHDC
;
3234 typedef unsigned int WXUINT
;
3235 typedef unsigned long WXDWORD
;
3236 typedef unsigned short WXWORD
;
3238 typedef unsigned long WXCOLORREF
;
3239 typedef void * WXMSG
;
3240 typedef unsigned long WXHTREEITEM
;
3242 typedef void * WXDRAWITEMSTRUCT
;
3243 typedef void * WXMEASUREITEMSTRUCT
;
3244 typedef void * WXLPCREATESTRUCT
;
3246 typedef WXHWND WXWidget
;
3249 /* Need a well-known type for WXFARPROC
3250 below. MPARAM is typedef'ed too late. */
3251 #define WXWPARAM void *
3252 #define WXLPARAM void *
3254 #define WXWPARAM MPARAM
3255 #define WXLPARAM MPARAM
3258 #define LOGFONT FATTRS
3259 #define LOWORD SHORT1FROMMP
3260 #define HIWORD SHORT2FROMMP
3262 typedef unsigned long WXMPARAM
;
3263 typedef unsigned long WXMSGID
;
3264 typedef void* WXRESULT
;
3265 /* typedef int (*WXFARPROC)(); */
3266 /* some windows handles not defined by PM */
3267 typedef unsigned long HANDLE
;
3268 typedef unsigned long HICON
;
3269 typedef unsigned long HFONT
;
3270 typedef unsigned long HMENU
;
3271 typedef unsigned long HPEN
;
3272 typedef unsigned long HBRUSH
;
3273 typedef unsigned long HPALETTE
;
3274 typedef unsigned long HCURSOR
;
3275 typedef unsigned long HINSTANCE
;
3276 typedef unsigned long HIMAGELIST
;
3277 typedef unsigned long HGLOBAL
;
3278 #endif /* WXPM || EMX */
3280 #if defined (__WXPM__)
3281 /* WIN32 graphics types for OS/2 GPI */
3283 /* RGB under OS2 is more like a PALETTEENTRY struct under Windows so we need a real RGB def */
3284 #define OS2RGB(r,g,b) ((DWORD)((unsigned char)(b) | ((unsigned char)(g) << 8)) | ((unsigned char)(r) << 16))
3286 typedef unsigned long COLORREF
;
3287 #define GetRValue(rgb) ((unsigned char)((rgb) >> 16))
3288 #define GetGValue(rgb) ((unsigned char)(((unsigned short)(rgb)) >> 8))
3289 #define GetBValue(rgb) ((unsigned char)(rgb))
3290 #define PALETTEINDEX(i) ((COLORREF)(0x01000000 | (DWORD)(WORD)(i)))
3291 #define PALETTERGB(r,g,b) (0x02000000 | OS2RGB(r,g,b))
3292 /* OS2's RGB/RGB2 is backwards from this */
3293 typedef struct tagPALETTEENTRY
3300 typedef struct tagLOGPALETTE
3304 WORD PALETTEENTRY
[1];
3307 #if (defined(__VISAGECPP__) && (__IBMCPP__ < 400)) || defined (__WATCOMC__)
3308 /* VA 3.0 for some reason needs base data types when typedefing a proc proto??? */
3309 typedef void* (_System
*WXFARPROC
)(unsigned long, unsigned long, void*, void*);
3311 #if defined(__EMX__) && !defined(_System)
3314 typedef WXRESULT (_System
*WXFARPROC
)(WXHWND
, WXMSGID
, WXWPARAM
, WXLPARAM
);
3317 #endif /* __WXPM__ */
3320 #if defined(__WXMOTIF__) || defined(__WXX11__)
3321 /* Stand-ins for X/Xt/Motif types */
3322 typedef void* WXWindow
;
3323 typedef void* WXWidget
;
3324 typedef void* WXAppContext
;
3325 typedef void* WXColormap
;
3326 typedef void* WXColor
;
3327 typedef void WXDisplay
;
3328 typedef void WXEvent
;
3329 typedef void* WXCursor
;
3330 typedef void* WXPixmap
;
3331 typedef void* WXFontStructPtr
;
3333 typedef void* WXRegion
;
3334 typedef void* WXFont
;
3335 typedef void* WXImage
;
3336 typedef void* WXFontList
;
3337 typedef void* WXFontSet
;
3338 typedef void* WXRendition
;
3339 typedef void* WXRenderTable
;
3340 typedef void* WXFontType
; /* either a XmFontList or XmRenderTable */
3341 typedef void* WXString
;
3343 typedef unsigned long Atom
; /* this might fail on a few architectures */
3344 typedef long WXPixel
; /* safety catch in src/motif/colour.cpp */
3350 /* Stand-ins for GLIB types */
3351 typedef struct _GSList GSList
;
3353 /* Stand-ins for GDK types */
3354 typedef struct _GdkColor GdkColor
;
3355 typedef struct _GdkCursor GdkCursor
;
3356 typedef struct _GdkDragContext GdkDragContext
;
3358 #if defined(__WXGTK20__)
3359 typedef struct _GdkAtom
* GdkAtom
;
3361 typedef unsigned long GdkAtom
;
3364 #if !defined(__WXGTK3__)
3365 typedef struct _GdkColormap GdkColormap
;
3366 typedef struct _GdkFont GdkFont
;
3367 typedef struct _GdkGC GdkGC
;
3368 typedef struct _GdkRegion GdkRegion
;
3371 #if defined(__WXGTK3__)
3372 typedef struct _GdkWindow GdkWindow
;
3373 #elif defined(__WXGTK20__)
3374 typedef struct _GdkDrawable GdkWindow
;
3375 typedef struct _GdkDrawable GdkPixmap
;
3377 typedef struct _GdkWindow GdkWindow
;
3378 typedef struct _GdkWindow GdkBitmap
;
3379 typedef struct _GdkWindow GdkPixmap
;
3382 /* Stand-ins for GTK types */
3383 typedef struct _GtkWidget GtkWidget
;
3384 typedef struct _GtkRcStyle GtkRcStyle
;
3385 typedef struct _GtkAdjustment GtkAdjustment
;
3386 typedef struct _GtkToolbar GtkToolbar
;
3387 typedef struct _GtkNotebook GtkNotebook
;
3388 typedef struct _GtkNotebookPage GtkNotebookPage
;
3389 typedef struct _GtkAccelGroup GtkAccelGroup
;
3390 typedef struct _GtkSelectionData GtkSelectionData
;
3391 typedef struct _GtkTextBuffer GtkTextBuffer
;
3392 typedef struct _GtkRange GtkRange
;
3393 typedef struct _GtkCellRenderer GtkCellRenderer
;
3395 typedef GtkWidget
*WXWidget
;
3398 #define GTK_OBJECT_GET_CLASS(object) (GTK_OBJECT(object)->klass)
3399 #define GTK_CLASS_TYPE(klass) ((klass)->type)
3402 #endif /* __WXGTK__ */
3404 #if defined(__WXGTK20__) || (defined(__WXX11__) && wxUSE_UNICODE)
3405 #define wxUSE_PANGO 1
3407 #define wxUSE_PANGO 0
3411 /* Stand-ins for Pango types */
3412 typedef struct _PangoContext PangoContext
;
3413 typedef struct _PangoLayout PangoLayout
;
3414 typedef struct _PangoFontDescription PangoFontDescription
;
3418 /* DirectFB doesn't have the concept of non-TLW window, so use
3419 something arbitrary */
3420 typedef const void* WXWidget
;
3423 /* This is required because of clashing macros in windows.h, which may be */
3424 /* included before or after wxWidgets classes, and therefore must be */
3425 /* disabled here before any significant wxWidgets headers are included. */
3428 #include "wx/msw/winundef.h"
3429 #endif /* __WINDOWS__ */
3430 #endif /* __cplusplus */
3433 /* include the feature test macros */
3434 #include "wx/features.h"
3436 /* --------------------------------------------------------------------------- */
3437 /* macros to define a class without copy ctor nor assignment operator */
3438 /* --------------------------------------------------------------------------- */
3440 #define wxDECLARE_NO_COPY_CLASS(classname) \
3442 classname(const classname&); \
3443 classname& operator=(const classname&)
3445 #define wxDECLARE_NO_COPY_TEMPLATE_CLASS(classname, arg) \
3447 classname(const classname<arg>&); \
3448 classname& operator=(const classname<arg>&)
3450 #define wxDECLARE_NO_COPY_TEMPLATE_CLASS_2(classname, arg1, arg2) \
3452 classname(const classname<arg1, arg2>&); \
3453 classname& operator=(const classname<arg1, arg2>&)
3455 #define wxDECLARE_NO_ASSIGN_CLASS(classname) \
3457 classname& operator=(const classname&)
3459 /* deprecated variants _not_ requiring a semicolon after them */
3460 #define DECLARE_NO_COPY_CLASS(classname) \
3461 wxDECLARE_NO_COPY_CLASS(classname);
3462 #define DECLARE_NO_COPY_TEMPLATE_CLASS(classname, arg) \
3463 wxDECLARE_NO_COPY_TEMPLATE_CLASS(classname, arg);
3464 #define DECLARE_NO_ASSIGN_CLASS(classname) \
3465 wxDECLARE_NO_ASSIGN_CLASS(classname);
3467 /* --------------------------------------------------------------------------- */
3468 /* If a manifest is being automatically generated, add common controls 6 to it */
3469 /* --------------------------------------------------------------------------- */
3472 (!defined wxUSE_NO_MANIFEST || wxUSE_NO_MANIFEST == 0 ) && \
3473 ( defined _MSC_FULL_VER && _MSC_FULL_VER >= 140040130 )
3475 #define WX_CC_MANIFEST(cpu) \
3476 "/manifestdependency:\"type='win32' \
3477 name='Microsoft.Windows.Common-Controls' \
3479 processorArchitecture='" cpu "' \
3480 publicKeyToken='6595b64144ccf1df' \
3484 #pragma comment(linker, WX_CC_MANIFEST("x86"))
3485 #elif defined _M_X64
3486 #pragma comment(linker, WX_CC_MANIFEST("amd64"))
3487 #elif defined _M_IA64
3488 #pragma comment(linker, WX_CC_MANIFEST("ia64"))
3490 #pragma comment(linker, WX_CC_MANIFEST("*"))
3493 #endif /* !wxUSE_NO_MANIFEST && _MSC_FULL_VER >= 140040130 */
3495 /* wxThread and wxProcess priorities */
3498 wxPRIORITY_MIN
= 0u, /* lowest possible priority */
3499 wxPRIORITY_DEFAULT
= 50u, /* normal priority */
3500 wxPRIORITY_MAX
= 100u /* highest possible priority */