]> git.saurik.com Git - wxWidgets.git/blame - include/wx/modalhook.h
wxMessageBox off the main thread lost result code.
[wxWidgets.git] / include / wx / modalhook.h
CommitLineData
691745ab
VZ
1///////////////////////////////////////////////////////////////////////////////
2// Name: wx/modalhook.h
3// Purpose: Allows to hook into showing modal dialogs.
4// Author: Vadim Zeitlin
5// Created: 2013-05-19
691745ab
VZ
6// Copyright: (c) 2013 Vadim Zeitlin <vadim@wxwidgets.org>
7// Licence: wxWindows licence
8///////////////////////////////////////////////////////////////////////////////
9
10#ifndef _WX_MODALHOOK_H_
11#define _WX_MODALHOOK_H_
12
13#include "wx/vector.h"
14
15class WXDLLIMPEXP_FWD_CORE wxDialog;
16
17// ----------------------------------------------------------------------------
18// Class allowing to be notified about any modal dialog calls.
19// ----------------------------------------------------------------------------
20
21// To be notified about entering and exiting modal dialogs and possibly to
22// replace them with something else (e.g. just return a predefined value for
23// testing), define an object of this class, override its Enter() and
24// possibly Exit() methods and call Register() on it.
25class WXDLLIMPEXP_CORE wxModalDialogHook
26{
27public:
28 // Default ctor doesn't do anything, call Register() to activate the hook.
29 wxModalDialogHook() { }
30
31 // Dtor unregisters the hook if it had been registered.
32 virtual ~wxModalDialogHook() { DoUnregister(); }
33
34 // Register this hook as being active, i.e. its Enter() and Exit() methods
35 // will be called.
36 //
37 // Notice that the order of registration matters: the last hook registered
38 // is called first, and if its Enter() returns something != wxID_NONE, the
39 // subsequent hooks are skipped.
40 void Register();
41
42 // Unregister this hook. Notice that is done automatically from the dtor.
43 void Unregister();
44
45 // Called from wxWidgets code before showing any modal dialogs and calls
46 // Enter() for every registered hook.
47 static int CallEnter(wxDialog* dialog);
48
49 // Called from wxWidgets code after dismissing the dialog and calls Exit()
50 // for every registered hook.
51 static void CallExit(wxDialog* dialog);
52
53protected:
54 // Called by wxWidgets before showing any modal dialogs, override this to
55 // be notified about this and return anything but wxID_NONE to skip showing
56 // the modal dialog entirely and just return the specified result.
57 virtual int Enter(wxDialog* dialog) = 0;
58
59 // Called by wxWidgets after dismissing the modal dialog. Notice that it
60 // won't be called if Enter() hadn't been.
61 virtual void Exit(wxDialog* WXUNUSED(dialog)) { }
62
63private:
64 // Unregister the given hook, return true if it was done or false if the
65 // hook wasn't found.
66 bool DoUnregister();
67
68 // All the hooks in reverse registration order (i.e. in call order).
69 typedef wxVector<wxModalDialogHook*> Hooks;
70 static Hooks ms_hooks;
71
72 wxDECLARE_NO_COPY_CLASS(wxModalDialogHook);
73};
74
75// Helper object used by WX_MODAL_DIALOG_HOOK below to ensure that CallExit()
76// is called on scope exit.
77class wxModalDialogHookExitGuard
78{
79public:
80 wxEXPLICIT wxModalDialogHookExitGuard(wxDialog* dialog)
81 : m_dialog(dialog)
82 {
83 }
84
85 ~wxModalDialogHookExitGuard()
86 {
87 wxModalDialogHook::CallExit(m_dialog);
88 }
89
90private:
91 wxDialog* const m_dialog;
92
93 wxDECLARE_NO_COPY_CLASS(wxModalDialogHookExitGuard);
94};
95
96// This macro needs to be used at the top of every implementation of
97// ShowModal() in order for wxModalDialogHook to work.
98#define WX_HOOK_MODAL_DIALOG() \
99 const int modalDialogHookRC = wxModalDialogHook::CallEnter(this); \
100 if ( modalDialogHookRC != wxID_NONE ) \
101 return modalDialogHookRC; \
102 wxModalDialogHookExitGuard modalDialogHookExit(this)
103
104#endif // _WX_MODALHOOK_H_