~registry/dolphin-emu/triforce

« back to all changes in this revision

Viewing changes to Externals/wxWidgets3/include/wx/defs.h

  • Committer: Sérgio Benjamim
  • Date: 2015-02-13 05:54:40 UTC
  • Revision ID: sergio_br2@yahoo.com.br-20150213055440-ey2rt3sjpy27km78
Dolphin Triforce branch from code.google, commit b957980 (4.0-315).

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
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_ */