]>
git.saurik.com Git - wxWidgets.git/blob - include/wx/msw/setup.h
c0e10007297bbc4255af90d5fe50a26c208c703d
1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: Configuration for the library
4 // Author: Julian Smart
8 // Copyright: (c) Julian Smart and Markus Holzem
9 // Licence: wxWindows license
10 /////////////////////////////////////////////////////////////////////////////
21 // Use wxConfig, with CreateConfig in wxApp
22 #define __GOODCOMPILER__
23 // gcc can have problems, but Windows compilers
25 #define WXWIN_COMPATIBILITY 1
26 // Compatibility with 1.66 API.
27 // Level 0: no backward compatibility, all new features
28 // Level 1: wxDC, OnSize (etc.) compatibility, but
29 // some new features such as event tables
31 #define USE_AUTOTRANS 1
33 #define USE_POSTSCRIPT 1
34 // 0 for no PostScript device context
35 #define USE_AFM_FOR_POSTSCRIPT 0
36 // 1 to use font metric files in GetTextExtent
37 #define USE_METAFILE 1
38 // 0 for no Metafile and metafile device context
42 // 0 for no interprocess comms
43 // Note: wxHELP uses IPC under X so these are interdependent!
45 // 0 for no help facility
46 #define USE_RESOURCES 1
47 // 0 for no wxGetResource/wxWriteResource
48 #define USE_CONSTRAINTS 1
49 // 0 for no window layout constraint system
51 #define USE_TIMEDATE 1
52 // 0 for no wxTime/wxDate classes
54 #define USE_CLIPBOARD 1
55 // 0 for no clipboard functions
58 #define USE_XFIG_SPLINE_CODE 1
59 // 1 for XFIG spline code, 0 for AIAI spline code.
60 // AIAI spline code is slower, but freer of copyright issues.
62 #define USE_DRAG_AND_DROP 1
63 // 0 for no drag and drop
66 // Define 1 to use toolbar classes
67 #define USE_BUTTONBAR 1
68 // Define 1 to use buttonbar classes (enhanced toolbar
71 // Define 1 to use Microsoft's gauge (Windows)
72 // or Bull's gauge (Motif) library (both in contrib).
73 #define USE_COMBOBOX 1
74 // Define 1 to use COMBOXBOX control (Windows)
75 // or FWW's ComboBox widget (Motif).
76 #define USE_RADIOBUTTON 1
77 // Define 1 to use radio button control
79 #define USE_SCROLLBAR 1
80 // Define 1 to compile contributed wxScrollBar class
81 #define USE_XPM_IN_X 1
82 #define USE_XPM_IN_MSW 0
83 // Define 1 to support the XPM package in wxBitmap,
84 // separated by platform. If 1, you must link in
85 // the XPM library to your applications.
86 #define USE_IMAGE_LOADING_IN_X 1
87 // Use dynamic icon/bitmap loading/saving code in utils/image under X.
88 // If this is 1, you will need to link your applications
89 // with image_X.lib. where X is motif, ol, or hp.
91 #define USE_IMAGE_LOADING_IN_MSW 1
92 // Use dynamic DIB loading/saving code in utils/dib under MSW.
93 #define USE_RESOURCE_LOADING_IN_MSW 0
94 // Use dynamic icon/cursor loading/saving code
96 #define USE_WX_RESOURCES 1
97 // Use .wxr resource mechanism (requires PrologIO library)
99 #define USE_GNU_WXSTRING 0
100 // Define 1 to use modified GNU wxString class
101 // from (stefan.hammes@urz.uni-heidelberg.de) in contrib\string
102 // TODO: why does this give an unresolved 'wxRegex::Search'
105 #define HAVE_SOCKET 1
107 #define USE_DOC_VIEW_ARCHITECTURE 1
108 // Set to 0 to disable document/view architecture
109 #define USE_PRINTING_ARCHITECTURE 1
110 // Set to 0 to disable print/preview architecture code
111 #define USE_POSTSCRIPT_ARCHITECTURE_IN_MSW 1
112 // Set to 0 to disable PostScript print/preview architecture code
113 // under Windows (just use Windows printing).
114 #define USE_DYNAMIC_CLASSES 1
115 // If 1, enables provision of run-time type information.
116 // NOW MANDATORY: don't change.
117 #define USE_MEMORY_TRACING 1
118 // If 1, enables debugging versions of wxObject::new and
119 // wxObject::delete *IF* WXDEBUG is also defined.
120 // WARNING: this code may not work with all architectures, especially
121 // if alignment is an issue.
122 #define USE_WXDEBUG_CONTEXT 1
123 // If 1, enables wxDebugContext, for
124 // writing error messages to file, etc.
125 // If WXDEBUG is not defined, will still use
126 // normal memory operators.
127 // It's recommended to set this to 1,
128 // since you may well need to output
129 // an error log in a production
130 // version (or non-debugging beta)
131 #define USE_GLOBAL_MEMORY_OPERATORS 1
132 // In debug mode, cause new and delete to be redefined globally.
133 // If this causes problems (e.g. link errors), set this to 0.
135 #define REMOVE_UNUSED_ARG 1
136 // Set this to 0 if your compiler can't cope
137 // with omission of prototype parameters.
140 // Set to 1 to use main.c instead of main.cpp (UNIX only)
143 // Define 1 to use ODBC classes
145 #define USE_ODBC_IN_MSW_ONLY 1
147 #if USE_ODBC && USE_ODBC_IN_MSW_ONLY
152 #define USE_IOSTREAMH 1
153 // VC++ 4.2 and above allows <iostream> and <iostream.h>
154 // but you can't mix them. Set to 1 for <iostream.h>,
157 #define USE_WXCONFIG 1
158 // if enabled, compiles built-in OS independent wxConfig
159 // class and it's file (any platform) and registry (Win)
160 // based implementations
166 #define USE_APPLE_IEEE 1
167 // if enabled, the float codec written by Apple
168 // will be used to write, in a portable way,
176 #define WX_STANDARD_GRAPHICS 0
177 // If 1, normalizes X drawing code to behave exactly as
178 // as MSW. If 0, is compatible with existing applications.
179 // Some Xlib drawing primitives have non-intuitive behaviour!
181 #define USE_GADGETS 0
182 // More efficient to use gadgets for some
183 // widgets in Motif. 0 for no gadgets.
184 // Please note: there is no reason to not
185 // use it except if you intend to modify
186 // color of individuals items OR
187 // you need to move panel items interactively
188 #define USE_BUTTON_GADGET 0
189 // On JACS's system, gadget buttons
190 // interfere with default button setting.
191 #define PIXEL0_DISABLE 0
192 // Define as 1 to disallow allocation
193 // of pixel #0 (wxXOR problem).
194 // JACS - I found this caused problems.
196 #define MOTIF_MENUBAR_DELETE_FIX 0
197 // On some systems (Ultrix, OSF), deleting a frame
198 // from within a menu callback causes a crash.
199 // Set to 1 to avoid deleting the menubar handle directly,
200 // which seems to cure it.
201 #define DEFAULT_FILE_SELECTOR_SIZE 0
202 // Let Motif defines the size of File
203 // Selector Box (if 1), or fix it to
204 // wxFSB_WIDTH x wxFSB_HEIGHT (if 0)
205 #define wxFSB_WIDTH 600
206 #define wxFSB_HEIGHT 500
208 #define MOTIF_MANAGE 1
209 // Control default style of Dialogs
210 // 1: use wxMOTIF_RESIZE as default
211 // 0: do not use wxMOTIF_RESIZE as default
215 * MS Windows/Windows NT
219 #if defined(__WIN95__)
223 // Define 1 to use Microsoft CTL3D library.
224 // See note above about using FAFA and CTL3D.
227 #define USE_COMMON_DIALOGS 1
228 // On rare occasions (e.g. using DJGPP) may want
229 // to omit common dialogs
230 // (e.g. file selector, printer dialog).
231 // Switching this off also switches off
232 // the printing architecture and interactive
234 #define USE_GREY_BACKGROUND 1
235 // If 1, uses grey (gray!) panels
236 // in FAFA and non-FAFA, non-CTL3D modes.
237 // I (JACS) think the controls look better
238 // this way. CTL3D always uses grey panels.
239 #define USE_ITSY_BITSY 1
240 // Define 1 to use Microsoft's ItsyBitsy
241 // small title bar library
242 #define USE_BITMAP_MESSAGE 1
243 // Define 1 to use bitmap messages.
244 #define USE_PORTABLE_FONTS_IN_MSW 0
245 // Define 1 to use new portable font scheme in Windows
246 // (used by default under X)
247 #define FONT_SIZE_COMPATIBILITY 0
248 // Define 1 for font size to be backward compatible
249 // to 1.63 and earlier. 1.64 and later define point
250 // sizes to be compatible with Windows.
251 #define USE_GENERIC_DIALOGS_IN_MSW 1
252 // Define 1 to use generic dialogs in Windows, even though
253 // they duplicate native common dialog (e.g. wxColourDialog)
254 #define USE_PENWINDOWS 0
255 // Set to 1 to use PenWindows
257 #define USE_OWNER_DRAWN 0
258 // Owner-drawn menus and listboxes
260 #define USE_NATIVE_STATUSBAR 1
261 // Set to 0 to use cross-platform wxStatusBar
268 #define USE_TYPEDEFS 0
269 // Use typedefs not classes for wxPoint
270 // and others, to reduce overhead and avoid
271 // MS C7 memory bug. Bounds checker
272 // complains about deallocating
273 // arrays of wxPoints if wxPoint is a class.
275 #if (!defined(WIN32) && !defined(__WIN32__)) || defined(__GNUWIN32__) || defined(__BORLANDC__)
276 // Can't use OLE drag and drop in Windows 3.1 because we don't know how
277 // to implement UUIDs
278 // GnuWin32 doesn't have appropriate headers for e.g. IUnknown.
279 #undef USE_DRAG_AND_DROP
280 #define USE_DRAG_AND_DROP 0
283 // Only WIN32 supports wxStatusBar95
284 #if !defined(__WIN32__) && USE_NATIVE_STATUSBAR
285 #undef USE_NATIVE_STATUSBAR
286 #define USE_NATIVE_STATUSBAR 0
289 // Minimal setup e.g. for compiling small utilities
290 #define MINIMAL_WXWINDOWS_SETUP 0
292 #if MINIMAL_WXWINDOWS_SETUP
293 #undef USE_POSTSCRIPT
294 # define USE_POSTSCRIPT 0
295 #undef USE_PRINTING_ARCHITECTURE
296 # define USE_PRINTING_ARCHITECTURE 0
297 #undef USE_POSTSCRIPT_ARCHITECTURE_IN_MSW
298 # define USE_POSTSCRIPT_ARCHITECTURE_IN_MSW 0
300 # define USE_METAFILE 0
304 # define USE_SPLINES 0
306 # define USE_SCROLLBAR 0
308 # define USE_COMBOBOX 0
309 #undef USE_RADIOBUTTON
310 # define USE_RADIOBUTTON 0
311 #undef USE_XPM_IN_MSW
312 # define USE_XPM_IN_MSW 0
313 #undef USE_WX_RESOURCES
314 # define USE_WX_RESOURCES 0
315 #undef USE_DOC_VIEW_ARCHITECTURE
316 # define USE_DOC_VIEW_ARCHITECTURE 0
317 #undef USE_GNU_WXSTRING
318 # define USE_GNU_WXSTRING 0
322 # define USE_TIMEDATE 0
325 #undef USE_ITSY_BITSY
326 # define USE_ITSY_BITSY 0
327 #undef USE_IMAGE_LOADING_IN_MSW
328 # define USE_IMAGE_LOADING_IN_MSW 0
331 #undef USE_RESOURCE_LOADING_IN_MSW
332 # define USE_RESOURCE_LOADING_IN_MSW 0
333 #undef USE_DRAG_AND_DROP
334 # define USE_DRAG_AND_DROP 0