File: wx.ModalDialogHook.txt

package info (click to toggle)
wxpython4.0 4.0.4%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 211,112 kB
  • sloc: cpp: 888,355; python: 223,130; makefile: 52,087; ansic: 45,780; sh: 3,012; xml: 1,534; perl: 264
file content (234 lines) | stat: -rw-r--r-- 7,569 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
.. wxPython Phoenix documentation

   This file was generated by Phoenix's sphinx generator and associated
   tools, do not edit by hand.

   Copyright: (c) 2011-2018 by Total Control Software
   License:   wxWindows License

.. include:: headings.inc



.. _wx.ModalDialogHook:

==========================================================================================================================================
|phoenix_title|  **wx.ModalDialogHook**
==========================================================================================================================================

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. :ref:`wx.ModalDialogHook`  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 :meth:`~wx.ModalDialogHook.Enter`  method. Then simply create an object of your class and call :meth:`~wx.ModalDialogHook.Register`  on it to start receiving calls to your overridden :meth:`~wx.ModalDialogHook.Enter`  (and possibly :ref:`wx.Exit`) methods: ::

    class MyModalDialogHook(wx.ModalDialogHook):

        def __init__(self, parent):

            wx.ModalDialogHook.__init__(self, parent)


        def Enter(self, dialog):

            # Just for demonstration purposes, intercept all uses of
            # wx.FileDialog. Notice that self doesn't provide any real
            # sandboxing, of course, the program can still read and write
            # files by not using wx.FileDialog to ask the user for their
            # names.
            if isinstance(dialog, wx.FileDialog):

                wx.LogError("Access to file system disallowed.")

                # Skip showing the file dialog entirely.
                return wx.ID_CANCEL


            self.lastEnter = wx.DateTime.Now()

            # Allow the dialog to be shown as usual.
            return wx.ID_NONE


        def Exit(self, dialog):

            # Again, just for demonstration purposes, show how long did
            # the user take to dismiss the dialog. Notice that we
            # shouldn't use wx.LogMessage() here as self would result in
            # another modal dialog call and hence infinite recursion. In
            # general, the hooks should be as unintrusive as possible.
            wx.LogDebug("%s dialog took %s to be dismissed",
                       dialog.GetClassInfo().GetClassName(),
                       (wx.DateTime.Now() - self.lastEnter).Format())



    if __name__ == '__main__':

        app = wx.App(0)
        self.myHook = MyModalDialogHook(None)
        self.myHook.Register()
        app.MainLoop()



         



.. versionadded:: 2.9.5 
     







|

|class_hierarchy| Class Hierarchy
=================================

.. raw:: html

   <div id="toggleBlock" onclick="return toggleVisibility(this)" class="closed" style="cursor:pointer;">
   <img id="toggleBlock-trigger" src="_static/images/closed.png"/>
   Inheritance diagram for class <strong>ModalDialogHook</strong>:
   </div>
   <div id="toggleBlock-summary" style="display:block;"></div>
   <div id="toggleBlock-content" style="display:none;">
   <p class="graphviz">
   <center><img src="_static/images/inheritance/wx.ModalDialogHook_inheritance.png" alt="Inheritance diagram of ModalDialogHook" usemap="#dummy" class="inheritance"/></center>
   </div>
   <script type="text/javascript">toggleVisibilityOnLoad(document.getElementById('toggleBlock'))</script>
   <map id="dummy" name="dummy"> <area shape="rect" id="node1" href="wx.ModalDialogHook.html" title="wx.ModalDialogHook" alt="" coords="5,5,157,35"/> </map> 
   </p>

|


|method_summary| Methods Summary
================================

================================================================================ ================================================================================
:meth:`~wx.ModalDialogHook.__init__`                                             Default and trivial constructor.
:meth:`~wx.ModalDialogHook.Enter`                                                Called by wxWidgets before showing any modal dialogs.
:meth:`~wx.ModalDialogHook.Exit`                                                 Called by wxWidgets after dismissing the modal dialog.
:meth:`~wx.ModalDialogHook.Register`                                             Register this hook as being active.
:meth:`~wx.ModalDialogHook.Unregister`                                           Unregister this hook.
================================================================================ ================================================================================


|


|api| Class API
===============


.. class:: wx.ModalDialogHook(object)

   **Possible constructors**::

       ModalDialogHook()
       
   
   Allows to intercept all modal dialog calls.



   .. method:: __init__(self)

      Default and trivial constructor.                  

      The constructor doesn't do anything, call :meth:`Register`   to make this hook active.                   





   .. method:: Enter(self, dialog)

      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 ``ID_NONE``, the dialog is shown as usual and :ref:`wx.Exit`  will be called when it is dismissed. If the return value is anything else, the dialog is not shown at all and its :meth:`wx.Dialog.ShowModal`   simply returns with the given result. In this case, :ref:`wx.Exit`  won't be called neither. 




      :param `dialog`: The dialog about to be shown, never ``None``.   
      :type `dialog`: wx.Dialog






      :rtype: `int`



                  



      :returns: 

         ``wx.ID_NONE`` to continue with showing the dialog or anything else to skip showing the dialog and just return this value from its ShowModal().   








   .. method:: Exit(self, dialog)

      Called by wxWidgets after dismissing the modal dialog.                  

      Notice that it won't be called if :meth:`Enter`   hadn't been called because another modal hook, registered after this one, intercepted the dialog or if our :meth:`Enter`   was called but returned a value different from ``ID_NONE``. 




      :param `dialog`: The dialog that was shown and dismissed, never ``None``.   
      :type `dialog`: wx.Dialog




                  





   .. method:: Register(self)

      Register this hook as being active.                  

      After registering the hook, its :meth:`Enter`   and :ref:`wx.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 :meth:`Enter`   returns a value different from ``ID_NONE``, the subsequent hooks are skipped. 

      It is an error to register the same hook twice.                   





   .. method:: Unregister(self)

      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.