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