]> git.saurik.com Git - wxWidgets.git/blame - include/wx/msw/setup0.h
EXPORTED an array to quiet the DLL compilation
[wxWidgets.git] / include / wx / msw / setup0.h
CommitLineData
9bd6a503
VZ
1/////////////////////////////////////////////////////////////////////////////
2// Name: setup.h
3// Purpose: Configuration for the library
4// Author: Julian Smart
5// Modified by:
6// Created: 01/02/97
7// RCS-ID: $Id$
8// Copyright: (c) Julian Smart
9// Licence: wxWindows licence
10/////////////////////////////////////////////////////////////////////////////
11
12#ifndef _WX_SETUP_H_
13#define _WX_SETUP_H_
14
73974df1
VZ
15// ----------------------------------------------------------------------------
16// global settings
17// ----------------------------------------------------------------------------
9bd6a503 18
73974df1
VZ
19// define this to 0 when building wxBase library
20#define wxUSE_GUI 1
1f112209 21
9bd6a503
VZ
22#define WXWIN_COMPATIBILITY 0
23 // Compatibility with 1.68 API.
24 // Level 0: no backward compatibility, all new features
25 // Level 1: Some compatibility. In fact
26 // the compatibility code is now very minimal so there
27 // is little advantage to setting it to 1.
28
73974df1
VZ
29// ----------------------------------------------------------------------------
30// General features
31// ----------------------------------------------------------------------------
32
33#define wxUSE_CONFIG 1
34 // Use wxConfig, with CreateConfig in wxApp
35
9bd6a503 36#define wxUSE_POSTSCRIPT 0
83b1bfaa 37 // 0 for no PostScript device context
9bd6a503
VZ
38#define wxUSE_AFM_FOR_POSTSCRIPT 0
39 // 1 to use font metric files in GetTextExtent
40#define wxUSE_METAFILE 1
41 // 0 for no Metafile and metafile device context
9bd6a503
VZ
42#define wxUSE_IPC 1
43 // 0 for no interprocess comms
44// Note: wxHELP uses IPC under X so these are interdependent!
45#define wxUSE_HELP 1
46 // 0 for no help facility
47#define wxUSE_RESOURCES 1
48 // 0 for no wxGetResource/wxWriteResource
49#define wxUSE_CONSTRAINTS 1
50 // 0 for no window layout constraint system
51
52#define wxUSE_TIMEDATE 1
53 // 0 for no wxTime/wxDate classes
54
55#define wxUSE_CLIPBOARD 1
56 // 0 for no clipboard functions
1f112209 57
9bd6a503 58#define wxUSE_SPLINES 1
83b1bfaa 59 // 0 for no splines
9bd6a503
VZ
60
61#define wxUSE_DRAG_AND_DROP 1
62 // 0 for no drag and drop
63
83b1bfaa
GRG
64#define wxUSE_TOOLBAR 1
65 // Define 1 to use toolbar classes
66#define wxUSE_BUTTONBAR 1
67 // Define 1 to use buttonbar classes (enhanced toolbar
68 // for MS Windows)
69#define wxUSE_GAUGE 1
70 // Define 1 to use Microsoft's gauge (Windows)
71 // or Bull's gauge (Motif) library (both in contrib).
72#define wxUSE_COMBOBOX 1
73 // Define 1 to use COMBOXBOX control (Windows)
74 // or FWW's ComboBox widget (Motif).
75#define wxUSE_CHOICE 1
76 // Define 1 to use CHOICE
77
78#define wxUSE_RADIOBUTTON 1
79 // Define 1 to use radio button control
80#define wxUSE_RADIOBTN 1
81 // Unfortunately someone introduced this one, too
82
83#define wxUSE_SCROLLBAR 1
84 // Define 1 to compile contributed wxScrollBar class
85
86#define wxUSE_CHECKBOX 1
87 // Define 1 to compile checkbox
88
89#define wxUSE_LISTBOX 1
90 // Define 1 to compile listbox
91
92#define wxUSE_SPINBTN 1
93 // Define 1 to compile spin button
28d52eed 94
448af9a4 95
83b1bfaa 96#define wxUSE_STATLINE 1
448af9a4 97 // use wxStaticLine class
c50f1fb9 98
28d52eed 99#define wxUSE_CHECKLISTBOX 1
83b1bfaa 100 // Define 1 to compile check listbox
28d52eed 101
83b1bfaa
GRG
102#define wxUSE_CHOICE 1
103 // Define 1 to compile choice
28d52eed 104
83b1bfaa
GRG
105#define wxUSE_CARET 1
106 // Define 1 to use wxCaret class
f85afd4e
MB
107
108#define wxUSE_NEW_GRID 1
109 // Define 1 to use the new wxGrid class
110 // (still under development, define 0 to
111 // use existing wxGrid class)
83b1bfaa
GRG
112#define wxUSE_XPM_IN_MSW 1
113 // Define 1 to support the XPM package in wxBitmap.
9bd6a503 114#define wxUSE_IMAGE_LOADING_IN_MSW 1
83b1bfaa 115 // Use dynamic DIB loading/saving code in utils/dib under MSW.
9bd6a503 116#define wxUSE_RESOURCE_LOADING_IN_MSW 1
83b1bfaa
GRG
117 // Use dynamic icon/cursor loading/saving code
118 // under MSW.
9bd6a503 119#define wxUSE_WX_RESOURCES 1
83b1bfaa 120 // Use .wxr resource mechanism (requires PrologIO library)
9bd6a503 121
83b1bfaa 122#define wxUSE_STARTUP_TIPS 1
448af9a4 123 // support for startup tips (wxShowTip &c)
9bd6a503 124
9bd6a503 125#define wxUSE_DOC_VIEW_ARCHITECTURE 1
83b1bfaa
GRG
126 // Set to 0 to disable document/view architecture
127#define wxUSE_MDI_ARCHITECTURE 1
128 // Set to 0 to disable MDI document/view architecture
9bd6a503 129#define wxUSE_PRINTING_ARCHITECTURE 1
83b1bfaa 130 // Set to 0 to disable print/preview architecture code
9bd6a503 131#define wxUSE_POSTSCRIPT_ARCHITECTURE_IN_MSW 1
83b1bfaa
GRG
132 // Set to 0 to disable PostScript print/preview architecture code
133 // under Windows (just use Windows printing).
9bd6a503 134#define wxUSE_DYNAMIC_CLASSES 1
83b1bfaa
GRG
135 // If 1, enables provision of run-time type information.
136 // NOW MANDATORY: don't change.
9bd6a503 137#define wxUSE_MEMORY_TRACING 1
83b1bfaa
GRG
138 // If 1, enables debugging versions of wxObject::new and
139 // wxObject::delete *IF* __WXDEBUG__ is also defined.
140 // WARNING: this code may not work with all architectures, especially
141 // if alignment is an issue.
9bd6a503 142#define wxUSE_DEBUG_CONTEXT 1
83b1bfaa
GRG
143 // If 1, enables wxDebugContext, for
144 // writing error messages to file, etc.
145 // If __WXDEBUG__ is not defined, will still use
146 // normal memory operators.
147 // It's recommended to set this to 1,
148 // since you may well need to output
149 // an error log in a production
150 // version (or non-debugging beta)
9bd6a503 151#define wxUSE_GLOBAL_MEMORY_OPERATORS 1
83b1bfaa
GRG
152 // In debug mode, cause new and delete to be redefined globally.
153 // If this causes problems (e.g. link errors), set this to 0.
9bd6a503
VZ
154
155#define wxUSE_DEBUG_NEW_ALWAYS 1
83b1bfaa
GRG
156 // In debug mode, causes new to be defined to
157 // be WXDEBUG_NEW (see object.h).
158 // If this causes problems (e.g. link errors), set this to 0.
159 // You may need to set this to 0 if using templates (at least
160 // for VC++).
9bd6a503 161
83b1bfaa
GRG
162#define REMOVE_UNUSED_ARG 1
163 // Set this to 0 if your compiler can't cope
164 // with omission of prototype parameters.
9bd6a503 165
83b1bfaa
GRG
166#define wxUSE_ODBC 0
167 // Define 1 to use ODBC classes
9bd6a503
VZ
168
169#ifndef __MWERKS__
170#define wxUSE_IOSTREAMH 1
171#else
dbda9e86 172#define wxUSE_IOSTREAMH 1
9bd6a503 173#endif
83b1bfaa
GRG
174 // VC++ 4.2 and above allows <iostream> and <iostream.h>
175 // but you can't mix them. Set to 1 for <iostream.h>,
176 // 0 for <iostream>
9bd6a503 177
d4ec5d32 178#define wxUSE_STREAMS 1
83b1bfaa 179 // If enabled (1), compiles wxWindows streams classes
d4ec5d32 180
83b1bfaa
GRG
181#define wxUSE_STD_IOSTREAM 0
182 // Use standard C++ streams if 1. If 0, use wxWin
183 // streams implementation.
d4ec5d32 184
9bd6a503 185#define wxUSE_WXCONFIG 1
83b1bfaa
GRG
186 // if enabled, compiles built-in OS independent wxConfig
187 // class and it's file (any platform) and registry (Win)
188 // based implementations
9bd6a503 189#define wxUSE_THREADS 1
83b1bfaa
GRG
190 // support for multithreaded applications: if
191 // 1, compile in thread classes (thread.h)
192 // and make the library thread safe
9bd6a503 193#define wxUSE_ZLIB 1
83b1bfaa 194 // Use zlib for compression in streams and PNG code
9bd6a503 195#define wxUSE_LIBPNG 1
83b1bfaa
GRG
196 // Use PNG bitmap/image code
197#define wxUSE_LIBJPEG 1
198 // Use JPEG bitmap/image code
199#define wxUSE_GIF 1
200 // Use GIF bitmap/image code
1044a386 201#define wxUSE_PNM 1
83b1bfaa 202 // Use PNM bitmap/image code
1044a386 203#define wxUSE_PCX 1
83b1bfaa 204 // Use PCX bitmap/image code
d4ec5d32 205#define wxUSE_SERIAL 0
83b1bfaa 206 // Use serialization (requires utils/serialize)
3aa0e8fa 207#define wxUSE_DYNLIB_CLASS 0
83b1bfaa
GRG
208 // Compile in wxLibrary class for run-time
209 // DLL loading and function calling
9bd6a503 210#define wxUSE_TOOLTIPS 1
83b1bfaa
GRG
211 // Define to use wxToolTip class and
212 // wxWindow::SetToolTip() method
213#define wxUSE_SOCKETS 1
214 // Set to 1 to use socket classes
5526e819 215#define wxUSE_HTML 0
83b1bfaa 216 // Set to 1 to use wxHTML sub-library
d78b3d64 217#define wxUSE_FS_ZIP 0
83b1bfaa 218#define wxUSE_FS_INET 0 // Set to 1 to enable virtual file systems
d78b3d64
VS
219
220#define wxUSE_BUSYINFO 0
83b1bfaa
GRG
221 // wxBusyInfo displays window with message
222 // when app is busy. Works in same way as
223 // wxBusyCursor
a8b96c3d 224#define wxUSE_ZIPSTREAM 0
83b1bfaa 225 // input stream for reading from zip archives
9bd6a503
VZ
226
227/*
228 * Finer detail
229 *
230 */
231
232#define wxUSE_APPLE_IEEE 1
233 // if enabled, the float codec written by Apple
234 // will be used to write, in a portable way,
235 // float on the disk
236
1318fabe
VZ
237// use wxFile class - required by i18n code, wxConfig and others - recommended
238#define wxUSE_FILE 1
239
240// use wxTextFile class: requires wxFile, required by wxConfig
241#define wxUSE_TEXTFILE 1
242
243// i18n support: _() macro, wxLocale class. Requires wxFile
244#define wxUSE_INTL 1
245
246// wxLogXXX functions - highly recommended
83b1bfaa 247#define wxUSE_LOG 1
1318fabe
VZ
248
249// wxValidator class
250#define wxUSE_VALIDATORS 1
251
252// wxAcceleratorTable/Entry classes and support for them in wxMenu(Bar)
253#define wxUSE_ACCEL 1
254
255// wxSashWindow class
256#define wxUSE_SASH 1
257
258// text entry dialog and wxGetTextFromUser function
259#define wxUSE_TEXTDLG 1
260
261// wxToolBar class
262#define wxUSE_TOOLBAR 1
263
264// wxStatusBar class
265#define wxUSE_STATUSBAR 1
266
267// progress dialog class for lengthy operations
268#define wxUSE_PROGRESSDLG 1
269
270// wxDirDlg class for getting a directory name from user
271#define wxUSE_DIRDLG 1
272
9bd6a503
VZ
273/*
274 * MS Windows/Windows NT
275 *
276 */
277
3aa0e8fa
VZ
278#define wxUSE_OLE 1
279 // drag-and-drop, clipboard, OLE Automation
280
9bd6a503 281#if defined(__WIN95__)
1f112209 282#define wxUSE_CTL3D 0
9bd6a503 283#else
1f112209 284#define wxUSE_CTL3D 1
83b1bfaa
GRG
285 // Define 1 to use Microsoft CTL3D library.
286 // See note above about using FAFA and CTL3D.
9bd6a503
VZ
287#endif
288
289#define wxUSE_COMMON_DIALOGS 1
83b1bfaa
GRG
290 // On rare occasions (e.g. using DJGPP) may want
291 // to omit common dialogs
292 // (e.g. file selector, printer dialog).
293 // Switching this off also switches off
294 // the printing architecture and interactive
295 // wxPrinterDC.
9bd6a503 296#define wxUSE_ITSY_BITSY 1
83b1bfaa
GRG
297 // Define 1 to use Microsoft's ItsyBitsy
298 // small title bar library, for wxMiniFrame
9bd6a503 299#define wxUSE_BITMAP_MESSAGE 1
83b1bfaa 300 // Define 1 to use bitmap messages.
9bd6a503 301#define wxUSE_PORTABLE_FONTS_IN_MSW 0
83b1bfaa
GRG
302 // Define 1 to use new portable font scheme in Windows
303 // (used by default under X)
1f112209 304#define wxFONT_SIZE_COMPATIBILITY 0
83b1bfaa
GRG
305 // Define 1 for font size to be backward compatible
306 // to 1.63 and earlier. 1.64 and later define point
307 // sizes to be compatible with Windows.
9bd6a503 308#define wxUSE_GENERIC_DIALOGS_IN_MSW 1
83b1bfaa
GRG
309 // Define 1 to use generic dialogs in Windows, even though
310 // they duplicate native common dialog (e.g. wxColourDialog)
9bd6a503 311#define wxUSE_PENWINDOWS 0
83b1bfaa 312 // Set to 1 to use PenWindows
9bd6a503
VZ
313
314#define wxUSE_OWNER_DRAWN 1
83b1bfaa 315 // Owner-drawn menus and listboxes
9bd6a503
VZ
316
317#define wxUSE_NATIVE_STATUSBAR 1
83b1bfaa 318 // Set to 0 to use cross-platform wxStatusBar
9bd6a503 319#define wxUSE_DBWIN32 1
83b1bfaa
GRG
320 // Use Andrew Tucker's OutputDebugString implementation
321 // (required on Win95 only). See utils.cpp.
9bd6a503
VZ
322
323/*
324 * Any platform
325 *
326 */
327
328#define wxUSE_TYPEDEFS 0
83b1bfaa
GRG
329 // Use typedefs not classes for wxPoint
330 // and others, to reduce overhead and avoid
331 // MS C7 memory bug. Bounds checker
332 // complains about deallocating
333 // arrays of wxPoints if wxPoint is a class.
9bd6a503 334
1a7f3062
JS
335#if defined(__MINGW32__) && ((__GNUC__>2) ||((__GNUC__==2) && (__GNUC_MINOR__>=95)))
336#ifndef wxUSE_NORLANDER_HEADERS
337# define wxUSE_NORLANDER_HEADERS 1
338#endif
339#endif
340
341#if (!defined(WIN32) && !defined(__WIN32__)) || (defined(__GNUWIN32__) && !defined(wxUSE_NORLANDER_HEADERS))
9bd6a503
VZ
342// Can't use OLE drag and drop in Windows 3.1 because we don't know how
343// to implement UUIDs
344// GnuWin32 doesn't have appropriate headers for e.g. IUnknown.
345#undef wxUSE_DRAG_AND_DROP
346#define wxUSE_DRAG_AND_DROP 0
347#endif
348
349// Only WIN32 supports wxStatusBar95
350#if !defined(__WIN32__) && wxUSE_NATIVE_STATUSBAR
351#undef wxUSE_NATIVE_STATUSBAR
352#define wxUSE_NATIVE_STATUSBAR 0
353#endif
354
355// Salford C++ doesn't like some of the memory operator definitions
356#ifdef __SALFORDC__
357#undef wxUSE_MEMORY_TRACING
358#define wxUSE_MEMORY_TRACING 0
359
360#undef wxUSE_GLOBAL_MEMORY_OPERATORS
361#define wxUSE_GLOBAL_MEMORY_OPERATORS 0
362
363#undef wxUSE_DEBUG_NEW_ALWAYS
364#define wxUSE_DEBUG_NEW_ALWAYS 0
365
366#undef wxUSE_THREADS
367#define wxUSE_THREADS 0
368
369#undef wxUSE_DBWIN32
370#define wxUSE_DBWIN32 0
371
372#undef wxUSE_OWNER_DRAWN
373#define wxUSE_OWNER_DRAWN 0
374#endif
375
376#ifdef __TWIN32__
377
378#undef wxUSE_THREADS
379#define wxUSE_THREADS 0
380
381#undef wxUSE_DBWIN32
382#define wxUSE_DBWIN32 0
383
384#undef wxUSE_ODBC
385#define wxUSE_ODBC 0
386
387#endif
388
dbdb39b2
JS
389#if defined(__WXMSW__) && defined(__BORLANDC__)
390#undef wxUSE_ODBC
391#define wxUSE_ODBC 0
392#endif
393
448af9a4
JS
394// BC++/Win16 can't cope with the amount of data in resource.cpp
395#if defined(__WIN16__) && defined(__BORLANDC__)
396#undef wxUSE_WX_RESOURCES
397#define wxUSE_WX_RESOURCES 0
398#endif
399
0cdf89ab 400#if defined(__WXMSW__) && defined(__WATCOMC__)
0cdf89ab
JS
401#undef wxUSE_LIBJPEG
402#define wxUSE_LIBJPEG 0
403#endif
404
9bd6a503
VZ
405#if defined(__WXMSW__) && !defined(__WIN32__)
406
8fb3a512
JS
407#undef wxUSE_SOCKETS
408#define wxUSE_SOCKETS 0
409
9bd6a503
VZ
410#undef wxUSE_THREADS
411#define wxUSE_THREADS 0
412
750b78ba
JS
413#undef wxUSE_TOOLTIPS
414#define wxUSE_TOOLTIPS 0
415
1044a386
JS
416#undef wxUSE_LIBPNG
417#define wxUSE_LIBPNG 0
418
419#undef wxUSE_LIBJPEG
420#define wxUSE_LIBJPEG 0
421
83b1bfaa
GRG
422#undef wxUSE_GIF
423#define wxUSE_GIF 0
1044a386
JS
424
425#undef wxUSE_PNM
426#define wxUSE_PNM 0
427
428#undef wxUSE_PCX
429#define wxUSE_PCX 0
430
9bd6a503
VZ
431#endif
432
9bd6a503
VZ
433#endif
434 // _WX_SETUP_H_