#include <wx/modalhook.h>
Allows to intercept all modal dialog calls.
This class can be used to hook into normal modal dialog handling for some special needs. One of the most common use cases is for testing: as automatic tests can't continue if a modal dialog is shown while they run, this class can be used to avoid showing the modal dialogs during unattended execution. wxModalDialogHook can also be used for disabling some background operation while a modal dialog is shown.
To install a modal dialog hook, you need to derive your own class from this one and implement its pure virtual Enter() method. Then simply create an object of your class and call Register() on it to start receiving calls to your overridden Enter() (and possibly Exit()) methods:
Public Member Functions | |
wxModalDialogHook () | |
Default and trivial constructor. More... | |
virtual | ~wxModalDialogHook () |
Destructor unregisters the hook if it's currently active. More... | |
void | Register () |
Register this hook as being active. More... | |
void | Unregister () |
Unregister this hook. More... | |
Protected Member Functions | |
virtual int | Enter (wxDialog *dialog)=0 |
Called by wxWidgets before showing any modal dialogs. More... | |
virtual void | Exit (wxDialog *dialog) |
Called by wxWidgets after dismissing the modal dialog. More... | |
wxModalDialogHook::wxModalDialogHook | ( | ) |
Default and trivial constructor.
The constructor doesn't do anything, call Register() to make this hook active.
|
virtual |
Destructor unregisters the hook if it's currently active.
|
protectedpure virtual |
Called by wxWidgets before showing any modal dialogs.
Override this to be notified whenever a modal dialog is about to be shown.
If the return value of this method is wxID_NONE, the dialog is shown as usual and Exit() will be called when it is dismissed. If the return value is anything else, the dialog is not shown at all and its wxDialog::ShowModal() simply returns with the given result. In this case, Exit() won't be called neither.
dialog | The dialog about to be shown, never NULL. |
|
protectedvirtual |
Called by wxWidgets after dismissing the modal dialog.
Notice that it won't be called if Enter() hadn't been called because another modal hook, registered after this one, intercepted the dialog or if our Enter() was called but returned a value different from wxID_NONE.
dialog | The dialog that was shown and dismissed, never NULL. |
void wxModalDialogHook::Register | ( | ) |
Register this hook as being active.
After registering the hook, its Enter() and Exit() methods will be called whenever a modal dialog is shown.
Notice that the order of registration matters: the last hook registered is called first, and if its Enter() returns a value different from wxID_NONE, the subsequent hooks are skipped.
It is an error to register the same hook twice.
void wxModalDialogHook::Unregister | ( | ) |
Unregister this hook.
Notice that is done automatically from the destructor, so usually calling this method explicitly is unnecessary.
The hook must be currently registered.