X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/90a1a975d4f1c07b53e0f70df7cde32ab1d84f53..12ac619f42b81420980aec14afc9433af6f911dc:/docs/latex/wx/tapp.tex diff --git a/docs/latex/wx/tapp.tex b/docs/latex/wx/tapp.tex index 563b3d085b..04447cc9c1 100644 --- a/docs/latex/wx/tapp.tex +++ b/docs/latex/wx/tapp.tex @@ -7,7 +7,7 @@ A wxWindows application does not have a {\it main} procedure; the equivalent is \rtfsp{\it OnInit} will usually create a top window as a bare minimum. Unlike in earlier versions of wxWindows, OnInit does not return a frame. Instead it -returns a boolean value which indicates whether processing should continue (TRUE) or not (FALSE). +returns a boolean value which indicates whether processing should continue (true) or not (false). You call \helpref{wxApp::SetTopWindow}{wxappsettopwindow} to let wxWindows know about the top window. @@ -22,7 +22,8 @@ is to explicitly delete child frames in the top-level frame's \helpref{wxCloseEv handler. In emergencies the \helpref{wxExit}{wxexit} function can be called to kill the -application. +application however normally the applications shuts down automatically, +\helpref{see below}{wxappshutdownoverview}. An example of defining an application follows: @@ -39,10 +40,10 @@ bool DerivedApp::OnInit() { wxFrame *the_frame = new wxFrame(NULL, ID_MYFRAME, argv[0]); ... - the_frame->Show(TRUE); + the_frame->Show(true); SetTopWindow(the_frame); - return TRUE; + return true; } \end{verbatim} @@ -53,13 +54,29 @@ because required global initialization may not have been performed at applicatio construction time. You can also use DECLARE\_APP(appClass) in a header file to declare the wxGetApp function which returns -a reference to the application object. +a reference to the application object. Otherwise you can only use the global +\texttt{wxTheApp} pointer which is of type \texttt{wxApp *}. -\subsection{Application shutdown} -\helpref{OnExit}{wxapponexit} is called when the application exits but {\it before} -wxWindows cleans its internal structures. Your should delete all wxWindows object that -your created by the time OnExit finishes. In particular, do {\bf not} destroy them +\subsection{Application shutdown}\label{wxappshutdownoverview} + +The application normally shuts down when the last of its top level windows is +closed. This is normally the expected behaviour and means that it is enough to +call \helpref{Close()}{wxwindowclose} in response to the {\tt "Exit"} menu +command if your program has a single top level window. If this behaviour is not +desirable \helpref{wxApp::SetExitOnFrameDelete}{wxappsetexitonframedelete} can +be called to change it. Note that starting from wxWindows 2.3.3 such logic +doesn't apply for the windows shown before the program enters the main loop: in +other words, you can safely show a dialog from +\helpref{wxApp::OnInit}{wxapponinit} and not be afraid that your application +terminates when this dialog -- which is the last top level window for the +moment -- is closed. + + +Another aspect of the application shutdown is the \helpref{OnExit}{wxapponexit} +which is called when the application exits but {\it before} wxWindows cleans up +its internal structures. Your should delete all wxWindows object that your +created by the time OnExit finishes. In particular, do {\bf not} destroy them from application class' destructor! For example, this code may crash: