]> git.saurik.com Git - wxWidgets.git/blame - docs/latex/wx/function.tex
added the possibility to hide the tip window automatically when the mouse leave the...
[wxWidgets.git] / docs / latex / wx / function.tex
CommitLineData
a660d684
KB
1\chapter{Functions}\label{functions}
2\setheader{{\it CHAPTER \thechapter}}{}{}{}{}{{\it CHAPTER \thechapter}}%
3\setfooter{\thepage}{}{}{}{}{\thepage}
4
b0fc8832
VZ
5The functions and macros defined in wxWindows are described here: you can
6either look up a function using the alphabetical listing of them or find it in
7the corresponding topic.
8
9\section{Alphabetical functions and macros list}
10
11\helpref{CLASSINFO}{classinfo}\\
12\helpref{DECLARE\_ABSTRACT\_CLASS}{declareabstractclass}\\
13\helpref{DECLARE\_APP}{declareapp}\\
14\helpref{DECLARE\_CLASS}{declareclass}\\
15\helpref{DECLARE\_DYNAMIC\_CLASS}{declaredynamicclass}\\
16\helpref{IMPLEMENT\_ABSTRACT\_CLASS2}{implementabstractclass2}\\
17\helpref{IMPLEMENT\_ABSTRACT\_CLASS}{implementabstractclass}\\
18\helpref{IMPLEMENT\_APP}{implementapp}\\
19\helpref{IMPLEMENT\_CLASS2}{implementclass2}\\
20\helpref{IMPLEMENT\_CLASS}{implementclass}\\
21\helpref{IMPLEMENT\_DYNAMIC\_CLASS2}{implementdynamicclass2}\\
22\helpref{IMPLEMENT\_DYNAMIC\_CLASS}{implementdynamicclass}\\
23\helpref{WXDEBUG\_NEW}{debugnew}\\
24\helpref{WXTRACELEVEL}{tracelevel}\\
25\helpref{WXTRACE}{trace}\\
26\helpref{copystring}{copystring}\\
27\helpref{wxASSERT\_MSG}{wxassertmsg}\\
28\helpref{wxASSERT}{wxassert}\\
29\helpref{wxBITMAP}{wxbitmapmacro}\\
30\helpref{wxBeginBusyCursor}{wxbeginbusycursor}\\
31\helpref{wxBell}{wxbell}\\
32\helpref{wxCHECK2\_MSG}{wxcheck2msg}\\
33\helpref{wxCHECK2}{wxcheck2}\\
34\helpref{wxCHECK\_MSG}{wxcheckmsg}\\
35\helpref{wxCHECK\_RET}{wxcheckret}\\
36\helpref{wxCHECK\_VERSION}{wxcheckversion}\\
37\helpref{wxCHECK}{wxcheck}\\
38\helpref{wxClientDisplayRect}{wxclientdisplayrect}\\
39\helpref{wxClipboardOpen}{wxclipboardopen}\\
40\helpref{wxCloseClipboard}{wxcloseclipboard}\\
41\helpref{wxColourDisplay}{wxcolourdisplay}\\
42\helpref{wxConcatFiles}{wxconcatfiles}\\
43\helpref{wxConstCast}{wxconstcast}\\
44\helpref{wxCopyFile}{wxcopyfile}\\
45\helpref{wxCreateDynamicObject}{wxcreatedynamicobject}\\
46\helpref{wxCreateFileTipProvider}{wxcreatefiletipprovider}\\
47\helpref{wxDDECleanUp}{wxddecleanup}\\
48\helpref{wxDDEInitialize}{wxddeinitialize}\\
49\helpref{wxDROP\_ICON}{wxdropicon}\\
50\helpref{wxDebugMsg}{wxdebugmsg}\\
51\helpref{wxDirExists}{wxdirexists}\\
52\helpref{wxDirSelector}{wxdirselector}\\
53\helpref{wxDisplayDepth}{wxdisplaydepth}\\
54\helpref{wxDisplaySizeMM}{wxdisplaysizemm}\\
55\helpref{wxDisplaySize}{wxdisplaysize}\\
56\helpref{wxDisplaySize}{wxdisplaysize}\\
57\helpref{wxDos2UnixFilename}{wxdos2unixfilename}\\
58\helpref{wxDynamicCastThis}{wxdynamiccastthis}\\
59\helpref{wxDynamicCast}{wxdynamiccast}\\
60\helpref{wxEmptyClipboard}{wxemptyclipboard}\\
61\helpref{wxEnableTopLevelWindows}{wxenabletoplevelwindows}\\
62\helpref{wxEndBusyCursor}{wxendbusycursor}\\
63\helpref{wxEntry}{wxentry}\\
64\helpref{wxEnumClipboardFormats}{wxenumclipboardformats}\\
65\helpref{wxError}{wxerror}\\
66\helpref{wxExecute}{wxexecute}\\
67\helpref{wxExit}{wxexit}\\
68\helpref{wxFAIL\_MSG}{wxfailmsg}\\
69\helpref{wxFAIL}{wxfail}\\
70\helpref{wxFatalError}{wxfatalerror}\\
71\helpref{wxFileExists}{wxfileexists}\\
72\helpref{wxFileModificationTime}{wxfilemodificationtime}\\
73\helpref{wxFileNameFromPath}{wxfilenamefrompath}\\
74\helpref{wxFileSelector}{wxfileselector}\\
75\helpref{wxFindFirstFile}{wxfindfirstfile}\\
76\helpref{wxFindMenuItemId}{wxfindmenuitemid}\\
77\helpref{wxFindNextFile}{wxfindnextfile}\\
78\helpref{wxFindWindowAtPointer}{wxfindwindowatpointer}\\
79\helpref{wxFindWindowAtPoint}{wxfindwindowatpoint}\\
80\helpref{wxFindWindowByLabel}{wxfindwindowbylabel}\\
81\helpref{wxFindWindowByName}{wxfindwindowbyname}\\
82\helpref{wxGetActiveWindow}{wxgetactivewindow}\\
83\helpref{wxGetClipboardData}{wxgetclipboarddata}\\
84\helpref{wxGetClipboardFormatName}{wxgetclipboardformatname}\\
85\helpref{wxGetColourFromUser}{wxgetcolourfromuser}\\
86\helpref{wxGetCwd}{wxgetcwd}\\
87\helpref{wxGetDiskSpace}{wxgetdiskspace}\\
88\helpref{wxGetDisplayName}{wxgetdisplayname}\\
89\helpref{wxGetElapsedTime}{wxgetelapsedtime}\\
90\helpref{wxGetEmailAddress}{wxgetemailaddress}\\
91\helpref{wxGetEnv}{wxgetenv}\\
92\helpref{wxGetFreeMemory}{wxgetfreememory}\\
93\helpref{wxGetFullHostName}{wxgetfullhostname}\\
94\helpref{wxGetHomeDir}{wxgethomedir}\\
95\helpref{wxGetHostName}{wxgethostname}\\
96\helpref{wxGetLocalTimeMillis}{wxgetlocaltimemillis}\\
97\helpref{wxGetLocalTime}{wxgetlocaltime}\\
98\helpref{wxGetMousePosition}{wxgetmouseposition}\\
99\helpref{wxGetMultipleChoices}{wxgetmultiplechoices}\\
100\helpref{wxGetMultipleChoice}{wxgetmultiplechoice}\\
101\helpref{wxGetNumberFromUser}{wxgetnumberfromuser}\\
102\helpref{wxGetOSDirectory}{wxgetosdirectory}\\
103\helpref{wxGetOsDescription}{wxgetosdescription}\\
104\helpref{wxGetOsVersion}{wxgetosversion}\\
105\helpref{wxGetPasswordFromUser}{wxgetpasswordfromuser}\\
106\helpref{wxGetPrinterCommand}{wxgetprintercommand}\\
107\helpref{wxGetPrinterFile}{wxgetprinterfile}\\
108\helpref{wxGetPrinterMode}{wxgetprintermode}\\
109\helpref{wxGetPrinterOptions}{wxgetprinteroptions}\\
110\helpref{wxGetPrinterOrientation}{wxgetprinterorientation}\\
111\helpref{wxGetPrinterPreviewCommand}{wxgetprinterpreviewcommand}\\
112\helpref{wxGetPrinterScaling}{wxgetprinterscaling}\\
113\helpref{wxGetPrinterTranslation}{wxgetprintertranslation}\\
114\helpref{wxGetResource}{wxgetresource}\\
115\helpref{wxGetSingleChoiceData}{wxgetsinglechoicedata}\\
116\helpref{wxGetSingleChoiceIndex}{wxgetsinglechoiceindex}\\
117\helpref{wxGetSingleChoice}{wxgetsinglechoice}\\
118\helpref{wxGetTempFileName}{wxgettempfilename}\\
119\helpref{wxGetTextFromUser}{wxgettextfromuser}\\
120\helpref{wxGetTranslation}{wxgettranslation}\\
121\helpref{wxGetUTCTime}{wxgetutctime}\\
122\helpref{wxGetUserHome}{wxgetuserhome}\\
123\helpref{wxGetUserId}{wxgetuserid}\\
124\helpref{wxGetUserName}{wxgetusername}\\
125\helpref{wxGetWorkingDirectory}{wxgetworkingdirectory}\\
126\helpref{wxGetenv}{wxgetenvmacro}\\
127\helpref{wxHandleFatalExceptions}{wxhandlefatalexceptions}\\
128\helpref{wxICON}{wxiconmacro}\\
129\helpref{wxINTXX\_SWAP\_ALWAYS}{intswapalways}\\
130\helpref{wxINTXX\_SWAP\_ON\_BE}{intswaponbe}\\
131\helpref{wxINTXX\_SWAP\_ON\_LE}{intswaponle}\\
132\helpref{wxInitAllImageHandlers}{wxinitallimagehandlers}\\
133\helpref{wxInitialize}{wxinitialize}\\
134\helpref{wxIsAbsolutePath}{wxisabsolutepath}\\
135\helpref{wxIsBusy}{wxisbusy}\\
136\helpref{wxIsClipboardFormatAvailable}{wxisclipboardformatavailable}\\
137\helpref{wxIsEmpty}{wxisempty}\\
138\helpref{wxIsWild}{wxiswild}\\
139\helpref{wxKill}{wxkill}\\
140\helpref{wxLoadUserResource}{wxloaduserresource}\\
141\helpref{wxLogDebug}{wxlogdebug}\\
142\helpref{wxLogError}{wxlogerror}\\
143\helpref{wxLogFatalError}{wxlogfatalerror}\\
144\helpref{wxLogMessage}{wxlogmessage}\\
145\helpref{wxLogStatus}{wxlogstatus}\\
146\helpref{wxLogSysError}{wxlogsyserror}\\
147\helpref{wxLogTrace}{wxlogtrace}\\
148\helpref{wxLogVerbose}{wxlogverbose}\\
149\helpref{wxLogWarning}{wxlogwarning}\\
150\helpref{wxMakeMetafilePlaceable}{wxmakemetafileplaceable}\\
151\helpref{wxMatchWild}{wxmatchwild}\\
152\helpref{wxMessageBox}{wxmessagebox}\\
153\helpref{wxMkdir}{wxmkdir}\\
154\helpref{wxMutexGuiEnter}{wxmutexguienter}\\
155\helpref{wxMutexGuiLeave}{wxmutexguileave}\\
156\helpref{wxNewId}{wxnewid}\\
157\helpref{wxNow}{wxnow}\\
158\helpref{wxOnAssert}{wxonassert}\\
159\helpref{wxOpenClipboard}{wxopenclipboard}\\
160\helpref{wxPathOnly}{wxpathonly}\\
161\helpref{wxPostDelete}{wxpostdelete}\\
162\helpref{wxPostEvent}{wxpostevent}\\
163\helpref{wxRegisterClipboardFormat}{wxregisterclipboardformat}\\
164\helpref{wxRegisterId}{wxregisterid}\\
165\helpref{wxRemoveFile}{wxremovefile}\\
166\helpref{wxRenameFile}{wxrenamefile}\\
167\helpref{wxResourceAddIdentifier}{wxresourceaddidentifier}\\
168\helpref{wxResourceClear}{wxresourceclear}\\
169\helpref{wxResourceCreateBitmap}{wxresourcecreatebitmap}\\
170\helpref{wxResourceCreateIcon}{wxresourcecreateicon}\\
171\helpref{wxResourceCreateMenuBar}{wxresourcecreatemenubar}\\
172\helpref{wxResourceGetIdentifier}{wxresourcegetidentifier}\\
173\helpref{wxResourceParseData}{wxresourcedata}\\
174\helpref{wxResourceParseFile}{wxresourceparsefile}\\
175\helpref{wxResourceParseString}{wxresourceparsestring}\\
176\helpref{wxResourceRegisterBitmapData}{registerbitmapdata}\\
177\helpref{wxResourceRegisterIconData}{wxresourceregistericondata}\\
178\helpref{wxRmdir}{wxrmdir}\\
179\helpref{wxSafeYield}{wxsafeyield}\\
180\helpref{wxSetClipboardData}{wxsetclipboarddata}\\
181\helpref{wxSetCursor}{wxsetcursor}\\
182\helpref{wxSetDisplayName}{wxsetdisplayname}\\
183\helpref{wxSetEnv}{wxsetenv}\\
184\helpref{wxSetPrinterCommand}{wxsetprintercommand}\\
185\helpref{wxSetPrinterFile}{wxsetprinterfile}\\
186\helpref{wxSetPrinterMode}{wxsetprintermode}\\
187\helpref{wxSetPrinterOptions}{wxsetprinteroptions}\\
188\helpref{wxSetPrinterOrientation}{wxsetprinterorientation}\\
189\helpref{wxSetPrinterPreviewCommand}{wxsetprinterpreviewcommand}\\
190\helpref{wxSetPrinterScaling}{wxsetprinterscaling}\\
191\helpref{wxSetPrinterTranslation}{wxsetprintertranslation}\\
192\helpref{wxSetWorkingDirectory}{wxsetworkingdirectory}\\
193\helpref{wxShell}{wxshell}\\
194\helpref{wxShowTip}{wxshowtip}\\
195\helpref{wxSleep}{wxsleep}\\
196\helpref{wxSnprintf}{wxsnprintf}\\
197\helpref{wxSplitPath}{wxsplitfunction}\\
198\helpref{wxStartTimer}{wxstarttimer}\\
199\helpref{wxStaticCast}{wxstaticcast}\\
200\helpref{wxStricmp}{wxstricmp}\\
201\helpref{wxStringEq}{wxstringeq}\\
202\helpref{wxStringMatch}{wxstringmatch}\\
203\helpref{wxStripMenuCodes}{wxstripmenucodes}\\
204\helpref{wxStrlen}{wxstrlen}\\
205\helpref{wxSysErrorCode}{wxsyserrorcode}\\
206\helpref{wxSysErrorMsg}{wxsyserrormsg}\\
207\helpref{wxToLower}{wxtolower}\\
208\helpref{wxToUpper}{wxtoupper}\\
209\helpref{wxTraceLevel}{wxtracelevel}\\
210\helpref{wxTrace}{wxtrace}\\
211\helpref{wxTransferFileToStream}{wxtransferfiletostream}\\
212\helpref{wxTransferStreamToFile}{wxtransferstreamtofile}\\
213\helpref{wxTrap}{wxtrap}\\
214\helpref{wxUninitialize}{wxuninitialize}\\
215\helpref{wxUnix2DosFilename}{wxunix2dosfilename}\\
216\helpref{wxUnsetEnv}{wxunsetenv}\\
217\helpref{wxUsleep}{wxusleep}\\
218\helpref{wxVsnprintf}{wxvsnprintf}\\
219\helpref{wxWakeUpIdle}{wxwakeupidle}\\
220\helpref{wxWriteResource}{wxwriteresource}\\
221\helpref{wxYield}{wxyield}
f6bcfd97
BP
222
223\section{Version macros}\label{versionfunctions}
224
225The following constants are defined in wxWindows:
226
227\begin{itemize}\itemsep=0pt
228\item {\tt wxMAJOR\_VERSION} is the major version of wxWindows
229\item {\tt wxMINOR\_VERSION} is the minor version of wxWindows
ff8fda36 230\item {\tt wxRELEASE\_NUMBER} is the release number
f6bcfd97
BP
231\end{itemize}
232
233For example, the values or these constants for wxWindows 2.1.15 are 2, 1 and
23415.
235
236Additionally, {\tt wxVERSION\_STRING} is a user-readable string containing
237the full wxWindows version and {\tt wxVERSION\_NUMBER} is a combination of the
238three version numbers above: for 2.1.15, it is 2115 and it is 2200 for
239wxWindows 2.2.
240
241\wxheading{Include files}
242
243<wx/version.h> or <wx/defs.h>
244
245\membersection{wxCHECK\_VERSION}\label{wxcheckversion}
246
247\func{bool}{wxCHECK\_VERSION}{\param{}{major, minor, release}}
248
249This is a macro which evaluates to true if the current wxWindows version is at
250least major.minor.release.
251
252For example, to test if the program is compiled with wxWindows 2.2 or higher,
253the following can be done:
254
255\begin{verbatim}
256 wxString s;
257#if wxCHECK_VERSION(2, 2, 0)
258 if ( s.StartsWith("foo") )
259#else // replacement code for old version
260 if ( strncmp(s, "foo", 3) == 0 )
261#endif
262 {
263 ...
264 }
265\end{verbatim}
a660d684 266
b0fc8832 267\section{Application initialization and termination}\label{appinifunctions}
c88275cb 268
b0fc8832
VZ
269The functions in this section are used on application startup/shutdown and also
270to control the behaviour of the main event loop of the GUI programs.
c88275cb 271
b0fc8832 272\membersection{::wxEntry}\label{wxentry}
c88275cb 273
b0fc8832
VZ
274This initializes wxWindows in a platform-dependent way. Use this if you
275are not using the default wxWindows entry code (e.g. main or WinMain). For example,
276you can initialize wxWindows from an Microsoft Foundation Classes application using
277this function.
c88275cb 278
b0fc8832
VZ
279\func{void}{wxEntry}{\param{HANDLE}{ hInstance}, \param{HANDLE}{ hPrevInstance},
280 \param{const wxString\& }{commandLine}, \param{int}{ cmdShow}, \param{bool}{ enterLoop = TRUE}}
c88275cb 281
b0fc8832
VZ
282wxWindows initialization under Windows (non-DLL). If {\it enterLoop} is FALSE, the
283function will return immediately after calling wxApp::OnInit. Otherwise, the wxWindows
284message loop will be entered.
c88275cb 285
b0fc8832
VZ
286\func{void}{wxEntry}{\param{HANDLE}{ hInstance}, \param{HANDLE}{ hPrevInstance},
287 \param{WORD}{ wDataSegment}, \param{WORD}{ wHeapSize}, \param{const wxString\& }{ commandLine}}
c88275cb 288
b0fc8832 289wxWindows initialization under Windows (for applications constructed as a DLL).
c88275cb 290
b0fc8832 291\func{int}{wxEntry}{\param{int}{ argc}, \param{const wxString\& *}{argv}}
c88275cb 292
b0fc8832 293wxWindows initialization under Unix.
c88275cb 294
b0fc8832 295\wxheading{Remarks}
c88275cb 296
b0fc8832
VZ
297To clean up wxWindows, call wxApp::OnExit followed by the static function
298wxApp::CleanUp. For example, if exiting from an MFC application that also uses wxWindows:
4aff28fc 299
b0fc8832
VZ
300\begin{verbatim}
301int CTheApp::ExitInstance()
302{
303 // OnExit isn't called by CleanUp so must be called explicitly.
304 wxTheApp->OnExit();
305 wxApp::CleanUp();
306
307 return CWinApp::ExitInstance();
c88275cb
RR
308}
309\end{verbatim}
310
b0fc8832 311\wxheading{Include files}
c88275cb 312
b0fc8832 313<wx/app.h>
c88275cb 314
b0fc8832 315\membersection{::wxHandleFatalExceptions}\label{wxhandlefatalexceptions}
c88275cb 316
b0fc8832 317\func{bool}{wxHandleFatalExceptions}{\param{bool}{ doIt = TRUE}}
c88275cb 318
b0fc8832
VZ
319If {\it doIt} is TRUE, the fatal exceptions (also known as general protection
320faults under Windows or segmentation violations in the Unix world) will be
321caught and passed to \helpref{wxApp::OnFatalException}{wxapponfatalexception}.
322By default, i.e. before this function is called, they will be handled in the
323normal way which usually just means that the application will be terminated.
324Calling wxHandleFatalExceptions() with {\it doIt} equal to FALSE will restore
325this default behaviour.
c88275cb 326
b0fc8832 327\membersection{::wxInitAllImageHandlers}\label{wxinitallimagehandlers}
a660d684 328
b0fc8832 329\func{void}{wxInitAllImageHandlers}{\void}
954b8ae6 330
b0fc8832
VZ
331Initializes all available image handlers. For a list of available handlers,
332see \helpref{wxImage}{wximage}.
954b8ae6
JS
333
334\wxheading{See also}
335
b0fc8832 336\helpref{wxImage}{wximage}, \helpref{wxImageHandler}{wximagehandler}
a660d684 337
b0fc8832 338\wxheading{Include files}
a660d684 339
b0fc8832 340<wx/image.h>
a660d684 341
b0fc8832 342\membersection{::wxInitialize}\label{wxinitialize}
a660d684 343
b0fc8832 344\func{bool}{wxInitialize}{\void}
a660d684 345
b0fc8832
VZ
346This function is used in wxBase only and only if you don't create
347\helpref{wxApp}{wxapp} object at all. In this case you must call it from your
348{\tt main()} function before calling any other wxWindows functions.
a660d684 349
b0fc8832
VZ
350If the function returns {\tt FALSE} the initialization could not be performed,
351in this case the library cannot be used and
352\helpref{wxUninitialize}{wxuninitialize} shouldn't be called neither.
a660d684 353
b0fc8832
VZ
354This function may be called several times but
355\helpref{wxUninitialize}{wxuninitialize} must be called for each successful
356call to this function.
a660d684 357
b0fc8832 358\wxheading{Include files}
a47ce4a7 359
b0fc8832 360<wx/app.h>
a47ce4a7 361
b0fc8832 362\membersection{::wxSafeYield}\label{wxsafeyield}
a47ce4a7 363
b0fc8832 364\func{bool}{wxSafeYield}{\param{wxWindow*}{ win = NULL}}
a660d684 365
b0fc8832
VZ
366This function is similar to wxYield, except that it disables the user input to
367all program windows before calling wxYield and re-enables it again
368afterwards. If {\it win} is not NULL, this window will remain enabled,
369allowing the implementation of some limited user interaction.
a660d684 370
b0fc8832 371Returns the result of the call to \helpref{::wxYield}{wxyield}.
532372a3 372
b0fc8832 373\wxheading{Include files}
a660d684 374
b0fc8832 375<wx/utils.h>
a660d684 376
b0fc8832 377\membersection{::wxUninitialize}\label{wxuninitialize}
a660d684 378
b0fc8832 379\func{void}{wxUninitialize}{\void}
a660d684 380
b0fc8832
VZ
381This function is for use in console (wxBase) programs only. It must be called
382once for each previous successful call to \helpref{wxInitialize}{wxinitialize}.
a660d684 383
b0fc8832 384\wxheading{Include files}
a660d684 385
b0fc8832 386<wx/app.h>
a660d684 387
b0fc8832 388\membersection{::wxYield}\label{wxyield}
a660d684 389
b0fc8832 390\func{bool}{wxYield}{\void}
a660d684 391
b0fc8832 392Calls \helpref{wxApp::Yield}{wxappyield}.
a660d684 393
b0fc8832
VZ
394This function is kept only for backwards compatibility, please use
395\helpref{wxApp::Yield}{wxappyield}method instead in any new code.
a660d684 396
b0fc8832 397\wxheading{Include files}
5ab656cd 398
b0fc8832 399<wx/app.h> or <wx/utils.h>
eadd7bd2 400
b0fc8832 401\membersection{::wxWakeUpIdle}\label{wxwakeupidle}
eadd7bd2 402
b0fc8832 403\func{void}{wxWakeUpIdle}{\void}
eadd7bd2 404
b0fc8832
VZ
405This functions wakes up the (internal and platform dependent) idle system, i.e. it
406will force the system to send an idle event even if the system currently {\it is}
407 idle and thus would not send any idle event until after some other event would get
408sent. This is also useful for sending events between two threads and is used by
409the corresponding functions \helpref{::wxPostEvent}{wxpostevent} and
410\helpref{wxEvtHandler::AddPendingEvent}{wxevthandleraddpendingevent}.
eadd7bd2 411
b0fc8832 412\wxheading{Include files}
eadd7bd2 413
b0fc8832 414<wx/app.h>
eadd7bd2 415
b0fc8832 416\section{Process control functions}\label{processfunctions}
eadd7bd2 417
b0fc8832
VZ
418The functions in this section are used to launch or terminate the other
419processes.
eadd7bd2 420
b0fc8832 421\membersection{::wxExecute}\label{wxexecute}
631f1bfe 422
b0fc8832 423\func{long}{wxExecute}{\param{const wxString\& }{command}, \param{bool }{sync = FALSE}, \param{wxProcess *}{callback = NULL}}
631f1bfe 424
b0fc8832 425\func{long}{wxExecute}{\param{char **}{argv}, \param{bool }{sync = FALSE}, \param{wxProcess *}{callback = NULL}}
631f1bfe 426
b0fc8832 427\func{long}{wxExecute}{\param{const wxString\& }{command}, \param{wxArrayString\& }{output}}
a660d684 428
b0fc8832 429\func{long}{wxExecute}{\param{const wxString\& }{command}, \param{wxArrayString\& }{output}, \param{wxArrayString\& }{errors}}
a660d684 430
b0fc8832 431Executes another program in Unix or Windows.
a660d684 432
b0fc8832 433The first form takes a command string, such as {\tt "emacs file.txt"}.
a660d684 434
b0fc8832
VZ
435The second form takes an array of values: a command, any number of
436arguments, terminated by NULL.
a660d684 437
b0fc8832
VZ
438The semantics of the third and fourth versions is different from the first two
439and is described in more details below.
a660d684 440
b0fc8832
VZ
441If {\it sync} is FALSE (the default), flow of control immediately returns.
442If TRUE, the current application waits until the other program has terminated.
a660d684 443
b0fc8832
VZ
444In the case of synchronous execution, the return value is the exit code of
445the process (which terminates by the moment the function returns) and will be
446$-1$ if the process couldn't be started and typically 0 if the process
447terminated successfully. Also, while waiting for the process to
448terminate, wxExecute will call \helpref{wxYield}{wxyield}. The caller
449should ensure that this can cause no recursion, in the simplest case by
450calling \helpref{wxEnableTopLevelWindows(FALSE)}{wxenabletoplevelwindows}.
a660d684 451
b0fc8832
VZ
452For asynchronous execution, however, the return value is the process id and
453zero value indicates that the command could not be executed. As an added
454complication, the return value of $-1$ in this case indicattes that we didn't
455launch a new process, but connected to the running one (this can only happen in
456case of using DDE under Windows for command execution). In particular, in this,
457and only this, case the calling code will not get the notification about
458process termination.
a660d684 459
b0fc8832
VZ
460If callback isn't NULL and if execution is asynchronous (note that callback
461parameter can not be non-NULL for synchronous execution),
462\helpref{wxProcess::OnTerminate}{wxprocessonterminate} will be called when
463the process finishes.
a660d684 464
b0fc8832
VZ
465Finally, you may use the third overloaded version of this function to execute
466a process (always synchronously) and capture its output in the array
467{\it output}. The fourth version adds the possibility to additionally capture
468the messages from standard error output in the {\it errors} array.
a660d684 469
b0fc8832
VZ
470See also \helpref{wxShell}{wxshell}, \helpref{wxProcess}{wxprocess},
471\helpref{Exec sample}{sampleexec}.
a660d684 472
b0fc8832 473\wxheading{Include files}
a660d684 474
b0fc8832 475<wx/utils.h>
a660d684 476
b0fc8832 477\membersection{::wxExit}\label{wxexit}
a660d684 478
b0fc8832 479\func{void}{wxExit}{\void}
7af89395 480
b0fc8832
VZ
481Exits application after calling \helpref{wxApp::OnExit}{wxapponexit}.
482Should only be used in an emergency: normally the top-level frame
483should be deleted (after deleting all other frames) to terminate the
484application. See \helpref{wxWindow::OnCloseWindow}{wxwindowonclosewindow} and \helpref{wxApp}{wxapp}.
7af89395 485
b0fc8832 486\wxheading{Include files}
7af89395 487
b0fc8832 488<wx/app.h>
a660d684 489
b0fc8832 490\membersection{::wxKill}\label{wxkill}
a660d684 491
b0fc8832 492\func{int}{wxKill}{\param{long}{ pid}, \param{int}{ sig = wxSIGTERM}, \param{wxKillError }{*rc = NULL}}
7af89395 493
b0fc8832
VZ
494Equivalent to the Unix kill function: send the given signal {\it sig} to the
495process with PID {\it pid}. The valud signal values are
a660d684 496
b0fc8832
VZ
497\begin{verbatim}
498enum wxSignal
499{
500 wxSIGNONE = 0, // verify if the process exists under Unix
501 wxSIGHUP,
502 wxSIGINT,
503 wxSIGQUIT,
504 wxSIGILL,
505 wxSIGTRAP,
506 wxSIGABRT,
507 wxSIGEMT,
508 wxSIGFPE,
509 wxSIGKILL, // forcefully kill, dangerous!
510 wxSIGBUS,
511 wxSIGSEGV,
512 wxSIGSYS,
513 wxSIGPIPE,
514 wxSIGALRM,
515 wxSIGTERM // terminate the process gently
516};
517\end{verbatim}
a660d684 518
b0fc8832
VZ
519{\tt wxSIGNONE}, {\tt wxSIGKILL} and {\tt wxSIGTERM} have the same meaning
520under both Unix and Windows but all the other signals are equivalent to
521{\tt wxSIGTERM} under Windows.
a660d684 522
b0fc8832
VZ
523Returns 0 on success, -1 on failure. If {\it rc} parameter is not NULL, it will
524be filled with an element of {\tt wxKillError} enum:
a660d684 525
b0fc8832
VZ
526\begin{verbatim}
527enum wxKillError
528{
529 wxKILL_OK, // no error
530 wxKILL_BAD_SIGNAL, // no such signal
531 wxKILL_ACCESS_DENIED, // permission denied
532 wxKILL_NO_PROCESS, // no such process
533 wxKILL_ERROR // another, unspecified error
534};
535\end{verbatim}
c0ab6adf 536
b0fc8832 537\wxheading{See also}
ade35f11 538
b0fc8832
VZ
539\helpref{wxProcess::Kill}{wxprocesskill},\rtfsp
540\helpref{wxProcess::Exists}{wxprocessexists},\rtfsp
541\helpref{Exec sample}{sampleexec}
a660d684 542
b0fc8832 543\wxheading{Include files}
a660d684 544
b0fc8832 545<wx/utils.h>
a660d684 546
b0fc8832 547\membersection{::wxShell}\label{wxshell}
a660d684 548
b0fc8832 549\func{bool}{wxShell}{\param{const wxString\& }{command = NULL}}
a660d684 550
b0fc8832
VZ
551Executes a command in an interactive shell window. If no command is
552specified, then just the shell is spawned.
a660d684 553
b0fc8832 554See also \helpref{wxExecute}{wxexecute}, \helpref{Exec sample}{sampleexec}.
a660d684 555
b0fc8832 556\wxheading{Include files}
a660d684 557
b0fc8832 558<wx/utils.h>
a660d684 559
a660d684 560
b0fc8832 561\section{Thread functions}\label{threadfunctions}
1a33c3ba 562
b0fc8832 563\wxheading{Include files}
a660d684 564
b0fc8832 565<wx/thread.h>
a660d684 566
b0fc8832 567\wxheading{See also}
a660d684 568
b0fc8832 569\helpref{wxThread}{wxthread}, \helpref{wxMutex}{wxmutex}, \helpref{Multithreading overview}{wxthreadoverview}
a660d684 570
b0fc8832 571\membersection{::wxMutexGuiEnter}\label{wxmutexguienter}
a660d684 572
b0fc8832 573\func{void}{wxMutexGuiEnter}{\void}
a660d684 574
b0fc8832
VZ
575This function must be called when any thread other than the main GUI thread
576wants to get access to the GUI library. This function will block the execution
577of the calling thread until the main thread (or any other thread holding the
578main GUI lock) leaves the GUI library and no other thread will enter the GUI
579library until the calling thread calls \helpref{::wxMutexGuiLeave()}{wxmutexguileave}.
a660d684 580
b0fc8832 581Typically, these functions are used like this:
a660d684 582
b0fc8832
VZ
583\begin{verbatim}
584void MyThread::Foo(void)
585{
586 // before doing any GUI calls we must ensure that this thread is the only
587 // one doing it!
a660d684 588
b0fc8832 589 wxMutexGuiEnter();
a660d684 590
b0fc8832
VZ
591 // Call GUI here:
592 my_window->DrawSomething();
a660d684 593
b0fc8832
VZ
594 wxMutexGuiLeave();
595}
596\end{verbatim}
a660d684 597
b0fc8832
VZ
598Note that under GTK, no creation of top-level windows is allowed in any
599thread but the main one.
a660d684 600
b0fc8832
VZ
601This function is only defined on platforms which support preemptive
602threads.
d37fd2fa 603
b0fc8832 604\membersection{::wxMutexGuiLeave}\label{wxmutexguileave}
d37fd2fa 605
b0fc8832 606\func{void}{wxMutexGuiLeave}{\void}
d37fd2fa 607
b0fc8832 608See \helpref{::wxMutexGuiEnter()}{wxmutexguienter}.
d37fd2fa 609
b0fc8832
VZ
610This function is only defined on platforms which support preemptive
611threads.
d37fd2fa 612
b0fc8832 613\section{File functions}\label{filefunctions}
d37fd2fa 614
b0fc8832 615\wxheading{Include files}
ed93168b 616
b0fc8832 617<wx/utils.h>
ed93168b 618
b0fc8832 619\wxheading{See also}
ed93168b 620
b0fc8832
VZ
621\helpref{wxPathList}{wxpathlist}\\
622\helpref{wxDir}{wxdir}\\
623\helpref{wxFile}{wxfile}\\
624\helpref{wxFileName}{wxfilename}
ed93168b 625
b0fc8832 626\membersection{::wxDirExists}\label{wxdirexists}
ed93168b 627
b0fc8832 628\func{bool}{wxDirExists}{\param{const wxString\& }{dirname}}
ed93168b 629
b0fc8832 630Returns TRUE if the directory exists.
ed93168b 631
b0fc8832 632\membersection{::wxDos2UnixFilename}\label{wxdos2unixfilename}
ed93168b 633
b0fc8832 634\func{void}{wxDos2UnixFilename}{\param{wxChar *}{s}}
d524e22d 635
b0fc8832
VZ
636Converts a DOS to a Unix filename by replacing backslashes with forward
637slashes.
d524e22d 638
b0fc8832 639\membersection{::wxFileExists}\label{wxfileexists}
d524e22d 640
b0fc8832 641\func{bool}{wxFileExists}{\param{const wxString\& }{filename}}
d524e22d 642
b0fc8832
VZ
643Returns TRUE if the file exists. It also returns TRUE if the file is
644a directory.
e12be2f7 645
b0fc8832 646\membersection{::wxFileModificationTime}\label{wxfilemodificationtime}
d524e22d 647
b0fc8832 648\func{time\_t}{wxFileModificationTime}{\param{const wxString\& }{filename}}
d524e22d 649
b0fc8832 650Returns time of last modification of given file.
d524e22d 651
b0fc8832 652\membersection{::wxFileNameFromPath}\label{wxfilenamefrompath}
d524e22d 653
b0fc8832 654\func{wxString}{wxFileNameFromPath}{\param{const wxString\& }{path}}
d524e22d 655
7ac13b21 656\func{char *}{wxFileNameFromPath}{\param{char *}{path}}
d524e22d 657
b0fc8832
VZ
658Returns the filename for a full path. The second form returns a pointer to
659temporary storage that should not be deallocated.
d524e22d 660
b0fc8832 661\membersection{::wxFindFirstFile}\label{wxfindfirstfile}
d524e22d 662
7ac13b21 663\func{wxString}{wxFindFirstFile}{\param{const char *}{spec}, \param{int}{ flags = 0}}
d524e22d 664
b0fc8832
VZ
665This function does directory searching; returns the first file
666that matches the path {\it spec}, or the empty string. Use \helpref{wxFindNextFile}{wxfindnextfile} to
667get the next matching file. Neither will report the current directory "." or the
668parent directory "..".
d524e22d 669
b0fc8832 670{\it spec} may contain wildcards.
85ec2f26 671
b0fc8832 672{\it flags} may be wxDIR for restricting the query to directories, wxFILE for files or zero for either.
d524e22d 673
b0fc8832 674For example:
d524e22d 675
b0fc8832
VZ
676\begin{verbatim}
677 wxString f = wxFindFirstFile("/home/project/*.*");
678 while ( !f.IsEmpty() )
679 {
680 ...
681 f = wxFindNextFile();
682 }
683\end{verbatim}
d524e22d 684
b0fc8832 685\membersection{::wxFindNextFile}\label{wxfindnextfile}
d524e22d 686
b0fc8832 687\func{wxString}{wxFindNextFile}{\void}
e12be2f7 688
b0fc8832 689Returns the next file that matches the path passed to \helpref{wxFindFirstFile}{wxfindfirstfile}.
d524e22d 690
b0fc8832 691See \helpref{wxFindFirstFile}{wxfindfirstfile} for an example.
d524e22d 692
b0fc8832 693\membersection{::wxGetDiskSpace}\label{wxgetdiskspace}
d524e22d 694
b0fc8832 695\func{bool}{wxGetDiskSpace}{\param{const wxString\& }{path}, \param{wxLongLong }{*total = NULL}, \param{wxLongLong }{*free = NULL}}
d524e22d 696
b0fc8832
VZ
697This function returns the total number of bytes and number of free bytes on
698the disk containing the directory {\it path} (it should exist). Both
699{\it total} and {\it free} parameters may be {\tt NULL} if the corresponding
700information is not needed.
d524e22d 701
b0fc8832 702\wxheading{Returns}
85ec2f26 703
b0fc8832
VZ
704{\tt TRUE} on success, {\tt FALSE} if an error occured (for example, the
705directory doesn't exist).
d524e22d 706
b0fc8832 707\wxheading{Portability}
d524e22d 708
b0fc8832
VZ
709This function is implemented for Win16 (only for drives less than 2Gb), Win32,
710Mac OS and generic Unix provided the system has {\tt statfs()} function.
d524e22d 711
b0fc8832 712This function first appeared in wxWindows 2.3.2.
d524e22d 713
b0fc8832 714\membersection{::wxGetOSDirectory}\label{wxgetosdirectory}
e12be2f7 715
b0fc8832 716\func{wxString}{wxGetOSDirectory}{\void}
d524e22d 717
b0fc8832 718Returns the Windows directory under Windows; on other platforms returns the empty string.
d524e22d 719
b0fc8832 720\membersection{::wxIsAbsolutePath}\label{wxisabsolutepath}
d524e22d 721
b0fc8832 722\func{bool}{wxIsAbsolutePath}{\param{const wxString\& }{filename}}
d524e22d 723
b0fc8832
VZ
724Returns TRUE if the argument is an absolute filename, i.e. with a slash
725or drive name at the beginning.
85ec2f26 726
b0fc8832 727\membersection{::wxPathOnly}\label{wxpathonly}
d524e22d 728
b0fc8832 729\func{wxString}{wxPathOnly}{\param{const wxString\& }{path}}
d524e22d 730
b0fc8832 731Returns the directory part of the filename.
d524e22d 732
b0fc8832 733\membersection{::wxUnix2DosFilename}\label{wxunix2dosfilename}
d524e22d 734
b0fc8832 735\func{void}{wxUnix2DosFilename}{\param{const wxString\& }{s}}
e12be2f7 736
b0fc8832
VZ
737Converts a Unix to a DOS filename by replacing forward
738slashes with backslashes.
d524e22d 739
b0fc8832 740\membersection{::wxConcatFiles}\label{wxconcatfiles}
d524e22d 741
b0fc8832
VZ
742\func{bool}{wxConcatFiles}{\param{const wxString\& }{file1}, \param{const wxString\& }{file2},
743\param{const wxString\& }{file3}}
d524e22d 744
b0fc8832
VZ
745Concatenates {\it file1} and {\it file2} to {\it file3}, returning
746TRUE if successful.
a660d684 747
b0fc8832 748\membersection{::wxCopyFile}\label{wxcopyfile}
a660d684 749
b0fc8832 750\func{bool}{wxCopyFile}{\param{const wxString\& }{file1}, \param{const wxString\& }{file2}, \param{bool }{overwrite = TRUE}}
a660d684 751
b0fc8832
VZ
752Copies {\it file1} to {\it file2}, returning TRUE if successful. If
753{\it overwrite} parameter is TRUE (default), the destination file is overwritten
754if it exists, but if {\it overwrite} is FALSE, the functions failes in this
755case.
a660d684 756
b0fc8832 757\membersection{::wxGetCwd}\label{wxgetcwd}
7ae8ee14 758
b0fc8832 759\func{wxString}{wxGetCwd}{\void}
7ae8ee14 760
b0fc8832 761Returns a string containing the current (or working) directory.
7ae8ee14 762
b0fc8832 763\membersection{::wxGetWorkingDirectory}\label{wxgetworkingdirectory}
7ae8ee14 764
7ac13b21 765\func{wxString}{wxGetWorkingDirectory}{\param{char *}{buf=NULL}, \param{int }{sz=1000}}
7ae8ee14 766
b0fc8832 767This function is obsolete: use \helpref{wxGetCwd}{wxgetcwd} instead.
7ae8ee14 768
b0fc8832
VZ
769Copies the current working directory into the buffer if supplied, or
770copies the working directory into new storage (which you must delete yourself)
771if the buffer is NULL.
7ae8ee14 772
b0fc8832 773{\it sz} is the size of the buffer if supplied.
a660d684 774
b0fc8832 775\membersection{::wxGetTempFileName}\label{wxgettempfilename}
a660d684 776
7ac13b21 777\func{char *}{wxGetTempFileName}{\param{const wxString\& }{prefix}, \param{char *}{buf=NULL}}
a660d684 778
b0fc8832 779\func{bool}{wxGetTempFileName}{\param{const wxString\& }{prefix}, \param{wxString\& }{buf}}
7ae8ee14 780
b0fc8832
VZ
781%% Makes a temporary filename based on {\it prefix}, opens and closes the file,
782%% and places the name in {\it buf}. If {\it buf} is NULL, new store
783%% is allocated for the temporary filename using {\it new}.
784%%
785%% Under Windows, the filename will include the drive and name of the
786%% directory allocated for temporary files (usually the contents of the
787%% TEMP variable). Under Unix, the {\tt /tmp} directory is used.
788%%
789%% It is the application's responsibility to create and delete the file.
a660d684 790
b0fc8832
VZ
791These functions are obsolete, please use\rtfsp
792\helpref{wxFileName::CreateTempFileName}{wxfilenamecreatetempfilename}\rtfsp
793instead.
a660d684 794
b0fc8832 795\membersection{::wxIsWild}\label{wxiswild}
a660d684 796
b0fc8832 797\func{bool}{wxIsWild}{\param{const wxString\& }{pattern}}
a660d684 798
b0fc8832 799Returns TRUE if the pattern contains wildcards. See \helpref{wxMatchWild}{wxmatchwild}.
a660d684 800
b0fc8832 801\membersection{::wxMatchWild}\label{wxmatchwild}
ed93168b 802
b0fc8832 803\func{bool}{wxMatchWild}{\param{const wxString\& }{pattern}, \param{const wxString\& }{text}, \param{bool}{ dot\_special}}
ed93168b 804
b0fc8832
VZ
805Returns TRUE if the {\it pattern}\/ matches the {\it text}\/; if {\it
806dot\_special}\/ is TRUE, filenames beginning with a dot are not matched
807with wildcard characters. See \helpref{wxIsWild}{wxiswild}.
ed93168b 808
b0fc8832 809\membersection{::wxMkdir}\label{wxmkdir}
ed93168b 810
b0fc8832 811\func{bool}{wxMkdir}{\param{const wxString\& }{dir}, \param{int }{perm = 0777}}
ed93168b 812
b0fc8832 813Makes the directory {\it dir}, returning TRUE if successful.
a660d684 814
b0fc8832
VZ
815{\it perm} is the access mask for the directory for the systems on which it is
816supported (Unix) and doesn't have effect for the other ones.
378b05f7 817
b0fc8832 818\membersection{::wxRemoveFile}\label{wxremovefile}
378b05f7 819
b0fc8832 820\func{bool}{wxRemoveFile}{\param{const wxString\& }{file}}
378b05f7 821
b0fc8832 822Removes {\it file}, returning TRUE if successful.
378b05f7 823
b0fc8832 824\membersection{::wxRenameFile}\label{wxrenamefile}
e12be2f7 825
b0fc8832 826\func{bool}{wxRenameFile}{\param{const wxString\& }{file1}, \param{const wxString\& }{file2}}
378b05f7 827
b0fc8832 828Renames {\it file1} to {\it file2}, returning TRUE if successful.
378b05f7 829
b0fc8832 830\membersection{::wxRmdir}\label{wxrmdir}
378b05f7 831
b0fc8832 832\func{bool}{wxRmdir}{\param{const wxString\& }{dir}, \param{int}{ flags=0}}
378b05f7 833
b0fc8832 834Removes the directory {\it dir}, returning TRUE if successful. Does not work under VMS.
e12be2f7 835
b0fc8832 836The {\it flags} parameter is reserved for future use.
378b05f7 837
b0fc8832 838\membersection{::wxSetWorkingDirectory}\label{wxsetworkingdirectory}
a660d684 839
b0fc8832 840\func{bool}{wxSetWorkingDirectory}{\param{const wxString\& }{dir}}
a660d684 841
b0fc8832
VZ
842Sets the current working directory, returning TRUE if the operation succeeded.
843Under MS Windows, the current drive is also changed if {\it dir} contains a drive specification.
c50f1fb9 844
b0fc8832 845\membersection{::wxSplitPath}\label{wxsplitfunction}
c50f1fb9 846
b0fc8832 847\func{void}{wxSplitPath}{\param{const char *}{ fullname}, \param{wxString *}{ path}, \param{wxString *}{ name}, \param{wxString *}{ ext}}
c50f1fb9 848
b0fc8832
VZ
849This function splits a full file name into components: the path (including possible disk/drive
850specification under Windows), the base name and the extension. Any of the output parameters
851({\it path}, {\it name} or {\it ext}) may be NULL if you are not interested in the value of
852a particular component.
c50f1fb9 853
b0fc8832
VZ
854wxSplitPath() will correctly handle filenames with both DOS and Unix path separators under
855Windows, however it will not consider backslashes as path separators under Unix (where backslash
856is a valid character in a filename).
c50f1fb9 857
b0fc8832 858On entry, {\it fullname} should be non-NULL (it may be empty though).
c50f1fb9 859
b0fc8832
VZ
860On return, {\it path} contains the file path (without the trailing separator), {\it name}
861contains the file name and {\it ext} contains the file extension without leading dot. All
862three of them may be empty if the corresponding component is. The old contents of the
863strings pointed to by these parameters will be overwritten in any case (if the pointers
864are not NULL).
c50f1fb9 865
b0fc8832 866\membersection{::wxTransferFileToStream}\label{wxtransferfiletostream}
c50f1fb9 867
b0fc8832 868\func{bool}{wxTransferFileToStream}{\param{const wxString\& }{filename}, \param{ostream\& }{stream}}
10eb1f1e 869
b0fc8832
VZ
870Copies the given file to {\it stream}. Useful when converting an old application to
871use streams (within the document/view framework, for example).
10eb1f1e 872
b0fc8832 873\wxheading{Include files}
10eb1f1e 874
b0fc8832 875<wx/docview.h>
10eb1f1e 876
b0fc8832
VZ
877\membersection{::wxTransferStreamToFile}\label{wxtransferstreamtofile}
878
879\func{bool}{wxTransferStreamToFile}{\param{istream\& }{stream} \param{const wxString\& }{filename}}
880
881Copies the given stream to the file {\it filename}. Useful when converting an old application to
882use streams (within the document/view framework, for example).
10eb1f1e
VZ
883
884\wxheading{Include files}
885
b0fc8832 886<wx/docview.h>
10eb1f1e 887
b0fc8832 888\section{Network, user and OS functions}\label{networkfunctions}
a660d684 889
b0fc8832
VZ
890The functions in this section are used to retrieve information about the
891current computer and/or user characteristics.
a660d684 892
b0fc8832 893\membersection{::wxGetFreeMemory}\label{wxgetfreememory}
a660d684 894
b0fc8832 895\func{long}{wxGetFreeMemory}{\void}
a660d684 896
b0fc8832
VZ
897Returns the amount of free memory in bytes under environments which
898support it, and -1 if not supported. Currently, it is supported only
899under Windows, Linux and Solaris.
a660d684 900
b0fc8832 901\wxheading{Include files}
a660d684 902
b0fc8832 903<wx/utils.h>
a660d684 904
b0fc8832 905\membersection{::wxGetFullHostName}\label{wxgetfullhostname}
a660d684 906
b0fc8832 907\func{wxString}{wxGetFullHostName}{\void}
954b8ae6 908
b0fc8832
VZ
909Returns the FQDN (fully qualified domain host name) or an empty string on
910error.
954b8ae6 911
b0fc8832 912\wxheading{See also}
c49245f8 913
b0fc8832 914\helpref{wxGetHostName}{wxgethostname}
4aff28fc 915
b0fc8832 916\wxheading{Include files}
4aff28fc 917
b0fc8832 918<wx/utils.h>
4aff28fc 919
b0fc8832 920\membersection{::wxGetEmailAddress}\label{wxgetemailaddress}
4aff28fc 921
b0fc8832
VZ
922\func{bool}{wxGetEmailAddress}{\param{const wxString\& }{buf}, \param{int }{sz}}
923
924Copies the user's email address into the supplied buffer, by
925concatenating the values returned by \helpref{wxGetFullHostName}{wxgetfullhostname}\rtfsp
926and \helpref{wxGetUserId}{wxgetuserid}.
927
928Returns TRUE if successful, FALSE otherwise.
4aff28fc
VZ
929
930\wxheading{Include files}
931
b0fc8832 932<wx/utils.h>
4aff28fc 933
b0fc8832 934\membersection{::wxGetHomeDir}\label{wxgethomedir}
d6c9c1b7 935
b0fc8832 936\func{wxString}{wxGetHomeDir}{\void}
d6c9c1b7 937
b0fc8832 938Return the (current) user's home directory.
d6c9c1b7 939
b0fc8832 940\wxheading{See also}
d6c9c1b7 941
b0fc8832 942\helpref{wxGetUserHome}{wxgetuserhome}
d6c9c1b7
VZ
943
944\wxheading{Include files}
945
b0fc8832 946<wx/utils.h>
d6c9c1b7 947
b0fc8832 948\membersection{::wxGetHostName}\label{wxgethostname}
f3539882 949
b0fc8832 950\func{wxString}{wxGetHostName}{\void}
4aff28fc 951
b0fc8832 952\func{bool}{wxGetHostName}{\param{char * }{buf}, \param{int }{sz}}
c49245f8 953
b0fc8832
VZ
954Copies the current host machine's name into the supplied buffer. Please note
955that the returned name is {\it not} fully qualified, i.e. it does not include
956the domain name.
c49245f8 957
b0fc8832
VZ
958Under Windows or NT, this function first looks in the environment
959variable SYSTEM\_NAME; if this is not found, the entry {\bf HostName}\rtfsp
960in the {\bf wxWindows} section of the WIN.INI file is tried.
c49245f8 961
b0fc8832
VZ
962The first variant of this function returns the hostname if successful or an
963empty string otherwise. The second (deprecated) function returns TRUE
964if successful, FALSE otherwise.
965
966\wxheading{See also}
967
968\helpref{wxGetFullHostName}{wxgetfullhostname}
c49245f8
VZ
969
970\wxheading{Include files}
a294c6d5 971
b0fc8832 972<wx/utils.h>
a294c6d5 973
b0fc8832 974\membersection{::wxGetUserId}\label{wxgetuserid}
a294c6d5 975
b0fc8832 976\func{wxString}{wxGetUserId}{\void}
a294c6d5 977
b0fc8832
VZ
978\func{bool}{wxGetUserId}{\param{char * }{buf}, \param{int }{sz}}
979
980This function returns the "user id" also known as "login name" under Unix i.e.
981something like "jsmith". It uniquely identifies the current user (on this system).
982
983Under Windows or NT, this function first looks in the environment
984variables USER and LOGNAME; if neither of these is found, the entry {\bf UserId}\rtfsp
985in the {\bf wxWindows} section of the WIN.INI file is tried.
986
987The first variant of this function returns the login name if successful or an
988empty string otherwise. The second (deprecated) function returns TRUE
989if successful, FALSE otherwise.
990
991\wxheading{See also}
992
993\helpref{wxGetUserName}{wxgetusername}
a294c6d5
VZ
994
995\wxheading{Include files}
c49245f8 996
b0fc8832 997<wx/utils.h>
c49245f8 998
b0fc8832 999\membersection{::wxGetOsDescription}\label{wxgetosdescription}
a660d684 1000
b0fc8832 1001\func{wxString}{wxGetOsDescription}{\void}
a660d684 1002
b0fc8832
VZ
1003Returns the string containing the description of the current platform in a
1004user-readable form. For example, this function may return strings like
1005{\tt Windows NT Version 4.0} or {\tt Linux 2.2.2 i386}.
a660d684 1006
b0fc8832
VZ
1007\wxheading{See also}
1008
1009\helpref{::wxGetOsVersion}{wxgetosversion}
a660d684 1010
954b8ae6
JS
1011\wxheading{Include files}
1012
b0fc8832 1013<wx/utils.h>
954b8ae6 1014
b0fc8832 1015\membersection{::wxGetOsVersion}\label{wxgetosversion}
a660d684 1016
b0fc8832 1017\func{int}{wxGetOsVersion}{\param{int *}{major = NULL}, \param{int *}{minor = NULL}}
a660d684 1018
b0fc8832 1019Gets operating system version information.
a660d684 1020
b0fc8832
VZ
1021\begin{twocollist}\itemsep=0pt
1022\twocolitemruled{Platform}{Return types}
1023\twocolitem{Mac OS}{Return value is wxMAC when compiled with CodeWarrior under Mac OS 8.x/9.x and Mac OS X, wxMAC\_DARWIN when compiled with the Apple Developer Tools under Mac OS X.}
1024\twocolitem{GTK}{Return value is wxGTK, For GTK 1.0, {\it major} is 1, {\it minor} is 0. }
1025\twocolitem{Motif}{Return value is wxMOTIF\_X, {\it major} is X version, {\it minor} is X revision.}
1026\twocolitem{OS/2}{Return value is wxOS2\_PM.}
1027\twocolitem{Windows 3.1}{Return value is wxWINDOWS, {\it major} is 3, {\it minor} is 1.}
1028\twocolitem{Windows NT/2000}{Return value is wxWINDOWS\_NT, version is returned in {\it major} and {\it minor}}
1029\twocolitem{Windows 98}{Return value is wxWIN95, {\it major} is 4, {\it minor} is 1 or greater.}
1030\twocolitem{Windows 95}{Return value is wxWIN95, {\it major} is 4, {\it minor} is 0.}
1031\twocolitem{Win32s (Windows 3.1)}{Return value is wxWIN32S, {\it major} is 3, {\it minor} is 1.}
1032\twocolitem{Watcom C++ 386 supervisor mode (Windows 3.1)}{Return value is wxWIN386, {\it major} is 3, {\it minor} is 1.}
1033\end{twocollist}
a660d684 1034
b0fc8832 1035\wxheading{See also}
a660d684 1036
b0fc8832 1037\helpref{::wxGetOsDescription}{wxgetosdescription}
a660d684 1038
b0fc8832
VZ
1039\wxheading{Include files}
1040
1041<wx/utils.h>
1042
1043\membersection{::wxGetUserHome}\label{wxgetuserhome}
1044
1045\func{const wxChar *}{wxGetUserHome}{\param{const wxString\& }{user = ""}}
1046
1047Returns the home directory for the given user. If the username is empty
1048(default value), this function behaves like
1049\helpref{wxGetHomeDir}{wxgethomedir}.
a660d684 1050
954b8ae6
JS
1051\wxheading{Include files}
1052
b0fc8832 1053<wx/utils.h>
954b8ae6 1054
b0fc8832 1055\membersection{::wxGetUserName}\label{wxgetusername}
a660d684 1056
b0fc8832 1057\func{wxString}{wxGetUserName}{\void}
d6c9c1b7 1058
b0fc8832 1059\func{bool}{wxGetUserName}{\param{char * }{buf}, \param{int }{sz}}
d6c9c1b7 1060
b0fc8832 1061This function returns the full user name (something like "Mr. John Smith").
d6c9c1b7 1062
b0fc8832
VZ
1063Under Windows or NT, this function looks for the entry {\bf UserName}\rtfsp
1064in the {\bf wxWindows} section of the WIN.INI file. If PenWindows
1065is running, the entry {\bf Current} in the section {\bf User} of
1066the PENWIN.INI file is used.
d6c9c1b7 1067
b0fc8832
VZ
1068The first variant of this function returns the user name if successful or an
1069empty string otherwise. The second (deprecated) function returns {\tt TRUE}
1070if successful, {\tt FALSE} otherwise.
1071
1072\wxheading{See also}
1073
1074\helpref{wxGetUserId}{wxgetuserid}
a660d684 1075
954b8ae6
JS
1076\wxheading{Include files}
1077
b0fc8832 1078<wx/utils.h>
954b8ae6 1079
b0fc8832 1080\section{String functions}
f3539882 1081
b0fc8832 1082\membersection{::copystring}\label{copystring}
a660d684 1083
7ac13b21 1084\func{char *}{copystring}{\param{const char *}{s}}
a660d684 1085
b0fc8832
VZ
1086Makes a copy of the string {\it s} using the C++ new operator, so it can be
1087deleted with the {\it delete} operator.
d6c9c1b7 1088
b0fc8832 1089This function is deprecated, use \helpref{wxString}{wxstring} class instead.
a660d684 1090
b0fc8832 1091\membersection{::wxIsEmpty}\label{wxisempty}
954b8ae6 1092
b0fc8832 1093\func{bool}{wxIsEmpty}{\param{const char *}{ p}}
954b8ae6 1094
b0fc8832
VZ
1095Returns {\tt TRUE} if the pointer is either {\tt NULL} or points to an empty
1096string, {\tt FALSE} otherwise.
f3539882 1097
b0fc8832 1098\membersection{::wxStricmp}\label{wxstricmp}
a660d684 1099
b0fc8832 1100\func{int}{wxStricmp}{\param{const char *}{p1}, \param{const char *}{p2}}
d6c9c1b7 1101
b0fc8832
VZ
1102Returns a negative value, 0, or positive value if {\it p1} is less than, equal
1103to or greater than {\it p2}. The comparison is case-insensitive.
a660d684 1104
b0fc8832
VZ
1105This function complements the standard C function {\it strcmp()} which performs
1106case-sensitive comparison.
a660d684 1107
b0fc8832 1108\membersection{::wxStringMatch}\label{wxstringmatch}
954b8ae6 1109
b0fc8832
VZ
1110\func{bool}{wxStringMatch}{\param{const wxString\& }{s1}, \param{const wxString\& }{s2},\\
1111 \param{bool}{ subString = TRUE}, \param{bool}{ exact = FALSE}}
954b8ae6 1112
b0fc8832
VZ
1113Returns {\tt TRUE} if the substring {\it s1} is found within {\it s2},
1114ignoring case if {\it exact} is FALSE. If {\it subString} is {\tt FALSE},
1115no substring matching is done.
f3539882 1116
b0fc8832 1117This function is obsolete, use \helpref{wxString::Find}{wxstringfind} instead.
a660d684 1118
b0fc8832 1119\membersection{::wxStringEq}\label{wxstringeq}
a660d684 1120
b0fc8832 1121\func{bool}{wxStringEq}{\param{const wxString\& }{s1}, \param{const wxString\& }{s2}}
a660d684 1122
b0fc8832
VZ
1123A macro defined as:
1124
1125\begin{verbatim}
1126#define wxStringEq(s1, s2) (s1 && s2 && (strcmp(s1, s2) == 0))
1127\end{verbatim}
1128
1129This function is obsolete, use \helpref{wxString}{wxstring} instead.
1130
1131\membersection{::wxStrlen}\label{wxstrlen}
1132
1133\func{size\_t}{wxStrlen}{\param{const char *}{ p}}
1134
1135This is a safe version of standard function {\it strlen()}: it does exactly the
1136same thing (i.e. returns the length of the string) except that it returns 0 if
1137{\it p} is the {\tt NULL} pointer.
1138
1139\membersection{::wxGetTranslation}\label{wxgettranslation}
1140
1141\func{const char *}{wxGetTranslation}{\param{const char * }{str}}
1142
1143This function returns the translation of string {\it str} in the current
1144\helpref{locale}{wxlocale}. If the string is not found in any of the loaded
1145message catalogs (see \helpref{internationalization overview}{internationalization}), the
1146original string is returned. In debug build, an error message is logged - this
1147should help to find the strings which were not yet translated. As this function
1148is used very often, an alternative syntax is provided: the \_() macro is
1149defined as wxGetTranslation().
1150
1151\membersection{::wxSnprintf}\label{wxsnprintf}
a660d684 1152
b0fc8832 1153\func{int}{wxSnprintf}{\param{wxChar *}{buf}, \param{size\_t }{len}, \param{const wxChar *}{format}, \param{}{...}}
a660d684 1154
b0fc8832
VZ
1155This function replaces the dangerous standard function {\tt sprintf()} and is
1156like {\tt snprintf()} available on some platforms. The only difference with
1157sprintf() is that an additional argument - buffer size - is taken and the
1158buffer is never overflowed.
a660d684 1159
b0fc8832
VZ
1160Returns the number of characters copied to the buffer or -1 if there is not
1161enough space.
a660d684 1162
b0fc8832 1163\wxheading{See also}
a660d684 1164
b0fc8832
VZ
1165\helpref{wxVsnprintf}{wxvsnprintf}, \helpref{wxString::Printf}{wxstringprintf}
1166
1167\membersection{::wxToLower}\label{wxtolower}
1168
1169\func{char}{wxToLower}{\param{char }{ch}}
1170
1171Converts the character to lower case. This is implemented as a macro for efficiency.
a660d684 1172
954b8ae6
JS
1173\wxheading{Include files}
1174
b0fc8832 1175<wx/utils.h>
954b8ae6 1176
b0fc8832 1177\membersection{::wxToUpper}\label{wxtoupper}
c50f1fb9 1178
b0fc8832 1179\func{char}{wxToUpper}{\param{char }{ch}}
c50f1fb9 1180
b0fc8832 1181Converts the character to upper case. This is implemented as a macro for efficiency.
c50f1fb9 1182
b0fc8832 1183\wxheading{Include files}
c50f1fb9 1184
b0fc8832 1185<wx/utils.h>
c50f1fb9 1186
b0fc8832
VZ
1187\membersection{::wxVsnprintf}\label{wxvsnprintf}
1188
ea44a631 1189\func{int}{wxVsnprintf}{\param{wxChar *}{buf}, \param{size\_t }{len}, \param{const wxChar *}{format}, \param{va\_list }{argPtr}}
b0fc8832 1190
7ac13b21 1191The same as \helpref{wxSnprintf}{wxsnprintf} but takes a {\tt va\_list }
b0fc8832 1192argument instead of arbitrary number of parameters.
c50f1fb9 1193
e12be2f7 1194\wxheading{See also}
c50f1fb9 1195
b0fc8832 1196\helpref{wxSnprintf}{wxsnprintf}, \helpref{wxString::PrintfV}{wxstringprintfv}
c50f1fb9 1197
b0fc8832 1198\section{Dialog functions}\label{dialogfunctions}
c50f1fb9 1199
b0fc8832
VZ
1200Below are a number of convenience functions for getting input from the
1201user or displaying messages. Note that in these functions the last three
1202parameters are optional. However, it is recommended to pass a parent frame
1203parameter, or (in MS Windows or Motif) the wrong window frame may be brought to
1204the front when the dialog box is popped up.
c50f1fb9 1205
b0fc8832 1206\membersection{::wxBeginBusyCursor}\label{wxbeginbusycursor}
a660d684 1207
b0fc8832
VZ
1208\func{void}{wxBeginBusyCursor}{\param{wxCursor *}{cursor = wxHOURGLASS\_CURSOR}}
1209
1210Changes the cursor to the given cursor for all windows in the application.
1211Use \helpref{wxEndBusyCursor}{wxendbusycursor} to revert the cursor back
1212to its previous state. These two calls can be nested, and a counter
1213ensures that only the outer calls take effect.
1214
1215See also \helpref{wxIsBusy}{wxisbusy}, \helpref{wxBusyCursor}{wxbusycursor}.
a660d684 1216
954b8ae6
JS
1217\wxheading{Include files}
1218
b0fc8832 1219<wx/utils.h>
954b8ae6 1220
b0fc8832 1221\membersection{::wxBell}\label{wxbell}
ec5d7799 1222
b0fc8832 1223\func{void}{wxBell}{\void}
ec5d7799 1224
b0fc8832 1225Ring the system bell.
ec5d7799 1226
b0fc8832 1227\wxheading{Include files}
ec5d7799 1228
b0fc8832 1229<wx/utils.h>
a660d684 1230
b0fc8832 1231\membersection{::wxCreateFileTipProvider}\label{wxcreatefiletipprovider}
a660d684 1232
b0fc8832
VZ
1233\func{wxTipProvider *}{wxCreateFileTipProvider}{\param{const wxString\& }{filename},
1234 \param{size\_t }{currentTip}}
a660d684 1235
b0fc8832
VZ
1236This function creates a \helpref{wxTipProvider}{wxtipprovider} which may be
1237used with \helpref{wxShowTip}{wxshowtip}.
a660d684 1238
b0fc8832
VZ
1239\docparam{filename}{The name of the file containing the tips, one per line}
1240\docparam{currentTip}{The index of the first tip to show - normally this index
1241is remembered between the 2 program runs.}
a660d684 1242
b0fc8832 1243\wxheading{See also}
a660d684 1244
b0fc8832 1245\helpref{Tips overview}{tipsoverview}
904a68b6 1246
b0fc8832 1247\wxheading{Include files}
904a68b6 1248
b0fc8832 1249<wx/tipdlg.h>
904a68b6 1250
b0fc8832 1251\membersection{::wxDirSelector}\label{wxdirselector}
904a68b6 1252
b0fc8832
VZ
1253\func{wxString}{wxDirSelector}{\param{const wxString\& }{message = wxDirSelectorPromptStr},\\
1254 \param{const wxString\& }{default\_path = ""},\\
1255 \param{long }{style = 0}, \param{const wxPoint\& }{pos = wxDefaultPosition},\\
1256 \param{wxWindow *}{parent = NULL}}
904a68b6 1257
b0fc8832
VZ
1258Pops up a directory selector dialog. The arguments have the same meaning as
1259those of wxDirDialog::wxDirDialog(). The message is displayed at the top,
1260and the default\_path, if specified, is set as the initial selection.
904a68b6 1261
b0fc8832
VZ
1262The application must check for an empty return value (if the user pressed
1263Cancel). For example:
904a68b6 1264
b0fc8832
VZ
1265\begin{verbatim}
1266const wxString& dir = wxDirSelector("Choose a folder");
1267if ( !dir.empty() )
1268{
1269 ...
1270}
1271\end{verbatim}
904a68b6 1272
b0fc8832 1273\wxheading{Include files}
a660d684 1274
b0fc8832 1275<wx/dirdlg.h>
a660d684 1276
b0fc8832 1277\membersection{::wxFileSelector}\label{wxfileselector}
a660d684 1278
b0fc8832
VZ
1279\func{wxString}{wxFileSelector}{\param{const wxString\& }{message}, \param{const wxString\& }{default\_path = ""},\\
1280 \param{const wxString\& }{default\_filename = ""}, \param{const wxString\& }{default\_extension = ""},\\
1281 \param{const wxString\& }{wildcard = ``*.*''}, \param{int }{flags = 0}, \param{wxWindow *}{parent = ""},\\
1282 \param{int}{ x = -1}, \param{int}{ y = -1}}
a660d684 1283
b0fc8832
VZ
1284Pops up a file selector box. In Windows, this is the common file selector
1285dialog. In X, this is a file selector box with the same functionality.
1286The path and filename are distinct elements of a full file pathname.
1287If path is empty, the current directory will be used. If filename is empty,
1288no default filename will be supplied. The wildcard determines what files
1289are displayed in the file selector, and file extension supplies a type
1290extension for the required filename. Flags may be a combination of wxOPEN,
1291wxSAVE, wxOVERWRITE\_PROMPT, wxHIDE\_READONLY, wxFILE\_MUST\_EXIST, wxMULTIPLE or 0.
a660d684 1292
b0fc8832
VZ
1293Both the Unix and Windows versions implement a wildcard filter. Typing a
1294filename containing wildcards (*, ?) in the filename text item, and
1295clicking on Ok, will result in only those files matching the pattern being
1296displayed.
a660d684 1297
b0fc8832
VZ
1298The wildcard may be a specification for multiple types of file
1299with a description for each, such as:
a660d684 1300
b0fc8832
VZ
1301\begin{verbatim}
1302 "BMP files (*.bmp)|*.bmp|GIF files (*.gif)|*.gif"
1303\end{verbatim}
a660d684 1304
b0fc8832
VZ
1305The application must check for an empty return value (the user pressed
1306Cancel). For example:
a660d684 1307
b0fc8832
VZ
1308\begin{verbatim}
1309const wxString& s = wxFileSelector("Choose a file to open");
1310if (s)
1311{
1312 ...
1313}
1314\end{verbatim}
a660d684 1315
b0fc8832 1316\wxheading{Include files}
a660d684 1317
b0fc8832 1318<wx/filedlg.h>
a660d684 1319
b0fc8832 1320\membersection{::wxEndBusyCursor}\label{wxendbusycursor}
a660d684 1321
b0fc8832 1322\func{void}{wxEndBusyCursor}{\void}
f53561f1 1323
b0fc8832
VZ
1324Changes the cursor back to the original cursor, for all windows in the application.
1325Use with \helpref{wxBeginBusyCursor}{wxbeginbusycursor}.
1326
1327See also \helpref{wxIsBusy}{wxisbusy}, \helpref{wxBusyCursor}{wxbusycursor}.
a660d684 1328
954b8ae6
JS
1329\wxheading{Include files}
1330
b0fc8832 1331<wx/utils.h>
954b8ae6 1332
b0fc8832 1333\membersection{::wxGetColourFromUser}\label{wxgetcolourfromuser}
a660d684 1334
b0fc8832 1335\func{wxColour}{wxGetColourFromUser}{\param{wxWindow *}{parent}, \param{const wxColour\& }{colInit}}
a660d684 1336
b0fc8832
VZ
1337Shows the colour selection dialog and returns the colour selected by user or
1338invalid colour (use \helpref{wxColour::Ok}{wxcolourok} to test whether a colour
1339is valid) if the dialog was cancelled.
a660d684 1340
b0fc8832 1341\wxheading{Parameters}
a660d684 1342
b0fc8832 1343\docparam{parent}{The parent window for the colour selection dialog}
a660d684 1344
b0fc8832 1345\docparam{colInit}{If given, this will be the colour initially selected in the dialog.}
a660d684 1346
b0fc8832 1347\wxheading{Include files}
a660d684 1348
b0fc8832 1349<wx/colordlg.h>
a660d684 1350
b0fc8832 1351\membersection{::wxGetMultipleChoices}\label{wxgetmultiplechoices}
a660d684 1352
b0fc8832
VZ
1353\func{size\_t}{wxGetMultipleChoices}{\\
1354 \param{wxArrayInt\& }{selections},\\
1355 \param{const wxString\& }{message},\\
1356 \param{const wxString\& }{caption},\\
1357 \param{const wxArrayString\& }{aChoices},\\
1358 \param{wxWindow *}{parent = NULL},\\
1359 \param{int}{ x = -1}, \param{int}{ y = -1},\\
1360 \param{bool}{ centre = TRUE},\\
1361 \param{int }{width=150}, \param{int }{height=200}}
a660d684 1362
b0fc8832
VZ
1363\func{size\_t}{wxGetMultipleChoices}{\\
1364 \param{wxArrayInt\& }{selections},\\
1365 \param{const wxString\& }{message},\\
1366 \param{const wxString\& }{caption},\\
1367 \param{int}{ n}, \param{const wxString\& }{choices[]},\\
1368 \param{wxWindow *}{parent = NULL},\\
1369 \param{int}{ x = -1}, \param{int}{ y = -1},\\
1370 \param{bool}{ centre = TRUE},\\
1371 \param{int }{width=150}, \param{int }{height=200}}
a660d684 1372
b0fc8832
VZ
1373Pops up a dialog box containing a message, OK/Cancel buttons and a
1374multiple-selection listbox. The user may choose an arbitrary (including 0)
1375number of items in the listbox whose indices will be returned in
1376{\it selection} array. The initial contents of this array will be used to
1377select the items when the dialog is shown.
a660d684 1378
b0fc8832
VZ
1379You may pass the list of strings to choose from either using {\it choices}
1380which is an array of {\it n} strings for the listbox or by using a single
1381{\it aChoices} parameter of type \helpref{wxArrayString}{wxarraystring}.
a660d684 1382
b0fc8832
VZ
1383If {\it centre} is TRUE, the message text (which may include new line
1384characters) is centred; if FALSE, the message is left-justified.
a660d684 1385
b0fc8832 1386\wxheading{Include files}
a660d684 1387
b0fc8832 1388<wx/choicdlg.h>
a660d684 1389
b0fc8832
VZ
1390\perlnote{In wxPerl there is just an array reference in place of {\tt n}
1391and {\tt choices}, and no {\tt selections} parameter; the function
1392returns an array containing the user selections.}
a660d684 1393
b0fc8832 1394\membersection{::wxGetNumberFromUser}\label{wxgetnumberfromuser}
a660d684 1395
b0fc8832
VZ
1396\func{long}{wxGetNumberFromUser}{
1397 \param{const wxString\& }{message},
1398 \param{const wxString\& }{prompt},
1399 \param{const wxString\& }{caption},
1400 \param{long }{value},
1401 \param{long }{min = 0},
1402 \param{long }{max = 100},
1403 \param{wxWindow *}{parent = NULL},
1404 \param{const wxPoint\& }{pos = wxDefaultPosition}}
a660d684 1405
b0fc8832
VZ
1406Shows a dialog asking the user for numeric input. The dialogs title is set to
1407{\it caption}, it contains a (possibly) multiline {\it message} above the
1408single line {\it prompt} and the zone for entering the number.
a660d684 1409
b0fc8832
VZ
1410The number entered must be in the range {\it min}..{\it max} (both of which
1411should be positive) and {\it value} is the initial value of it. If the user
1412enters an invalid value or cancels the dialog, the function will return -1.
a660d684 1413
b0fc8832
VZ
1414Dialog is centered on its {\it parent} unless an explicit position is given in
1415{\it pos}.
a660d684 1416
b0fc8832 1417\wxheading{Include files}
a660d684 1418
b0fc8832 1419<wx/textdlg.h>
a660d684 1420
b0fc8832 1421\membersection{::wxGetPasswordFromUser}\label{wxgetpasswordfromuser}
a660d684 1422
b0fc8832
VZ
1423\func{wxString}{wxGetTextFromUser}{\param{const wxString\& }{message}, \param{const wxString\& }{caption = ``Input text"},\\
1424 \param{const wxString\& }{default\_value = ``"}, \param{wxWindow *}{parent = NULL}}
a660d684 1425
b0fc8832
VZ
1426Similar to \helpref{wxGetTextFromUser}{wxgettextfromuser} but the text entered
1427in the dialog is not shown on screen but replaced with stars. This is intended
1428to be used for entering passwords as the function name implies.
a660d684 1429
b0fc8832 1430\wxheading{Include files}
a660d684 1431
b0fc8832 1432<wx/textdlg.h>
a660d684 1433
b0fc8832 1434\membersection{::wxGetTextFromUser}\label{wxgettextfromuser}
a660d684 1435
b0fc8832
VZ
1436\func{wxString}{wxGetTextFromUser}{\param{const wxString\& }{message}, \param{const wxString\& }{caption = ``Input text"},\\
1437 \param{const wxString\& }{default\_value = ``"}, \param{wxWindow *}{parent = NULL},\\
1438 \param{int}{ x = -1}, \param{int}{ y = -1}, \param{bool}{ centre = TRUE}}
a660d684 1439
b0fc8832
VZ
1440Pop up a dialog box with title set to {\it caption}, {\it message}, and a
1441\rtfsp{\it default\_value}. The user may type in text and press OK to return this text,
1442or press Cancel to return the empty string.
a660d684 1443
b0fc8832
VZ
1444If {\it centre} is TRUE, the message text (which may include new line characters)
1445is centred; if FALSE, the message is left-justified.
a660d684 1446
b0fc8832 1447\wxheading{Include files}
a660d684 1448
b0fc8832 1449<wx/textdlg.h>
a660d684 1450
b0fc8832 1451\membersection{::wxGetMultipleChoice}\label{wxgetmultiplechoice}
a660d684 1452
b0fc8832
VZ
1453\func{int}{wxGetMultipleChoice}{\param{const wxString\& }{message}, \param{const wxString\& }{caption}, \param{int}{ n}, \param{const wxString\& }{choices[]},\\
1454 \param{int }{nsel}, \param{int *}{selection},
1455 \param{wxWindow *}{parent = NULL}, \param{int}{ x = -1}, \param{int}{ y = -1},\\
1456 \param{bool}{ centre = TRUE}, \param{int }{width=150}, \param{int }{height=200}}
a660d684 1457
b0fc8832
VZ
1458Pops up a dialog box containing a message, OK/Cancel buttons and a multiple-selection
1459listbox. The user may choose one or more item(s) and press OK or Cancel.
a660d684 1460
b0fc8832
VZ
1461The number of initially selected choices, and array of the selected indices,
1462are passed in; this array will contain the user selections on exit, with
1463the function returning the number of selections. {\it selection} must be
1464as big as the number of choices, in case all are selected.
a660d684 1465
b0fc8832 1466If Cancel is pressed, -1 is returned.
a660d684 1467
b0fc8832 1468{\it choices} is an array of {\it n} strings for the listbox.
a660d684 1469
b0fc8832
VZ
1470If {\it centre} is TRUE, the message text (which may include new line characters)
1471is centred; if FALSE, the message is left-justified.
a660d684 1472
b0fc8832 1473\wxheading{Include files}
a660d684 1474
b0fc8832 1475<wx/choicdlg.h>
a660d684 1476
b0fc8832 1477\membersection{::wxGetSingleChoice}\label{wxgetsinglechoice}
a660d684 1478
b0fc8832
VZ
1479\func{wxString}{wxGetSingleChoice}{\param{const wxString\& }{message},\\
1480 \param{const wxString\& }{caption},\\
1481 \param{const wxArrayString\& }{aChoices},\\
1482 \param{wxWindow *}{parent = NULL},\\
1483 \param{int}{ x = -1}, \param{int}{ y = -1},\\
1484 \param{bool}{ centre = TRUE},\\
1485 \param{int }{width=150}, \param{int }{height=200}}
a660d684 1486
b0fc8832
VZ
1487\func{wxString}{wxGetSingleChoice}{\param{const wxString\& }{message},\\
1488 \param{const wxString\& }{caption},\\
1489 \param{int}{ n}, \param{const wxString\& }{choices[]},\\
1490 \param{wxWindow *}{parent = NULL},\\
1491 \param{int}{ x = -1}, \param{int}{ y = -1},\\
1492 \param{bool}{ centre = TRUE},\\
1493 \param{int }{width=150}, \param{int }{height=200}}
a660d684 1494
b0fc8832
VZ
1495Pops up a dialog box containing a message, OK/Cancel buttons and a
1496single-selection listbox. The user may choose an item and press OK to return a
1497string or Cancel to return the empty string. Use
1498\helpref{wxGetSingleChoiceIndex}{wxgetsinglechoiceindex} if empty string is a
1499valid choice and if you want to be able to detect pressing Cancel reliably.
a660d684 1500
b0fc8832
VZ
1501You may pass the list of strings to choose from either using {\it choices}
1502which is an array of {\it n} strings for the listbox or by using a single
1503{\it aChoices} parameter of type \helpref{wxArrayString}{wxarraystring}.
a660d684 1504
b0fc8832
VZ
1505If {\it centre} is TRUE, the message text (which may include new line
1506characters) is centred; if FALSE, the message is left-justified.
a660d684 1507
954b8ae6
JS
1508\wxheading{Include files}
1509
b0fc8832 1510<wx/choicdlg.h>
954b8ae6 1511
b0fc8832
VZ
1512\perlnote{In wxPerl there is just an array reference in place of {\tt n}
1513and {\tt choices}.}
a660d684 1514
b0fc8832 1515\membersection{::wxGetSingleChoiceIndex}\label{wxgetsinglechoiceindex}
a660d684 1516
b0fc8832
VZ
1517\func{int}{wxGetSingleChoiceIndex}{\param{const wxString\& }{message},\\
1518 \param{const wxString\& }{caption},\\
1519 \param{const wxArrayString\& }{aChoices},\\
1520 \param{wxWindow *}{parent = NULL}, \param{int}{ x = -1}, \param{int}{ y = -1},\\
1521 \param{bool}{ centre = TRUE}, \param{int }{width=150}, \param{int }{height=200}}
a660d684 1522
b0fc8832
VZ
1523\func{int}{wxGetSingleChoiceIndex}{\param{const wxString\& }{message},\\
1524 \param{const wxString\& }{caption},\\
1525 \param{int}{ n}, \param{const wxString\& }{choices[]},\\
1526 \param{wxWindow *}{parent = NULL}, \param{int}{ x = -1}, \param{int}{ y = -1},\\
1527 \param{bool}{ centre = TRUE}, \param{int }{width=150}, \param{int }{height=200}}
a660d684 1528
b0fc8832
VZ
1529As {\bf wxGetSingleChoice} but returns the index representing the selected
1530string. If the user pressed cancel, -1 is returned.
a660d684 1531
b0fc8832 1532\wxheading{Include files}
a660d684 1533
b0fc8832 1534<wx/choicdlg.h>
a660d684 1535
b0fc8832
VZ
1536\perlnote{In wxPerl there is just an array reference in place of {\tt n}
1537and {\tt choices}.}
a660d684 1538
b0fc8832 1539\membersection{::wxGetSingleChoiceData}\label{wxgetsinglechoicedata}
a660d684 1540
b0fc8832
VZ
1541\func{wxString}{wxGetSingleChoiceData}{\param{const wxString\& }{message},\\
1542 \param{const wxString\& }{caption},\\
1543 \param{const wxArrayString\& }{aChoices},\\
1544 \param{const wxString\& }{client\_data[]},\\
1545 \param{wxWindow *}{parent = NULL},\\
1546 \param{int}{ x = -1}, \param{int}{ y = -1},\\
1547 \param{bool}{ centre = TRUE}, \param{int }{width=150}, \param{int }{height=200}}
a660d684 1548
b0fc8832
VZ
1549\func{wxString}{wxGetSingleChoiceData}{\param{const wxString\& }{message},\\
1550 \param{const wxString\& }{caption},\\
1551 \param{int}{ n}, \param{const wxString\& }{choices[]},\\
1552 \param{const wxString\& }{client\_data[]},\\
1553 \param{wxWindow *}{parent = NULL},\\
1554 \param{int}{ x = -1}, \param{int}{ y = -1},\\
1555 \param{bool}{ centre = TRUE}, \param{int }{width=150}, \param{int }{height=200}}
a660d684 1556
b0fc8832
VZ
1557As {\bf wxGetSingleChoice} but takes an array of client data pointers
1558corresponding to the strings, and returns one of these pointers or NULL if
1559Cancel was pressed. The {\it client\_data} array must have the same number of
1560elements as {\it choices} or {\it aChoices}!
a660d684 1561
b0fc8832 1562\wxheading{Include files}
a660d684 1563
b0fc8832 1564<wx/choicdlg.h>
a660d684 1565
b0fc8832
VZ
1566\perlnote{In wxPerl there is just an array reference in place of {\tt n}
1567and {\tt choices}, and the client data array must have the
1568same length as the choices array.}
a660d684 1569
b0fc8832 1570\membersection{::wxIsBusy}\label{wxisbusy}
a660d684 1571
b0fc8832 1572\func{bool}{wxIsBusy}{\void}
a660d684 1573
b0fc8832
VZ
1574Returns TRUE if between two \helpref{wxBeginBusyCursor}{wxbeginbusycursor} and\rtfsp
1575\helpref{wxEndBusyCursor}{wxendbusycursor} calls.
a660d684 1576
b0fc8832 1577See also \helpref{wxBusyCursor}{wxbusycursor}.
a660d684 1578
b0fc8832 1579\wxheading{Include files}
a660d684 1580
b0fc8832 1581<wx/utils.h>
a660d684 1582
b0fc8832 1583\membersection{::wxMessageBox}\label{wxmessagebox}
a660d684 1584
b0fc8832
VZ
1585\func{int}{wxMessageBox}{\param{const wxString\& }{message}, \param{const wxString\& }{caption = ``Message"}, \param{int}{ style = wxOK \pipe wxCENTRE},\\
1586 \param{wxWindow *}{parent = NULL}, \param{int}{ x = -1}, \param{int}{ y = -1}}
a660d684 1587
b0fc8832
VZ
1588General purpose message dialog. {\it style} may be a bit list of the
1589following identifiers:
a660d684 1590
b0fc8832
VZ
1591\begin{twocollist}\itemsep=0pt
1592\twocolitem{wxYES\_NO}{Puts Yes and No buttons on the message box. May be combined with
1593wxCANCEL.}
1594\twocolitem{wxCANCEL}{Puts a Cancel button on the message box. May be combined with
1595wxYES\_NO or wxOK.}
1596\twocolitem{wxOK}{Puts an Ok button on the message box. May be combined with wxCANCEL.}
1597\twocolitem{wxCENTRE}{Centres the text.}
1598\twocolitem{wxICON\_EXCLAMATION}{Displays an exclamation mark symbol.}
1599\twocolitem{wxICON\_HAND}{Displays an error symbol.}
1600\twocolitem{wxICON\_ERROR}{Displays an error symbol - the same as wxICON\_HAND.}
1601\twocolitem{wxICON\_QUESTION}{Displays a question mark symbol.}
1602\twocolitem{wxICON\_INFORMATION}{Displays an information symbol.}
1603\end{twocollist}
a660d684 1604
b0fc8832 1605The return value is one of: wxYES, wxNO, wxCANCEL, wxOK.
a660d684 1606
b0fc8832 1607For example:
a660d684 1608
b0fc8832
VZ
1609\begin{verbatim}
1610 ...
1611 int answer = wxMessageBox("Quit program?", "Confirm",
1612 wxYES_NO | wxCANCEL, main_frame);
1613 if (answer == wxYES)
1614 delete main_frame;
1615 ...
1616\end{verbatim}
a660d684 1617
b0fc8832
VZ
1618{\it message} may contain newline characters, in which case the
1619message will be split into separate lines, to cater for large messages.
a660d684 1620
b0fc8832
VZ
1621Under Windows, the native MessageBox function is used unless wxCENTRE
1622is specified in the style, in which case a generic function is used.
1623This is because the native MessageBox function cannot centre text.
1624The symbols are not shown when the generic function is used.
a660d684 1625
b0fc8832 1626\wxheading{Include files}
a660d684 1627
b0fc8832 1628<wx/msgdlg.h>
a660d684 1629
b0fc8832 1630\membersection{::wxShowTip}\label{wxshowtip}
a660d684 1631
b0fc8832
VZ
1632\func{bool}{wxShowTip}{\param{wxWindow *}{parent},
1633 \param{wxTipProvider *}{tipProvider},
1634 \param{bool }{showAtStartup = TRUE}}
a660d684 1635
b0fc8832 1636This function shows a "startup tip" to the user.
a660d684 1637
b0fc8832 1638\docparam{parent}{The parent window for the modal dialog}
a660d684 1639
b0fc8832
VZ
1640\docparam{tipProvider}{An object which is used to get the text of the tips.
1641It may be created with the \helpref{wxCreateFileTipProvider}{wxcreatefiletipprovider} function.}
a660d684 1642
b0fc8832
VZ
1643\docparam{showAtStartup}{Should be TRUE if startup tips are shown, FALSE
1644otherwise. This is used as the initial value for "Show tips at startup"
1645checkbox which is shown in the tips dialog.}
a660d684 1646
b0fc8832 1647\wxheading{See also}
a660d684 1648
b0fc8832 1649\helpref{Tips overview}{tipsoverview}
a660d684 1650
b0fc8832 1651\wxheading{Include files}
f6bcfd97 1652
b0fc8832 1653<wx/tipdlg.h>
f6bcfd97 1654
b0fc8832 1655\section{GDI functions}\label{gdifunctions}
f6bcfd97 1656
b0fc8832 1657The following are relevant to the GDI (Graphics Device Interface).
f6bcfd97
BP
1658
1659\wxheading{Include files}
1660
b0fc8832 1661<wx/gdicmn.h>
f6bcfd97 1662
b0fc8832 1663\membersection{wxBITMAP}\label{wxbitmapmacro}
a660d684 1664
b0fc8832 1665\func{}{wxBITMAP}{bitmapName}
a660d684 1666
b0fc8832
VZ
1667This macro loads a bitmap from either application resources (on the platforms
1668for which they exist, i.e. Windows and OS2) or from an XPM file. It allows to
1669avoid using {\tt \#ifdef}s when creating bitmaps.
a660d684 1670
b0fc8832 1671\wxheading{See also}
954b8ae6 1672
b0fc8832
VZ
1673\helpref{Bitmaps and icons overview}{wxbitmapoverview},
1674\helpref{wxICON}{wxiconmacro}
a660d684 1675
b0fc8832 1676\wxheading{Include files}
954b8ae6 1677
b0fc8832 1678<wx/gdicmn.h>
a660d684 1679
b0fc8832 1680\membersection{::wxClientDisplayRect}\label{wxclientdisplayrect}
a660d684 1681
b0fc8832
VZ
1682\func{void}{wxClientDisplayRect}{\param{int *}{x}, \param{int *}{y},
1683\param{int *}{width}, \param{int *}{height}}
954b8ae6 1684
b0fc8832 1685\func{wxRect}{wxGetClientDisplayRect}{\void}
954b8ae6 1686
b0fc8832
VZ
1687Returns the dimensions of the work area on the display. On Windows
1688this means the area not covered by the taskbar, etc. Other platforms
1689are currently defaulting to the whole display until a way is found to
1690provide this info for all window managers, etc.
a660d684 1691
b0fc8832 1692\membersection{::wxColourDisplay}\label{wxcolourdisplay}
a660d684 1693
b0fc8832 1694\func{bool}{wxColourDisplay}{\void}
a660d684 1695
b0fc8832 1696Returns TRUE if the display is colour, FALSE otherwise.
a660d684 1697
b0fc8832 1698\membersection{::wxDisplayDepth}\label{wxdisplaydepth}
954b8ae6 1699
b0fc8832 1700\func{int}{wxDisplayDepth}{\void}
954b8ae6 1701
b0fc8832 1702Returns the depth of the display (a value of 1 denotes a monochrome display).
a660d684 1703
b0fc8832 1704\membersection{::wxDisplaySize}\label{wxdisplaysize}
a660d684 1705
b0fc8832 1706\func{void}{wxDisplaySize}{\param{int *}{width}, \param{int *}{height}}
a660d684 1707
b0fc8832 1708\func{wxSize}{wxGetDisplaySize}{\void}
a660d684 1709
b0fc8832 1710Returns the display size in pixels.
a660d684 1711
b0fc8832 1712\membersection{::wxDisplaySizeMM}\label{wxdisplaysizemm}
a660d684 1713
b0fc8832 1714\func{void}{wxDisplaySizeMM}{\param{int *}{width}, \param{int *}{height}}
a660d684 1715
b0fc8832 1716\func{wxSize}{wxGetDisplaySizeMM}{\void}
a660d684 1717
b0fc8832 1718Returns the display size in millimeters.
e2a6f233 1719
b0fc8832 1720\membersection{::wxDROP\_ICON}\label{wxdropicon}
e2a6f233 1721
b0fc8832 1722\func{wxIconOrCursor}{wxDROP\_ICON}{\param{const char *}{name}}
e2a6f233 1723
b0fc8832
VZ
1724This macro creates either a cursor (MSW) or an icon (elsewhere) with the given
1725name. Under MSW, the cursor is loaded from the resource file and the icon is
1726loaded from XPM file under other platforms.
1727
1728This macro should be used with
1729\helpref{wxDropSource constructor}{wxdropsourcewxdropsource}.
e2a6f233 1730
954b8ae6
JS
1731\wxheading{Include files}
1732
b0fc8832 1733<wx/dnd.h>
954b8ae6 1734
b0fc8832 1735\membersection{wxICON}\label{wxiconmacro}
e2a6f233 1736
b0fc8832 1737\func{}{wxICON}{iconName}
e2a6f233 1738
b0fc8832
VZ
1739This macro loads an icon from either application resources (on the platforms
1740for which they exist, i.e. Windows and OS2) or from an XPM file. It allows to
1741avoid using {\tt \#ifdef}s when creating icons.
e2a6f233 1742
b0fc8832 1743\wxheading{See also}
e2a6f233 1744
b0fc8832
VZ
1745\helpref{Bitmaps and icons overview}{wxbitmapoverview},
1746\helpref{wxBITMAP}{wxbitmapmacro}
e2a6f233 1747
954b8ae6
JS
1748\wxheading{Include files}
1749
b0fc8832 1750<wx/gdicmn.h>
a660d684 1751
b0fc8832 1752\membersection{::wxMakeMetafilePlaceable}\label{wxmakemetafileplaceable}
de6019fb 1753
b0fc8832
VZ
1754\func{bool}{wxMakeMetafilePlaceable}{\param{const wxString\& }{filename}, \param{int }{minX}, \param{int }{minY},
1755 \param{int }{maxX}, \param{int }{maxY}, \param{float }{scale=1.0}}
a660d684 1756
b0fc8832
VZ
1757Given a filename for an existing, valid metafile (as constructed using \helpref{wxMetafileDC}{wxmetafiledc})
1758makes it into a placeable metafile by prepending a header containing the given
1759bounding box. The bounding box may be obtained from a device context after drawing
1760into it, using the functions wxDC::MinX, wxDC::MinY, wxDC::MaxX and wxDC::MaxY.
a660d684 1761
b0fc8832
VZ
1762In addition to adding the placeable metafile header, this function adds
1763the equivalent of the following code to the start of the metafile data:
a660d684 1764
b0fc8832
VZ
1765\begin{verbatim}
1766 SetMapMode(dc, MM_ANISOTROPIC);
1767 SetWindowOrg(dc, minX, minY);
1768 SetWindowExt(dc, maxX - minX, maxY - minY);
1769\end{verbatim}
6fb26ea3 1770
b0fc8832 1771This simulates the wxMM\_TEXT mapping mode, which wxWindows assumes.
954b8ae6 1772
b0fc8832
VZ
1773Placeable metafiles may be imported by many Windows applications, and can be
1774used in RTF (Rich Text Format) files.
954b8ae6 1775
b0fc8832 1776{\it scale} allows the specification of scale for the metafile.
a660d684 1777
b0fc8832 1778This function is only available under Windows.
a660d684 1779
b0fc8832 1780\membersection{::wxSetCursor}\label{wxsetcursor}
a660d684 1781
b0fc8832 1782\func{void}{wxSetCursor}{\param{wxCursor *}{cursor}}
954b8ae6 1783
b0fc8832
VZ
1784Globally sets the cursor; only has an effect in Windows and GTK.
1785See also \helpref{wxCursor}{wxcursor}, \helpref{wxWindow::SetCursor}{wxwindowsetcursor}.
954b8ae6 1786
b0fc8832 1787\section{Printer settings}\label{printersettings}
8e193f38 1788
b0fc8832 1789These routines are obsolete and should no longer be used!
8e193f38 1790
b0fc8832
VZ
1791The following functions are used to control PostScript printing. Under
1792Windows, PostScript output can only be sent to a file.
8e193f38
VZ
1793
1794\wxheading{Include files}
1795
b0fc8832 1796<wx/dcps.h>
a660d684 1797
b0fc8832 1798\membersection{::wxGetPrinterCommand}\label{wxgetprintercommand}
a660d684 1799
b0fc8832 1800\func{wxString}{wxGetPrinterCommand}{\void}
a660d684 1801
b0fc8832 1802Gets the printer command used to print a file. The default is {\tt lpr}.
a660d684 1803
b0fc8832 1804\membersection{::wxGetPrinterFile}\label{wxgetprinterfile}
a660d684 1805
b0fc8832 1806\func{wxString}{wxGetPrinterFile}{\void}
a660d684 1807
b0fc8832 1808Gets the PostScript output filename.
a660d684 1809
b0fc8832 1810\membersection{::wxGetPrinterMode}\label{wxgetprintermode}
a660d684 1811
b0fc8832 1812\func{int}{wxGetPrinterMode}{\void}
954b8ae6 1813
b0fc8832
VZ
1814Gets the printing mode controlling where output is sent (PS\_PREVIEW, PS\_FILE or PS\_PRINTER).
1815The default is PS\_PREVIEW.
954b8ae6 1816
b0fc8832 1817\membersection{::wxGetPrinterOptions}\label{wxgetprinteroptions}
954b8ae6 1818
b0fc8832 1819\func{wxString}{wxGetPrinterOptions}{\void}
954b8ae6 1820
b0fc8832 1821Gets the additional options for the print command (e.g. specific printer). The default is nothing.
954b8ae6 1822
b0fc8832 1823\membersection{::wxGetPrinterOrientation}\label{wxgetprinterorientation}
954b8ae6 1824
b0fc8832 1825\func{int}{wxGetPrinterOrientation}{\void}
a660d684 1826
b0fc8832 1827Gets the orientation (PS\_PORTRAIT or PS\_LANDSCAPE). The default is PS\_PORTRAIT.
a660d684 1828
b0fc8832 1829\membersection{::wxGetPrinterPreviewCommand}\label{wxgetprinterpreviewcommand}
8e193f38 1830
b0fc8832 1831\func{wxString}{wxGetPrinterPreviewCommand}{\void}
a660d684 1832
b0fc8832 1833Gets the command used to view a PostScript file. The default depends on the platform.
954b8ae6 1834
b0fc8832 1835\membersection{::wxGetPrinterScaling}\label{wxgetprinterscaling}
954b8ae6 1836
b0fc8832 1837\func{void}{wxGetPrinterScaling}{\param{float *}{x}, \param{float *}{y}}
a660d684 1838
b0fc8832 1839Gets the scaling factor for PostScript output. The default is 1.0, 1.0.
a660d684 1840
b0fc8832 1841\membersection{::wxGetPrinterTranslation}\label{wxgetprintertranslation}
a660d684 1842
b0fc8832 1843\func{void}{wxGetPrinterTranslation}{\param{float *}{x}, \param{float *}{y}}
954b8ae6 1844
b0fc8832 1845Gets the translation (from the top left corner) for PostScript output. The default is 0.0, 0.0.
954b8ae6 1846
b0fc8832 1847\membersection{::wxSetPrinterCommand}\label{wxsetprintercommand}
a660d684 1848
b0fc8832 1849\func{void}{wxSetPrinterCommand}{\param{const wxString\& }{command}}
a660d684 1850
b0fc8832 1851Sets the printer command used to print a file. The default is {\tt lpr}.
a660d684 1852
b0fc8832 1853\membersection{::wxSetPrinterFile}\label{wxsetprinterfile}
cd6ce4a9 1854
b0fc8832 1855\func{void}{wxSetPrinterFile}{\param{const wxString\& }{filename}}
f6bcfd97 1856
b0fc8832 1857Sets the PostScript output filename.
a660d684 1858
b0fc8832 1859\membersection{::wxSetPrinterMode}\label{wxsetprintermode}
a660d684 1860
b0fc8832 1861\func{void}{wxSetPrinterMode}{\param{int }{mode}}
a660d684 1862
b0fc8832
VZ
1863Sets the printing mode controlling where output is sent (PS\_PREVIEW, PS\_FILE or PS\_PRINTER).
1864The default is PS\_PREVIEW.
cd6ce4a9 1865
b0fc8832 1866\membersection{::wxSetPrinterOptions}\label{wxsetprinteroptions}
a660d684 1867
b0fc8832 1868\func{void}{wxSetPrinterOptions}{\param{const wxString\& }{options}}
e6045e08 1869
b0fc8832 1870Sets the additional options for the print command (e.g. specific printer). The default is nothing.
a660d684 1871
b0fc8832 1872\membersection{::wxSetPrinterOrientation}\label{wxsetprinterorientation}
eafc087e 1873
b0fc8832 1874\func{void}{wxSetPrinterOrientation}{\param{int}{ orientation}}
cd6ce4a9 1875
b0fc8832 1876Sets the orientation (PS\_PORTRAIT or PS\_LANDSCAPE). The default is PS\_PORTRAIT.
a660d684 1877
b0fc8832 1878\membersection{::wxSetPrinterPreviewCommand}\label{wxsetprinterpreviewcommand}
954b8ae6 1879
b0fc8832 1880\func{void}{wxSetPrinterPreviewCommand}{\param{const wxString\& }{command}}
954b8ae6 1881
b0fc8832 1882Sets the command used to view a PostScript file. The default depends on the platform.
a660d684 1883
b0fc8832 1884\membersection{::wxSetPrinterScaling}\label{wxsetprinterscaling}
a660d684 1885
b0fc8832 1886\func{void}{wxSetPrinterScaling}{\param{float }{x}, \param{float }{y}}
a660d684 1887
b0fc8832 1888Sets the scaling factor for PostScript output. The default is 1.0, 1.0.
954b8ae6 1889
b0fc8832 1890\membersection{::wxSetPrinterTranslation}\label{wxsetprintertranslation}
954b8ae6 1891
b0fc8832 1892\func{void}{wxSetPrinterTranslation}{\param{float }{x}, \param{float }{y}}
a660d684 1893
b0fc8832 1894Sets the translation (from the top left corner) for PostScript output. The default is 0.0, 0.0.
a660d684 1895
b0fc8832
VZ
1896\section{Clipboard functions}\label{clipsboard}
1897
1898These clipboard functions are implemented for Windows only. The use of these functions
1899is deprecated and the code is no longer maintained. Use the \helpref{wxClipboard}{wxclipboard}
1900class instead.
a660d684 1901
954b8ae6
JS
1902\wxheading{Include files}
1903
b0fc8832 1904<wx/clipbrd.h>
954b8ae6 1905
b0fc8832 1906\membersection{::wxClipboardOpen}\label{wxclipboardopen}
a660d684 1907
b0fc8832 1908\func{bool}{wxClipboardOpen}{\void}
a660d684 1909
b0fc8832 1910Returns TRUE if this application has already opened the clipboard.
a660d684 1911
b0fc8832 1912\membersection{::wxCloseClipboard}\label{wxcloseclipboard}
954b8ae6 1913
b0fc8832 1914\func{bool}{wxCloseClipboard}{\void}
954b8ae6 1915
b0fc8832 1916Closes the clipboard to allow other applications to use it.
a660d684 1917
b0fc8832 1918\membersection{::wxEmptyClipboard}\label{wxemptyclipboard}
a660d684 1919
b0fc8832 1920\func{bool}{wxEmptyClipboard}{\void}
a660d684 1921
b0fc8832 1922Empties the clipboard.
954b8ae6 1923
b0fc8832 1924\membersection{::wxEnumClipboardFormats}\label{wxenumclipboardformats}
954b8ae6 1925
b0fc8832 1926\func{int}{wxEnumClipboardFormats}{\param{int}{dataFormat}}
a660d684 1927
b0fc8832
VZ
1928Enumerates the formats found in a list of available formats that belong
1929to the clipboard. Each call to this function specifies a known
1930available format; the function returns the format that appears next in
1931the list.
a660d684 1932
b0fc8832
VZ
1933{\it dataFormat} specifies a known format. If this parameter is zero,
1934the function returns the first format in the list.
a660d684 1935
b0fc8832
VZ
1936The return value specifies the next known clipboard data format if the
1937function is successful. It is zero if the {\it dataFormat} parameter specifies
1938the last format in the list of available formats, or if the clipboard
1939is not open.
a660d684 1940
b0fc8832
VZ
1941Before it enumerates the formats function, an application must open the clipboard by using the
1942wxOpenClipboard function.
954b8ae6 1943
b0fc8832 1944\membersection{::wxGetClipboardData}\label{wxgetclipboarddata}
954b8ae6 1945
b0fc8832 1946\func{wxObject *}{wxGetClipboardData}{\param{int}{dataFormat}}
26a80c22 1947
b0fc8832 1948Gets data from the clipboard.
26a80c22 1949
b0fc8832 1950{\it dataFormat} may be one of:
26a80c22 1951
b0fc8832
VZ
1952\begin{itemize}\itemsep=0pt
1953\item wxCF\_TEXT or wxCF\_OEMTEXT: returns a pointer to new memory containing a null-terminated text string.
1954\item wxCF\_BITMAP: returns a new wxBitmap.
1955\end{itemize}
26a80c22 1956
b0fc8832 1957The clipboard must have previously been opened for this call to succeed.
26a80c22 1958
b0fc8832 1959\membersection{::wxGetClipboardFormatName}\label{wxgetclipboardformatname}
26a80c22 1960
b0fc8832 1961\func{bool}{wxGetClipboardFormatName}{\param{int}{dataFormat}, \param{const wxString\& }{formatName}, \param{int}{maxCount}}
a660d684 1962
b0fc8832
VZ
1963Gets the name of a registered clipboard format, and puts it into the buffer {\it formatName} which is of maximum
1964length {\it maxCount}. {\it dataFormat} must not specify a predefined clipboard format.
a660d684 1965
b0fc8832 1966\membersection{::wxIsClipboardFormatAvailable}\label{wxisclipboardformatavailable}
a660d684 1967
b0fc8832 1968\func{bool}{wxIsClipboardFormatAvailable}{\param{int}{dataFormat}}
954b8ae6 1969
b0fc8832 1970Returns TRUE if the given data format is available on the clipboard.
954b8ae6 1971
b0fc8832 1972\membersection{::wxOpenClipboard}\label{wxopenclipboard}
a660d684 1973
b0fc8832 1974\func{bool}{wxOpenClipboard}{\void}
a660d684 1975
b0fc8832 1976Opens the clipboard for passing data to it or getting data from it.
a660d684 1977
b0fc8832 1978\membersection{::wxRegisterClipboardFormat}\label{wxregisterclipboardformat}
954b8ae6 1979
b0fc8832 1980\func{int}{wxRegisterClipboardFormat}{\param{const wxString\& }{formatName}}
954b8ae6 1981
b0fc8832 1982Registers the clipboard data format name and returns an identifier.
a660d684 1983
b0fc8832 1984\membersection{::wxSetClipboardData}\label{wxsetclipboarddata}
a660d684 1985
b0fc8832 1986\func{bool}{wxSetClipboardData}{\param{int}{dataFormat}, \param{wxObject *}{data}, \param{int}{width}, \param{int}{height}}
c51deffc 1987
b0fc8832 1988Passes data to the clipboard.
c51deffc 1989
b0fc8832 1990{\it dataFormat} may be one of:
a660d684 1991
b0fc8832
VZ
1992\begin{itemize}\itemsep=0pt
1993\item wxCF\_TEXT or wxCF\_OEMTEXT: {\it data} is a null-terminated text string.
1994\item wxCF\_BITMAP: {\it data} is a wxBitmap.
1995\item wxCF\_DIB: {\it data} is a wxBitmap. The bitmap is converted to a DIB (device independent bitmap).
1996\item wxCF\_METAFILE: {\it data} is a wxMetafile. {\it width} and {\it height} are used to give recommended dimensions.
1997\end{itemize}
954b8ae6 1998
b0fc8832 1999The clipboard must have previously been opened for this call to succeed.
954b8ae6 2000
b0fc8832 2001\section{Miscellaneous functions}\label{miscellany}
a660d684 2002
b0fc8832 2003\membersection{::wxNewId}\label{wxnewid}
a660d684 2004
b0fc8832
VZ
2005\func{long}{wxNewId}{\void}
2006
2007Generates an integer identifier unique to this run of the program.
a660d684 2008
954b8ae6
JS
2009\wxheading{Include files}
2010
2011<wx/utils.h>
2012
b0fc8832 2013\membersection{::wxRegisterId}\label{wxregisterid}
a660d684 2014
b0fc8832 2015\func{void}{wxRegisterId}{\param{long}{ id}}
a660d684 2016
b0fc8832
VZ
2017Ensures that ids subsequently generated by {\bf NewId} do not clash with
2018the given {\bf id}.
a660d684 2019
954b8ae6
JS
2020\wxheading{Include files}
2021
2022<wx/utils.h>
2023
b0fc8832 2024\membersection{::wxDDECleanUp}\label{wxddecleanup}
bdc72a22 2025
b0fc8832 2026\func{void}{wxDDECleanUp}{\void}
bdc72a22 2027
b0fc8832
VZ
2028Called when wxWindows exits, to clean up the DDE system. This no longer needs to be
2029called by the application.
bdc72a22 2030
b0fc8832 2031See also \helpref{wxDDEInitialize}{wxddeinitialize}.
bdc72a22
VZ
2032
2033\wxheading{Include files}
2034
b0fc8832 2035<wx/dde.h>
a660d684 2036
b0fc8832 2037\membersection{::wxDDEInitialize}\label{wxddeinitialize}
a660d684 2038
b0fc8832 2039\func{void}{wxDDEInitialize}{\void}
a660d684 2040
b0fc8832 2041Initializes the DDE system. May be called multiple times without harm.
a660d684 2042
b0fc8832
VZ
2043This no longer needs to be called by the application: it will be called
2044by wxWindows if necessary.
bdc72a22 2045
b0fc8832
VZ
2046See also \helpref{wxDDEServer}{wxddeserver}, \helpref{wxDDEClient}{wxddeclient}, \helpref{wxDDEConnection}{wxddeconnection},
2047\helpref{wxDDECleanUp}{wxddecleanup}.
bdc72a22 2048
954b8ae6
JS
2049\wxheading{Include files}
2050
b0fc8832 2051<wx/dde.h>
a660d684 2052
b0fc8832 2053\membersection{::wxDisplaySize}\label{wxdisplaysize}
a660d684 2054
b0fc8832 2055\func{void}{wxDisplaySize}{\param{int *}{width}, \param{int *}{height}}
a660d684 2056
b0fc8832 2057Gets the physical size of the display in pixels.
a660d684 2058
b0fc8832 2059\wxheading{Include files}
a660d684 2060
b0fc8832 2061<wx/gdicmn.h>
a660d684 2062
b0fc8832 2063\membersection{::wxEnableTopLevelWindows}\label{wxenabletoplevelwindows}
a660d684 2064
b0fc8832 2065\func{void}{wxEnableTopLevelWindow}{\param{bool}{ enable = TRUE}}
a660d684 2066
b0fc8832
VZ
2067This function enables or disables all top level windows. It is used by
2068\helpref{::wxSafeYield}{wxsafeyield}.
a660d684 2069
954b8ae6
JS
2070\wxheading{Include files}
2071
2072<wx/utils.h>
2073
b0fc8832 2074\membersection{::wxFindMenuItemId}\label{wxfindmenuitemid}
a660d684 2075
b0fc8832 2076\func{int}{wxFindMenuItemId}{\param{wxFrame *}{frame}, \param{const wxString\& }{menuString}, \param{const wxString\& }{itemString}}
a660d684 2077
b0fc8832 2078Find a menu item identifier associated with the given frame's menu bar.
a660d684 2079
954b8ae6
JS
2080\wxheading{Include files}
2081
2082<wx/utils.h>
2083
b0fc8832 2084\membersection{::wxFindWindowByLabel}\label{wxfindwindowbylabel}
c51deffc 2085
b0fc8832 2086\func{wxWindow *}{wxFindWindowByLabel}{\param{const wxString\& }{label}, \param{wxWindow *}{parent=NULL}}
c51deffc 2087
b0fc8832
VZ
2088Find a window by its label. Depending on the type of window, the label may be a window title
2089or panel item label. If {\it parent} is NULL, the search will start from all top-level
2090frames and dialog boxes; if non-NULL, the search will be limited to the given window hierarchy.
2091The search is recursive in both cases.
c51deffc
VZ
2092
2093\wxheading{Include files}
2094
2095<wx/utils.h>
2096
b0fc8832
VZ
2097\membersection{::wxFindWindowByName}\label{wxfindwindowbyname}
2098
2099\func{wxWindow *}{wxFindWindowByName}{\param{const wxString\& }{name}, \param{wxWindow *}{parent=NULL}}
a660d684 2100
b0fc8832
VZ
2101Find a window by its name (as given in a window constructor or {\bf Create} function call).
2102If {\it parent} is NULL, the search will start from all top-level
2103frames and dialog boxes; if non-NULL, the search will be limited to the given window hierarchy.
2104The search is recursive in both cases.
a660d684 2105
b0fc8832 2106If no such named window is found, {\bf wxFindWindowByLabel} is called.
a660d684 2107
954b8ae6
JS
2108\wxheading{Include files}
2109
2110<wx/utils.h>
2111
b0fc8832 2112\membersection{::wxFindWindowAtPoint}\label{wxfindwindowatpoint}
6787e41e 2113
b0fc8832 2114\func{wxWindow *}{wxFindWindowAtPoint}{\param{const wxPoint\& }{pt}}
6787e41e 2115
b0fc8832
VZ
2116Find the deepest window at the given mouse position in screen coordinates,
2117returning the window if found, or NULL if not.
4d01e583 2118
b0fc8832 2119\membersection{::wxFindWindowAtPointer}\label{wxfindwindowatpointer}
4d01e583 2120
b0fc8832 2121\func{wxWindow *}{wxFindWindowAtPointer}{\param{wxPoint\& }{pt}}
4d01e583 2122
b0fc8832
VZ
2123Find the deepest window at the mouse pointer position, returning the window
2124and current pointer position in screen coordinates.
4d01e583 2125
b0fc8832 2126\membersection{::wxGetActiveWindow}\label{wxgetactivewindow}
4d01e583 2127
b0fc8832 2128\func{wxWindow *}{wxGetActiveWindow}{\void}
4d01e583 2129
b0fc8832 2130Gets the currently active window (Windows only).
4d01e583 2131
b0fc8832 2132\wxheading{Include files}
4d01e583 2133
b0fc8832 2134<wx/windows.h>
4d01e583 2135
b0fc8832 2136\membersection{::wxGetDisplayName}\label{wxgetdisplayname}
4d01e583 2137
b0fc8832 2138\func{wxString}{wxGetDisplayName}{\void}
4d01e583 2139
b0fc8832 2140Under X only, returns the current display name. See also \helpref{wxSetDisplayName}{wxsetdisplayname}.
4d01e583
VZ
2141
2142\wxheading{Include files}
2143
b0fc8832 2144<wx/utils.h>
4d01e583 2145
b0fc8832 2146\membersection{::wxGetMousePosition}\label{wxgetmouseposition}
4d01e583 2147
b0fc8832 2148\func{wxPoint}{wxGetMousePosition}{\void}
4d01e583 2149
b0fc8832 2150Returns the mouse position in screen coordinates.
4d01e583
VZ
2151
2152\wxheading{Include files}
2153
2154<wx/utils.h>
2155
b0fc8832 2156\membersection{::wxGetResource}\label{wxgetresource}
a660d684 2157
b0fc8832
VZ
2158\func{bool}{wxGetResource}{\param{const wxString\& }{section}, \param{const wxString\& }{entry},
2159 \param{const wxString\& *}{value}, \param{const wxString\& }{file = NULL}}
a660d684 2160
b0fc8832
VZ
2161\func{bool}{wxGetResource}{\param{const wxString\& }{section}, \param{const wxString\& }{entry},
2162 \param{float *}{value}, \param{const wxString\& }{file = NULL}}
a660d684 2163
b0fc8832
VZ
2164\func{bool}{wxGetResource}{\param{const wxString\& }{section}, \param{const wxString\& }{entry},
2165 \param{long *}{value}, \param{const wxString\& }{file = NULL}}
50567b69 2166
b0fc8832
VZ
2167\func{bool}{wxGetResource}{\param{const wxString\& }{section}, \param{const wxString\& }{entry},
2168 \param{int *}{value}, \param{const wxString\& }{file = NULL}}
50567b69 2169
b0fc8832
VZ
2170Gets a resource value from the resource database (for example, WIN.INI, or
2171.Xdefaults). If {\it file} is NULL, WIN.INI or .Xdefaults is used,
2172otherwise the specified file is used.
50567b69 2173
b0fc8832
VZ
2174Under X, if an application class (wxApp::GetClassName) has been defined,
2175it is appended to the string /usr/lib/X11/app-defaults/ to try to find
2176an applications default file when merging all resource databases.
50567b69 2177
b0fc8832
VZ
2178The reason for passing the result in an argument is that it
2179can be convenient to define a default value, which gets overridden
2180if the value exists in the resource file. It saves a separate
2181test for that resource's existence, and it also allows
2182the overloading of the function for different types.
50567b69 2183
b0fc8832 2184See also \helpref{wxWriteResource}{wxwriteresource}, \helpref{wxConfigBase}{wxconfigbase}.
a660d684 2185
954b8ae6 2186\wxheading{Include files}
a660d684 2187
954b8ae6 2188<wx/utils.h>
a660d684 2189
a660d684
KB
2190\membersection{::wxLoadUserResource}\label{wxloaduserresource}
2191
2192\func{wxString}{wxLoadUserResource}{\param{const wxString\& }{resourceName}, \param{const wxString\& }{resourceType=``TEXT"}}
2193
2194Loads a user-defined Windows resource as a string. If the resource is found, the function creates
2195a new character array and copies the data into it. A pointer to this data is returned. If unsuccessful, NULL is returned.
2196
2197The resource must be defined in the {\tt .rc} file using the following syntax:
2198
2199\begin{verbatim}
2200myResource TEXT file.ext
2201\end{verbatim}
2202
2203where {\tt file.ext} is a file that the resource compiler can find.
2204
2205One use of this is to store {\tt .wxr} files instead of including the data in the C++ file; some compilers
2206cannot cope with the long strings in a {\tt .wxr} file. The resource data can then be parsed
2207using \helpref{wxResourceParseString}{wxresourceparsestring}.
2208
2209This function is available under Windows only.
2210
954b8ae6
JS
2211\wxheading{Include files}
2212
2213<wx/utils.h>
2214
a660d684
KB
2215\membersection{::wxPostDelete}\label{wxpostdelete}
2216
2217\func{void}{wxPostDelete}{\param{wxObject *}{object}}
2218
954b8ae6 2219Tells the system to delete the specified object when
a660d684
KB
2220all other events have been processed. In some environments, it is
2221necessary to use this instead of deleting a frame directly with the
954b8ae6 2222delete operator, because some GUIs will still send events to a deleted window.
a660d684
KB
2223
2224Now obsolete: use \helpref{wxWindow::Close}{wxwindowclose} instead.
2225
954b8ae6
JS
2226\wxheading{Include files}
2227
2228<wx/utils.h>
2229
8e193f38
VZ
2230\membersection{::wxPostEvent}\label{wxpostevent}
2231
2232\func{void}{wxPostEvent}{\param{wxEvtHandler *}{dest}, \param{wxEvent\& }{event}}
2233
2234This function posts the event to the specified {\it dest} object. The
2235difference between sending an event and posting it is that in the first case
2236the event is processed before the function returns (in wxWindows, event sending
2237is done with \helpref{ProcessEvent}{wxevthandlerprocessevent} function), but in
2238the second, the function returns immediately and the event will be processed
2239sometime later - usually during the next even loop iteration.
2240
2241Note that a copy of the {\it event} is made by the function, so the original
2242copy can be deleted as soon as function returns. This function can also be used
8a293590
RR
2243to send events between different threads safely. As this function makes a
2244copy of the event, the event needs to have a fully implemented Clone() method,
2245which may not be the case for all event in wxWindows.
2246
2247See also \helpref{AddPendingEvent}{wxevthandleraddpendingevent} (which this function
2248uses internally).
8e193f38
VZ
2249
2250\wxheading{Include files}
2251
2252<wx/app.h>
2253
a660d684
KB
2254\membersection{::wxSetDisplayName}\label{wxsetdisplayname}
2255
2256\func{void}{wxSetDisplayName}{\param{const wxString\& }{displayName}}
2257
2258Under X only, sets the current display name. This is the X host and display name such
2259as ``colonsay:0.0", and the function indicates which display should be used for creating
2260windows from this point on. Setting the display within an application allows multiple
2261displays to be used.
2262
2263See also \helpref{wxGetDisplayName}{wxgetdisplayname}.
2264
954b8ae6
JS
2265\wxheading{Include files}
2266
2267<wx/utils.h>
2268
b0fc8832 2269\membersection{::wxStripMenuCodes}\label{wxstripmenucodes}
a660d684 2270
8a2c6ef8
JS
2271\func{wxString}{wxStripMenuCodes}{\param{const wxString\& }{in}}
2272
7ac13b21 2273\func{void}{wxStripMenuCodes}{\param{char *}{in}, \param{char *}{out}}
a660d684 2274
b0fc8832
VZ
2275This function is obsolete, please use
2276\helpref{wxMenuItem::GetLabelFromText}{wxmenuitemgetlabelfromtext} instead.
2277
a660d684 2278Strips any menu codes from {\it in} and places the result
8a2c6ef8
JS
2279in {\it out} (or returns the new string, in the first form).
2280
2281Menu codes include \& (mark the next character with an underline
a660d684
KB
2282as a keyboard shortkey in Windows and Motif) and $\backslash$t (tab in Windows).
2283
954b8ae6
JS
2284\wxheading{Include files}
2285
2286<wx/utils.h>
2287
a660d684
KB
2288\membersection{::wxWriteResource}\label{wxwriteresource}
2289
2290\func{bool}{wxWriteResource}{\param{const wxString\& }{section}, \param{const wxString\& }{entry},
2291 \param{const wxString\& }{value}, \param{const wxString\& }{file = NULL}}
2292
2293\func{bool}{wxWriteResource}{\param{const wxString\& }{section}, \param{const wxString\& }{entry},
2294 \param{float }{value}, \param{const wxString\& }{file = NULL}}
2295
2296\func{bool}{wxWriteResource}{\param{const wxString\& }{section}, \param{const wxString\& }{entry},
2297 \param{long }{value}, \param{const wxString\& }{file = NULL}}
2298
2299\func{bool}{wxWriteResource}{\param{const wxString\& }{section}, \param{const wxString\& }{entry},
2300 \param{int }{value}, \param{const wxString\& }{file = NULL}}
2301
2302Writes a resource value into the resource database (for example, WIN.INI, or
2303.Xdefaults). If {\it file} is NULL, WIN.INI or .Xdefaults is used,
2304otherwise the specified file is used.
2305
2306Under X, the resource databases are cached until the internal function
b0fc8832
VZ
2307\rtfsp{\bf wxFlushResources} is called automatically on exit, when
2308all updated resource databases are written to their files.
8a293590 2309
b0fc8832
VZ
2310Note that it is considered bad manners to write to the .Xdefaults
2311file under Unix, although the WIN.INI file is fair game under Windows.
8a293590 2312
b0fc8832 2313See also \helpref{wxGetResource}{wxgetresource}, \helpref{wxConfigBase}{wxconfigbase}.
8a293590
RR
2314
2315\wxheading{Include files}
2316
b0fc8832 2317<wx/utils.h>
8a293590 2318
b0fc8832 2319\section{Byte order macros}\label{macros}
a660d684 2320
b0fc8832
VZ
2321The endian-ness issues (that is the difference between big-endian and
2322little-endian architectures) are important for the portable programs working
2323with the external binary data (for example, data files or data coming from
2324network) which is usually in some fixed, platform-independent format. The
2325macros are helpful for transforming the data to the correct format.
a660d684 2326
0180dad6
RR
2327\membersection{wxINTXX\_SWAP\_ALWAYS}\label{intswapalways}
2328
2329\func{wxInt32}{wxINT32\_SWAP\_ALWAYS}{\param{wxInt32 }{value}}
2330
2331\func{wxUint32}{wxUINT32\_SWAP\_ALWAYS}{\param{wxUint32 }{value}}
2332
2333\func{wxInt16}{wxINT16\_SWAP\_ALWAYS}{\param{wxInt16 }{value}}
2334
2335\func{wxUint16}{wxUINT16\_SWAP\_ALWAYS}{\param{wxUint16 }{value}}
2336
b0fc8832
VZ
2337These macros will swap the bytes of the {\it value} variable from little
2338endian to big endian or vice versa unconditionally, i.e. independently of the
2339current platform.
0180dad6
RR
2340
2341\membersection{wxINTXX\_SWAP\_ON\_BE}\label{intswaponbe}
2342
2343\func{wxInt32}{wxINT32\_SWAP\_ON\_BE}{\param{wxInt32 }{value}}
2344
2345\func{wxUint32}{wxUINT32\_SWAP\_ON\_BE}{\param{wxUint32 }{value}}
2346
2347\func{wxInt16}{wxINT16\_SWAP\_ON\_BE}{\param{wxInt16 }{value}}
2348
2349\func{wxUint16}{wxUINT16\_SWAP\_ON\_BE}{\param{wxUint16 }{value}}
2350
2351This macro will swap the bytes of the {\it value} variable from little
2352endian to big endian or vice versa if the program is compiled on a
ec5d7799 2353big-endian architecture (such as Sun work stations). If the program has
0180dad6
RR
2354been compiled on a little-endian architecture, the value will be unchanged.
2355
ec5d7799 2356Use these macros to read data from and write data to a file that stores
b0fc8832 2357data in little-endian (for example Intel i386) format.
0180dad6
RR
2358
2359\membersection{wxINTXX\_SWAP\_ON\_LE}\label{intswaponle}
2360
2361\func{wxInt32}{wxINT32\_SWAP\_ON\_LE}{\param{wxInt32 }{value}}
2362
2363\func{wxUint32}{wxUINT32\_SWAP\_ON\_LE}{\param{wxUint32 }{value}}
2364
2365\func{wxInt16}{wxINT16\_SWAP\_ON\_LE}{\param{wxInt16 }{value}}
2366
2367\func{wxUint16}{wxUINT16\_SWAP\_ON\_LE}{\param{wxUint16 }{value}}
2368
2369This macro will swap the bytes of the {\it value} variable from little
2370endian to big endian or vice versa if the program is compiled on a
ec5d7799 2371little-endian architecture (such as Intel PCs). If the program has
0180dad6
RR
2372been compiled on a big-endian architecture, the value will be unchanged.
2373
ec5d7799 2374Use these macros to read data from and write data to a file that stores
b0fc8832
VZ
2375data in big-endian format.
2376
2377\section{RTTI functions}\label{macros}
2378
2379wxWindows uses its own RTTI ("run-time type identification") system which
2380predates the current standard C++ RTTI and so is kept for backwards
2381compatribility reasons but also because it allows some things which the
2382standard RTTI doesn't directly support (such as creating a class from its
2383name).
2384
2385The standard C++ RTTI can be used in the user code without any problems and in
2386general you shouldn't need to use the functions and the macros in this section
2387unless you are thinking of modifying or adding any wxWindows classes.
2388
2389\wxheading{See also}
2390
2391\helpref{RTTI overview}{runtimeclassoverview}
0180dad6 2392
a660d684
KB
2393\membersection{CLASSINFO}\label{classinfo}
2394
2395\func{wxClassInfo *}{CLASSINFO}{className}
2396
2397Returns a pointer to the wxClassInfo object associated with this class.
2398
954b8ae6
JS
2399\wxheading{Include files}
2400
2401<wx/object.h>
2402
b0fc8832 2403\membersection{DECLARE\_ABSTRACT\_CLASS}\label{declareabstractclass}
a660d684
KB
2404
2405\func{}{DECLARE\_ABSTRACT\_CLASS}{className}
2406
2407Used inside a class declaration to declare that the class should be
2408made known to the class hierarchy, but objects of this class cannot be created
2409dynamically. The same as DECLARE\_CLASS.
2410
2411Example:
2412
2413\begin{verbatim}
2414class wxCommand: public wxObject
2415{
2416 DECLARE_ABSTRACT_CLASS(wxCommand)
2417
2418 private:
2419 ...
2420 public:
2421 ...
2422};
2423\end{verbatim}
2424
954b8ae6
JS
2425\wxheading{Include files}
2426
2427<wx/object.h>
2428
a660d684
KB
2429\membersection{DECLARE\_APP}\label{declareapp}
2430
2431\func{}{DECLARE\_APP}{className}
2432
2433This is used in headers to create a forward declaration of the wxGetApp function implemented
2434by IMPLEMENT\_APP. It creates the declaration {\tt className\& wxGetApp(void)}.
2435
2436Example:
2437
2438\begin{verbatim}
2439 DECLARE_APP(MyApp)
2440\end{verbatim}
2441
954b8ae6
JS
2442\wxheading{Include files}
2443
2444<wx/app.h>
2445
b0fc8832 2446\membersection{DECLARE\_CLASS}\label{declareclass}
a660d684
KB
2447
2448\func{}{DECLARE\_CLASS}{className}
2449
2450Used inside a class declaration to declare that the class should be
2451made known to the class hierarchy, but objects of this class cannot be created
2452dynamically. The same as DECLARE\_ABSTRACT\_CLASS.
2453
954b8ae6
JS
2454\wxheading{Include files}
2455
2456<wx/object.h>
2457
b0fc8832 2458\membersection{DECLARE\_DYNAMIC\_CLASS}\label{declaredynamicclass}
a660d684
KB
2459
2460\func{}{DECLARE\_DYNAMIC\_CLASS}{className}
2461
2462Used inside a class declaration to declare that the objects of this class should be dynamically
f6bcfd97 2463creatable from run-time type information.
a660d684
KB
2464
2465Example:
2466
2467\begin{verbatim}
2468class wxFrame: public wxWindow
2469{
2470 DECLARE_DYNAMIC_CLASS(wxFrame)
2471
2472 private:
2473 const wxString\& frameTitle;
2474 public:
2475 ...
2476};
2477\end{verbatim}
2478
954b8ae6
JS
2479\wxheading{Include files}
2480
2481<wx/object.h>
2482
b0fc8832 2483\membersection{IMPLEMENT\_ABSTRACT\_CLASS}\label{implementabstractclass}
a660d684
KB
2484
2485\func{}{IMPLEMENT\_ABSTRACT\_CLASS}{className, baseClassName}
2486
2487Used in a C++ implementation file to complete the declaration of
2488a class that has run-time type information. The same as IMPLEMENT\_CLASS.
2489
2490Example:
2491
2492\begin{verbatim}
2493IMPLEMENT_ABSTRACT_CLASS(wxCommand, wxObject)
2494
2495wxCommand::wxCommand(void)
2496{
2497...
2498}
2499\end{verbatim}
2500
954b8ae6
JS
2501\wxheading{Include files}
2502
2503<wx/object.h>
2504
b0fc8832 2505\membersection{IMPLEMENT\_ABSTRACT\_CLASS2}\label{implementabstractclass2}
a660d684
KB
2506
2507\func{}{IMPLEMENT\_ABSTRACT\_CLASS2}{className, baseClassName1, baseClassName2}
2508
2509Used in a C++ implementation file to complete the declaration of
2510a class that has run-time type information and two base classes. The same as IMPLEMENT\_CLASS2.
2511
954b8ae6
JS
2512\wxheading{Include files}
2513
2514<wx/object.h>
2515
a660d684
KB
2516\membersection{IMPLEMENT\_APP}\label{implementapp}
2517
2518\func{}{IMPLEMENT\_APP}{className}
2519
2520This is used in the application class implementation file to make the application class known to
2521wxWindows for dynamic construction. You use this instead of
2522
2523Old form:
2524
2525\begin{verbatim}
2526 MyApp myApp;
2527\end{verbatim}
2528
2529New form:
2530
2531\begin{verbatim}
2532 IMPLEMENT_APP(MyApp)
2533\end{verbatim}
2534
2535See also \helpref{DECLARE\_APP}{declareapp}.
2536
954b8ae6
JS
2537\wxheading{Include files}
2538
2539<wx/app.h>
2540
b0fc8832 2541\membersection{IMPLEMENT\_CLASS}\label{implementclass}
a660d684
KB
2542
2543\func{}{IMPLEMENT\_CLASS}{className, baseClassName}
2544
2545Used in a C++ implementation file to complete the declaration of
2546a class that has run-time type information. The same as IMPLEMENT\_ABSTRACT\_CLASS.
2547
954b8ae6
JS
2548\wxheading{Include files}
2549
2550<wx/object.h>
2551
b0fc8832 2552\membersection{IMPLEMENT\_CLASS2}\label{implementclass2}
a660d684
KB
2553
2554\func{}{IMPLEMENT\_CLASS2}{className, baseClassName1, baseClassName2}
2555
2556Used in a C++ implementation file to complete the declaration of a
2557class that has run-time type information and two base classes. The
2558same as IMPLEMENT\_ABSTRACT\_CLASS2.
2559
954b8ae6
JS
2560\wxheading{Include files}
2561
2562<wx/object.h>
2563
b0fc8832 2564\membersection{IMPLEMENT\_DYNAMIC\_CLASS}\label{implementdynamicclass}
a660d684
KB
2565
2566\func{}{IMPLEMENT\_DYNAMIC\_CLASS}{className, baseClassName}
2567
2568Used in a C++ implementation file to complete the declaration of
2569a class that has run-time type information, and whose instances
2570can be created dynamically.
2571
2572Example:
2573
2574\begin{verbatim}
2575IMPLEMENT_DYNAMIC_CLASS(wxFrame, wxWindow)
2576
2577wxFrame::wxFrame(void)
2578{
2579...
2580}
2581\end{verbatim}
2582
954b8ae6
JS
2583\wxheading{Include files}
2584
2585<wx/object.h>
2586
b0fc8832 2587\membersection{IMPLEMENT\_DYNAMIC\_CLASS2}\label{implementdynamicclass2}
a660d684
KB
2588
2589\func{}{IMPLEMENT\_DYNAMIC\_CLASS2}{className, baseClassName1, baseClassName2}
2590
2591Used in a C++ implementation file to complete the declaration of
2592a class that has run-time type information, and whose instances
2593can be created dynamically. Use this for classes derived from two
2594base classes.
2595
954b8ae6
JS
2596\wxheading{Include files}
2597
2598<wx/object.h>
2599
f6bcfd97
BP
2600\membersection{wxConstCast}\label{wxconstcast}
2601
f7637829 2602\func{classname *}{wxConstCast}{ptr, classname}
f6bcfd97
BP
2603
2604This macro expands into {\tt const\_cast<classname *>(ptr)} if the compiler
2605supports {\it const\_cast} or into an old, C-style cast, otherwise.
2606
2607\wxheading{See also}
2608
2609\helpref{wxDynamicCast}{wxdynamiccast}\\
2610\helpref{wxStaticCast}{wxstaticcast}
2611
b0fc8832
VZ
2612\membersection{::wxCreateDynamicObject}\label{wxcreatedynamicobject}
2613
2614\func{wxObject *}{wxCreateDynamicObject}{\param{const wxString\& }{className}}
2615
2616Creates and returns an object of the given class, if the class has been
2617registered with the dynamic class system using DECLARE... and IMPLEMENT... macros.
2618
34636400
VZ
2619\membersection{WXDEBUG\_NEW}\label{debugnew}
2620
2621\func{}{WXDEBUG\_NEW}{arg}
2622
2623This is defined in debug mode to be call the redefined new operator
2624with filename and line number arguments. The definition is:
2625
2626\begin{verbatim}
2627#define WXDEBUG_NEW new(__FILE__,__LINE__)
2628\end{verbatim}
2629
2630In non-debug mode, this is defined as the normal new operator.
2631
2632\wxheading{Include files}
2633
2634<wx/object.h>
2635
2636\membersection{wxDynamicCast}\label{wxdynamiccast}
2637
f7637829 2638\func{classname *}{wxDynamicCast}{ptr, classname}
34636400
VZ
2639
2640This macro returns the pointer {\it ptr} cast to the type {\it classname *} if
8a7f3379 2641the pointer is of this type (the check is done during the run-time) or
f7637829
VZ
2642{\tt NULL} otherwise. Usage of this macro is preferred over obsoleted
2643wxObject::IsKindOf() function.
34636400 2644
f7637829
VZ
2645The {\it ptr} argument may be {\tt NULL}, in which case {\tt NULL} will be
2646returned.
34636400
VZ
2647
2648Example:
2649
2650\begin{verbatim}
2651 wxWindow *win = wxWindow::FindFocus();
2652 wxTextCtrl *text = wxDynamicCast(win, wxTextCtrl);
2653 if ( text )
2654 {
2655 // a text control has the focus...
2656 }
2657 else
2658 {
f6bcfd97 2659 // no window has the focus or it is not a text control
34636400
VZ
2660 }
2661\end{verbatim}
2662
2663\wxheading{See also}
2664
f6bcfd97 2665\helpref{RTTI overview}{runtimeclassoverview}\\
f7637829 2666\helpref{wxDynamicCastThis}{wxdynamiccastthis}\\
f6bcfd97
BP
2667\helpref{wxConstCast}{wxconstcast}\\
2668\helpref{wxStatiicCast}{wxstaticcast}
34636400 2669
f7637829
VZ
2670\membersection{wxDynamicCastThis}\label{wxdynamiccastthis}
2671
2672\func{classname *}{wxDynamicCastThis}{classname}
2673
2674This macro is equivalent to {\tt wxDynamicCast(this, classname)} but the
2675latter provokes spurious compilation warnings from some compilers (because it
2676tests whether {\tt this} pointer is non {\tt NULL} which is always true), so
2677this macro should be used to avoid them.
2678
2679\wxheading{See also}
2680
2681\helpref{wxDynamicCast}{wxdynamiccast}
2682
f6bcfd97
BP
2683\membersection{wxStaticCast}\label{wxstaticcast}
2684
f7637829 2685\func{classname *}{wxStaticCast}{ptr, classname}
f6bcfd97
BP
2686
2687This macro checks that the cast is valid in debug mode (an assert failure will
2688result if {\tt wxDynamicCast(ptr, classname) == NULL}) and then returns the
2689result of executing an equivalent of {\tt static\_cast<classname *>(ptr)}.
2690
2691\helpref{wxDynamicCast}{wxdynamiccast}\\
2692\helpref{wxConstCast}{wxconstcast}
2693
b0fc8832 2694\section{Resource functions}\label{resourcefuncs}
a660d684 2695
b0fc8832 2696\overview{Resource functions}{resourceformats}
a660d684
KB
2697
2698This section details functions for manipulating wxWindows (.WXR) resource
2699files and loading user interface elements from resources.
2700
2701\normalbox{Please note that this use of the word `resource' is different from that used when talking
2702about initialisation file resource reading and writing, using such functions
f6bcfd97 2703as wxWriteResource and wxGetResource. It is just an unfortunate clash of terminology.}
a660d684
KB
2704
2705\helponly{For an overview of the wxWindows resource mechanism, see \helpref{the wxWindows resource system}{resourceformats}.}
2706
2707See also \helpref{wxWindow::LoadFromResource}{wxwindowloadfromresource} for
2708loading from resource data.
2709
2710\membersection{::wxResourceAddIdentifier}\label{wxresourceaddidentifier}
2711
2712\func{bool}{wxResourceAddIdentifier}{\param{const wxString\& }{name}, \param{int }{value}}
2713
2714Used for associating a name with an integer identifier (equivalent to dynamically\rtfsp
6aa358ae 2715\tt{#}defining a name to an integer). Unlikely to be used by an application except
a660d684
KB
2716perhaps for implementing resource functionality for interpreted languages.
2717
b0fc8832 2718\membersection{::wxResourceClear}\label{wxresourceclear}
a660d684
KB
2719
2720\func{void}{wxResourceClear}{\void}
2721
2722Clears the wxWindows resource table.
2723
b0fc8832 2724\membersection{::wxResourceCreateBitmap}\label{wxresourcecreatebitmap}
a660d684
KB
2725
2726\func{wxBitmap *}{wxResourceCreateBitmap}{\param{const wxString\& }{resource}}
2727
2728Creates a new bitmap from a file, static data, or Windows resource, given a valid
2729wxWindows bitmap resource identifier. For example, if the .WXR file contains
2730the following:
2731
2732\begin{verbatim}
f6bcfd97
BP
2733static const wxString\& project_resource = "bitmap(name = 'project_resource',\
2734 bitmap = ['project', wxBITMAP_TYPE_BMP_RESOURCE, 'WINDOWS'],\
2735 bitmap = ['project.xpm', wxBITMAP_TYPE_XPM, 'X']).";
a660d684
KB
2736\end{verbatim}
2737
2738then this function can be called as follows:
2739
2740\begin{verbatim}
f6bcfd97 2741 wxBitmap *bitmap = wxResourceCreateBitmap("project_resource");
a660d684
KB
2742\end{verbatim}
2743
b0fc8832 2744\membersection{::wxResourceCreateIcon}\label{wxresourcecreateicon}
a660d684
KB
2745
2746\func{wxIcon *}{wxResourceCreateIcon}{\param{const wxString\& }{resource}}
2747
2748Creates a new icon from a file, static data, or Windows resource, given a valid
2749wxWindows icon resource identifier. For example, if the .WXR file contains
2750the following:
2751
2752\begin{verbatim}
f6bcfd97
BP
2753static const wxString\& project_resource = "icon(name = 'project_resource',\
2754 icon = ['project', wxBITMAP_TYPE_ICO_RESOURCE, 'WINDOWS'],\
2755 icon = ['project', wxBITMAP_TYPE_XBM_DATA, 'X']).";
a660d684
KB
2756\end{verbatim}
2757
2758then this function can be called as follows:
2759
2760\begin{verbatim}
f6bcfd97 2761 wxIcon *icon = wxResourceCreateIcon("project_resource");
a660d684
KB
2762\end{verbatim}
2763
b0fc8832 2764\membersection{::wxResourceCreateMenuBar}\label{wxresourcecreatemenubar}
a660d684
KB
2765
2766\func{wxMenuBar *}{wxResourceCreateMenuBar}{\param{const wxString\& }{resource}}
2767
2768Creates a new menu bar given a valid wxWindows menubar resource
2769identifier. For example, if the .WXR file contains the following:
2770
2771\begin{verbatim}
2772static const wxString\& menuBar11 = "menu(name = 'menuBar11',\
2773 menu = \
2774 [\
2775 ['&File', 1, '', \
2776 ['&Open File', 2, 'Open a file'],\
2777 ['&Save File', 3, 'Save a file'],\
2778 [],\
2779 ['E&xit', 4, 'Exit program']\
2780 ],\
2781 ['&Help', 5, '', \
2782 ['&About', 6, 'About this program']\
2783 ]\
2784 ]).";
2785\end{verbatim}
2786
2787then this function can be called as follows:
2788
2789\begin{verbatim}
2790 wxMenuBar *menuBar = wxResourceCreateMenuBar("menuBar11");
2791\end{verbatim}
2792
2793
b0fc8832 2794\membersection{::wxResourceGetIdentifier}\label{wxresourcegetidentifier}
a660d684
KB
2795
2796\func{int}{wxResourceGetIdentifier}{\param{const wxString\& }{name}}
2797
2798Used for retrieving the integer value associated with an identifier.
2799A zero value indicates that the identifier was not found.
2800
2801See \helpref{wxResourceAddIdentifier}{wxresourceaddidentifier}.
2802
2803\membersection{::wxResourceParseData}\label{wxresourcedata}
2804
2805\func{bool}{wxResourceParseData}{\param{const wxString\& }{resource}, \param{wxResourceTable *}{table = NULL}}
2806
2807Parses a string containing one or more wxWindows resource objects. If
2808the resource objects are global static data that are included into the
2809C++ program, then this function must be called for each variable
2810containing the resource data, to make it known to wxWindows.
2811
2812{\it resource} should contain data in the following form:
2813
2814\begin{verbatim}
2815dialog(name = 'dialog1',
2816 style = 'wxCAPTION | wxDEFAULT_DIALOG_STYLE',
2817 title = 'Test dialog box',
2818 x = 312, y = 234, width = 400, height = 300,
2819 modal = 0,
f6bcfd97 2820 control = [1000, wxStaticBox, 'Groupbox', '0', 'group6', 5, 4, 380, 262,
a660d684 2821 [11, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0]],
f6bcfd97 2822 control = [1001, wxTextCtrl, '', 'wxTE_MULTILINE', 'text3',
a660d684
KB
2823 156, 126, 200, 70, 'wxWindows is a multi-platform, GUI toolkit.',
2824 [11, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0],
2825 [11, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0]]).
2826\end{verbatim}
2827
2828This function will typically be used after including a {\tt .wxr} file into
2829a C++ program as follows:
2830
2831\begin{verbatim}
2832#include "dialog1.wxr"
2833\end{verbatim}
2834
2835Each of the contained resources will declare a new C++ variable, and each
2836of these variables should be passed to wxResourceParseData.
2837
b0fc8832 2838\membersection{::wxResourceParseFile}\label{wxresourceparsefile}
a660d684
KB
2839
2840\func{bool}{wxResourceParseFile}{\param{const wxString\& }{filename}, \param{wxResourceTable *}{table = NULL}}
2841
2842Parses a file containing one or more wxWindows resource objects
2843in C++-compatible syntax. Use this function to dynamically load
2844wxWindows resource data.
2845
2846\membersection{::wxResourceParseString}\label{wxresourceparsestring}
2847
7ac13b21 2848\func{bool}{wxResourceParseString}{\param{char *}{s}, \param{wxResourceTable *}{table = NULL}}
a660d684
KB
2849
2850Parses a string containing one or more wxWindows resource objects. If
2851the resource objects are global static data that are included into the
2852C++ program, then this function must be called for each variable
2853containing the resource data, to make it known to wxWindows.
2854
2855{\it resource} should contain data with the following form:
2856
2857\begin{verbatim}
f6bcfd97
BP
2858dialog(name = 'dialog1',
2859 style = 'wxCAPTION | wxDEFAULT_DIALOG_STYLE',
2860 title = 'Test dialog box',
2861 x = 312, y = 234, width = 400, height = 300,
2862 modal = 0,
2863 control = [1000, wxStaticBox, 'Groupbox', '0', 'group6', 5, 4, 380, 262,
2864 [11, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0]],
2865 control = [1001, wxTextCtrl, '', 'wxTE_MULTILINE', 'text3',
2866 156, 126, 200, 70, 'wxWindows is a multi-platform, GUI toolkit.',
2867 [11, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0],
2868 [11, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0]]).
a660d684
KB
2869\end{verbatim}
2870
2871This function will typically be used after calling \helpref{wxLoadUserResource}{wxloaduserresource} to
2872load an entire {\tt .wxr file} into a string.
2873
2874\membersection{::wxResourceRegisterBitmapData}\label{registerbitmapdata}
2875
7ac13b21 2876\func{bool}{wxResourceRegisterBitmapData}{\param{const wxString\& }{name}, \param{char *}{xbm\_data}, \param{int }{width},
a660d684
KB
2877\param{int }{height}, \param{wxResourceTable *}{table = NULL}}
2878
7ac13b21 2879\func{bool}{wxResourceRegisterBitmapData}{\param{const wxString\& }{name}, \param{char **}{xpm\_data}}
a660d684 2880
6aa358ae 2881Makes \tt{#}included XBM or XPM bitmap data known to the wxWindows resource system.
a660d684
KB
2882This is required if other resources will use the bitmap data, since otherwise there
2883is no connection between names used in resources, and the global bitmap data.
2884
b0fc8832 2885\membersection{::wxResourceRegisterIconData}\label{wxresourceregistericondata}
a660d684
KB
2886
2887Another name for \helpref{wxResourceRegisterBitmapData}{registerbitmapdata}.
2888
6fb26ea3
JS
2889\section{Log functions}\label{logfunctions}
2890
2891These functions provide a variety of logging functions: see \helpref{Log classes overview}{wxlogoverview} for
f68586e5
VZ
2892further information. The functions use (implicitly) the currently active log
2893target, so their descriptions here may not apply if the log target is not the
2894standard one (installed by wxWindows in the beginning of the program).
6fb26ea3 2895
954b8ae6
JS
2896\wxheading{Include files}
2897
2898<wx/log.h>
2899
b0fc8832
VZ
2900\membersection{::wxDebugMsg}\label{wxdebugmsg}
2901
2902\func{void}{wxDebugMsg}{\param{const wxString\& }{fmt}, \param{...}{}}
2903
2904{\bf This function is deprecated, use \helpref{wxLogDebug}{wxlogdebug} instead!}
2905
2906Display a debugging message; under Windows, this will appear on the
2907debugger command window, and under Unix, it will be written to standard
2908error.
2909
2910The syntax is identical to {\bf printf}: pass a format string and a
2911variable list of arguments.
2912
2913{\bf Tip:} under Windows, if your application crashes before the
2914message appears in the debugging window, put a wxYield call after
2915each wxDebugMsg call. wxDebugMsg seems to be broken under WIN32s
2916(at least for Watcom C++): preformat your messages and use OutputDebugString
2917instead.
2918
2919This function is now obsolete, replaced by \helpref{Log functions}{logfunctions}.
2920
2921\wxheading{Include files}
2922
2923<wx/utils.h>
2924
2925\membersection{::wxError}\label{wxerror}
2926
2927\func{void}{wxError}{\param{const wxString\& }{msg}, \param{const wxString\& }{title = "wxWindows Internal Error"}}
2928
2929This function is now obsolete, please use \helpref{wxLogError}{wxlogerror}
2930instead.
2931
2932Displays {\it msg} and continues. This writes to standard error under
2933Unix, and pops up a message box under Windows. Used for internal
2934wxWindows errors. See also \helpref{wxFatalError}{wxfatalerror}.
2935
2936\wxheading{Include files}
2937
2938<wx/utils.h>
2939
2940\membersection{::wxFatalError}\label{wxfatalerror}
2941
2942\func{void}{wxFatalError}{\param{const wxString\& }{msg}, \param{const wxString\& }{title = "wxWindows Fatal Error"}}
2943
2944This function is now obsolete, please use
2945\helpref{wxLogFatalError}{wxlogfatalerror} instead.
2946
2947Displays {\it msg} and exits. This writes to standard error under Unix,
2948and pops up a message box under Windows. Used for fatal internal
2949wxWindows errors. See also \helpref{wxError}{wxerror}.
2950
2951\wxheading{Include files}
2952
2953<wx/utils.h>
2954
6fb26ea3
JS
2955\membersection{::wxLogError}\label{wxlogerror}
2956
7ac13b21 2957\func{void}{wxLogError}{\param{const char *}{formatString}, \param{...}{}}
6fb26ea3 2958
1d63fd6b
GD
2959\func{void}{wxVLogError}{\param{const char *}{formatString}, \param{va\_list }{argPtr}}
2960
ea44a631 2961The functions to use for error messages, i.e. the messages that must be shown
f68586e5
VZ
2962to the user. The default processing is to pop up a message box to inform the
2963user about it.
6fb26ea3
JS
2964
2965\membersection{::wxLogFatalError}\label{wxlogfatalerror}
2966
7ac13b21 2967\func{void}{wxLogFatalError}{\param{const char *}{formatString}, \param{...}{}}
6fb26ea3 2968
1d63fd6b
GD
2969\func{void}{wxVLogFatalError}{\param{const char *}{formatString}, \param{va\_list }{argPtr}}
2970
6fb26ea3
JS
2971Like \helpref{wxLogError}{wxlogerror}, but also
2972terminates the program with the exit code 3. Using {\it abort()} standard
2973function also terminates the program with this exit code.
2974
2975\membersection{::wxLogWarning}\label{wxlogwarning}
2976
7ac13b21 2977\func{void}{wxLogWarning}{\param{const char *}{formatString}, \param{...}{}}
6fb26ea3 2978
1d63fd6b
GD
2979\func{void}{wxVLogWarning}{\param{const char *}{formatString}, \param{va\_list }{argPtr}}
2980
f68586e5
VZ
2981For warnings - they are also normally shown to the user, but don't interrupt
2982the program work.
6fb26ea3
JS
2983
2984\membersection{::wxLogMessage}\label{wxlogmessage}
2985
7ac13b21 2986\func{void}{wxLogMessage}{\param{const char *}{formatString}, \param{...}{}}
6fb26ea3 2987
1d63fd6b
GD
2988\func{void}{wxVLogMessage}{\param{const char *}{formatString}, \param{va\_list }{argPtr}}
2989
ea44a631 2990For all normal, informational messages. They also appear in a message box by
f68586e5
VZ
2991default (but it can be changed). Notice that the standard behaviour is to not
2992show informational messages if there are any errors later - the logic being
2993that the later error messages make the informational messages preceding them
2994meaningless.
6fb26ea3
JS
2995
2996\membersection{::wxLogVerbose}\label{wxlogverbose}
2997
7ac13b21
GT
2998\func{void}{wxLogVerbose}{\param{const char *}{formatString}, \param{...}{}}
2999
1d63fd6b 3000\func{void}{wxVLogVerbose}{\param{const char *}{formatString}, \param{va\_list }{argPtr}}
6fb26ea3 3001
f6bcfd97 3002For verbose output. Normally, it is suppressed, but
6fb26ea3
JS
3003might be activated if the user wishes to know more details about the program
3004progress (another, but possibly confusing name for the same function is {\bf wxLogInfo}).
3005
3006\membersection{::wxLogStatus}\label{wxlogstatus}
3007
7ac13b21 3008\func{void}{wxLogStatus}{\param{wxFrame *}{frame}, \param{const char *}{formatString}, \param{...}{}}
f68586e5 3009
1d63fd6b 3010\func{void}{wxVLogStatus}{\param{wxFrame *}{frame}, \param{const char *}{formatString}, \param{va\_list }{argPtr}}
7ac13b21
GT
3011
3012\func{void}{wxLogStatus}{\param{const char *}{formatString}, \param{...}{}}
6fb26ea3 3013
1d63fd6b
GD
3014\func{void}{wxVLogStatus}{\param{const char *}{formatString}, \param{va\_list }{argPtr}}
3015
ea44a631 3016Messages logged by these functions will appear in the statusbar of the {\it
f68586e5 3017frame} or of the top level application window by default (i.e. when using
ea44a631 3018the second version of the functions).
f68586e5
VZ
3019
3020If the target frame doesn't have a statusbar, the message will be lost.
6fb26ea3
JS
3021
3022\membersection{::wxLogSysError}\label{wxlogsyserror}
3023
7ac13b21
GT
3024\func{void}{wxLogSysError}{\param{const char *}{formatString}, \param{...}{}}
3025
1d63fd6b 3026\func{void}{wxVLogSysError}{\param{const char *}{formatString}, \param{va\_list }{argPtr}}
6fb26ea3 3027
f68586e5
VZ
3028Mostly used by wxWindows itself, but might be handy for logging errors after
3029system call (API function) failure. It logs the specified message text as well
3030as the last system error code ({\it errno} or {\it ::GetLastError()} depending
3031on the platform) and the corresponding error message. The second form
f6bcfd97 3032of this function takes the error code explicitly as the first argument.
6fb26ea3 3033
6d516e09
VZ
3034\wxheading{See also}
3035
3036\helpref{wxSysErrorCode}{wxsyserrorcode},
3037\helpref{wxSysErrorMsg}{wxsyserrormsg}
3038
6fb26ea3
JS
3039\membersection{::wxLogDebug}\label{wxlogdebug}
3040
7ac13b21
GT
3041\func{void}{wxLogDebug}{\param{const char *}{formatString}, \param{...}{}}
3042
1d63fd6b 3043\func{void}{wxVLogDebug}{\param{const char *}{formatString}, \param{va\_list }{argPtr}}
6fb26ea3 3044
ea44a631
GD
3045The right functions for debug output. They only do something in debug
3046mode (when the preprocessor symbol \_\_WXDEBUG\_\_ is defined) and expand to
f68586e5 3047nothing in release mode (otherwise).
6fb26ea3
JS
3048
3049\membersection{::wxLogTrace}\label{wxlogtrace}
3050
7ac13b21 3051\func{void}{wxLogTrace}{\param{const char *}{formatString}, \param{...}{}}
1d63fd6b
GD
3052
3053\func{void}{wxVLogTrace}{\param{const char *}{formatString}, \param{va\_list }{argPtr}}
6fb26ea3 3054
f68586e5 3055\func{void}{wxLogTrace}{\param{const char *}{mask}, \param{const char *}{formatString}, \param{...}{}}
7ac13b21 3056
1d63fd6b 3057\func{void}{wxVLogTrace}{\param{const char *}{mask}, \param{const char *}{formatString}, \param{va\_list }{argPtr}}
f68586e5
VZ
3058
3059\func{void}{wxLogTrace}{\param{wxTraceMask}{ mask}, \param{const char *}{formatString}, \param{...}{}}
7ac13b21 3060
1d63fd6b 3061\func{void}{wxVLogTrace}{\param{wxTraceMask}{ mask}, \param{const char *}{formatString}, \param{va\_list }{argPtr}}
f68586e5
VZ
3062
3063As {\bf wxLogDebug}, trace functions only do something in debug build and
3064expand to nothing in the release one. The reason for making
3065it a separate function from it is that usually there are a lot of trace
3066messages, so it might make sense to separate them from other debug messages.
3067
3068The trace messages also usually can be separated into different categories and
ec5d7799 3069the second and third versions of this function only log the message if the
f68586e5
VZ
3070{\it mask} which it has is currently enabled in \helpref{wxLog}{wxlog}. This
3071allows to selectively trace only some operations and not others by changing
3072the value of the trace mask (possible during the run-time).
3073
3074For the second function (taking a string mask), the message is logged only if
ec5d7799 3075the mask has been previously enabled by the call to
f68586e5
VZ
3076\helpref{AddTraceMask}{wxlogaddtracemask}. The predefined string trace masks
3077used by wxWindows are:
3078
3079\begin{itemize}\itemsep=0pt
3080\item wxTRACE\_MemAlloc: trace memory allocation (new/delete)
3081\item wxTRACE\_Messages: trace window messages/X callbacks
3082\item wxTRACE\_ResAlloc: trace GDI resource allocation
3083\item wxTRACE\_RefCount: trace various ref counting operations
3084\item wxTRACE\_OleCalls: trace OLE method calls (Win32 only)
3085\end{itemize}
6fb26ea3 3086
f68586e5
VZ
3087The third version of the function only logs the message if all the bit
3088corresponding to the {\it mask} are set in the wxLog trace mask which can be
3089set by \helpref{SetTraceMask}{wxlogsettracemask}. This version is less
3090flexible than the previous one because it doesn't allow defining the user
3091trace masks easily - this is why it is deprecated in favour of using string
3092trace masks.
6fb26ea3
JS
3093
3094\begin{itemize}\itemsep=0pt
3095\item wxTraceMemAlloc: trace memory allocation (new/delete)
3096\item wxTraceMessages: trace window messages/X callbacks
3097\item wxTraceResAlloc: trace GDI resource allocation
3098\item wxTraceRefCount: trace various ref counting operations
f68586e5 3099\item wxTraceOleCalls: trace OLE method calls (Win32 only)
6fb26ea3
JS
3100\end{itemize}
3101
6d516e09
VZ
3102\membersection{::wxSysErrorCode}\label{wxsyserrorcode}
3103
3104\func{unsigned long}{wxSysErrorCode}{\void}
3105
3106Returns the error code from the last system call. This function uses
3107{\tt errno} on Unix platforms and {\tt GetLastError} under Win32.
3108
3109\wxheading{See also}
3110
3111\helpref{wxSysErrorMsg}{wxsyserrormsg},
3112\helpref{wxLogSysError}{wxlogsyserror}
3113
3114\membersection{::wxSysErrorMsg}\label{wxsyserrormsg}
3115
3116\func{const wxChar *}{wxSysErrorMsg}{\param{unsigned long }{errCode = 0}}
3117
ec5d7799
RD
3118Returns the error message corresponding to the given system error code. If
3119{\it errCode} is $0$ (default), the last error code (as returned by
6d516e09
VZ
3120\helpref{wxSysErrorCode}{wxsyserrorcode}) is used.
3121
3122\wxheading{See also}
3123
3124\helpref{wxSysErrorCode}{wxsyserrorcode},
3125\helpref{wxLogSysError}{wxlogsyserror}
3126
b0fc8832
VZ
3127\membersection{WXTRACE}\label{trace}
3128
3129\wxheading{Include files}
3130
3131<wx/object.h>
3132
3133\func{}{WXTRACE}{formatString, ...}
3134
3135Calls wxTrace with printf-style variable argument syntax. Output
3136is directed to the current output stream (see \helpref{wxDebugContext}{wxdebugcontextoverview}).
3137
3138This macro is now obsolete, replaced by \helpref{Log functions}{logfunctions}.
3139
3140\wxheading{Include files}
3141
3142<wx/memory.h>
3143
3144\membersection{WXTRACELEVEL}\label{tracelevel}
3145
3146\func{}{WXTRACELEVEL}{level, formatString, ...}
3147
3148Calls wxTraceLevel with printf-style variable argument syntax. Output
3149is directed to the current output stream (see \helpref{wxDebugContext}{wxdebugcontextoverview}).
3150The first argument should be the level at which this information is appropriate.
3151It will only be output if the level returned by wxDebugContext::GetLevel is equal to or greater than
3152this value.
3153
3154This function is now obsolete, replaced by \helpref{Log functions}{logfunctions}.
3155
3156\wxheading{Include files}
3157
3158<wx/memory.h>
3159
3160\membersection{::wxTrace}\label{wxtrace}
3161
3162\func{void}{wxTrace}{\param{const wxString\& }{fmt}, \param{...}{}}
3163
3164Takes printf-style variable argument syntax. Output
3165is directed to the current output stream (see \helpref{wxDebugContext}{wxdebugcontextoverview}).
3166
3167This function is now obsolete, replaced by \helpref{Log functions}{logfunctions}.
3168
3169\wxheading{Include files}
3170
3171<wx/memory.h>
3172
3173\membersection{::wxTraceLevel}\label{wxtracelevel}
3174
3175\func{void}{wxTraceLevel}{\param{int}{ level}, \param{const wxString\& }{fmt}, \param{...}{}}
3176
3177Takes printf-style variable argument syntax. Output
3178is directed to the current output stream (see \helpref{wxDebugContext}{wxdebugcontextoverview}).
3179The first argument should be the level at which this information is appropriate.
3180It will only be output if the level returned by wxDebugContext::GetLevel is equal to or greater than
3181this value.
3182
3183This function is now obsolete, replaced by \helpref{Log functions}{logfunctions}.
3184
3185\wxheading{Include files}
3186
3187<wx/memory.h>
3188
f6bcfd97
BP
3189\section{Time functions}\label{timefunctions}
3190
3191The functions in this section deal with getting the current time and
3192starting/stopping the global timers. Please note that the timer functions are
ec5d7799 3193deprecated because they work with one global timer only and
f6bcfd97 3194\helpref{wxTimer}{wxtimer} and/or \helpref{wxStopWatch}{wxstopwatch} classes
ec5d7799
RD
3195should be used instead. For retrieving the current time, you may also use
3196\helpref{wxDateTime::Now}{wxdatetimenow} or
f6bcfd97
BP
3197\helpref{wxDateTime::UNow}{wxdatetimeunow} methods.
3198
3199\membersection{::wxGetElapsedTime}\label{wxgetelapsedtime}
3200
3201\func{long}{wxGetElapsedTime}{\param{bool}{ resetTimer = TRUE}}
3202
3203Gets the time in milliseconds since the last \helpref{::wxStartTimer}{wxstarttimer}.
3204
3205If {\it resetTimer} is TRUE (the default), the timer is reset to zero
3206by this call.
3207
3208See also \helpref{wxTimer}{wxtimer}.
3209
3210\wxheading{Include files}
3211
3212<wx/timer.h>
3213
3214\membersection{::wxGetLocalTime}\label{wxgetlocaltime}
3215
3216\func{long}{wxGetLocalTime}{\void}
3217
3218Returns the number of seconds since local time 00:00:00 Jan 1st 1970.
3219
3220\wxheading{See also}
3221
3222\helpref{wxDateTime::Now}{wxdatetimenow}
3223
3224\wxheading{Include files}
3225
3226<wx/timer.h>
3227
3228\membersection{::wxGetLocalTimeMillis}\label{wxgetlocaltimemillis}
3229
3230\func{wxLongLone}{wxGetLocalTimeMillis}{\void}
3231
3232Returns the number of milliseconds since local time 00:00:00 Jan 1st 1970.
3233
3234\wxheading{See also}
3235
3236\helpref{wxDateTime::Now}{wxdatetimenow},\\
3237\helpref{wxLongLone}{wxlonglong}
3238
3239\wxheading{Include files}
3240
3241<wx/timer.h>
3242
3243\membersection{::wxGetUTCTime}\label{wxgetutctime}
3244
3245\func{long}{wxGetUTCTime}{\void}
3246
3247Returns the number of seconds since GMT 00:00:00 Jan 1st 1970.
3248
3249\wxheading{See also}
3250
3251\helpref{wxDateTime::Now}{wxdatetimenow}
3252
3253\wxheading{Include files}
3254
3255<wx/timer.h>
3256
b0fc8832
VZ
3257\membersection{::wxNow}\label{wxnow}
3258
3259\func{wxString}{wxNow}{\void}
3260
3261Returns a string representing the current date and time.
3262
3263\wxheading{Include files}
3264
3265<wx/utils.h>
3266
3267\membersection{::wxSleep}\label{wxsleep}
3268
3269\func{void}{wxSleep}{\param{int}{ secs}}
3270
3271Sleeps for the specified number of seconds.
3272
3273\wxheading{Include files}
3274
3275<wx/utils.h>
3276
f6bcfd97
BP
3277\membersection{::wxStartTimer}\label{wxstarttimer}
3278
3279\func{void}{wxStartTimer}{\void}
3280
3281Starts a stopwatch; use \helpref{::wxGetElapsedTime}{wxgetelapsedtime} to get the elapsed time.
3282
3283See also \helpref{wxTimer}{wxtimer}.
3284
3285\wxheading{Include files}
3286
3287<wx/timer.h>
3288
b0fc8832
VZ
3289\membersection{::wxUsleep}\label{wxusleep}
3290
3291\func{void}{wxUsleep}{\param{unsigned long}{ milliseconds}}
3292
3293Sleeps for the specified number of milliseconds. Notice that usage of this
3294function is encouraged instead of calling usleep(3) directly because the
3295standard usleep() function is not MT safe.
3296
3297\wxheading{Include files}
3298
3299<wx/utils.h>
3300
6fb26ea3
JS
3301\section{Debugging macros and functions}\label{debugmacros}
3302
f6bcfd97 3303Useful macros and functions for error checking and defensive programming. ASSERTs are only
6fb26ea3
JS
3304compiled if \_\_WXDEBUG\_\_ is defined, whereas CHECK macros stay in release
3305builds.
3306
954b8ae6
JS
3307\wxheading{Include files}
3308
3309<wx/debug.h>
3310
6fb26ea3
JS
3311\membersection{::wxOnAssert}\label{wxonassert}
3312
7ac13b21 3313\func{void}{wxOnAssert}{\param{const char *}{fileName}, \param{int}{ lineNumber}, \param{const char *}{msg = NULL}}
6fb26ea3
JS
3314
3315This function may be redefined to do something non trivial and is called
3316whenever one of debugging macros fails (i.e. condition is false in an
5b6aa0ff
JS
3317assertion).
3318% TODO: this should probably be an overridable in wxApp.
6fb26ea3
JS
3319
3320\membersection{wxASSERT}\label{wxassert}
3321
3322\func{}{wxASSERT}{\param{}{condition}}
3323
b207457c
VZ
3324Assert macro. An error message will be generated if the condition is FALSE in
3325debug mode, but nothing will be done in the release build.
3326
3327Please note that the condition in wxASSERT() should have no side effects
3328because it will not be executed in release mode at all.
3329
3330See also: \helpref{wxASSERT\_MSG}{wxassertmsg}
6fb26ea3
JS
3331
3332\membersection{wxASSERT\_MSG}\label{wxassertmsg}
3333
3334\func{}{wxASSERT\_MSG}{\param{}{condition}, \param{}{msg}}
3335
3336Assert macro with message. An error message will be generated if the condition is FALSE.
3337
b207457c
VZ
3338See also: \helpref{wxASSERT}{wxassert}
3339
6fb26ea3
JS
3340\membersection{wxFAIL}\label{wxfail}
3341
b207457c 3342\func{}{wxFAIL}{\void}
6fb26ea3
JS
3343
3344Will always generate an assert error if this code is reached (in debug mode).
3345
b207457c
VZ
3346See also: \helpref{wxFAIL\_MSG}{wxfailmsg}
3347
6fb26ea3
JS
3348\membersection{wxFAIL\_MSG}\label{wxfailmsg}
3349
b207457c 3350\func{}{wxFAIL\_MSG}{\param{}{msg}}
6fb26ea3
JS
3351
3352Will always generate an assert error with specified message if this code is reached (in debug mode).
3353
b207457c
VZ
3354This macro is useful for marking unreachable" code areas, for example
3355it may be used in the "default:" branch of a switch statement if all possible
3356cases are processed above.
3357
3358See also: \helpref{wxFAIL}{wxfail}
3359
6fb26ea3
JS
3360\membersection{wxCHECK}\label{wxcheck}
3361
3362\func{}{wxCHECK}{\param{}{condition}, \param{}{retValue}}
3363
3364Checks that the condition is true, returns with the given return value if not (FAILs in debug mode).
3365This check is done even in release mode.
3366
3367\membersection{wxCHECK\_MSG}\label{wxcheckmsg}
3368
3369\func{}{wxCHECK\_MSG}{\param{}{condition}, \param{}{retValue}, \param{}{msg}}
3370
3371Checks that the condition is true, returns with the given return value if not (FAILs in debug mode).
3372This check is done even in release mode.
3373
ec5d7799 3374This macro may be only used in non void functions, see also
b207457c
VZ
3375\helpref{wxCHECK\_RET}{wxcheckret}.
3376
3377\membersection{wxCHECK\_RET}\label{wxcheckret}
3378
3379\func{}{wxCHECK\_RET}{\param{}{condition}, \param{}{msg}}
3380
3381Checks that the condition is true, and returns if not (FAILs with given error
3382message in debug mode). This check is done even in release mode.
3383
ec5d7799 3384This macro should be used in void functions instead of
b207457c
VZ
3385\helpref{wxCHECK\_MSG}{wxcheckmsg}.
3386
3387\membersection{wxCHECK2}\label{wxcheck2}
3388
3389\func{}{wxCHECK2}{\param{}{condition}, \param{}{operation}}
3390
ec5d7799
RD
3391Checks that the condition is true and \helpref{wxFAIL}{wxfail} and execute
3392{\it operation} if it is not. This is a generalisation of
b207457c
VZ
3393\helpref{wxCHECK}{wxcheck} and may be used when something else than just
3394returning from the function must be done when the {\it condition} is false.
3395
3396This check is done even in release mode.
3397
3398\membersection{wxCHECK2\_MSG}\label{wxcheck2msg}
3399
3400\func{}{wxCHECK2}{\param{}{condition}, \param{}{operation}, \param{}{msg}}
3401
ec5d7799 3402This is the same as \helpref{wxCHECK2}{wxcheck2}, but
b207457c
VZ
3403\helpref{wxFAIL\_MSG}{wxfailmsg} with the specified {\it msg} is called
3404instead of wxFAIL() if the {\it condition} is false.
3405
b0fc8832
VZ
3406\membersection{::wxTrap}\label{wxtrap}
3407
3408\func{void}{wxTrap}{\void}
3409
3410In debug mode (when {\tt \_\_WXDEBUG\_\_} is defined) this function generates a
3411debugger exception meaning that the control is passed to the debugger if one is
3412attached to the process. Otherwise the program just terminates abnormally.
3413
3414In release mode this function does nothing.
3415
3416\wxheading{Include files}
3417
3418<wx/debug.h>
3419
5807634c
VZ
3420\section{Environment access functions}\label{environfunctions}
3421
3422The functions in this section allow to access (get) or change value of
3423environment variables in a portable way. They are currently implemented under
3424Win32 and POSIX-like systems (Unix).
3425
3426% TODO add some stuff about env var inheriting but not propagating upwards (VZ)
3427
3428\wxheading{Include files}
3429
3430<wx/utils.h>
3431
308978f6 3432\membersection{wxGetenv}\label{wxgetenvmacro}
5807634c
VZ
3433
3434\func{wxChar *}{wxGetEnv}{\param{const wxString\&}{ var}}
3435
308978f6
VZ
3436This is a macro defined as {\tt getenv()} or its wide char version in Unicode
3437mode.
3438
3439Note that under Win32 it may not return correct value for the variables set
3440with \helpref{wxSetEnv}{wxsetenv}, use \helpref{wxGetEnv}{wxgetenv} function
3441instead.
3442
3443\membersection{wxGetEnv}\label{wxgetenv}
3444
3445\func{bool}{wxGetEnv}{\param{const wxString\&}{ var}, \param{wxString *}{value}}
3446
3447Returns the current value of the environment variable {\it var} in {\it value}.
3448{\it value} may be {\tt NULL} if you just want to know if the variable exists
3449and are not interested in its value.
3450
3451Returns {\tt TRUE} if the variable exists, {\tt FALSE} otherwise.
5807634c
VZ
3452
3453\membersection{wxSetEnv}\label{wxsetenv}
3454
3455\func{bool}{wxSetEnv}{\param{const wxString\&}{ var}, \param{const wxChar *}{value}}
3456
3457Sets the value of the environment variable {\it var} (adding it if necessary)
3458to {\it value}.
3459
3460Returns {\tt TRUE} on success.
3461
3462\membersection{wxUnsetEnv}\label{wxunsetenv}
3463
3464\func{bool}{wxUnsetEnv}{\param{const wxString\&}{ var}}
3465
ec5d7799 3466Removes the variable {\it var} from the environment.
5df6ed1c 3467\helpref{wxGetEnv}{wxgetenv} will return {\tt NULL} after the call to this
5807634c
VZ
3468function.
3469
3470Returns {\tt TRUE} on success.
3471