made wxDELETE[A]() template functions instead of macros; they now also check that...
[wxWidgets.git] / include / wx / defs.h
1 /*
2 * Name: wx/defs.h
3 * Purpose: Declarations/definitions common to all wx source files
4 * Author: Julian Smart and others
5 * Modified by: Ryan Norton (Converted to C)
6 * Created: 01/02/97
7 * RCS-ID: $Id$
8 * Copyright: (c) Julian Smart
9 * Licence: wxWindows licence
10 */
11
12 /* THIS IS A C FILE, DON'T USE C++ FEATURES (IN PARTICULAR COMMENTS) IN IT */
13
14 #ifndef _WX_DEFS_H_
15 #define _WX_DEFS_H_
16
17 // NOTE: this symbol will be replaced with "WXWIN_COMPATIBILITY_3_0" as soon
18 // as the development branch for 3.1 is created
19 #define FUTURE_WXWIN_COMPATIBILITY_3_0 1
20 #define wxDEPRECATED_FUTURE( x ) x
21
22 /* ---------------------------------------------------------------------------- */
23 /* compiler and OS identification */
24 /* ---------------------------------------------------------------------------- */
25
26 #include "wx/platform.h"
27
28 #ifdef __cplusplus
29 /* Make sure the environment is set correctly */
30 # if defined(__WXMSW__) && defined(__X__)
31 # error "Target can't be both X and Windows"
32 # elif defined(__WXMSW__) && defined(__PALMOS__)
33 # error "Target can't be both PalmOS and Windows"
34 # elif !defined(__WXMOTIF__) && \
35 !defined(__WXMSW__) && \
36 !defined(__WXPALMOS__)&& \
37 !defined(__WXGTK__) && \
38 !defined(__WXPM__) && \
39 !defined(__WXMAC__) && \
40 !defined(__WXCOCOA__) && \
41 !defined(__X__) && \
42 !defined(__WXMGL__) && \
43 !defined(__WXDFB__) && \
44 !defined(__WXX11__) && \
45 wxUSE_GUI
46 # ifdef __UNIX__
47 # error "No Target! You should use wx-config program for compilation flags!"
48 # else /* !Unix */
49 # error "No Target! You should use supplied makefiles for compilation!"
50 # endif /* Unix/!Unix */
51 # endif
52 #endif /*__cplusplus*/
53
54 #ifndef __WXWINDOWS__
55 #define __WXWINDOWS__ 1
56 #endif
57
58 #ifndef wxUSE_BASE
59 /* by default consider that this is a monolithic build */
60 #define wxUSE_BASE 1
61 #endif
62
63 #if !wxUSE_GUI && !defined(__WXBASE__)
64 #define __WXBASE__
65 #endif
66
67 /* suppress some Visual C++ warnings */
68 #ifdef __VISUALC__
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:4710) /* function not inlined */
78
79 /* There are too many false positivies for this one, particularly when
80 using templates like wxVector<T> */
81 /* class 'foo' needs to have dll-interface to be used by clients of
82 class 'bar'" */
83 # pragma warning(disable:4251)
84
85 /* For VC++ 5.0 for release mode, the warning 'C4702: unreachable code */
86 /* is buggy, and occurs for code that does actually get executed */
87 # if !defined __WXDEBUG__ && __VISUALC__ <= 1100
88 # pragma warning(disable:4702) /* unreachable code */
89 # endif
90 /* The VC++ 5.0 warning 'C4003: not enough actual parameters for macro'
91 * is incompatible with the wxWidgets headers since it is given when
92 * parameters are empty but not missing. */
93 # if __VISUALC__ <= 1100
94 # pragma warning(disable:4003) /* not enough actual parameters for macro */
95 # endif
96
97 /*
98 When compiling with VC++ 7 /Wp64 option we get thousands of warnings for
99 conversion from size_t to int or long. Some precious few of them might
100 be worth looking into but unfortunately it seems infeasible to fix all
101 the other, harmless ones (e.g. inserting static_cast<int>(s.length())
102 everywhere this method is used though we are quite sure that using >4GB
103 strings is a bad idea anyhow) so just disable it globally for now.
104 */
105 #if wxCHECK_VISUALC_VERSION(7)
106 /* conversion from 'size_t' to 'unsigned long', possible loss of data */
107 #pragma warning(disable:4267)
108 #endif /* VC++ 7 or later */
109
110 /*
111 VC++ 8 gives a warning when using standard functions such as sprintf,
112 localtime, ... -- stop this madness, unless the user had already done it
113 */
114 #if wxCHECK_VISUALC_VERSION(8)
115 #ifndef _CRT_SECURE_NO_DEPRECATE
116 #define _CRT_SECURE_NO_DEPRECATE 1
117 #endif
118 #ifndef _CRT_NON_CONFORMING_SWPRINTFS
119 #define _CRT_NON_CONFORMING_SWPRINTFS 1
120 #endif
121 #endif /* VC++ 8 */
122 #endif /* __VISUALC__ */
123
124 /* suppress some Borland C++ warnings */
125 #ifdef __BORLANDC__
126 # pragma warn -inl /* Functions containing reserved words and certain constructs are not expanded inline */
127 #endif /* __BORLANDC__ */
128
129 /*
130 g++ gives a warning when a class has private dtor if it has no friends but
131 this is a perfectly valid situation for a ref-counted class which destroys
132 itself when its ref count drops to 0, so provide a macro to suppress this
133 warning
134 */
135 #ifdef __GNUG__
136 # define wxSUPPRESS_GCC_PRIVATE_DTOR_WARNING(name) \
137 friend class wxDummyFriendFor ## name;
138 #else /* !g++ */
139 # define wxSUPPRESS_GCC_PRIVATE_DTOR_WARNING(name)
140 #endif
141
142 /* ---------------------------------------------------------------------------- */
143 /* wxWidgets version and compatibility defines */
144 /* ---------------------------------------------------------------------------- */
145
146 #include "wx/version.h"
147
148 /* ============================================================================ */
149 /* non portable C++ features */
150 /* ============================================================================ */
151
152 /* ---------------------------------------------------------------------------- */
153 /* compiler defects workarounds */
154 /* ---------------------------------------------------------------------------- */
155
156 /*
157 Digital Unix C++ compiler only defines this symbol for .cxx and .hxx files,
158 so define it ourselves (newer versions do it for all files, though, and
159 don't allow it to be redefined)
160 */
161 #if defined(__DECCXX) && !defined(__VMS) && !defined(__cplusplus)
162 #define __cplusplus
163 #endif /* __DECCXX */
164
165 /* Resolves linking problems under HP-UX when compiling with gcc/g++ */
166 #if defined(__HPUX__) && defined(__GNUG__)
167 #define va_list __gnuc_va_list
168 #endif /* HP-UX */
169
170 /* ---------------------------------------------------------------------------- */
171 /* check for native bool type and TRUE/FALSE constants */
172 /* ---------------------------------------------------------------------------- */
173
174 /* Add more tests here for Windows compilers that already define bool */
175 /* (under Unix, configure tests for this) */
176 #ifndef HAVE_BOOL
177 #if defined( __MWERKS__ )
178 #if (__MWERKS__ >= 0x1000) && __option(bool)
179 #define HAVE_BOOL
180 #endif
181 #elif defined(__APPLE__) && defined(__APPLE_CC__)
182 /* Apple bundled gcc supports bool */
183 #define HAVE_BOOL
184 #elif defined(__VISUALC__) && (__VISUALC__ == 1020)
185 /* in VC++ 4.2 the bool keyword is reserved (hence can't be typedefed) */
186 /* but not implemented, so we must #define it */
187 #define bool unsigned int
188 #elif defined(__VISUALC__) && (__VISUALC__ == 1010)
189 /* For VisualC++ 4.1, we need to define */
190 /* bool as something between 4.0 & 5.0... */
191 typedef unsigned int wxbool;
192 #define bool wxbool
193 #define HAVE_BOOL
194 #elif defined(__VISUALC__) && (__VISUALC__ > 1020)
195 /* VC++ supports bool since 4.2 */
196 #define HAVE_BOOL
197 #elif defined(__BORLANDC__) && (__BORLANDC__ >= 0x500)
198 /* Borland 5.0+ supports bool */
199 #define HAVE_BOOL
200 #elif wxCHECK_WATCOM_VERSION(1,0)
201 /* Watcom 11+ supports bool */
202 #define HAVE_BOOL
203 #elif defined(__DIGITALMARS__)
204 /* DigitalMars supports bool */
205 #define HAVE_BOOL
206 #elif defined(__GNUWIN32__) || defined(__MINGW32__) || defined(__CYGWIN__)
207 /* Cygwin supports bool */
208 #define HAVE_BOOL
209 #elif defined(__VISAGECPP__)
210 #if __IBMCPP__ < 400
211 typedef unsigned long bool;
212 #define true ((bool)1)
213 #define false ((bool)0)
214 #endif
215 #define HAVE_BOOL
216 #elif defined(__WXPALMOS__)
217 /* Palm OS supports bool */
218 #define HAVE_BOOL
219 #endif /* compilers */
220 #endif /* HAVE_BOOL */
221
222 #if !defined(__MWERKS__) || !defined(true)
223 #if !defined(HAVE_BOOL) && !defined(bool) && !defined(VMS)
224 /* NB: of course, this doesn't replace the standard type, because, for */
225 /* example, overloading based on bool/int parameter doesn't work and */
226 /* so should be avoided in portable programs */
227 typedef unsigned int bool;
228 #endif /* bool */
229
230 /* deal with TRUE/true stuff: we assume that if the compiler supports bool, it */
231 /* supports true/false as well and that, OTOH, if it does _not_ support bool, */
232 /* it doesn't support these keywords (this is less sure, in particular VC++ */
233 /* 4.x could be a problem here) */
234 #ifndef HAVE_BOOL
235 #define true ((bool)1)
236 #define false ((bool)0)
237 #endif
238 #endif
239
240 /* for backwards compatibility, also define TRUE and FALSE */
241 /* */
242 /* note that these definitions should work both in C++ and C code, so don't */
243 /* use true/false below */
244 #ifndef TRUE
245 #define TRUE 1
246 #endif
247
248 #ifndef FALSE
249 #define FALSE 0
250 #endif
251
252 typedef short int WXTYPE;
253
254
255 /* ---------------------------------------------------------------------------- */
256 /* other feature tests */
257 /* ---------------------------------------------------------------------------- */
258
259 /* Every ride down a slippery slope begins with a single step.. */
260 /* */
261 /* Yes, using nested classes is indeed against our coding standards in */
262 /* general, but there are places where you can use them to advantage */
263 /* without totally breaking ports that cannot use them. If you do, then */
264 /* wrap it in this guard, but such cases should still be relatively rare. */
265 #define wxUSE_NESTED_CLASSES 1
266
267 /* check for explicit keyword support */
268 #ifndef HAVE_EXPLICIT
269 #if defined(__VISUALC__) && (__VISUALC__ >= 1100)
270 /* VC++ 6.0 and 5.0 have explicit (what about earlier versions?) */
271 #define HAVE_EXPLICIT
272 #elif ( defined(__MINGW32__) || defined(__CYGWIN32__) ) \
273 && wxCHECK_GCC_VERSION(2, 95)
274 /* GCC 2.95 has explicit, what about earlier versions? */
275 #define HAVE_EXPLICIT
276 #elif defined(__BORLANDC__) && (__BORLANDC__ >= 0x0520)
277 /* BC++ 4.52 doesn't support explicit, CBuilder 1 does */
278 #define HAVE_EXPLICIT
279 #elif defined(__MWERKS__) && (__MWERKS__ >= 0x2400)
280 /* Metrowerks CW6 or higher has explicit */
281 #define HAVE_EXPLICIT
282 #elif defined(__DIGITALMARS__)
283 #define HAVE_EXPLICIT
284 #elif defined(__WATCOMC__)
285 #define HAVE_EXPLICIT
286 #endif
287 #endif /* !HAVE_EXPLICIT */
288
289 #ifdef HAVE_EXPLICIT
290 #define wxEXPLICIT explicit
291 #else /* !HAVE_EXPLICIT */
292 #define wxEXPLICIT
293 #endif /* HAVE_EXPLICIT/!HAVE_EXPLICIT */
294
295 /* check for static/const_cast<>() (we don't use the other ones for now) */
296 #ifndef HAVE_CXX_CASTS
297 #if defined(__VISUALC__) && (__VISUALC__ >= 1100)
298 /* VC++ 6.0 and 5.0 have C++ casts (what about earlier versions?) */
299 #define HAVE_CXX_CASTS
300 #elif defined(__MINGW32__) || defined(__CYGWIN32__)
301 #if wxCHECK_GCC_VERSION(2, 95)
302 /* GCC 2.95 has C++ casts, what about earlier versions? */
303 #define HAVE_CXX_CASTS
304 #endif
305 #endif
306 #endif /* !HAVE_CXX_CASTS */
307
308 #ifdef HAVE_CXX_CASTS
309 #ifndef HAVE_CONST_CAST
310 #define HAVE_CONST_CAST
311 #endif
312 #ifndef HAVE_REINTERPRET_CAST
313 #define HAVE_REINTERPRET_CAST
314 #endif
315 #ifndef HAVE_STATIC_CAST
316 #define HAVE_STATIC_CAST
317 #endif
318 #ifndef HAVE_DYNAMIC_CAST
319 #define HAVE_DYNAMIC_CAST
320 #endif
321 #endif /* HAVE_CXX_CASTS */
322
323 #ifdef HAVE_STATIC_CAST
324 #define wx_static_cast(t, x) static_cast<t>(x)
325 #else
326 #define wx_static_cast(t, x) ((t)(x))
327 #endif
328
329 #ifdef HAVE_CONST_CAST
330 #define wx_const_cast(t, x) const_cast<t>(x)
331 #else
332 #define wx_const_cast(t, x) ((t)(x))
333 #endif
334
335 #ifdef HAVE_REINTERPRET_CAST
336 #define wx_reinterpret_cast(t, x) reinterpret_cast<t>(x)
337 #else
338 #define wx_reinterpret_cast(t, x) ((t)(x))
339 #endif
340
341 /*
342 This one is a wx invention: like static cast but used when we intentionally
343 truncate from a larger to smaller type, static_cast<> can't be used for it
344 as it results in warnings when using some compilers (SGI mipspro for example)
345 */
346 #if defined(__INTELC__) && defined(__cplusplus)
347 template <typename T, typename X>
348 inline T wx_truncate_cast_impl(X x)
349 {
350 #pragma warning(push)
351 /* implicit conversion of a 64-bit integral type to a smaller integral type */
352 #pragma warning(disable: 1682)
353 /* conversion from "X" to "T" may lose significant bits */
354 #pragma warning(disable: 810)
355
356 return x;
357
358 #pragma warning(pop)
359 }
360
361 #define wx_truncate_cast(t, x) wx_truncate_cast_impl<t>(x)
362
363 #elif defined(__cplusplus) && defined(__VISUALC__) && __VISUALC__ >= 1310
364 template <typename T, typename X>
365 inline T wx_truncate_cast_impl(X x)
366 {
367 #pragma warning(push)
368 /* conversion from 'X' to 'T', possible loss of data */
369 #pragma warning(disable: 4267)
370
371 return x;
372
373 #pragma warning(pop)
374 }
375
376 #define wx_truncate_cast(t, x) wx_truncate_cast_impl<t>(x)
377 #else
378 #define wx_truncate_cast(t, x) ((t)(x))
379 #endif
380
381 /* for consistency with wxStatic/DynamicCast defined in wx/object.h */
382 #define wxConstCast(obj, className) wx_const_cast(className *, obj)
383
384 #ifndef HAVE_STD_WSTRING
385 #if defined(__VISUALC__) && (__VISUALC__ >= 1100)
386 /* VC++ 6.0 and 5.0 have std::wstring (what about earlier versions?) */
387 #define HAVE_STD_WSTRING
388 #elif ( defined(__MINGW32__) || defined(__CYGWIN32__) ) \
389 && wxCHECK_GCC_VERSION(3, 3)
390 /* GCC 3.1 has std::wstring; 3.0 never was in MinGW, 2.95 hasn't it */
391 #define HAVE_STD_WSTRING
392 #endif
393 #endif
394
395 #ifndef HAVE_STD_STRING_COMPARE
396 #if defined(__VISUALC__) && (__VISUALC__ >= 1100)
397 /* VC++ 6.0 and 5.0 have std::string::compare */
398 /* (what about earlier versions?) */
399 #define HAVE_STD_STRING_COMPARE
400 #elif ( defined(__MINGW32__) || defined(__CYGWIN32__) ) \
401 && wxCHECK_GCC_VERSION(3, 1)
402 /* GCC 3.1 has std::string::compare; */
403 /* 3.0 never was in MinGW, 2.95 hasn't it */
404 #define HAVE_STD_STRING_COMPARE
405 #endif
406 #endif
407
408 /* provide replacement for C99 va_copy() if the compiler doesn't have it */
409
410 /* could be already defined by configure or the user */
411 #ifndef wxVaCopy
412 /* if va_copy is a macro or configure detected that we have it, use it */
413 #if defined(va_copy) || defined(HAVE_VA_COPY)
414 #define wxVaCopy va_copy
415 #else /* no va_copy, try to provide a replacement */
416 /*
417 configure tries to determine whether va_list is an array or struct
418 type, but it may not be used under Windows, so deal with a few
419 special cases.
420 */
421
422 #ifdef __WATCOMC__
423 /* Watcom uses array type for va_list except for PPC and Alpha */
424 #if !defined(__PPC__) && !defined(__AXP__)
425 #define VA_LIST_IS_ARRAY
426 #endif
427 #endif /* __WATCOMC__ */
428
429 #if defined(__PPC__) && (defined(_CALL_SYSV) || defined (_WIN32))
430 /*
431 PPC using SysV ABI and NT/PPC are special in that they use an
432 extra level of indirection.
433 */
434 #define VA_LIST_IS_POINTER
435 #endif /* SysV or Win32 on __PPC__ */
436
437 /*
438 note that we use memmove(), not memcpy(), in case anybody tries
439 to do wxVaCopy(ap, ap)
440 */
441 #if defined(VA_LIST_IS_POINTER)
442 #define wxVaCopy(d, s) memmove(*(d), *(s), sizeof(va_list))
443 #elif defined(VA_LIST_IS_ARRAY)
444 #define wxVaCopy(d, s) memmove((d), (s), sizeof(va_list))
445 #else /* we can only hope that va_lists are simple lvalues */
446 #define wxVaCopy(d, s) ((d) = (s))
447 #endif
448 #endif /* va_copy/!va_copy */
449 #endif /* wxVaCopy */
450
451 #ifndef HAVE_VARIADIC_MACROS
452 #if wxCHECK_WATCOM_VERSION(1,2)
453 #define HAVE_VARIADIC_MACROS
454 #endif
455 #endif /* HAVE_VARIADIC_MACROS */
456
457
458 #ifndef HAVE_WOSTREAM
459 // Mingw <= 3.4 and any version (so far) when targetting PalmOS don't have
460 // std::wostream
461 #if defined(__PALMOS__) || \
462 (defined(__MINGW32__) && !wxCHECK_GCC_VERSION(4, 0))
463 #define wxNO_WOSTREAM
464 #endif
465
466 // VC++ doesn't have it in the old iostream library
467 #if defined(__VISUALC__) && wxUSE_IOSTREAMH
468 #define wxNO_WOSTREAM
469 #endif
470
471 #ifndef wxNO_WOSTREAM
472 #define HAVE_WOSTREAM
473 #endif
474
475 #undef wxNO_WOSTREAM
476 #endif /* HAVE_WOSTREAM */
477
478 // ----------------------------------------------------------------------------
479 // other C++ features
480 // ----------------------------------------------------------------------------
481
482 #ifndef HAVE_PARTIAL_SPECIALIZATION
483 // be optimistic by default
484 #define HAVE_PARTIAL_SPECIALIZATION
485 #endif
486
487 #ifdef __VISUALC__
488 #if __VISUALC__ < 1310
489 #undef HAVE_PARTIAL_SPECIALIZATION
490 #endif
491 #endif // __VISUALC__
492
493
494 #ifndef HAVE_TEMPLATE_OVERLOAD_RESOLUTION
495 // assume the compiler can use type or const expressions as template
496 // arguments if it supports partial specialization -- except if it's a
497 // Borland one which can't
498 #if defined(HAVE_PARTIAL_SPECIALIZATION) && !defined(__BORLANDC__)
499 #define HAVE_TEMPLATE_OVERLOAD_RESOLUTION
500 #endif // __BORLANDC__
501 #endif // !defined(HAVE_TEMPLATE_OVERLOAD_RESOLUTION)
502
503 /* ---------------------------------------------------------------------------- */
504 /* portable calling conventions macros */
505 /* ---------------------------------------------------------------------------- */
506
507 /* stdcall is used for all functions called by Windows under Windows */
508 #if defined(__WINDOWS__)
509 #if defined(__GNUWIN32__)
510 #define wxSTDCALL __attribute__((stdcall))
511 #else
512 /* both VC++ and Borland understand this */
513 #define wxSTDCALL _stdcall
514 #endif
515
516 #else /* Win */
517 /* no such stupidness under Unix */
518 #define wxSTDCALL
519 #endif /* platform */
520
521 /* LINKAGEMODE mode is empty for everyting except OS/2 */
522 #ifndef LINKAGEMODE
523 #define LINKAGEMODE
524 #endif /* LINKAGEMODE */
525
526 /* wxCALLBACK should be used for the functions which are called back by */
527 /* Windows (such as compare function for wxListCtrl) */
528 #if defined(__WIN32__) && !defined(__WXMICROWIN__)
529 #define wxCALLBACK wxSTDCALL
530 #else
531 /* no stdcall under Unix nor Win16 */
532 #define wxCALLBACK
533 #endif /* platform */
534
535 /* generic calling convention for the extern "C" functions */
536
537 #if defined(__VISUALC__)
538 #define wxC_CALLING_CONV _cdecl
539 #elif defined(__VISAGECPP__)
540 #define wxC_CALLING_CONV _Optlink
541 #else /* !Visual C++ */
542 #define wxC_CALLING_CONV
543 #endif /* compiler */
544
545 /* callling convention for the qsort(3) callback */
546 #define wxCMPFUNC_CONV wxC_CALLING_CONV
547
548 /* compatibility :-( */
549 #define CMPFUNC_CONV wxCMPFUNC_CONV
550
551 /* DLL import/export declarations */
552 #include "wx/dlimpexp.h"
553
554 /* ---------------------------------------------------------------------------- */
555 /* Very common macros */
556 /* ---------------------------------------------------------------------------- */
557
558 /* Printf-like attribute definitions to obtain warnings with GNU C/C++ */
559 #ifndef ATTRIBUTE_PRINTF
560 # if defined(__GNUC__) && !wxUSE_UNICODE
561 # define ATTRIBUTE_PRINTF(m, n) __attribute__ ((__format__ (__printf__, m, n)))
562 # else
563 # define ATTRIBUTE_PRINTF(m, n)
564 # endif
565
566 # define ATTRIBUTE_PRINTF_1 ATTRIBUTE_PRINTF(1, 2)
567 # define ATTRIBUTE_PRINTF_2 ATTRIBUTE_PRINTF(2, 3)
568 # define ATTRIBUTE_PRINTF_3 ATTRIBUTE_PRINTF(3, 4)
569 # define ATTRIBUTE_PRINTF_4 ATTRIBUTE_PRINTF(4, 5)
570 # define ATTRIBUTE_PRINTF_5 ATTRIBUTE_PRINTF(5, 6)
571 #endif /* !defined(ATTRIBUTE_PRINTF) */
572
573
574 /* Macro to issue warning when using deprecated functions with gcc3 or MSVC7: */
575 #if wxCHECK_GCC_VERSION(3, 1)
576 #define wxDEPRECATED(x) __attribute__((deprecated)) x
577 #elif defined(__VISUALC__) && (__VISUALC__ >= 1300)
578 #define wxDEPRECATED(x) __declspec(deprecated) x
579 #else
580 #define wxDEPRECATED(x) x
581 #endif
582
583 /*
584 Macro which marks the function as being deprecated but also defines it
585 inline.
586
587 Currently it's defined in the same trivial way in all cases but it could
588 need a special definition with some other compilers in the future which
589 explains why do we have it.
590 */
591 #define wxDEPRECATED_INLINE(func, body) wxDEPRECATED(func) { body }
592
593 /*
594 Special variant of the macro above which should be used for the functions
595 which are deprecated but called by wx itself: this often happens with
596 deprecated virtual functions which are called by the library.
597 */
598 #ifdef WXBUILDING
599 # define wxDEPRECATED_BUT_USED_INTERNALLY(x) x
600 #else
601 # define wxDEPRECATED_BUT_USED_INTERNALLY(x) wxDEPRECATED(x)
602 #endif
603
604 /* everybody gets the assert and other debug macros */
605 #include "wx/debug.h"
606
607 /* NULL declaration: it must be defined as 0 for C++ programs (in particular, */
608 /* it must not be defined as "(void *)0" which is standard for C but completely */
609 /* breaks C++ code) */
610 #if !defined(__HANDHELDPC__) && !defined(__PALMOS__)
611 #include <stddef.h>
612 #endif
613
614 #ifdef __cplusplus
615 // delete pointer if it is not NULL and NULL it afterwards
616 template <typename T>
617 inline void wxDELETE(T*& ptr)
618 {
619 typedef char TypeIsCompleteCheck[sizeof(T)];
620
621 if ( ptr != NULL )
622 {
623 delete ptr;
624 ptr = NULL;
625 }
626 }
627
628 // delete an array and NULL it (see comments above)
629 template <typename T>
630 inline void wxDELETEA(T*& ptr)
631 {
632 typedef char TypeIsCompleteCheck[sizeof(T)];
633
634 if ( ptr != NULL )
635 {
636 delete [] ptr;
637 ptr = NULL;
638 }
639 }
640 #endif /*__cplusplus*/
641
642 /* size of statically declared array */
643 #define WXSIZEOF(array) (sizeof(array)/sizeof(array[0]))
644
645 /* symbolic constant used by all Find()-like functions returning positive */
646 /* integer on success as failure indicator */
647 #define wxNOT_FOUND (-1)
648
649 /* ---------------------------------------------------------------------------- */
650 /* macros dealing with comparison operators */
651 /* ---------------------------------------------------------------------------- */
652
653 /*
654 Expands into m(op, args...) for each op in the set { ==, !=, <, <=, >, >= }.
655 */
656 #define wxFOR_ALL_COMPARISONS(m) \
657 m(==) m(!=) m(>=) m(<=) m(>) m(<)
658
659 #define wxFOR_ALL_COMPARISONS_1(m, x) \
660 m(==,x) m(!=,x) m(>=,x) m(<=,x) m(>,x) m(<,x)
661
662 #define wxFOR_ALL_COMPARISONS_2(m, x, y) \
663 m(==,x,y) m(!=,x,y) m(>=,x,y) m(<=,x,y) m(>,x,y) m(<,x,y)
664
665 #define wxFOR_ALL_COMPARISONS_3(m, x, y, z) \
666 m(==,x,y,z) m(!=,x,y,z) m(>=,x,y,z) m(<=,x,y,z) m(>,x,y,z) m(<,x,y,z)
667
668 /*
669 This is only used with wxDEFINE_COMPARISON_REV: it passes both the normal
670 and the reversed comparison operators to the macro.
671 */
672 #define wxFOR_ALL_COMPARISONS_3_REV(m, x, y, z) \
673 m(==,x,y,z,==) m(!=,x,y,z,!=) m(>=,x,y,z,<=) \
674 m(<=,x,y,z,>=) m(>,x,y,z,<) m(<,x,y,z,>)
675
676
677 #define wxDEFINE_COMPARISON(op, T1, T2, cmp) \
678 inline bool operator op(T1 x, T2 y) { return cmp(x, y, op); }
679
680 #define wxDEFINE_COMPARISON_REV(op, T1, T2, cmp, oprev) \
681 inline bool operator op(T2 y, T1 x) { return cmp(x, y, oprev); }
682
683 /*
684 Define all 6 comparison operators (==, !=, <, <=, >, >=) for the given
685 types in the specified order. The implementation is provided by the cmp
686 macro. Normally wxDEFINE_ALL_COMPARISONS should be used as comparison
687 operators are usually symmetric.
688 */
689 #define wxDEFINE_COMPARISONS(T1, T2, cmp) \
690 wxFOR_ALL_COMPARISONS_3(wxDEFINE_COMPARISON, T1, T2, cmp)
691
692 /*
693 This macro allows to define all 12 comparison operators (6 operators for
694 both orders of arguments) for the given types using the provided "cmp"
695 macro to implement the actual comparison: the macro is called with the 2
696 arguments names, the first of type T1 and the second of type T2, and the
697 comparison operator being implemented.
698 */
699 #define wxDEFINE_ALL_COMPARISONS(T1, T2, cmp) \
700 wxFOR_ALL_COMPARISONS_3(wxDEFINE_COMPARISON, T1, T2, cmp) \
701 wxFOR_ALL_COMPARISONS_3_REV(wxDEFINE_COMPARISON_REV, T1, T2, cmp)
702
703 /* ---------------------------------------------------------------------------- */
704 /* macros to avoid compiler warnings */
705 /* ---------------------------------------------------------------------------- */
706
707 /* Macro to cut down on compiler warnings. */
708 #if 1 /* there should be no more any compilers needing the "#else" version */
709 #define WXUNUSED(identifier) /* identifier */
710 #else /* stupid, broken compiler */
711 #define WXUNUSED(identifier) identifier
712 #endif
713
714 /* some arguments are only used in debug mode, but unused in release one */
715 #ifdef __WXDEBUG__
716 #define WXUNUSED_UNLESS_DEBUG(param) param
717 #else
718 #define WXUNUSED_UNLESS_DEBUG(param) WXUNUSED(param)
719 #endif
720
721 /* some arguments are not used in unicode mode */
722 #if wxUSE_UNICODE
723 #define WXUNUSED_IN_UNICODE(param) WXUNUSED(param)
724 #else
725 #define WXUNUSED_IN_UNICODE(param) param
726 #endif
727
728 /* some arguments are not used in WinCE build */
729 #ifdef __WXWINCE__
730 #define WXUNUSED_IN_WINCE(param) WXUNUSED(param)
731 #else
732 #define WXUNUSED_IN_WINCE(param) param
733 #endif
734
735 /* unused parameters in non stream builds */
736 #if wxUSE_STREAMS
737 #define WXUNUSED_UNLESS_STREAMS(param) param
738 #else
739 #define WXUNUSED_UNLESS_STREAMS(param) WXUNUSED(param)
740 #endif
741
742 /* some compilers give warning about a possibly unused variable if it is */
743 /* initialized in both branches of if/else and shut up if it is initialized */
744 /* when declared, but other compilers then give warnings about unused variable */
745 /* value -- this should satisfy both of them */
746 #if defined(__VISUALC__)
747 #define wxDUMMY_INITIALIZE(val) = val
748 #else
749 #define wxDUMMY_INITIALIZE(val)
750 #endif
751
752 /* sometimes the value of a variable is *really* not used, to suppress the */
753 /* resulting warning you may pass it to this function */
754 #ifdef __cplusplus
755 # ifdef __BORLANDC__
756 # define wxUnusedVar(identifier) identifier
757 # else
758 template <class T>
759 inline void wxUnusedVar(const T& WXUNUSED(t)) { }
760 # endif
761 #endif
762
763 /* ---------------------------------------------------------------------------- */
764 /* compiler specific settings */
765 /* ---------------------------------------------------------------------------- */
766
767 /* to allow compiling with warning level 4 under Microsoft Visual C++ some */
768 /* warnings just must be disabled */
769 #ifdef __VISUALC__
770 #pragma warning(disable: 4514) /* unreferenced inline func has been removed */
771 /*
772 you might be tempted to disable this one also: triggered by CHECK and FAIL
773 macros in debug.h, but it's, overall, a rather useful one, so I leave it and
774 will try to find some way to disable this warning just for CHECK/FAIL. Anyone?
775 */
776 #pragma warning(disable: 4127) /* conditional expression is constant */
777 #endif /* VC++ */
778
779 #if defined(__MWERKS__)
780 #undef try
781 #undef except
782 #undef finally
783 #define except(x) catch(...)
784 #endif /* Metrowerks */
785
786 #if wxONLY_WATCOM_EARLIER_THAN(1,4)
787 typedef short mode_t;
788 #endif
789
790 /* where should i put this? we need to make sure of this as it breaks */
791 /* the <iostream> code. */
792 #if !wxUSE_IOSTREAMH && defined(__WXDEBUG__)
793 # ifndef __MWERKS__
794 /* #undef __WXDEBUG__ */
795 # ifdef wxUSE_DEBUG_NEW_ALWAYS
796 # undef wxUSE_DEBUG_NEW_ALWAYS
797 # define wxUSE_DEBUG_NEW_ALWAYS 0
798 # endif
799 # endif
800 #endif
801
802 /* ---------------------------------------------------------------------------- */
803 /* standard wxWidgets types */
804 /* ---------------------------------------------------------------------------- */
805
806 /* the type for screen and DC coordinates */
807 typedef int wxCoord;
808
809 enum { wxDefaultCoord = -1 };
810
811 /* ---------------------------------------------------------------------------- */
812 /* define fixed length types */
813 /* ---------------------------------------------------------------------------- */
814
815 #if defined(__WXPALMOS__) || defined(__MINGW32__)
816 #if !defined(__MWERKS__)
817 #include <sys/types.h>
818 #endif
819 #endif
820
821 /* chars are always one byte (by definition), shorts are always two (in */
822 /* practice) */
823
824 /* 8bit */
825 typedef signed char wxInt8;
826 typedef unsigned char wxUint8;
827 typedef wxUint8 wxByte;
828
829
830 /* 16bit */
831 #ifdef SIZEOF_SHORT
832 #if SIZEOF_SHORT != 2
833 #error "wxWidgets assumes sizeof(short) == 2, please fix the code"
834 #endif
835 #else
836 #define SIZEOF_SHORT 2
837 #endif
838
839 typedef signed short wxInt16;
840 typedef unsigned short wxUint16;
841
842 typedef wxUint16 wxWord;
843
844 /*
845 things are getting more interesting with ints, longs and pointers
846
847 there are several different standard data models described by this table:
848
849 +-----------+----------------------------+
850 |type\model | LP64 ILP64 LLP64 ILP32 LP32|
851 +-----------+----------------------------+
852 |char | 8 8 8 8 8 |
853 |short | 16 16 16 16 16 |
854 |int | 32 64 32 32 16 |
855 |long | 64 64 32 32 32 |
856 |long long | 64 64 64 -- -- |
857 |void * | 64 64 64 32 32 |
858 +-----------+----------------------------+
859
860 Win16 used LP32 (but we don't support it any longer), Win32 obviously used
861 ILP32 and Win64 uses LLP64 (a.k.a. P64)
862
863 Under Unix LP64 is the most widely used (the only I've ever seen, in fact)
864 */
865
866 /* 32bit */
867 #ifdef __PALMOS__
868 typedef int wxInt32;
869 typedef unsigned int wxUint32;
870 #define SIZEOF_INT 4
871 #define SIZEOF_LONG 4
872 #define SIZEOF_WCHAR_T 2
873 #define SIZEOF_SIZE_T 4
874 #ifdef __WXPALMOS6__
875 #define wxSIZE_T_IS_UINT
876 #endif
877 #define SIZEOF_VOID_P 4
878 #define SIZEOF_SIZE_T 4
879 #elif defined(__WINDOWS__)
880 /* Win64 uses LLP64 model and so ints and longs have the same size as in */
881 /* Win32 */
882 #if defined(__WIN32__)
883 typedef int wxInt32;
884 typedef unsigned int wxUint32;
885
886 /* Assume that if SIZEOF_INT is defined that all the other ones except
887 SIZEOF_SIZE_T, are too. See next #if below. */
888 #ifndef SIZEOF_INT
889 #define SIZEOF_INT 4
890 #define SIZEOF_LONG 4
891 #define SIZEOF_WCHAR_T 2
892
893 /*
894 under Win64 sizeof(size_t) == 8 and so it is neither unsigned
895 int nor unsigned long!
896 */
897 #ifdef __WIN64__
898 #define SIZEOF_SIZE_T 8
899
900 #undef wxSIZE_T_IS_UINT
901 #else /* Win32 */
902 #define SIZEOF_SIZE_T 4
903
904 #define wxSIZE_T_IS_UINT
905 #endif
906 #undef wxSIZE_T_IS_ULONG
907
908 #ifdef __WIN64__
909 #define SIZEOF_VOID_P 8
910 #else /* Win32 */
911 #define SIZEOF_VOID_P 4
912 #endif /* Win64/32 */
913 #endif /* !defined(SIZEOF_INT) */
914
915 /*
916 If Python.h was included first, it defines all of the SIZEOF's above
917 except for SIZEOF_SIZE_T, so we need to do it here to avoid
918 triggering the #error in the ssize_t typedefs below...
919 */
920 #ifndef SIZEOF_SIZE_T
921 #ifdef __WIN64__
922 #define SIZEOF_SIZE_T 8
923 #else /* Win32 */
924 #define SIZEOF_SIZE_T 4
925 #endif
926 #endif
927 #else
928 #error "Unsupported Windows version"
929 #endif
930 #else /* !Windows */
931 /* SIZEOF_XXX are normally defined by configure */
932 #ifdef SIZEOF_INT
933 #if SIZEOF_INT == 8
934 /* must be ILP64 data model, there is normally a special 32 bit */
935 /* type in it but we don't know what it is... */
936 #error "No 32bit int type on this platform"
937 #elif SIZEOF_INT == 4
938 typedef int wxInt32;
939 typedef unsigned int wxUint32;
940 #elif SIZEOF_INT == 2
941 /* must be LP32 */
942 #if SIZEOF_LONG != 4
943 #error "No 32bit int type on this platform"
944 #endif
945
946 typedef long wxInt32;
947 typedef unsigned long wxUint32;
948 #else
949 /* wxWidgets is not ready for 128bit systems yet... */
950 #error "Unknown sizeof(int) value, what are you compiling for?"
951 #endif
952 #else /* !defined(SIZEOF_INT) */
953 /* assume default 32bit machine -- what else can we do? */
954 wxCOMPILE_TIME_ASSERT( sizeof(int) == 4, IntMustBeExactly4Bytes);
955 wxCOMPILE_TIME_ASSERT( sizeof(size_t) == 4, SizeTMustBeExactly4Bytes);
956 wxCOMPILE_TIME_ASSERT( sizeof(void *) == 4, PtrMustBeExactly4Bytes);
957
958 #define SIZEOF_INT 4
959 #define SIZEOF_SIZE_T 4
960 #define SIZEOF_VOID_P 4
961
962 typedef int wxInt32;
963 typedef unsigned int wxUint32;
964
965 #if defined(__MACH__) && !defined(SIZEOF_WCHAR_T)
966 #define SIZEOF_WCHAR_T 4
967 #endif
968 #if wxUSE_WCHAR_T && !defined(SIZEOF_WCHAR_T)
969 /* also assume that sizeof(wchar_t) == 2 (under Unix the most */
970 /* common case is 4 but there configure would have defined */
971 /* SIZEOF_WCHAR_T for us) */
972 /* the most common case */
973 wxCOMPILE_TIME_ASSERT( sizeof(wchar_t) == 2,
974 Wchar_tMustBeExactly2Bytes);
975
976 #define SIZEOF_WCHAR_T 2
977 #endif /* wxUSE_WCHAR_T */
978 #endif
979 #endif /* Win/!Win */
980
981 /* also define C99-like sized MIN/MAX constants */
982 #define wxINT8_MIN CHAR_MIN
983 #define wxINT8_MAX CHAR_MAX
984
985 #define wxINT16_MIN SHRT_MIN
986 #define wxINT16_MAX SHRT_MAX
987
988 #if SIZEOF_INT == 4
989 #define wxINT32_MIN INT_MIN
990 #define wxINT32_MAX INT_MAX
991 #elif SIZEOF_LONG == 4
992 #define wxINT32_MIN LONG_MIN
993 #define wxINT32_MAX LONG_MAX
994 #else
995 #error "Unknown 32 bit type"
996 #endif
997
998 typedef wxUint32 wxDword;
999
1000 #ifdef LLONG_MAX
1001 #define wxINT64_MAX LLONG_MAX
1002 #define wxINT64_MIN LLONG_MIN
1003 #else
1004 #define wxINT64_MAX wxLL(9223372036854775807)
1005 #define wxINT64_MIN (wxLL(-9223372036854775807)-1)
1006 #endif
1007
1008 /* 64 bit */
1009
1010 /* NB: we #define and not typedef wxLongLong_t because we use "#ifdef */
1011 /* wxLongLong_t" in wx/longlong.h */
1012
1013 /* wxULongLong_t is set later (usually to unsigned wxLongLong_t) */
1014
1015 /* to avoid compilation problems on 64bit machines with ambiguous method calls */
1016 /* we will need to define this */
1017 #undef wxLongLongIsLong
1018
1019 /*
1020 First check for specific compilers which have known 64 bit integer types,
1021 this avoids clashes with SIZEOF_LONG[_LONG] being defined incorrectly for
1022 e.g. MSVC builds (Python.h defines it as 8 even for MSVC).
1023
1024 Also notice that we check for "long long" before checking for 64 bit long as
1025 we still want to use "long long" and not "long" for wxLongLong_t on 64 bit
1026 architectures to be able to pass wxLongLong_t to the standard functions
1027 prototyped as taking "long long" such as strtoll().
1028 */
1029 #if (defined(__VISUALC__) && defined(__WIN32__))
1030 #define wxLongLong_t __int64
1031 #define wxLongLongSuffix i64
1032 #define wxLongLongFmtSpec _T("I64")
1033 #elif defined(__BORLANDC__) && defined(__WIN32__) && (__BORLANDC__ >= 0x520)
1034 #define wxLongLong_t __int64
1035 #define wxLongLongSuffix i64
1036 #define wxLongLongFmtSpec _T("L")
1037 #elif (defined(__WATCOMC__) && (defined(__WIN32__) || defined(__DOS__) || defined(__OS2__)))
1038 #define wxLongLong_t __int64
1039 #define wxLongLongSuffix i64
1040 #define wxLongLongFmtSpec _T("L")
1041 #elif defined(__DIGITALMARS__)
1042 #define wxLongLong_t __int64
1043 #define wxLongLongSuffix LL
1044 #define wxLongLongFmtSpec _T("ll")
1045 #elif defined(__MINGW32__)
1046 #define wxLongLong_t long long
1047 #define wxLongLongSuffix ll
1048 #define wxLongLongFmtSpec _T("I64")
1049 #elif defined(__MWERKS__)
1050 #if __option(longlong)
1051 #define wxLongLong_t long long
1052 #define wxLongLongSuffix ll
1053 #define wxLongLongFmtSpec _T("ll")
1054 #else
1055 #error "The 64 bit integer support in CodeWarrior has been disabled."
1056 #error "See the documentation on the 'longlong' pragma."
1057 #endif
1058 #elif defined(__WXPALMOS__)
1059 #if defined(__WXPALMOS6__)
1060 #define wxLongLong_t int64_t
1061 #else
1062 #define wxLongLong_t long long
1063 #endif /* __WXPALMOS6__ */
1064 #define wxLongLongSuffix ll
1065 #define wxLongLongFmtSpec _T("ll")
1066 #elif defined(__VISAGECPP__) && __IBMCPP__ >= 400
1067 #define wxLongLong_t long long
1068 #elif (defined(SIZEOF_LONG_LONG) && SIZEOF_LONG_LONG >= 8) || \
1069 defined(__GNUC__) || \
1070 defined(__CYGWIN__) || \
1071 defined(__WXMICROWIN__) || \
1072 (defined(__DJGPP__) && __DJGPP__ >= 2)
1073 #define wxLongLong_t long long
1074 #define wxLongLongSuffix ll
1075 #define wxLongLongFmtSpec _T("ll")
1076 #elif defined(SIZEOF_LONG) && (SIZEOF_LONG == 8)
1077 #define wxLongLong_t long
1078 #define wxLongLongSuffix l
1079 #define wxLongLongFmtSpec _T("l")
1080 #define wxLongLongIsLong
1081 #endif
1082
1083
1084 #ifdef wxLongLong_t
1085
1086 #ifdef __WXPALMOS__
1087 #if defined(__WXPALMOS6__)
1088 #define wxULongLong_t uint64_t
1089 #else
1090 #define wxULongLong_t unsigned long long
1091 #endif /* __WXPALMOS6__ */
1092 #else
1093 #define wxULongLong_t unsigned wxLongLong_t
1094 #endif
1095
1096 /* these macros allow to define 64 bit constants in a portable way */
1097 #define wxLL(x) wxCONCAT(x, wxLongLongSuffix)
1098 #define wxULL(x) wxCONCAT(x, wxCONCAT(u, wxLongLongSuffix))
1099
1100 typedef wxLongLong_t wxInt64;
1101 typedef wxULongLong_t wxUint64;
1102
1103 #define wxHAS_INT64 1
1104
1105 #elif wxUSE_LONGLONG
1106 /* these macros allow to define 64 bit constants in a portable way */
1107 #define wxLL(x) wxLongLong(x)
1108 #define wxULL(x) wxULongLong(x)
1109
1110 #define wxInt64 wxLongLong
1111 #define wxUint64 wxULongLong
1112
1113 #define wxHAS_INT64 1
1114
1115 #else /* !wxUSE_LONGLONG */
1116
1117 #define wxHAS_INT64 0
1118
1119 #endif
1120
1121
1122 /* Make sure ssize_t is defined (a signed type the same size as size_t) */
1123 /* HAVE_SSIZE_T should be defined for compiliers that already have it */
1124 #ifdef __MINGW32__
1125 #if defined(_SSIZE_T_) && !defined(HAVE_SSIZE_T)
1126 #define HAVE_SSIZE_T
1127 #endif
1128 #endif
1129 #if defined(__PALMOS__) && !defined(HAVE_SSIZE_T)
1130 #define HAVE_SSIZE_T
1131 #endif
1132 #if wxCHECK_WATCOM_VERSION(1,4)
1133 #define HAVE_SSIZE_T
1134 #endif
1135 #ifdef HAVE_SSIZE_T
1136 #ifdef __UNIX__
1137 #include <sys/types.h>
1138 #endif
1139 #else // !HAVE_SSIZE_T
1140 #if SIZEOF_SIZE_T == 4
1141 typedef wxInt32 ssize_t;
1142 #elif SIZEOF_SIZE_T == 8
1143 typedef wxInt64 ssize_t;
1144 #else
1145 #error "error defining ssize_t, size_t is not 4 or 8 bytes"
1146 #endif
1147 #endif
1148
1149 // we can't rely on Windows _W64 being defined as windows.h may not be included
1150 // so define our own equivalent: this should be used with types like WXLPARAM
1151 // or WXWPARAM which are 64 bit under Win64 to avoid warnings each time we cast
1152 // it to a pointer or a handle (which results in hundreds of warnings as Win32
1153 // API often passes pointers in them)
1154 #if wxCHECK_VISUALC_VERSION(7)
1155 #define wxW64 __w64
1156 #else
1157 #define wxW64
1158 #endif
1159
1160 /*
1161 Define signed and unsigned integral types big enough to contain all of long,
1162 size_t and void *.
1163 */
1164 #if SIZEOF_SIZE_T >= SIZEOF_VOID_P
1165 /*
1166 Win64 case: size_t is the only integral type big enough for "void *".
1167
1168 Notice that we must use __w64 to avoid warnings about casting pointers
1169 to wxIntPtr (which we do often as this is what it is defined for) in 32
1170 bit build with MSVC.
1171 */
1172 typedef wxW64 ssize_t wxIntPtr;
1173 typedef size_t wxUIntPtr;
1174 #elif SIZEOF_LONG >= SIZEOF_VOID_P
1175 /*
1176 Normal case when long is the largest integral type.
1177 */
1178 typedef long wxIntPtr;
1179 typedef unsigned long wxUIntPtr;
1180 #else
1181 /*
1182 This should never happen for the current architectures but if you're
1183 using one where it does, please contact wx-dev@lists.wxwidgets.org.
1184 */
1185 #error "Pointers can't be stored inside integer types."
1186 #endif
1187
1188 #ifdef __cplusplus
1189 /* And also define a couple of simple functions to cast pointer to/from it. */
1190 inline wxUIntPtr wxPtrToUInt(const void *p)
1191 {
1192 /*
1193 VC++ 7.1 gives warnings about casts such as below even when they're
1194 explicit with /Wp64 option, suppress them as we really know what we're
1195 doing here. Same thing with icc with -Wall.
1196 */
1197 #ifdef __VISUALC__
1198 #if __VISUALC__ >= 1200
1199 #pragma warning(push)
1200 #endif
1201 /* pointer truncation from '' to '' */
1202 #pragma warning(disable: 4311)
1203 #elif defined(__INTELC__)
1204 #pragma warning(push)
1205 /* conversion from pointer to same-sized integral type */
1206 #pragma warning(disable: 1684)
1207 #endif
1208
1209 return wx_reinterpret_cast(wxUIntPtr, p);
1210
1211 #if (defined(__VISUALC__) && __VISUALC__ >= 1200) || defined(__INTELC__)
1212 #pragma warning(pop)
1213 #endif
1214 }
1215
1216 inline void *wxUIntToPtr(wxUIntPtr p)
1217 {
1218 #ifdef __VISUALC__
1219 #if __VISUALC__ >= 1200
1220 #pragma warning(push)
1221 #endif
1222 /* conversion to type of greater size */
1223 #pragma warning(disable: 4312)
1224 #elif defined(__INTELC__)
1225 #pragma warning(push)
1226 /* invalid type conversion: "wxUIntPtr={unsigned long}" to "void *" */
1227 #pragma warning(disable: 171)
1228 #endif
1229
1230 return wx_reinterpret_cast(void *, p);
1231
1232 #if (defined(__VISUALC__) && __VISUALC__ >= 1200) || defined(__INTELC__)
1233 #pragma warning(pop)
1234 #endif
1235 }
1236 #endif /*__cplusplus*/
1237
1238
1239
1240 /* base floating point types */
1241 /* wxFloat32: 32 bit IEEE float ( 1 sign, 8 exponent bits, 23 fraction bits */
1242 /* wxFloat64: 64 bit IEEE float ( 1 sign, 11 exponent bits, 52 fraction bits */
1243 /* wxDouble: native fastest representation that has at least wxFloat64 */
1244 /* precision, so use the IEEE types for storage, and this for */
1245 /* calculations */
1246
1247 typedef float wxFloat32;
1248 #if (defined( __WXMAC__ ) || defined(__WXCOCOA__)) && defined (__MWERKS__)
1249 typedef short double wxFloat64;
1250 #else
1251 typedef double wxFloat64;
1252 #endif
1253
1254 typedef double wxDouble;
1255
1256 /*
1257 Some (non standard) compilers typedef wchar_t as an existing type instead
1258 of treating it as a real fundamental type, set wxWCHAR_T_IS_REAL_TYPE to 0
1259 for them and to 1 for all the others.
1260 */
1261 #ifndef wxWCHAR_T_IS_REAL_TYPE
1262 /*
1263 VC++ typedefs wchar_t as unsigned short by default until VC8, that is
1264 unless /Za or /Zc:wchar_t option is used in which case _WCHAR_T_DEFINED
1265 is defined.
1266 */
1267 # if defined(__VISUALC__) && !defined(_NATIVE_WCHAR_T_DEFINED)
1268 # define wxWCHAR_T_IS_REAL_TYPE 0
1269 # else /* compiler having standard-conforming wchar_t */
1270 # define wxWCHAR_T_IS_REAL_TYPE 1
1271 # endif
1272 #endif /* !defined(wxWCHAR_T_IS_REAL_TYPE) */
1273
1274 /* Helper macro for doing something dependent on whether wchar_t is or isn't a
1275 typedef inside another macro. */
1276 #if wxWCHAR_T_IS_REAL_TYPE
1277 #define wxIF_WCHAR_T_TYPE(x) x
1278 #else /* !wxWCHAR_T_IS_REAL_TYPE */
1279 #define wxIF_WCHAR_T_TYPE(x)
1280 #endif /* wxWCHAR_T_IS_REAL_TYPE/!wxWCHAR_T_IS_REAL_TYPE */
1281
1282 /*
1283 This constant should be used instead of NULL in vararg functions taking
1284 wxChar* arguments: passing NULL (which is the same as 0, unless the compiler
1285 defines it specially, e.g. like gcc does with its __null built-in) doesn't
1286 work in this case as va_arg() wouldn't interpret the integer 0 correctly
1287 when trying to convert it to a pointer on architectures where sizeof(int) is
1288 strictly less than sizeof(void *).
1289
1290 Examples of places where this must be used include wxFileTypeInfo ctor.
1291 */
1292 #define wxNullPtr ((void *)NULL)
1293
1294
1295 /* Define wxChar16 and wxChar32 */
1296
1297 #if wxUSE_WCHAR_T && (!defined(SIZEOF_WCHAR_T) || (SIZEOF_WCHAR_T == 2))
1298 #define wxWCHAR_T_IS_WXCHAR16
1299 typedef wchar_t wxChar16;
1300 #else
1301 typedef wxUint16 wxChar16;
1302 #endif
1303
1304 #if wxUSE_WCHAR_T && defined(SIZEOF_WCHAR_T) && (SIZEOF_WCHAR_T == 4)
1305 #define wxWCHAR_T_IS_WXCHAR32
1306 typedef wchar_t wxChar32;
1307 #else
1308 typedef wxUint32 wxChar32;
1309 #endif
1310
1311
1312 /* ---------------------------------------------------------------------------- */
1313 /* byte ordering related definition and macros */
1314 /* ---------------------------------------------------------------------------- */
1315
1316 /* byte sex */
1317
1318 #define wxBIG_ENDIAN 4321
1319 #define wxLITTLE_ENDIAN 1234
1320 #define wxPDP_ENDIAN 3412
1321
1322 #ifdef WORDS_BIGENDIAN
1323 #define wxBYTE_ORDER wxBIG_ENDIAN
1324 #else
1325 #define wxBYTE_ORDER wxLITTLE_ENDIAN
1326 #endif
1327
1328 /* byte swapping */
1329
1330 #if defined (__MWERKS__) && ( (__MWERKS__ < 0x0900) || macintosh )
1331 /* assembler versions for these */
1332 #ifdef __POWERPC__
1333 inline wxUint16 wxUINT16_SWAP_ALWAYS( wxUint16 i )
1334 {return (__lhbrx( &i , 0 ) );}
1335 inline wxInt16 wxINT16_SWAP_ALWAYS( wxInt16 i )
1336 {return (__lhbrx( &i , 0 ) );}
1337 inline wxUint32 wxUINT32_SWAP_ALWAYS( wxUint32 i )
1338 {return (__lwbrx( &i , 0 ) );}
1339 inline wxInt32 wxINT32_SWAP_ALWAYS( wxInt32 i )
1340 {return (__lwbrx( &i , 0 ) );}
1341 #else
1342 #pragma parameter __D0 wxUINT16_SWAP_ALWAYS(__D0)
1343 pascal wxUint16 wxUINT16_SWAP_ALWAYS(wxUint16 value)
1344 = { 0xE158 };
1345
1346 #pragma parameter __D0 wxINT16_SWAP_ALWAYS(__D0)
1347 pascal wxInt16 wxINT16_SWAP_ALWAYS(wxInt16 value)
1348 = { 0xE158 };
1349
1350 #pragma parameter __D0 wxUINT32_SWAP_ALWAYS (__D0)
1351 pascal wxUint32 wxUINT32_SWAP_ALWAYS(wxUint32 value)
1352 = { 0xE158, 0x4840, 0xE158 };
1353
1354 #pragma parameter __D0 wxINT32_SWAP_ALWAYS (__D0)
1355 pascal wxInt32 wxINT32_SWAP_ALWAYS(wxInt32 value)
1356 = { 0xE158, 0x4840, 0xE158 };
1357
1358 #endif
1359 #else /* !MWERKS */
1360 #define wxUINT16_SWAP_ALWAYS(val) \
1361 ((wxUint16) ( \
1362 (((wxUint16) (val) & (wxUint16) 0x00ffU) << 8) | \
1363 (((wxUint16) (val) & (wxUint16) 0xff00U) >> 8)))
1364
1365 #define wxINT16_SWAP_ALWAYS(val) \
1366 ((wxInt16) ( \
1367 (((wxUint16) (val) & (wxUint16) 0x00ffU) << 8) | \
1368 (((wxUint16) (val) & (wxUint16) 0xff00U) >> 8)))
1369
1370 #define wxUINT32_SWAP_ALWAYS(val) \
1371 ((wxUint32) ( \
1372 (((wxUint32) (val) & (wxUint32) 0x000000ffU) << 24) | \
1373 (((wxUint32) (val) & (wxUint32) 0x0000ff00U) << 8) | \
1374 (((wxUint32) (val) & (wxUint32) 0x00ff0000U) >> 8) | \
1375 (((wxUint32) (val) & (wxUint32) 0xff000000U) >> 24)))
1376
1377 #define wxINT32_SWAP_ALWAYS(val) \
1378 ((wxInt32) ( \
1379 (((wxUint32) (val) & (wxUint32) 0x000000ffU) << 24) | \
1380 (((wxUint32) (val) & (wxUint32) 0x0000ff00U) << 8) | \
1381 (((wxUint32) (val) & (wxUint32) 0x00ff0000U) >> 8) | \
1382 (((wxUint32) (val) & (wxUint32) 0xff000000U) >> 24)))
1383 #endif
1384 /* machine specific byte swapping */
1385
1386 #ifdef wxLongLong_t
1387 #define wxUINT64_SWAP_ALWAYS(val) \
1388 ((wxUint64) ( \
1389 (((wxUint64) (val) & (wxUint64) wxULL(0x00000000000000ff)) << 56) | \
1390 (((wxUint64) (val) & (wxUint64) wxULL(0x000000000000ff00)) << 40) | \
1391 (((wxUint64) (val) & (wxUint64) wxULL(0x0000000000ff0000)) << 24) | \
1392 (((wxUint64) (val) & (wxUint64) wxULL(0x00000000ff000000)) << 8) | \
1393 (((wxUint64) (val) & (wxUint64) wxULL(0x000000ff00000000)) >> 8) | \
1394 (((wxUint64) (val) & (wxUint64) wxULL(0x0000ff0000000000)) >> 24) | \
1395 (((wxUint64) (val) & (wxUint64) wxULL(0x00ff000000000000)) >> 40) | \
1396 (((wxUint64) (val) & (wxUint64) wxULL(0xff00000000000000)) >> 56)))
1397
1398 #define wxINT64_SWAP_ALWAYS(val) \
1399 ((wxInt64) ( \
1400 (((wxUint64) (val) & (wxUint64) wxULL(0x00000000000000ff)) << 56) | \
1401 (((wxUint64) (val) & (wxUint64) wxULL(0x000000000000ff00)) << 40) | \
1402 (((wxUint64) (val) & (wxUint64) wxULL(0x0000000000ff0000)) << 24) | \
1403 (((wxUint64) (val) & (wxUint64) wxULL(0x00000000ff000000)) << 8) | \
1404 (((wxUint64) (val) & (wxUint64) wxULL(0x000000ff00000000)) >> 8) | \
1405 (((wxUint64) (val) & (wxUint64) wxULL(0x0000ff0000000000)) >> 24) | \
1406 (((wxUint64) (val) & (wxUint64) wxULL(0x00ff000000000000)) >> 40) | \
1407 (((wxUint64) (val) & (wxUint64) wxULL(0xff00000000000000)) >> 56)))
1408 #elif wxUSE_LONGLONG /* !wxLongLong_t */
1409 #define wxUINT64_SWAP_ALWAYS(val) \
1410 ((wxUint64) ( \
1411 ((wxULongLong(val) & wxULongLong(0L, 0x000000ffU)) << 56) | \
1412 ((wxULongLong(val) & wxULongLong(0L, 0x0000ff00U)) << 40) | \
1413 ((wxULongLong(val) & wxULongLong(0L, 0x00ff0000U)) << 24) | \
1414 ((wxULongLong(val) & wxULongLong(0L, 0xff000000U)) << 8) | \
1415 ((wxULongLong(val) & wxULongLong(0x000000ffL, 0U)) >> 8) | \
1416 ((wxULongLong(val) & wxULongLong(0x0000ff00L, 0U)) >> 24) | \
1417 ((wxULongLong(val) & wxULongLong(0x00ff0000L, 0U)) >> 40) | \
1418 ((wxULongLong(val) & wxULongLong(0xff000000L, 0U)) >> 56)))
1419
1420 #define wxINT64_SWAP_ALWAYS(val) \
1421 ((wxInt64) ( \
1422 ((wxLongLong(val) & wxLongLong(0L, 0x000000ffU)) << 56) | \
1423 ((wxLongLong(val) & wxLongLong(0L, 0x0000ff00U)) << 40) | \
1424 ((wxLongLong(val) & wxLongLong(0L, 0x00ff0000U)) << 24) | \
1425 ((wxLongLong(val) & wxLongLong(0L, 0xff000000U)) << 8) | \
1426 ((wxLongLong(val) & wxLongLong(0x000000ffL, 0U)) >> 8) | \
1427 ((wxLongLong(val) & wxLongLong(0x0000ff00L, 0U)) >> 24) | \
1428 ((wxLongLong(val) & wxLongLong(0x00ff0000L, 0U)) >> 40) | \
1429 ((wxLongLong(val) & wxLongLong(0xff000000L, 0U)) >> 56)))
1430 #endif /* wxLongLong_t/!wxLongLong_t */
1431
1432 #ifdef WORDS_BIGENDIAN
1433 #define wxUINT16_SWAP_ON_BE(val) wxUINT16_SWAP_ALWAYS(val)
1434 #define wxINT16_SWAP_ON_BE(val) wxINT16_SWAP_ALWAYS(val)
1435 #define wxUINT16_SWAP_ON_LE(val) (val)
1436 #define wxINT16_SWAP_ON_LE(val) (val)
1437 #define wxUINT32_SWAP_ON_BE(val) wxUINT32_SWAP_ALWAYS(val)
1438 #define wxINT32_SWAP_ON_BE(val) wxINT32_SWAP_ALWAYS(val)
1439 #define wxUINT32_SWAP_ON_LE(val) (val)
1440 #define wxINT32_SWAP_ON_LE(val) (val)
1441 #if wxHAS_INT64
1442 #define wxUINT64_SWAP_ON_BE(val) wxUINT64_SWAP_ALWAYS(val)
1443 #define wxUINT64_SWAP_ON_LE(val) (val)
1444 #define wxINT64_SWAP_ON_BE(val) wxINT64_SWAP_ALWAYS(val)
1445 #define wxINT64_SWAP_ON_LE(val) (val)
1446 #endif
1447 #else
1448 #define wxUINT16_SWAP_ON_LE(val) wxUINT16_SWAP_ALWAYS(val)
1449 #define wxINT16_SWAP_ON_LE(val) wxINT16_SWAP_ALWAYS(val)
1450 #define wxUINT16_SWAP_ON_BE(val) (val)
1451 #define wxINT16_SWAP_ON_BE(val) (val)
1452 #define wxUINT32_SWAP_ON_LE(val) wxUINT32_SWAP_ALWAYS(val)
1453 #define wxINT32_SWAP_ON_LE(val) wxINT32_SWAP_ALWAYS(val)
1454 #define wxUINT32_SWAP_ON_BE(val) (val)
1455 #define wxINT32_SWAP_ON_BE(val) (val)
1456 #if wxHAS_INT64
1457 #define wxUINT64_SWAP_ON_LE(val) wxUINT64_SWAP_ALWAYS(val)
1458 #define wxUINT64_SWAP_ON_BE(val) (val)
1459 #define wxINT64_SWAP_ON_LE(val) wxINT64_SWAP_ALWAYS(val)
1460 #define wxINT64_SWAP_ON_BE(val) (val)
1461 #endif
1462 #endif
1463
1464 /* ---------------------------------------------------------------------------- */
1465 /* Geometric flags */
1466 /* ---------------------------------------------------------------------------- */
1467
1468 enum wxGeometryCentre
1469 {
1470 wxCENTRE = 0x0001,
1471 wxCENTER = wxCENTRE
1472 };
1473
1474 /* centering into frame rather than screen (obsolete) */
1475 #define wxCENTER_FRAME 0x0000
1476 /* centre on screen rather than parent */
1477 #define wxCENTRE_ON_SCREEN 0x0002
1478 #define wxCENTER_ON_SCREEN wxCENTRE_ON_SCREEN
1479
1480 enum wxOrientation
1481 {
1482 /* don't change the values of these elements, they are used elsewhere */
1483 wxHORIZONTAL = 0x0004,
1484 wxVERTICAL = 0x0008,
1485
1486 wxBOTH = wxVERTICAL | wxHORIZONTAL,
1487
1488 /* a mask to extract orientation from the combination of flags */
1489 wxORIENTATION_MASK = wxBOTH
1490 };
1491
1492 enum wxDirection
1493 {
1494 wxLEFT = 0x0010,
1495 wxRIGHT = 0x0020,
1496 wxUP = 0x0040,
1497 wxDOWN = 0x0080,
1498
1499 wxTOP = wxUP,
1500 wxBOTTOM = wxDOWN,
1501
1502 wxNORTH = wxUP,
1503 wxSOUTH = wxDOWN,
1504 wxWEST = wxLEFT,
1505 wxEAST = wxRIGHT,
1506
1507 wxALL = (wxUP | wxDOWN | wxRIGHT | wxLEFT),
1508
1509 /* a mask to extract direction from the combination of flags */
1510 wxDIRECTION_MASK = wxALL
1511 };
1512
1513 enum wxAlignment
1514 {
1515 wxALIGN_NOT = 0x0000,
1516 wxALIGN_CENTER_HORIZONTAL = 0x0100,
1517 wxALIGN_CENTRE_HORIZONTAL = wxALIGN_CENTER_HORIZONTAL,
1518 wxALIGN_LEFT = wxALIGN_NOT,
1519 wxALIGN_TOP = wxALIGN_NOT,
1520 wxALIGN_RIGHT = 0x0200,
1521 wxALIGN_BOTTOM = 0x0400,
1522 wxALIGN_CENTER_VERTICAL = 0x0800,
1523 wxALIGN_CENTRE_VERTICAL = wxALIGN_CENTER_VERTICAL,
1524
1525 wxALIGN_CENTER = (wxALIGN_CENTER_HORIZONTAL | wxALIGN_CENTER_VERTICAL),
1526 wxALIGN_CENTRE = wxALIGN_CENTER,
1527
1528 /* a mask to extract alignment from the combination of flags */
1529 wxALIGN_MASK = 0x0f00
1530 };
1531
1532 /* misc. flags for wxSizer items */
1533 enum wxSizerFlagBits
1534 {
1535 /* for compatibility only, default now, don't use explicitly any more */
1536 #if WXWIN_COMPATIBILITY_2_6
1537 wxADJUST_MINSIZE = 0,
1538 #endif
1539 wxFIXED_MINSIZE = 0x8000,
1540 wxRESERVE_SPACE_EVEN_IF_HIDDEN = 0x0002,
1541
1542 /* a mask to extract wxSizerFlagBits from combination of flags */
1543 wxSIZER_FLAG_BITS_MASK = 0x8002
1544 };
1545
1546 enum wxStretch
1547 {
1548 wxSTRETCH_NOT = 0x0000,
1549 wxSHRINK = 0x1000,
1550 wxGROW = 0x2000,
1551 wxEXPAND = wxGROW,
1552 wxSHAPED = 0x4000,
1553 wxTILE = wxSHAPED | wxFIXED_MINSIZE,
1554
1555 /* a mask to extract stretch from the combination of flags */
1556 wxSTRETCH_MASK = 0x7000 /* sans wxTILE */
1557 };
1558
1559 /* border flags: the values are chosen for backwards compatibility */
1560 enum wxBorder
1561 {
1562 /* this is different from wxBORDER_NONE as by default the controls do have */
1563 /* border */
1564 wxBORDER_DEFAULT = 0,
1565
1566 wxBORDER_NONE = 0x00200000,
1567 wxBORDER_STATIC = 0x01000000,
1568 wxBORDER_SIMPLE = 0x02000000,
1569 wxBORDER_RAISED = 0x04000000,
1570 wxBORDER_SUNKEN = 0x08000000,
1571 wxBORDER_DOUBLE = 0x10000000, /* deprecated */
1572 wxBORDER_THEME = wxBORDER_DOUBLE,
1573
1574 /* a mask to extract border style from the combination of flags */
1575 wxBORDER_MASK = 0x1f200000
1576 };
1577
1578 /* This makes it easier to specify a 'normal' border for a control */
1579 #if defined(__SMARTPHONE__) || defined(__POCKETPC__)
1580 #define wxDEFAULT_CONTROL_BORDER wxBORDER_SIMPLE
1581 #else
1582 #define wxDEFAULT_CONTROL_BORDER wxBORDER_SUNKEN
1583 #endif
1584
1585 /* ---------------------------------------------------------------------------- */
1586 /* Window style flags */
1587 /* ---------------------------------------------------------------------------- */
1588
1589 /*
1590 * Values are chosen so they can be |'ed in a bit list.
1591 * Some styles are used across more than one group,
1592 * so the values mustn't clash with others in the group.
1593 * Otherwise, numbers can be reused across groups.
1594 *
1595 * From version 1.66:
1596 * Window (cross-group) styles now take up the first half
1597 * of the flag, and control-specific styles the
1598 * second half.
1599 *
1600 */
1601
1602 /*
1603 * Window (Frame/dialog/subwindow/panel item) style flags
1604 */
1605 #define wxVSCROLL 0x80000000
1606 #define wxHSCROLL 0x40000000
1607 #define wxCAPTION 0x20000000
1608
1609 /* New styles (border styles are now in their own enum) */
1610 #define wxDOUBLE_BORDER wxBORDER_DOUBLE
1611 #define wxSUNKEN_BORDER wxBORDER_SUNKEN
1612 #define wxRAISED_BORDER wxBORDER_RAISED
1613 #define wxBORDER wxBORDER_SIMPLE
1614 #define wxSIMPLE_BORDER wxBORDER_SIMPLE
1615 #define wxSTATIC_BORDER wxBORDER_STATIC
1616 #define wxNO_BORDER wxBORDER_NONE
1617
1618 /* wxALWAYS_SHOW_SB: instead of hiding the scrollbar when it is not needed, */
1619 /* disable it - but still show (see also wxLB_ALWAYS_SB style) */
1620 /* */
1621 /* NB: as this style is only supported by wxUniversal and wxMSW so far */
1622 #define wxALWAYS_SHOW_SB 0x00800000
1623
1624 /* Clip children when painting, which reduces flicker in e.g. frames and */
1625 /* splitter windows, but can't be used in a panel where a static box must be */
1626 /* 'transparent' (panel paints the background for it) */
1627 #define wxCLIP_CHILDREN 0x00400000
1628
1629 /* Note we're reusing the wxCAPTION style because we won't need captions */
1630 /* for subwindows/controls */
1631 #define wxCLIP_SIBLINGS 0x20000000
1632
1633 #define wxTRANSPARENT_WINDOW 0x00100000
1634
1635 /* Add this style to a panel to get tab traversal working outside of dialogs */
1636 /* (on by default for wxPanel, wxDialog, wxScrolledWindow) */
1637 #define wxTAB_TRAVERSAL 0x00080000
1638
1639 /* Add this style if the control wants to get all keyboard messages (under */
1640 /* Windows, it won't normally get the dialog navigation key events) */
1641 #define wxWANTS_CHARS 0x00040000
1642
1643 /* Make window retained (Motif only, see src/generic/scrolwing.cpp)
1644 * This is non-zero only under wxMotif, to avoid a clash with wxPOPUP_WINDOW
1645 * on other platforms
1646 */
1647
1648 #ifdef __WXMOTIF__
1649 #define wxRETAINED 0x00020000
1650 #else
1651 #define wxRETAINED 0x00000000
1652 #endif
1653 #define wxBACKINGSTORE wxRETAINED
1654
1655 /* set this flag to create a special popup window: it will be always shown on */
1656 /* top of other windows, will capture the mouse and will be dismissed when the */
1657 /* mouse is clicked outside of it or if it loses focus in any other way */
1658 #define wxPOPUP_WINDOW 0x00020000
1659
1660 /* force a full repaint when the window is resized (instead of repainting just */
1661 /* the invalidated area) */
1662 #define wxFULL_REPAINT_ON_RESIZE 0x00010000
1663
1664 /* obsolete: now this is the default behaviour */
1665 /* */
1666 /* don't invalidate the whole window (resulting in a PAINT event) when the */
1667 /* window is resized (currently, makes sense for wxMSW only) */
1668 #define wxNO_FULL_REPAINT_ON_RESIZE 0
1669
1670 /* A mask which can be used to filter (out) all wxWindow-specific styles.
1671 */
1672 #define wxWINDOW_STYLE_MASK \
1673 (wxVSCROLL|wxHSCROLL|wxBORDER_MASK|wxALWAYS_SHOW_SB|wxCLIP_CHILDREN| \
1674 wxCLIP_SIBLINGS|wxTRANSPARENT_WINDOW|wxTAB_TRAVERSAL|wxWANTS_CHARS| \
1675 wxRETAINED|wxPOPUP_WINDOW|wxFULL_REPAINT_ON_RESIZE)
1676
1677 /*
1678 * Extra window style flags (use wxWS_EX prefix to make it clear that they
1679 * should be passed to wxWindow::SetExtraStyle(), not SetWindowStyle())
1680 */
1681
1682 /* by default, TransferDataTo/FromWindow() only work on direct children of the */
1683 /* window (compatible behaviour), set this flag to make them recursively */
1684 /* descend into all subwindows */
1685 #define wxWS_EX_VALIDATE_RECURSIVELY 0x00000001
1686
1687 /* wxCommandEvents and the objects of the derived classes are forwarded to the */
1688 /* parent window and so on recursively by default. Using this flag for the */
1689 /* given window allows to block this propagation at this window, i.e. prevent */
1690 /* the events from being propagated further upwards. The dialogs have this */
1691 /* flag on by default. */
1692 #define wxWS_EX_BLOCK_EVENTS 0x00000002
1693
1694 /* don't use this window as an implicit parent for the other windows: this must */
1695 /* be used with transient windows as otherwise there is the risk of creating a */
1696 /* dialog/frame with this window as a parent which would lead to a crash if the */
1697 /* parent is destroyed before the child */
1698 #define wxWS_EX_TRANSIENT 0x00000004
1699
1700 /* don't paint the window background, we'll assume it will */
1701 /* be done by a theming engine. This is not yet used but could */
1702 /* possibly be made to work in the future, at least on Windows */
1703 #define wxWS_EX_THEMED_BACKGROUND 0x00000008
1704
1705 /* this window should always process idle events */
1706 #define wxWS_EX_PROCESS_IDLE 0x00000010
1707
1708 /* this window should always process UI update events */
1709 #define wxWS_EX_PROCESS_UI_UPDATES 0x00000020
1710
1711 /* Draw the window in a metal theme on Mac */
1712 #define wxFRAME_EX_METAL 0x00000040
1713 #define wxDIALOG_EX_METAL 0x00000040
1714
1715 /* Use this style to add a context-sensitive help to the window (currently for */
1716 /* Win32 only and it doesn't work if wxMINIMIZE_BOX or wxMAXIMIZE_BOX are used) */
1717 #define wxWS_EX_CONTEXTHELP 0x00000080
1718
1719 /* synonyms for wxWS_EX_CONTEXTHELP for compatibility */
1720 #define wxFRAME_EX_CONTEXTHELP wxWS_EX_CONTEXTHELP
1721 #define wxDIALOG_EX_CONTEXTHELP wxWS_EX_CONTEXTHELP
1722
1723 /* Create a window which is attachable to another top level window */
1724 #define wxFRAME_DRAWER 0x0020
1725
1726 /*
1727 * MDI parent frame style flags
1728 * Can overlap with some of the above.
1729 */
1730
1731 #define wxFRAME_NO_WINDOW_MENU 0x0100
1732
1733 /*
1734 * wxMenuBar style flags
1735 */
1736 /* use native docking */
1737 #define wxMB_DOCKABLE 0x0001
1738
1739 /*
1740 * wxMenu style flags
1741 */
1742 #define wxMENU_TEAROFF 0x0001
1743
1744 /*
1745 * Apply to all panel items
1746 */
1747 #define wxCOLOURED 0x0800
1748 #define wxFIXED_LENGTH 0x0400
1749
1750 /*
1751 * Styles for wxListBox
1752 */
1753 #define wxLB_SORT 0x0010
1754 #define wxLB_SINGLE 0x0020
1755 #define wxLB_MULTIPLE 0x0040
1756 #define wxLB_EXTENDED 0x0080
1757 /* wxLB_OWNERDRAW is Windows-only */
1758 #define wxLB_OWNERDRAW 0x0100
1759 #define wxLB_NEEDED_SB 0x0200
1760 #define wxLB_ALWAYS_SB 0x0400
1761 #define wxLB_HSCROLL wxHSCROLL
1762 /* always show an entire number of rows */
1763 #define wxLB_INT_HEIGHT 0x0800
1764
1765 #if WXWIN_COMPATIBILITY_2_6
1766 /* deprecated synonyms */
1767 #define wxPROCESS_ENTER 0x0400 /* wxTE_PROCESS_ENTER */
1768 #define wxPASSWORD 0x0800 /* wxTE_PASSWORD */
1769 #endif
1770
1771 /*
1772 * wxComboBox style flags
1773 */
1774 #define wxCB_SIMPLE 0x0004
1775 #define wxCB_SORT 0x0008
1776 #define wxCB_READONLY 0x0010
1777 #define wxCB_DROPDOWN 0x0020
1778
1779 /*
1780 * wxRadioBox style flags
1781 */
1782 /* should we number the items from left to right or from top to bottom in a 2d */
1783 /* radiobox? */
1784 #define wxRA_LEFTTORIGHT 0x0001
1785 #define wxRA_TOPTOBOTTOM 0x0002
1786
1787 /* New, more intuitive names to specify majorDim argument */
1788 #define wxRA_SPECIFY_COLS wxHORIZONTAL
1789 #define wxRA_SPECIFY_ROWS wxVERTICAL
1790
1791 /* Old names for compatibility */
1792 #define wxRA_HORIZONTAL wxHORIZONTAL
1793 #define wxRA_VERTICAL wxVERTICAL
1794 #define wxRA_USE_CHECKBOX 0x0010 /* alternative native subcontrols (wxPalmOS) */
1795
1796 /*
1797 * wxRadioButton style flag
1798 */
1799 #define wxRB_GROUP 0x0004
1800 #define wxRB_SINGLE 0x0008
1801 #define wxRB_USE_CHECKBOX 0x0010 /* alternative native control (wxPalmOS) */
1802
1803 /*
1804 * wxScrollBar flags
1805 */
1806 #define wxSB_HORIZONTAL wxHORIZONTAL
1807 #define wxSB_VERTICAL wxVERTICAL
1808
1809 /*
1810 * wxSpinButton flags.
1811 * Note that a wxSpinCtrl is sometimes defined as
1812 * a wxTextCtrl, and so the flags must be different
1813 * from wxTextCtrl's.
1814 */
1815 #define wxSP_HORIZONTAL wxHORIZONTAL /* 4 */
1816 #define wxSP_VERTICAL wxVERTICAL /* 8 */
1817 #define wxSP_ARROW_KEYS 0x1000
1818 #define wxSP_WRAP 0x2000
1819
1820 /*
1821 * wxTabCtrl flags
1822 */
1823 #define wxTC_RIGHTJUSTIFY 0x0010
1824 #define wxTC_FIXEDWIDTH 0x0020
1825 #define wxTC_TOP 0x0000 /* default */
1826 #define wxTC_LEFT 0x0020
1827 #define wxTC_RIGHT 0x0040
1828 #define wxTC_BOTTOM 0x0080
1829 #define wxTC_MULTILINE 0x0200 /* == wxNB_MULTILINE */
1830 #define wxTC_OWNERDRAW 0x0400
1831
1832 /*
1833 * wxStatusBar95 flags
1834 */
1835 #define wxST_SIZEGRIP 0x0010
1836
1837 /*
1838 * wxStaticBitmap flags
1839 */
1840 #define wxBI_EXPAND wxEXPAND
1841
1842 /*
1843 * wxStaticLine flags
1844 */
1845 #define wxLI_HORIZONTAL wxHORIZONTAL
1846 #define wxLI_VERTICAL wxVERTICAL
1847
1848
1849 /*
1850 * extended dialog specifiers. these values are stored in a different
1851 * flag and thus do not overlap with other style flags. note that these
1852 * values do not correspond to the return values of the dialogs (for
1853 * those values, look at the wxID_XXX defines).
1854 */
1855
1856 /* wxCENTRE already defined as 0x00000001 */
1857 #define wxYES 0x00000002
1858 #define wxOK 0x00000004
1859 #define wxNO 0x00000008
1860 #define wxYES_NO (wxYES | wxNO)
1861 #define wxCANCEL 0x00000010
1862 #define wxAPPLY 0x00000020
1863 #define wxCLOSE 0x00000040
1864
1865 #define wxYES_DEFAULT 0x00000000 /* has no effect (default) */
1866 #define wxNO_DEFAULT 0x00000080
1867
1868 #define wxICON_EXCLAMATION 0x00000100
1869 #define wxICON_HAND 0x00000200
1870 #define wxICON_WARNING wxICON_EXCLAMATION
1871 #define wxICON_ERROR wxICON_HAND
1872 #define wxICON_QUESTION 0x00000400
1873 #define wxICON_INFORMATION 0x00000800
1874 #define wxICON_STOP wxICON_HAND
1875 #define wxICON_ASTERISK wxICON_INFORMATION
1876 #define wxICON_MASK (0x00000100|0x00000200|0x00000400|0x00000800)
1877
1878 #define wxFORWARD 0x00001000
1879 #define wxBACKWARD 0x00002000
1880 #define wxRESET 0x00004000
1881 #define wxHELP 0x00008000
1882 #define wxMORE 0x00010000
1883 #define wxSETUP 0x00020000
1884
1885 /*
1886 * Background styles. See wxWindow::SetBackgroundStyle
1887 */
1888
1889 enum wxBackgroundStyle
1890 {
1891 wxBG_STYLE_SYSTEM,
1892 wxBG_STYLE_COLOUR,
1893 wxBG_STYLE_CUSTOM,
1894 wxBG_STYLE_TRANSPARENT
1895 };
1896
1897 /*
1898 * Key types used by (old style) lists and hashes.
1899 */
1900 enum wxKeyType
1901 {
1902 wxKEY_NONE,
1903 wxKEY_INTEGER,
1904 wxKEY_STRING
1905 };
1906
1907 /* ---------------------------------------------------------------------------- */
1908 /* standard IDs */
1909 /* ---------------------------------------------------------------------------- */
1910
1911 /* Standard menu IDs */
1912 enum
1913 {
1914 /*
1915 These ids delimit the range used by automatically-generated ids
1916 (i.e. those used when wxID_ANY is specified during construction).
1917 */
1918 #if defined(__WXMSW__) || wxUSE_AUTOID_MANAGEMENT
1919 /*
1920 On MSW the range is always restricted no matter if id management
1921 is used or not because the native window ids are limited to short
1922 range. On other platforms the range is only restricted if id
1923 management is used so the reference count buffer won't be so big.
1924 */
1925 wxID_AUTO_LOWEST = -32000,
1926 wxID_AUTO_HIGHEST = -2000,
1927 #else
1928 wxID_AUTO_LOWEST = -1000000,
1929 wxID_AUTO_HIGHEST = -2000,
1930 #endif
1931
1932 /* no id matches this one when compared to it */
1933 wxID_NONE = -3,
1934
1935 /* id for a separator line in the menu (invalid for normal item) */
1936 wxID_SEPARATOR = -2,
1937
1938 /* any id: means that we don't care about the id, whether when installing
1939 * an event handler or when creating a new window */
1940 wxID_ANY = -1,
1941
1942
1943 /* all predefined ids are between wxID_LOWEST and wxID_HIGHEST */
1944 wxID_LOWEST = 4999,
1945
1946 wxID_OPEN,
1947 wxID_CLOSE,
1948 wxID_NEW,
1949 wxID_SAVE,
1950 wxID_SAVEAS,
1951 wxID_REVERT,
1952 wxID_EXIT,
1953 wxID_UNDO,
1954 wxID_REDO,
1955 wxID_HELP,
1956 wxID_PRINT,
1957 wxID_PRINT_SETUP,
1958 wxID_PAGE_SETUP,
1959 wxID_PREVIEW,
1960 wxID_ABOUT,
1961 wxID_HELP_CONTENTS,
1962 wxID_HELP_INDEX,
1963 wxID_HELP_SEARCH,
1964 wxID_HELP_COMMANDS,
1965 wxID_HELP_PROCEDURES,
1966 wxID_HELP_CONTEXT,
1967 wxID_CLOSE_ALL,
1968 wxID_PREFERENCES,
1969
1970 wxID_EDIT = 5030,
1971 wxID_CUT,
1972 wxID_COPY,
1973 wxID_PASTE,
1974 wxID_CLEAR,
1975 wxID_FIND,
1976 wxID_DUPLICATE,
1977 wxID_SELECTALL,
1978 wxID_DELETE,
1979 wxID_REPLACE,
1980 wxID_REPLACE_ALL,
1981 wxID_PROPERTIES,
1982
1983 wxID_VIEW_DETAILS,
1984 wxID_VIEW_LARGEICONS,
1985 wxID_VIEW_SMALLICONS,
1986 wxID_VIEW_LIST,
1987 wxID_VIEW_SORTDATE,
1988 wxID_VIEW_SORTNAME,
1989 wxID_VIEW_SORTSIZE,
1990 wxID_VIEW_SORTTYPE,
1991
1992 wxID_FILE = 5050,
1993 wxID_FILE1,
1994 wxID_FILE2,
1995 wxID_FILE3,
1996 wxID_FILE4,
1997 wxID_FILE5,
1998 wxID_FILE6,
1999 wxID_FILE7,
2000 wxID_FILE8,
2001 wxID_FILE9,
2002
2003 /* Standard button and menu IDs */
2004 wxID_OK = 5100,
2005 wxID_CANCEL,
2006 wxID_APPLY,
2007 wxID_YES,
2008 wxID_NO,
2009 wxID_STATIC,
2010 wxID_FORWARD,
2011 wxID_BACKWARD,
2012 wxID_DEFAULT,
2013 wxID_MORE,
2014 wxID_SETUP,
2015 wxID_RESET,
2016 wxID_CONTEXT_HELP,
2017 wxID_YESTOALL,
2018 wxID_NOTOALL,
2019 wxID_ABORT,
2020 wxID_RETRY,
2021 wxID_IGNORE,
2022 wxID_ADD,
2023 wxID_REMOVE,
2024
2025 wxID_UP,
2026 wxID_DOWN,
2027 wxID_HOME,
2028 wxID_REFRESH,
2029 wxID_STOP,
2030 wxID_INDEX,
2031
2032 wxID_BOLD,
2033 wxID_ITALIC,
2034 wxID_JUSTIFY_CENTER,
2035 wxID_JUSTIFY_FILL,
2036 wxID_JUSTIFY_RIGHT,
2037 wxID_JUSTIFY_LEFT,
2038 wxID_UNDERLINE,
2039 wxID_INDENT,
2040 wxID_UNINDENT,
2041 wxID_ZOOM_100,
2042 wxID_ZOOM_FIT,
2043 wxID_ZOOM_IN,
2044 wxID_ZOOM_OUT,
2045 wxID_UNDELETE,
2046 wxID_REVERT_TO_SAVED,
2047 wxID_CDROM,
2048 wxID_CONVERT,
2049 wxID_EXECUTE,
2050 wxID_FLOPPY,
2051 wxID_HARDDISK,
2052 wxID_BOTTOM,
2053 wxID_FIRST,
2054 wxID_LAST,
2055 wxID_TOP,
2056 wxID_INFO,
2057 wxID_JUMP_TO,
2058 wxID_NETWORK,
2059 wxID_SELECT_COLOR,
2060 wxID_SELECT_FONT,
2061 wxID_SORT_ASCENDING,
2062 wxID_SORT_DESCENDING,
2063 wxID_SPELL_CHECK,
2064 wxID_STRIKETHROUGH,
2065
2066 /* System menu IDs (used by wxUniv): */
2067 wxID_SYSTEM_MENU = 5200,
2068 wxID_CLOSE_FRAME,
2069 wxID_MOVE_FRAME,
2070 wxID_RESIZE_FRAME,
2071 wxID_MAXIMIZE_FRAME,
2072 wxID_ICONIZE_FRAME,
2073 wxID_RESTORE_FRAME,
2074
2075 /* IDs used by generic file dialog (13 consecutive starting from this value) */
2076 wxID_FILEDLGG = 5900,
2077
2078 /* IDs used by generic file ctrl (4 consecutive starting from this value) */
2079 wxID_FILECTRL = 5950,
2080
2081 wxID_HIGHEST = 5999
2082 };
2083
2084 /* ---------------------------------------------------------------------------- */
2085 /* wxWindowID type (after wxID_XYZ enum, platform detection, and dlimpexp.h) */
2086 /* ---------------------------------------------------------------------------- */
2087
2088 /* special care should be taken with this type under Windows where the real */
2089 /* window id is unsigned, so we must always do the cast before comparing them */
2090 /* (or else they would be always different!). Using wxGetWindowId() which does */
2091 /* the cast itself is recommended. Note that this type can't be unsigned */
2092 /* because wxID_ANY == -1 is a valid (and largely used) value for window id. */
2093 #if defined(__cplusplus) && wxUSE_GUI
2094 #include "wx/windowid.h"
2095 #endif
2096
2097 /* ---------------------------------------------------------------------------- */
2098 /* other constants */
2099 /* ---------------------------------------------------------------------------- */
2100
2101 /* menu and toolbar item kinds */
2102 enum wxItemKind
2103 {
2104 wxITEM_SEPARATOR = -1,
2105 wxITEM_NORMAL,
2106 wxITEM_CHECK,
2107 wxITEM_RADIO,
2108 wxITEM_DROPDOWN,
2109 wxITEM_MAX
2110 };
2111
2112 /* hit test results */
2113 enum wxHitTest
2114 {
2115 wxHT_NOWHERE,
2116
2117 /* scrollbar */
2118 wxHT_SCROLLBAR_FIRST = wxHT_NOWHERE,
2119 wxHT_SCROLLBAR_ARROW_LINE_1, /* left or upper arrow to scroll by line */
2120 wxHT_SCROLLBAR_ARROW_LINE_2, /* right or down */
2121 wxHT_SCROLLBAR_ARROW_PAGE_1, /* left or upper arrow to scroll by page */
2122 wxHT_SCROLLBAR_ARROW_PAGE_2, /* right or down */
2123 wxHT_SCROLLBAR_THUMB, /* on the thumb */
2124 wxHT_SCROLLBAR_BAR_1, /* bar to the left/above the thumb */
2125 wxHT_SCROLLBAR_BAR_2, /* bar to the right/below the thumb */
2126 wxHT_SCROLLBAR_LAST,
2127
2128 /* window */
2129 wxHT_WINDOW_OUTSIDE, /* not in this window at all */
2130 wxHT_WINDOW_INSIDE, /* in the client area */
2131 wxHT_WINDOW_VERT_SCROLLBAR, /* on the vertical scrollbar */
2132 wxHT_WINDOW_HORZ_SCROLLBAR, /* on the horizontal scrollbar */
2133 wxHT_WINDOW_CORNER, /* on the corner between 2 scrollbars */
2134
2135 wxHT_MAX
2136 };
2137
2138 /* ---------------------------------------------------------------------------- */
2139 /* Possible SetSize flags */
2140 /* ---------------------------------------------------------------------------- */
2141
2142 /* Use internally-calculated width if -1 */
2143 #define wxSIZE_AUTO_WIDTH 0x0001
2144 /* Use internally-calculated height if -1 */
2145 #define wxSIZE_AUTO_HEIGHT 0x0002
2146 /* Use internally-calculated width and height if each is -1 */
2147 #define wxSIZE_AUTO (wxSIZE_AUTO_WIDTH|wxSIZE_AUTO_HEIGHT)
2148 /* Ignore missing (-1) dimensions (use existing). */
2149 /* For readability only: test for wxSIZE_AUTO_WIDTH/HEIGHT in code. */
2150 #define wxSIZE_USE_EXISTING 0x0000
2151 /* Allow -1 as a valid position */
2152 #define wxSIZE_ALLOW_MINUS_ONE 0x0004
2153 /* Don't do parent client adjustments (for implementation only) */
2154 #define wxSIZE_NO_ADJUSTMENTS 0x0008
2155 /* Change the window position even if it seems to be already correct */
2156 #define wxSIZE_FORCE 0x0010
2157
2158 /* ---------------------------------------------------------------------------- */
2159 /* GDI descriptions */
2160 /* ---------------------------------------------------------------------------- */
2161
2162 /* don't use any elements of this enum in the new code */
2163 enum wxDeprecatedGUIConstants
2164 {
2165 /* Text font families */
2166 wxDEFAULT = 70,
2167 wxDECORATIVE,
2168 wxROMAN,
2169 wxSCRIPT,
2170 wxSWISS,
2171 wxMODERN,
2172 wxTELETYPE, /* @@@@ */
2173
2174 /* Proportional or Fixed width fonts (not yet used) */
2175 wxVARIABLE = 80,
2176 wxFIXED,
2177
2178 wxNORMAL = 90,
2179 wxLIGHT,
2180 wxBOLD,
2181 /* Also wxNORMAL for normal (non-italic text) */
2182 wxITALIC,
2183 wxSLANT,
2184
2185
2186 #if FUTURE_WXWIN_COMPATIBILITY_3_0
2187 /*
2188 WARNING: the following styles are deprecated; use the wxBrushStyle,
2189 wxPenStyle, wxPenCap, wxPenJoin enum values instead!
2190 */
2191
2192 /* Pen styles */
2193 wxSOLID = 100,
2194 wxDOT,
2195 wxLONG_DASH,
2196 wxSHORT_DASH,
2197 wxDOT_DASH,
2198 wxUSER_DASH,
2199
2200 wxTRANSPARENT,
2201
2202 /* Brush & Pen Stippling. Note that a stippled pen cannot be dashed!! */
2203 /* Note also that stippling a Pen IS meaningfull, because a Line is */
2204 wxSTIPPLE_MASK_OPAQUE, /* mask is used for blitting monochrome using text fore and back ground colors */
2205 wxSTIPPLE_MASK, /* mask is used for masking areas in the stipple bitmap (TO DO) */
2206 /* drawn with a Pen, and without any Brush -- and it can be stippled. */
2207 wxSTIPPLE = 110,
2208
2209 wxBDIAGONAL_HATCH, /* In wxWidgets < 2.6 use WX_HATCH macro */
2210 wxCROSSDIAG_HATCH, /* to verify these wx*_HATCH are in style */
2211 wxFDIAGONAL_HATCH, /* of wxBrush. In wxWidgets >= 2.6 use */
2212 wxCROSS_HATCH, /* wxBrush::IsHatch() instead. */
2213 wxHORIZONTAL_HATCH,
2214 wxVERTICAL_HATCH,
2215 wxFIRST_HATCH = wxBDIAGONAL_HATCH,
2216 wxLAST_HATCH = wxVERTICAL_HATCH
2217 #endif
2218 };
2219
2220 /* Logical ops */
2221 typedef enum
2222 {
2223 wxCLEAR, wxROP_BLACK = wxCLEAR, wxBLIT_BLACKNESS = wxCLEAR, /* 0 */
2224 wxXOR, wxROP_XORPEN = wxXOR, wxBLIT_SRCINVERT = wxXOR, /* src XOR dst */
2225 wxINVERT, wxROP_NOT = wxINVERT, wxBLIT_DSTINVERT = wxINVERT, /* NOT dst */
2226 wxOR_REVERSE, wxROP_MERGEPENNOT = wxOR_REVERSE, wxBLIT_00DD0228 = wxOR_REVERSE, /* src OR (NOT dst) */
2227 wxAND_REVERSE, wxROP_MASKPENNOT = wxAND_REVERSE, wxBLIT_SRCERASE = wxAND_REVERSE, /* src AND (NOT dst) */
2228 wxCOPY, wxROP_COPYPEN = wxCOPY, wxBLIT_SRCCOPY = wxCOPY, /* src */
2229 wxAND, wxROP_MASKPEN = wxAND, wxBLIT_SRCAND = wxAND, /* src AND dst */
2230 wxAND_INVERT, wxROP_MASKNOTPEN = wxAND_INVERT, wxBLIT_00220326 = wxAND_INVERT, /* (NOT src) AND dst */
2231 wxNO_OP, wxROP_NOP = wxNO_OP, wxBLIT_00AA0029 = wxNO_OP, /* dst */
2232 wxNOR, wxROP_NOTMERGEPEN = wxNOR, wxBLIT_NOTSRCERASE = wxNOR, /* (NOT src) AND (NOT dst) */
2233 wxEQUIV, wxROP_NOTXORPEN = wxEQUIV, wxBLIT_00990066 = wxEQUIV, /* (NOT src) XOR dst */
2234 wxSRC_INVERT, wxROP_NOTCOPYPEN = wxSRC_INVERT, wxBLIT_NOTSCRCOPY = wxSRC_INVERT, /* (NOT src) */
2235 wxOR_INVERT, wxROP_MERGENOTPEN = wxOR_INVERT, wxBLIT_MERGEPAINT = wxOR_INVERT, /* (NOT src) OR dst */
2236 wxNAND, wxROP_NOTMASKPEN = wxNAND, wxBLIT_007700E6 = wxNAND, /* (NOT src) OR (NOT dst) */
2237 wxOR, wxROP_MERGEPEN = wxOR, wxBLIT_SRCPAINT = wxOR, /* src OR dst */
2238 wxSET, wxROP_WHITE = wxSET, wxBLIT_WHITENESS = wxSET /* 1 */
2239 } form_ops_t;
2240
2241 /* Flood styles */
2242 enum
2243 {
2244 wxFLOOD_SURFACE = 1,
2245 wxFLOOD_BORDER
2246 };
2247
2248 /* Polygon filling mode */
2249 enum
2250 {
2251 wxODDEVEN_RULE = 1,
2252 wxWINDING_RULE
2253 };
2254
2255 /* ToolPanel in wxFrame (VZ: unused?) */
2256 enum
2257 {
2258 wxTOOL_TOP = 1,
2259 wxTOOL_BOTTOM,
2260 wxTOOL_LEFT,
2261 wxTOOL_RIGHT
2262 };
2263
2264 /* the values of the format constants should be the same as corresponding */
2265 /* CF_XXX constants in Windows API */
2266 enum wxDataFormatId
2267 {
2268 wxDF_INVALID = 0,
2269 wxDF_TEXT = 1, /* CF_TEXT */
2270 wxDF_BITMAP = 2, /* CF_BITMAP */
2271 wxDF_METAFILE = 3, /* CF_METAFILEPICT */
2272 wxDF_SYLK = 4,
2273 wxDF_DIF = 5,
2274 wxDF_TIFF = 6,
2275 wxDF_OEMTEXT = 7, /* CF_OEMTEXT */
2276 wxDF_DIB = 8, /* CF_DIB */
2277 wxDF_PALETTE = 9,
2278 wxDF_PENDATA = 10,
2279 wxDF_RIFF = 11,
2280 wxDF_WAVE = 12,
2281 wxDF_UNICODETEXT = 13,
2282 wxDF_ENHMETAFILE = 14,
2283 wxDF_FILENAME = 15, /* CF_HDROP */
2284 wxDF_LOCALE = 16,
2285 wxDF_PRIVATE = 20,
2286 wxDF_HTML = 30, /* Note: does not correspond to CF_ constant */
2287 wxDF_MAX
2288 };
2289
2290 /* Virtual keycodes */
2291 enum wxKeyCode
2292 {
2293 WXK_BACK = 8,
2294 WXK_TAB = 9,
2295 WXK_RETURN = 13,
2296 WXK_ESCAPE = 27,
2297 WXK_SPACE = 32,
2298 WXK_DELETE = 127,
2299
2300 /* These are, by design, not compatible with unicode characters.
2301 If you want to get a unicode character from a key event, use
2302 wxKeyEvent::GetUnicodeKey instead. */
2303 WXK_START = 300,
2304 WXK_LBUTTON,
2305 WXK_RBUTTON,
2306 WXK_CANCEL,
2307 WXK_MBUTTON,
2308 WXK_CLEAR,
2309 WXK_SHIFT,
2310 WXK_ALT,
2311 WXK_CONTROL,
2312 WXK_MENU,
2313 WXK_PAUSE,
2314 WXK_CAPITAL,
2315 WXK_END,
2316 WXK_HOME,
2317 WXK_LEFT,
2318 WXK_UP,
2319 WXK_RIGHT,
2320 WXK_DOWN,
2321 WXK_SELECT,
2322 WXK_PRINT,
2323 WXK_EXECUTE,
2324 WXK_SNAPSHOT,
2325 WXK_INSERT,
2326 WXK_HELP,
2327 WXK_NUMPAD0,
2328 WXK_NUMPAD1,
2329 WXK_NUMPAD2,
2330 WXK_NUMPAD3,
2331 WXK_NUMPAD4,
2332 WXK_NUMPAD5,
2333 WXK_NUMPAD6,
2334 WXK_NUMPAD7,
2335 WXK_NUMPAD8,
2336 WXK_NUMPAD9,
2337 WXK_MULTIPLY,
2338 WXK_ADD,
2339 WXK_SEPARATOR,
2340 WXK_SUBTRACT,
2341 WXK_DECIMAL,
2342 WXK_DIVIDE,
2343 WXK_F1,
2344 WXK_F2,
2345 WXK_F3,
2346 WXK_F4,
2347 WXK_F5,
2348 WXK_F6,
2349 WXK_F7,
2350 WXK_F8,
2351 WXK_F9,
2352 WXK_F10,
2353 WXK_F11,
2354 WXK_F12,
2355 WXK_F13,
2356 WXK_F14,
2357 WXK_F15,
2358 WXK_F16,
2359 WXK_F17,
2360 WXK_F18,
2361 WXK_F19,
2362 WXK_F20,
2363 WXK_F21,
2364 WXK_F22,
2365 WXK_F23,
2366 WXK_F24,
2367 WXK_NUMLOCK,
2368 WXK_SCROLL,
2369 WXK_PAGEUP,
2370 WXK_PAGEDOWN,
2371 #if WXWIN_COMPATIBILITY_2_6
2372 WXK_PRIOR = WXK_PAGEUP,
2373 WXK_NEXT = WXK_PAGEDOWN,
2374 #endif
2375
2376 WXK_NUMPAD_SPACE,
2377 WXK_NUMPAD_TAB,
2378 WXK_NUMPAD_ENTER,
2379 WXK_NUMPAD_F1,
2380 WXK_NUMPAD_F2,
2381 WXK_NUMPAD_F3,
2382 WXK_NUMPAD_F4,
2383 WXK_NUMPAD_HOME,
2384 WXK_NUMPAD_LEFT,
2385 WXK_NUMPAD_UP,
2386 WXK_NUMPAD_RIGHT,
2387 WXK_NUMPAD_DOWN,
2388 WXK_NUMPAD_PAGEUP,
2389 WXK_NUMPAD_PAGEDOWN,
2390 #if WXWIN_COMPATIBILITY_2_6
2391 WXK_NUMPAD_PRIOR = WXK_NUMPAD_PAGEUP,
2392 WXK_NUMPAD_NEXT = WXK_NUMPAD_PAGEDOWN,
2393 #endif
2394 WXK_NUMPAD_END,
2395 WXK_NUMPAD_BEGIN,
2396 WXK_NUMPAD_INSERT,
2397 WXK_NUMPAD_DELETE,
2398 WXK_NUMPAD_EQUAL,
2399 WXK_NUMPAD_MULTIPLY,
2400 WXK_NUMPAD_ADD,
2401 WXK_NUMPAD_SEPARATOR,
2402 WXK_NUMPAD_SUBTRACT,
2403 WXK_NUMPAD_DECIMAL,
2404 WXK_NUMPAD_DIVIDE,
2405
2406 WXK_WINDOWS_LEFT,
2407 WXK_WINDOWS_RIGHT,
2408 WXK_WINDOWS_MENU ,
2409 WXK_COMMAND,
2410
2411 /* Hardware-specific buttons */
2412 WXK_SPECIAL1 = 193,
2413 WXK_SPECIAL2,
2414 WXK_SPECIAL3,
2415 WXK_SPECIAL4,
2416 WXK_SPECIAL5,
2417 WXK_SPECIAL6,
2418 WXK_SPECIAL7,
2419 WXK_SPECIAL8,
2420 WXK_SPECIAL9,
2421 WXK_SPECIAL10,
2422 WXK_SPECIAL11,
2423 WXK_SPECIAL12,
2424 WXK_SPECIAL13,
2425 WXK_SPECIAL14,
2426 WXK_SPECIAL15,
2427 WXK_SPECIAL16,
2428 WXK_SPECIAL17,
2429 WXK_SPECIAL18,
2430 WXK_SPECIAL19,
2431 WXK_SPECIAL20
2432 };
2433
2434 /* This enum contains bit mask constants used in wxKeyEvent */
2435 enum wxKeyModifier
2436 {
2437 wxMOD_NONE = 0x0000,
2438 wxMOD_ALT = 0x0001,
2439 wxMOD_CONTROL = 0x0002,
2440 wxMOD_ALTGR = wxMOD_ALT | wxMOD_CONTROL,
2441 wxMOD_SHIFT = 0x0004,
2442 wxMOD_META = 0x0008,
2443 wxMOD_WIN = wxMOD_META,
2444 #if defined(__WXMAC__) || defined(__WXCOCOA__)
2445 wxMOD_CMD = wxMOD_META,
2446 #else
2447 wxMOD_CMD = wxMOD_CONTROL,
2448 #endif
2449 wxMOD_ALL = 0xffff
2450 };
2451
2452 /* Mapping modes (same values as used by Windows, don't change) */
2453 enum
2454 {
2455 wxMM_TEXT = 1,
2456 wxMM_LOMETRIC,
2457 wxMM_HIMETRIC,
2458 wxMM_LOENGLISH,
2459 wxMM_HIENGLISH,
2460 wxMM_TWIPS,
2461 wxMM_ISOTROPIC,
2462 wxMM_ANISOTROPIC,
2463 wxMM_POINTS,
2464 wxMM_METRIC
2465 };
2466
2467 /* Shortcut for easier dialog-unit-to-pixel conversion */
2468 #define wxDLG_UNIT(parent, pt) parent->ConvertDialogToPixels(pt)
2469
2470 /* Paper types */
2471 typedef enum
2472 {
2473 wxPAPER_NONE, /* Use specific dimensions */
2474 wxPAPER_LETTER, /* Letter, 8 1/2 by 11 inches */
2475 wxPAPER_LEGAL, /* Legal, 8 1/2 by 14 inches */
2476 wxPAPER_A4, /* A4 Sheet, 210 by 297 millimeters */
2477 wxPAPER_CSHEET, /* C Sheet, 17 by 22 inches */
2478 wxPAPER_DSHEET, /* D Sheet, 22 by 34 inches */
2479 wxPAPER_ESHEET, /* E Sheet, 34 by 44 inches */
2480 wxPAPER_LETTERSMALL, /* Letter Small, 8 1/2 by 11 inches */
2481 wxPAPER_TABLOID, /* Tabloid, 11 by 17 inches */
2482 wxPAPER_LEDGER, /* Ledger, 17 by 11 inches */
2483 wxPAPER_STATEMENT, /* Statement, 5 1/2 by 8 1/2 inches */
2484 wxPAPER_EXECUTIVE, /* Executive, 7 1/4 by 10 1/2 inches */
2485 wxPAPER_A3, /* A3 sheet, 297 by 420 millimeters */
2486 wxPAPER_A4SMALL, /* A4 small sheet, 210 by 297 millimeters */
2487 wxPAPER_A5, /* A5 sheet, 148 by 210 millimeters */
2488 wxPAPER_B4, /* B4 sheet, 250 by 354 millimeters */
2489 wxPAPER_B5, /* B5 sheet, 182-by-257-millimeter paper */
2490 wxPAPER_FOLIO, /* Folio, 8-1/2-by-13-inch paper */
2491 wxPAPER_QUARTO, /* Quarto, 215-by-275-millimeter paper */
2492 wxPAPER_10X14, /* 10-by-14-inch sheet */
2493 wxPAPER_11X17, /* 11-by-17-inch sheet */
2494 wxPAPER_NOTE, /* Note, 8 1/2 by 11 inches */
2495 wxPAPER_ENV_9, /* #9 Envelope, 3 7/8 by 8 7/8 inches */
2496 wxPAPER_ENV_10, /* #10 Envelope, 4 1/8 by 9 1/2 inches */
2497 wxPAPER_ENV_11, /* #11 Envelope, 4 1/2 by 10 3/8 inches */
2498 wxPAPER_ENV_12, /* #12 Envelope, 4 3/4 by 11 inches */
2499 wxPAPER_ENV_14, /* #14 Envelope, 5 by 11 1/2 inches */
2500 wxPAPER_ENV_DL, /* DL Envelope, 110 by 220 millimeters */
2501 wxPAPER_ENV_C5, /* C5 Envelope, 162 by 229 millimeters */
2502 wxPAPER_ENV_C3, /* C3 Envelope, 324 by 458 millimeters */
2503 wxPAPER_ENV_C4, /* C4 Envelope, 229 by 324 millimeters */
2504 wxPAPER_ENV_C6, /* C6 Envelope, 114 by 162 millimeters */
2505 wxPAPER_ENV_C65, /* C65 Envelope, 114 by 229 millimeters */
2506 wxPAPER_ENV_B4, /* B4 Envelope, 250 by 353 millimeters */
2507 wxPAPER_ENV_B5, /* B5 Envelope, 176 by 250 millimeters */
2508 wxPAPER_ENV_B6, /* B6 Envelope, 176 by 125 millimeters */
2509 wxPAPER_ENV_ITALY, /* Italy Envelope, 110 by 230 millimeters */
2510 wxPAPER_ENV_MONARCH, /* Monarch Envelope, 3 7/8 by 7 1/2 inches */
2511 wxPAPER_ENV_PERSONAL, /* 6 3/4 Envelope, 3 5/8 by 6 1/2 inches */
2512 wxPAPER_FANFOLD_US, /* US Std Fanfold, 14 7/8 by 11 inches */
2513 wxPAPER_FANFOLD_STD_GERMAN, /* German Std Fanfold, 8 1/2 by 12 inches */
2514 wxPAPER_FANFOLD_LGL_GERMAN, /* German Legal Fanfold, 8 1/2 by 13 inches */
2515
2516 wxPAPER_ISO_B4, /* B4 (ISO) 250 x 353 mm */
2517 wxPAPER_JAPANESE_POSTCARD, /* Japanese Postcard 100 x 148 mm */
2518 wxPAPER_9X11, /* 9 x 11 in */
2519 wxPAPER_10X11, /* 10 x 11 in */
2520 wxPAPER_15X11, /* 15 x 11 in */
2521 wxPAPER_ENV_INVITE, /* Envelope Invite 220 x 220 mm */
2522 wxPAPER_LETTER_EXTRA, /* Letter Extra 9 \275 x 12 in */
2523 wxPAPER_LEGAL_EXTRA, /* Legal Extra 9 \275 x 15 in */
2524 wxPAPER_TABLOID_EXTRA, /* Tabloid Extra 11.69 x 18 in */
2525 wxPAPER_A4_EXTRA, /* A4 Extra 9.27 x 12.69 in */
2526 wxPAPER_LETTER_TRANSVERSE, /* Letter Transverse 8 \275 x 11 in */
2527 wxPAPER_A4_TRANSVERSE, /* A4 Transverse 210 x 297 mm */
2528 wxPAPER_LETTER_EXTRA_TRANSVERSE, /* Letter Extra Transverse 9\275 x 12 in */
2529 wxPAPER_A_PLUS, /* SuperA/SuperA/A4 227 x 356 mm */
2530 wxPAPER_B_PLUS, /* SuperB/SuperB/A3 305 x 487 mm */
2531 wxPAPER_LETTER_PLUS, /* Letter Plus 8.5 x 12.69 in */
2532 wxPAPER_A4_PLUS, /* A4 Plus 210 x 330 mm */
2533 wxPAPER_A5_TRANSVERSE, /* A5 Transverse 148 x 210 mm */
2534 wxPAPER_B5_TRANSVERSE, /* B5 (JIS) Transverse 182 x 257 mm */
2535 wxPAPER_A3_EXTRA, /* A3 Extra 322 x 445 mm */
2536 wxPAPER_A5_EXTRA, /* A5 Extra 174 x 235 mm */
2537 wxPAPER_B5_EXTRA, /* B5 (ISO) Extra 201 x 276 mm */
2538 wxPAPER_A2, /* A2 420 x 594 mm */
2539 wxPAPER_A3_TRANSVERSE, /* A3 Transverse 297 x 420 mm */
2540 wxPAPER_A3_EXTRA_TRANSVERSE, /* A3 Extra Transverse 322 x 445 mm */
2541
2542 wxPAPER_DBL_JAPANESE_POSTCARD,/* Japanese Double Postcard 200 x 148 mm */
2543 wxPAPER_A6, /* A6 105 x 148 mm */
2544 wxPAPER_JENV_KAKU2, /* Japanese Envelope Kaku #2 */
2545 wxPAPER_JENV_KAKU3, /* Japanese Envelope Kaku #3 */
2546 wxPAPER_JENV_CHOU3, /* Japanese Envelope Chou #3 */
2547 wxPAPER_JENV_CHOU4, /* Japanese Envelope Chou #4 */
2548 wxPAPER_LETTER_ROTATED, /* Letter Rotated 11 x 8 1/2 in */
2549 wxPAPER_A3_ROTATED, /* A3 Rotated 420 x 297 mm */
2550 wxPAPER_A4_ROTATED, /* A4 Rotated 297 x 210 mm */
2551 wxPAPER_A5_ROTATED, /* A5 Rotated 210 x 148 mm */
2552 wxPAPER_B4_JIS_ROTATED, /* B4 (JIS) Rotated 364 x 257 mm */
2553 wxPAPER_B5_JIS_ROTATED, /* B5 (JIS) Rotated 257 x 182 mm */
2554 wxPAPER_JAPANESE_POSTCARD_ROTATED,/* Japanese Postcard Rotated 148 x 100 mm */
2555 wxPAPER_DBL_JAPANESE_POSTCARD_ROTATED,/* Double Japanese Postcard Rotated 148 x 200 mm */
2556 wxPAPER_A6_ROTATED, /* A6 Rotated 148 x 105 mm */
2557 wxPAPER_JENV_KAKU2_ROTATED, /* Japanese Envelope Kaku #2 Rotated */
2558 wxPAPER_JENV_KAKU3_ROTATED, /* Japanese Envelope Kaku #3 Rotated */
2559 wxPAPER_JENV_CHOU3_ROTATED, /* Japanese Envelope Chou #3 Rotated */
2560 wxPAPER_JENV_CHOU4_ROTATED, /* Japanese Envelope Chou #4 Rotated */
2561 wxPAPER_B6_JIS, /* B6 (JIS) 128 x 182 mm */
2562 wxPAPER_B6_JIS_ROTATED, /* B6 (JIS) Rotated 182 x 128 mm */
2563 wxPAPER_12X11, /* 12 x 11 in */
2564 wxPAPER_JENV_YOU4, /* Japanese Envelope You #4 */
2565 wxPAPER_JENV_YOU4_ROTATED, /* Japanese Envelope You #4 Rotated */
2566 wxPAPER_P16K, /* PRC 16K 146 x 215 mm */
2567 wxPAPER_P32K, /* PRC 32K 97 x 151 mm */
2568 wxPAPER_P32KBIG, /* PRC 32K(Big) 97 x 151 mm */
2569 wxPAPER_PENV_1, /* PRC Envelope #1 102 x 165 mm */
2570 wxPAPER_PENV_2, /* PRC Envelope #2 102 x 176 mm */
2571 wxPAPER_PENV_3, /* PRC Envelope #3 125 x 176 mm */
2572 wxPAPER_PENV_4, /* PRC Envelope #4 110 x 208 mm */
2573 wxPAPER_PENV_5, /* PRC Envelope #5 110 x 220 mm */
2574 wxPAPER_PENV_6, /* PRC Envelope #6 120 x 230 mm */
2575 wxPAPER_PENV_7, /* PRC Envelope #7 160 x 230 mm */
2576 wxPAPER_PENV_8, /* PRC Envelope #8 120 x 309 mm */
2577 wxPAPER_PENV_9, /* PRC Envelope #9 229 x 324 mm */
2578 wxPAPER_PENV_10, /* PRC Envelope #10 324 x 458 mm */
2579 wxPAPER_P16K_ROTATED, /* PRC 16K Rotated */
2580 wxPAPER_P32K_ROTATED, /* PRC 32K Rotated */
2581 wxPAPER_P32KBIG_ROTATED, /* PRC 32K(Big) Rotated */
2582 wxPAPER_PENV_1_ROTATED, /* PRC Envelope #1 Rotated 165 x 102 mm */
2583 wxPAPER_PENV_2_ROTATED, /* PRC Envelope #2 Rotated 176 x 102 mm */
2584 wxPAPER_PENV_3_ROTATED, /* PRC Envelope #3 Rotated 176 x 125 mm */
2585 wxPAPER_PENV_4_ROTATED, /* PRC Envelope #4 Rotated 208 x 110 mm */
2586 wxPAPER_PENV_5_ROTATED, /* PRC Envelope #5 Rotated 220 x 110 mm */
2587 wxPAPER_PENV_6_ROTATED, /* PRC Envelope #6 Rotated 230 x 120 mm */
2588 wxPAPER_PENV_7_ROTATED, /* PRC Envelope #7 Rotated 230 x 160 mm */
2589 wxPAPER_PENV_8_ROTATED, /* PRC Envelope #8 Rotated 309 x 120 mm */
2590 wxPAPER_PENV_9_ROTATED, /* PRC Envelope #9 Rotated 324 x 229 mm */
2591 wxPAPER_PENV_10_ROTATED /* PRC Envelope #10 Rotated 458 x 324 m */
2592 } wxPaperSize;
2593
2594 /* Printing orientation */
2595 #ifndef wxPORTRAIT
2596 #define wxPORTRAIT 1
2597 #define wxLANDSCAPE 2
2598 #endif
2599
2600 /* Duplex printing modes
2601 */
2602
2603 enum wxDuplexMode
2604 {
2605 wxDUPLEX_SIMPLEX, /* Non-duplex */
2606 wxDUPLEX_HORIZONTAL,
2607 wxDUPLEX_VERTICAL
2608 };
2609
2610 /* Print quality.
2611 */
2612
2613 #define wxPRINT_QUALITY_HIGH -1
2614 #define wxPRINT_QUALITY_MEDIUM -2
2615 #define wxPRINT_QUALITY_LOW -3
2616 #define wxPRINT_QUALITY_DRAFT -4
2617
2618 typedef int wxPrintQuality;
2619
2620 /* Print mode (currently PostScript only)
2621 */
2622
2623 enum wxPrintMode
2624 {
2625 wxPRINT_MODE_NONE = 0,
2626 wxPRINT_MODE_PREVIEW = 1, /* Preview in external application */
2627 wxPRINT_MODE_FILE = 2, /* Print to file */
2628 wxPRINT_MODE_PRINTER = 3, /* Send to printer */
2629 wxPRINT_MODE_STREAM = 4 /* Send postscript data into a stream */
2630 };
2631
2632 /* ---------------------------------------------------------------------------- */
2633 /* UpdateWindowUI flags */
2634 /* ---------------------------------------------------------------------------- */
2635
2636 enum wxUpdateUI
2637 {
2638 wxUPDATE_UI_NONE = 0x0000,
2639 wxUPDATE_UI_RECURSE = 0x0001,
2640 wxUPDATE_UI_FROMIDLE = 0x0002 /* Invoked from On(Internal)Idle */
2641 };
2642
2643 /* ---------------------------------------------------------------------------- */
2644 /* miscellaneous */
2645 /* ---------------------------------------------------------------------------- */
2646
2647 /* define this macro if font handling is done using the X font names */
2648 #if (defined(__WXGTK__) && !defined(__WXGTK20__)) || defined(__X__)
2649 #define _WX_X_FONTLIKE
2650 #endif
2651
2652 /* macro to specify "All Files" on different platforms */
2653 #if defined(__WXMSW__) || defined(__WXPM__)
2654 # define wxALL_FILES_PATTERN wxT("*.*")
2655 # define wxALL_FILES gettext_noop("All files (*.*)|*.*")
2656 #else
2657 # define wxALL_FILES_PATTERN wxT("*")
2658 # define wxALL_FILES gettext_noop("All files (*)|*")
2659 #endif
2660
2661 #if defined(__CYGWIN__) && defined(__WXMSW__)
2662 # if wxUSE_STL || defined(wxUSE_STD_STRING)
2663 /*
2664 NASTY HACK because the gethostname in sys/unistd.h which the gnu
2665 stl includes and wx builds with by default clash with each other
2666 (windows version 2nd param is int, sys/unistd.h version is unsigned
2667 int).
2668 */
2669 # define gethostname gethostnameHACK
2670 # include <unistd.h>
2671 # undef gethostname
2672 # endif
2673 #endif
2674
2675 /* --------------------------------------------------------------------------- */
2676 /* macros that enable wxWidgets apps to be compiled in absence of the */
2677 /* sytem headers, although some platform specific types are used in the */
2678 /* platform specific (implementation) parts of the headers */
2679 /* --------------------------------------------------------------------------- */
2680
2681 #ifdef __WXMAC__
2682
2683 #define WX_OPAQUE_TYPE( name ) struct wxOpaque##name
2684
2685 typedef void* WXHBITMAP;
2686 typedef void* WXHCURSOR;
2687 typedef void* WXRECTPTR;
2688 typedef void* WXPOINTPTR;
2689 typedef void* WXHWND;
2690 typedef void* WXEVENTREF;
2691 typedef void* WXEVENTHANDLERREF;
2692 typedef void* WXEVENTHANDLERCALLREF;
2693 typedef void* WXAPPLEEVENTREF;
2694 typedef void* WXHMENU;
2695
2696 typedef unsigned int WXUINT;
2697 typedef unsigned long WXDWORD;
2698 typedef unsigned short WXWORD;
2699
2700 typedef WX_OPAQUE_TYPE(PicHandle ) * WXHMETAFILE ;
2701 #if wxOSX_USE_CARBON
2702 typedef WX_OPAQUE_TYPE(ControlRef ) * WXWidget ;
2703 typedef WX_OPAQUE_TYPE(WindowRef) * WXWindow ;
2704 #endif
2705
2706 typedef void* WXDisplay;
2707
2708 /*
2709 * core frameworks
2710 */
2711
2712 typedef const void * CFTypeRef;
2713
2714 typedef const struct __CFString * CFStringRef;
2715 typedef struct __CFString * CFMutableStringRef;
2716
2717 typedef struct __CFRunLoopSource * CFRunLoopSourceRef;
2718
2719 #define DECLARE_WXMAC_OPAQUE_CGREF( name ) typedef struct name* name##Ref;
2720
2721 DECLARE_WXMAC_OPAQUE_CGREF( CGColor )
2722 DECLARE_WXMAC_OPAQUE_CGREF( CGImage )
2723 DECLARE_WXMAC_OPAQUE_CGREF( CGContext )
2724
2725 typedef CGColorRef WXCOLORREF;
2726 typedef CGImageRef WXCGIMAGEREF;
2727 typedef CGContextRef WXHDC;
2728
2729 /*
2730 * carbon
2731 */
2732
2733 typedef const struct __HIShape * HIShapeRef;
2734 typedef struct __HIShape * HIMutableShapeRef;
2735
2736 #define DECLARE_WXMAC_OPAQUE_REF( name ) typedef struct Opaque##name* name;
2737
2738 DECLARE_WXMAC_OPAQUE_REF( PasteboardRef )
2739 DECLARE_WXMAC_OPAQUE_REF( IconRef )
2740
2741 typedef IconRef WXHICON ;
2742 typedef HIShapeRef WXHRGN;
2743
2744 #endif
2745
2746 #if defined( __WXCOCOA__ ) || defined(__WXMAC__)
2747
2748 /* Definitions of 32-bit/64-bit types
2749 * These are typedef'd exactly the same way in newer OS X headers so
2750 * redefinition when real headers are included should not be a problem. If
2751 * it is, the types are being defined wrongly here.
2752 * The purpose of these types is so they can be used from public wx headers.
2753 * and also because the older (pre-Leopard) headers don't define them.
2754 */
2755
2756 /* NOTE: We don't pollute namespace with CGFLOAT_MIN/MAX/IS_DOUBLE macros
2757 * since they are unlikely to be needed in a public header.
2758 */
2759 #if defined(__LP64__) && __LP64__
2760 typedef double CGFloat;
2761 #else
2762 typedef float CGFloat;
2763 #endif
2764
2765 #if (defined(__LP64__) && __LP64__) || (defined(NS_BUILD_32_LIKE_64) && NS_BUILD_32_LIKE_64)
2766 typedef long NSInteger;
2767 typedef unsigned long NSUInteger;
2768 #else
2769 typedef int NSInteger;
2770 typedef unsigned int NSUInteger;
2771 #endif
2772
2773 /* Objective-C type declarations.
2774 * These are to be used in public headers in lieu of NSSomething* because
2775 * Objective-C class names are not available in C/C++ code.
2776 */
2777
2778 /* NOTE: This ought to work with other compilers too, but I'm being cautious */
2779 #if (defined(__GNUC__) && defined(__APPLE__)) || defined(__MWERKS__)
2780 /* It's desirable to have type safety for Objective-C(++) code as it does
2781 at least catch typos of method names among other things. However, it
2782 is not possible to declare an Objective-C class from plain old C or C++
2783 code. Furthermore, because of C++ name mangling, the type name must
2784 be the same for both C++ and Objective-C++ code. Therefore, we define
2785 what should be a pointer to an Objective-C class as a pointer to a plain
2786 old C struct with the same name. Unfortunately, because the compiler
2787 does not see a struct as an Objective-C class we cannot declare it
2788 as a struct in Objective-C(++) mode.
2789 */
2790 #if defined(__OBJC__)
2791 #define DECLARE_WXCOCOA_OBJC_CLASS(klass) \
2792 @class klass; \
2793 typedef klass *WX_##klass
2794 #else /* not defined(__OBJC__) */
2795 #define DECLARE_WXCOCOA_OBJC_CLASS(klass) \
2796 typedef struct klass *WX_##klass
2797 #endif /* defined(__OBJC__) */
2798
2799 #else /* not Apple's GNU or CodeWarrior */
2800 #warning "Objective-C types will not be checked by the compiler."
2801 /* NOTE: typedef struct objc_object *id; */
2802 /* IOW, we're declaring these using the id type without using that name, */
2803 /* since "id" is used extensively not only within wxWidgets itself, but */
2804 /* also in wxWidgets application code. The following works fine when */
2805 /* compiling C(++) code, and works without typesafety for Obj-C(++) code */
2806 #define DECLARE_WXCOCOA_OBJC_CLASS(klass) \
2807 typedef struct objc_object *WX_##klass
2808
2809 #endif /* (defined(__GNUC__) && defined(__APPLE__)) || defined(__MWERKS__) */
2810
2811 DECLARE_WXCOCOA_OBJC_CLASS(NSApplication);
2812 DECLARE_WXCOCOA_OBJC_CLASS(NSBitmapImageRep);
2813 DECLARE_WXCOCOA_OBJC_CLASS(NSBox);
2814 DECLARE_WXCOCOA_OBJC_CLASS(NSButton);
2815 DECLARE_WXCOCOA_OBJC_CLASS(NSColor);
2816 DECLARE_WXCOCOA_OBJC_CLASS(NSColorPanel);
2817 DECLARE_WXCOCOA_OBJC_CLASS(NSControl);
2818 DECLARE_WXCOCOA_OBJC_CLASS(NSCursor);
2819 DECLARE_WXCOCOA_OBJC_CLASS(NSEvent);
2820 DECLARE_WXCOCOA_OBJC_CLASS(NSFontPanel);
2821 DECLARE_WXCOCOA_OBJC_CLASS(NSImage);
2822 DECLARE_WXCOCOA_OBJC_CLASS(NSLayoutManager);
2823 DECLARE_WXCOCOA_OBJC_CLASS(NSMenu);
2824 DECLARE_WXCOCOA_OBJC_CLASS(NSMenuExtra);
2825 DECLARE_WXCOCOA_OBJC_CLASS(NSMenuItem);
2826 DECLARE_WXCOCOA_OBJC_CLASS(NSMutableArray);
2827 DECLARE_WXCOCOA_OBJC_CLASS(NSNotification);
2828 DECLARE_WXCOCOA_OBJC_CLASS(NSObject);
2829 DECLARE_WXCOCOA_OBJC_CLASS(NSPanel);
2830 DECLARE_WXCOCOA_OBJC_CLASS(NSScrollView);
2831 DECLARE_WXCOCOA_OBJC_CLASS(NSSound);
2832 DECLARE_WXCOCOA_OBJC_CLASS(NSStatusItem);
2833 DECLARE_WXCOCOA_OBJC_CLASS(NSTableColumn);
2834 DECLARE_WXCOCOA_OBJC_CLASS(NSTableView);
2835 DECLARE_WXCOCOA_OBJC_CLASS(NSTextContainer);
2836 DECLARE_WXCOCOA_OBJC_CLASS(NSTextField);
2837 DECLARE_WXCOCOA_OBJC_CLASS(NSTextStorage);
2838 DECLARE_WXCOCOA_OBJC_CLASS(NSThread);
2839 DECLARE_WXCOCOA_OBJC_CLASS(NSWindow);
2840 DECLARE_WXCOCOA_OBJC_CLASS(NSView);
2841 #ifndef __WXMAC__
2842 typedef WX_NSView WXWidget; /* wxWidgets BASE definition */
2843 #endif
2844 #endif /* __WXCOCOA__ || ( __WXMAC__ &__DARWIN__)*/
2845
2846 #ifdef __WXMAC__
2847
2848 DECLARE_WXCOCOA_OBJC_CLASS(NSString);
2849
2850 #if wxOSX_USE_COCOA
2851
2852 typedef WX_NSWindow WXWindow;
2853 typedef WX_NSView WXWidget;
2854
2855 #elif wxOSX_USE_IPHONE
2856
2857 DECLARE_WXCOCOA_OBJC_CLASS(UIWindow);
2858 DECLARE_WXCOCOA_OBJC_CLASS(UIView);
2859 DECLARE_WXCOCOA_OBJC_CLASS(UIFont);
2860
2861 typedef WX_UIWindow WXWindow;
2862 typedef WX_UIView WXWidget;
2863
2864 #endif
2865
2866 #endif // __WXMAC__
2867
2868 #if defined(__WXPALMOS__)
2869
2870 typedef void * WXHWND;
2871 typedef void * WXHANDLE;
2872 typedef void * WXHICON;
2873 typedef void * WXHFONT;
2874 typedef void * WXHMENU;
2875 typedef void * WXHPEN;
2876 typedef void * WXHBRUSH;
2877 typedef void * WXHPALETTE;
2878 typedef void * WXHCURSOR;
2879 typedef void * WXHRGN;
2880 typedef void * WXHACCEL;
2881 typedef void * WXHINSTANCE;
2882 typedef void * WXHBITMAP;
2883 typedef void * WXHIMAGELIST;
2884 typedef void * WXHGLOBAL;
2885 typedef void * WXHDC;
2886 typedef unsigned int WXUINT;
2887 typedef unsigned long WXDWORD;
2888 typedef unsigned short WXWORD;
2889
2890 typedef unsigned long WXCOLORREF;
2891 typedef struct tagMSG WXMSG;
2892
2893 typedef WXHWND WXWINHANDLE; /* WinHandle of PalmOS */
2894 typedef WXWINHANDLE WXWidget;
2895
2896 typedef void * WXFORMPTR;
2897 typedef void * WXEVENTPTR;
2898 typedef void * WXRECTANGLEPTR;
2899
2900 #endif /* __WXPALMOS__ */
2901
2902
2903 /* ABX: check __WIN32__ instead of __WXMSW__ for the same MSWBase in any Win32 port */
2904 #if defined(__WIN32__)
2905
2906 /* the keywords needed for WinMain() declaration */
2907 #ifndef WXFAR
2908 # define WXFAR
2909 #endif
2910
2911 /* Stand-ins for Windows types to avoid #including all of windows.h */
2912 typedef void * WXHWND;
2913 typedef void * WXHANDLE;
2914 typedef void * WXHICON;
2915 typedef void * WXHFONT;
2916 typedef void * WXHMENU;
2917 typedef void * WXHPEN;
2918 typedef void * WXHBRUSH;
2919 typedef void * WXHPALETTE;
2920 typedef void * WXHCURSOR;
2921 typedef void * WXHRGN;
2922 typedef void * WXRECTPTR;
2923 typedef void * WXHACCEL;
2924 typedef void WXFAR * WXHINSTANCE;
2925 typedef void * WXHBITMAP;
2926 typedef void * WXHIMAGELIST;
2927 typedef void * WXHGLOBAL;
2928 typedef void * WXHDC;
2929 typedef unsigned int WXUINT;
2930 typedef unsigned long WXDWORD;
2931 typedef unsigned short WXWORD;
2932
2933 typedef unsigned long WXCOLORREF;
2934 typedef void * WXRGNDATA;
2935 typedef struct tagMSG WXMSG;
2936 typedef void * WXHCONV;
2937 typedef void * WXHKEY;
2938 typedef void * WXHTREEITEM;
2939
2940 typedef void * WXDRAWITEMSTRUCT;
2941 typedef void * WXMEASUREITEMSTRUCT;
2942 typedef void * WXLPCREATESTRUCT;
2943
2944 typedef WXHWND WXWidget;
2945
2946 #ifdef __WIN64__
2947 typedef unsigned __int64 WXWPARAM;
2948 typedef __int64 WXLPARAM;
2949 typedef __int64 WXLRESULT;
2950 #else
2951 typedef wxW64 unsigned int WXWPARAM;
2952 typedef wxW64 long WXLPARAM;
2953 typedef wxW64 long WXLRESULT;
2954 #endif
2955
2956 #if defined(__GNUWIN32__) || defined(__WXMICROWIN__)
2957 typedef int (*WXFARPROC)();
2958 #else
2959 typedef int (__stdcall *WXFARPROC)();
2960 #endif
2961 #endif /* __WIN32__ */
2962
2963
2964 #if defined(__OS2__)
2965 typedef unsigned long DWORD;
2966 typedef unsigned short WORD;
2967 #endif
2968
2969 #if defined(__WXPM__) || defined(__EMX__)
2970 #ifdef __WXPM__
2971 /* Stand-ins for OS/2 types, to avoid #including all of os2.h */
2972 typedef unsigned long WXHWND;
2973 typedef unsigned long WXHANDLE;
2974 typedef unsigned long WXHICON;
2975 typedef unsigned long WXHFONT;
2976 typedef unsigned long WXHMENU;
2977 typedef unsigned long WXHPEN;
2978 typedef unsigned long WXHBRUSH;
2979 typedef unsigned long WXHPALETTE;
2980 typedef unsigned long WXHCURSOR;
2981 typedef unsigned long WXHRGN;
2982 typedef unsigned long WXHACCEL;
2983 typedef unsigned long WXHBITMAP;
2984 typedef unsigned long WXHDC;
2985 typedef unsigned int WXUINT;
2986 typedef unsigned long WXDWORD;
2987 typedef unsigned short WXWORD;
2988
2989 typedef unsigned long WXCOLORREF;
2990 typedef void * WXMSG;
2991 typedef unsigned long WXHTREEITEM;
2992
2993 typedef void * WXDRAWITEMSTRUCT;
2994 typedef void * WXMEASUREITEMSTRUCT;
2995 typedef void * WXLPCREATESTRUCT;
2996
2997 typedef WXHWND WXWidget;
2998 #endif
2999 #ifdef __EMX__
3000 /* Need a well-known type for WXFARPROC
3001 below. MPARAM is typedef'ed too late. */
3002 #define WXWPARAM void *
3003 #define WXLPARAM void *
3004 #else
3005 #define WXWPARAM MPARAM
3006 #define WXLPARAM MPARAM
3007 #endif
3008 #define RECT RECTL
3009 #define LOGFONT FATTRS
3010 #define LOWORD SHORT1FROMMP
3011 #define HIWORD SHORT2FROMMP
3012
3013 typedef unsigned long WXMPARAM;
3014 typedef unsigned long WXMSGID;
3015 typedef void* WXRESULT;
3016 /* typedef int (*WXFARPROC)(); */
3017 /* some windows handles not defined by PM */
3018 typedef unsigned long HANDLE;
3019 typedef unsigned long HICON;
3020 typedef unsigned long HFONT;
3021 typedef unsigned long HMENU;
3022 typedef unsigned long HPEN;
3023 typedef unsigned long HBRUSH;
3024 typedef unsigned long HPALETTE;
3025 typedef unsigned long HCURSOR;
3026 typedef unsigned long HINSTANCE;
3027 typedef unsigned long HIMAGELIST;
3028 typedef unsigned long HGLOBAL;
3029 #endif /* WXPM || EMX */
3030
3031 #if defined (__WXPM__)
3032 /* WIN32 graphics types for OS/2 GPI */
3033
3034 /* RGB under OS2 is more like a PALETTEENTRY struct under Windows so we need a real RGB def */
3035 #define OS2RGB(r,g,b) ((DWORD)((unsigned char)(b) | ((unsigned char)(g) << 8)) | ((unsigned char)(r) << 16))
3036
3037 typedef unsigned long COLORREF;
3038 #define GetRValue(rgb) ((unsigned char)((rgb) >> 16))
3039 #define GetGValue(rgb) ((unsigned char)(((unsigned short)(rgb)) >> 8))
3040 #define GetBValue(rgb) ((unsigned char)(rgb))
3041 #define PALETTEINDEX(i) ((COLORREF)(0x01000000 | (DWORD)(WORD)(i)))
3042 #define PALETTERGB(r,g,b) (0x02000000 | OS2RGB(r,g,b))
3043 /* OS2's RGB/RGB2 is backwards from this */
3044 typedef struct tagPALETTEENTRY
3045 {
3046 char bRed;
3047 char bGreen;
3048 char bBlue;
3049 char bFlags;
3050 } PALETTEENTRY;
3051 typedef struct tagLOGPALETTE
3052 {
3053 WORD palVersion;
3054 WORD palNumentries;
3055 WORD PALETTEENTRY[1];
3056 } LOGPALETTE;
3057
3058 #if (defined(__VISAGECPP__) && (__IBMCPP__ < 400)) || defined (__WATCOMC__)
3059 /* VA 3.0 for some reason needs base data types when typedefing a proc proto??? */
3060 typedef void* (_System *WXFARPROC)(unsigned long, unsigned long, void*, void*);
3061 #else
3062 #if defined(__EMX__) && !defined(_System)
3063 #define _System
3064 #endif
3065 typedef WXRESULT (_System *WXFARPROC)(WXHWND, WXMSGID, WXWPARAM, WXLPARAM);
3066 #endif
3067
3068 #endif /* __WXPM__ */
3069
3070
3071 #if defined(__WXMOTIF__) || defined(__WXX11__)
3072 /* Stand-ins for X/Xt/Motif types */
3073 typedef void* WXWindow;
3074 typedef void* WXWidget;
3075 typedef void* WXAppContext;
3076 typedef void* WXColormap;
3077 typedef void* WXColor;
3078 typedef void WXDisplay;
3079 typedef void WXEvent;
3080 typedef void* WXCursor;
3081 typedef void* WXPixmap;
3082 typedef void* WXFontStructPtr;
3083 typedef void* WXGC;
3084 typedef void* WXRegion;
3085 typedef void* WXFont;
3086 typedef void* WXImage;
3087 typedef void* WXFontList;
3088 typedef void* WXFontSet;
3089 typedef void* WXRendition;
3090 typedef void* WXRenderTable;
3091 typedef void* WXFontType; /* either a XmFontList or XmRenderTable */
3092 typedef void* WXString;
3093
3094 typedef unsigned long Atom; /* this might fail on a few architectures */
3095 typedef long WXPixel; /* safety catch in src/motif/colour.cpp */
3096
3097 #endif /* Motif */
3098
3099 #ifdef __WXGTK__
3100
3101 /* Stand-ins for GLIB types */
3102 typedef char gchar;
3103 typedef signed char gint8;
3104 typedef int gint;
3105 typedef unsigned guint;
3106 typedef unsigned long gulong;
3107 typedef void* gpointer;
3108 typedef struct _GSList GSList;
3109
3110 /* Stand-ins for GDK types */
3111 typedef struct _GdkColor GdkColor;
3112 typedef struct _GdkColormap GdkColormap;
3113 typedef struct _GdkFont GdkFont;
3114 typedef struct _GdkGC GdkGC;
3115 typedef struct _GdkVisual GdkVisual;
3116
3117 #ifdef __WXGTK20__
3118 typedef struct _GdkAtom *GdkAtom;
3119 typedef struct _GdkDrawable GdkWindow;
3120 typedef struct _GdkDrawable GdkBitmap;
3121 typedef struct _GdkDrawable GdkPixmap;
3122 #else /* GTK+ 1.2 */
3123 typedef gulong GdkAtom;
3124 typedef struct _GdkWindow GdkWindow;
3125 typedef struct _GdkWindow GdkBitmap;
3126 typedef struct _GdkWindow GdkPixmap;
3127 #endif /* GTK+ 1.2/2.0 */
3128
3129 typedef struct _GdkCursor GdkCursor;
3130 typedef struct _GdkRegion GdkRegion;
3131 typedef struct _GdkDragContext GdkDragContext;
3132
3133 #ifdef HAVE_XIM
3134 typedef struct _GdkIC GdkIC;
3135 typedef struct _GdkICAttr GdkICAttr;
3136 #endif
3137
3138 /* Stand-ins for GTK types */
3139 typedef struct _GtkWidget GtkWidget;
3140 typedef struct _GtkRcStyle GtkRcStyle;
3141 typedef struct _GtkAdjustment GtkAdjustment;
3142 typedef struct _GtkList GtkList;
3143 typedef struct _GtkToolbar GtkToolbar;
3144 typedef struct _GtkTooltips GtkTooltips;
3145 typedef struct _GtkNotebook GtkNotebook;
3146 typedef struct _GtkNotebookPage GtkNotebookPage;
3147 typedef struct _GtkAccelGroup GtkAccelGroup;
3148 typedef struct _GtkItemFactory GtkItemFactory;
3149 typedef struct _GtkSelectionData GtkSelectionData;
3150 typedef struct _GtkTextBuffer GtkTextBuffer;
3151 typedef struct _GtkRange GtkRange;
3152 typedef struct _GtkCellRenderer GtkCellRenderer;
3153
3154 typedef GtkWidget *WXWidget;
3155
3156 #ifndef __WXGTK20__
3157 #define GTK_OBJECT_GET_CLASS(object) (GTK_OBJECT(object)->klass)
3158 #define GTK_CLASS_TYPE(klass) ((klass)->type)
3159 #endif
3160
3161 #endif /* __WXGTK__ */
3162
3163 #if defined(__WXGTK20__) || (defined(__WXX11__) && wxUSE_UNICODE)
3164 #define wxUSE_PANGO 1
3165 #else
3166 #define wxUSE_PANGO 0
3167 #endif
3168
3169 #if wxUSE_PANGO
3170 /* Stand-ins for Pango types */
3171 typedef struct _PangoContext PangoContext;
3172 typedef struct _PangoLayout PangoLayout;
3173 typedef struct _PangoFontDescription PangoFontDescription;
3174 #endif
3175
3176 #ifdef __WXMGL__
3177 typedef struct window_t *WXWidget;
3178 #endif /* MGL */
3179
3180 #ifdef __WXDFB__
3181 /* DirectFB doesn't have the concept of non-TLW window, so use
3182 something arbitrary */
3183 typedef const void* WXWidget;
3184 #endif /* DFB */
3185
3186 /* This is required because of clashing macros in windows.h, which may be */
3187 /* included before or after wxWidgets classes, and therefore must be */
3188 /* disabled here before any significant wxWidgets headers are included. */
3189 #ifdef __WXMSW__
3190 #include "wx/msw/winundef.h"
3191 #endif /* __WXMSW__ */
3192
3193
3194 /* include the feature test macros */
3195 #include "wx/features.h"
3196
3197 /* --------------------------------------------------------------------------- */
3198 /* macro to define a class without copy ctor nor assignment operator */
3199 /* --------------------------------------------------------------------------- */
3200
3201 #define DECLARE_NO_COPY_CLASS(classname) \
3202 private: \
3203 classname(const classname&); \
3204 classname& operator=(const classname&);
3205
3206 #define DECLARE_NO_ASSIGN_CLASS(classname) \
3207 private: \
3208 classname& operator=(const classname&);
3209
3210 /* --------------------------------------------------------------------------- */
3211 /* If a manifest is being automatically generated, add common controls 6 to it */
3212 /* --------------------------------------------------------------------------- */
3213
3214 #if (!defined wxUSE_NO_MANIFEST || wxUSE_NO_MANIFEST == 0 ) && \
3215 ( defined _MSC_FULL_VER && _MSC_FULL_VER >= 140040130 )
3216
3217 #define WX_CC_MANIFEST(cpu) \
3218 "/manifestdependency:\"type='win32' \
3219 name='Microsoft.Windows.Common-Controls' \
3220 version='6.0.0.0' \
3221 processorArchitecture='"cpu"' \
3222 publicKeyToken='6595b64144ccf1df' \
3223 language='*'\""
3224
3225 #if defined _M_IX86
3226 #pragma comment(linker, WX_CC_MANIFEST("x86"))
3227 #elif defined _M_X64
3228 #pragma comment(linker, WX_CC_MANIFEST("amd64"))
3229 #elif defined _M_IA64
3230 #pragma comment(linker, WX_CC_MANIFEST("ia64"))
3231 #else
3232 #pragma comment(linker, WX_CC_MANIFEST("*"))
3233 #endif
3234
3235 #endif /* !wxUSE_NO_MANIFEST && _MSC_FULL_VER >= 140040130 */
3236
3237 #endif
3238 /* _WX_DEFS_H_ */