%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %% Name: texcept.tex %% Purpose: C++ exceptions and wxWindows overview %% Author: Vadim Zeitlin %% Modified by: %% Created: 17.09.03 %% RCS-ID: $Id$ %% Copyright: (c) 2003 Vadim Zeitlin %% License: wxWindows license %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \section{C++ exceptions overview}\label{exceptionsoverview} \subsection{Introduction} wxWindows had been started long before the exceptions were introduced in C++ so it is not very surprizing that it is not built around using them as some more modern C++ libraries are. For instance, the library doesn't throw exceptions to signal about the errors. Moreover, up to (and including) the version 2.4 of wxWindows, even using the exceptions in the user code was dangerous because the library code wasn't exception-safe and so an exception propagating through it could result in memory and/or resource leaks, and also not very convenient. Starting from the version 2.5.1 wxWindows becomes more exception-friendly. It still doesn't use the exceptions by itself but it should be now safe to use the exceptions in the user code and the library tries to help you with this. Please note that making the library exception-safe is still work in progress. \subsection{Strategies for exceptions handling} There are several choice for using the exceptions in wxWindows programs. First of all, you may not use them at all. As stated above, the library doesn't throw any exceptions by itself and so you don't have to worry about exceptions at all unless your own code throws them. This is, of course, the simplest solution but may be not the best one to deal with all possible errors. Another strategy is to use exceptions only to signal truly fatal errors. In this case you probably don't expect to recover from them and the default behaviour -- to simply terminate the program -- may be appropriate. If it is not, you may override \helpref{OnUnhandledException()}{wxapponunhandledexception} in your wxApp-derived class to perform any clean up tasks. Note, however, that any information about the exact exception type is lost when this function is called, so if you need you should override \helpref{OnRun()}{wxapponrun} and add a try/catch clause around the call of the base class version. This would allow you to catch any exceptions generated during the execution of the main event loop. To deal with the exceptions which may arise during the program startup and/or shutdown you should insert try/catch clauses in \helpref{OnInit()}{wxapponinit} and/or \helpref{OnExit()}{wxapponexit} as well. Finally, you may also want to continue running even when certain exceptions occur. If all of your exceptions may happen only in the event handlers of a single class (or only in the classes derived from it), you may centralize your exception handling code in \helpref{ProcessEvent}{wxevthandlerprocessevent} method of this class. If this is impractical, you may also consider overriding the \helpref{wxApp::HandleEvent()}{wxapphandleevent} which allows you to handle all the exceptions thrown by any event handler. \subsection{Technicalities} To use any kind of exception support in the library you need to build it with \texttt{wxUSE\_EXCEPTIONS} set to $1$. This should be the case by default but if it isn't, you should edit the \texttt{include/wx/msw/setup.h} file under Windows or run \texttt{configure} with \texttt{--enable-exceptions} argument under Unix. On the other hand, if you do \emph{not} plan to use exceptions, setting this flag to $0$ or using \texttt{--disable-exceptions} could result in a leaner and slightly faster library. As for any other library feature, there is a \helpref{sample}{sampleexcept} showing how to use it. Please look at its sources for further information.