[pygobject/ebassi/gtk4-overrides: 3/4] Add GTK4 override for GtkDialog




commit d49dcebd2a9b76b4dfaa694e16dd93a8f5bab7db
Author: Emmanuele Bassi <ebassi gnome org>
Date:   Fri Sep 11 17:47:26 2020 +0100

    Add GTK4 override for GtkDialog
    
    Drop all the deprecated compatibility layer for pygtk, and the
    inheritance from GtkContainer.

 gi/overrides/Gtk.py | 178 +++++++++++++++++++++++++++++++---------------------
 1 file changed, 105 insertions(+), 73 deletions(-)
---
diff --git a/gi/overrides/Gtk.py b/gi/overrides/Gtk.py
index 605b7851..46abcaf6 100644
--- a/gi/overrides/Gtk.py
+++ b/gi/overrides/Gtk.py
@@ -531,95 +531,127 @@ Window = override(Window)
 __all__.append('Window')
 
 
-class Dialog(Gtk.Dialog, Container):
-    _old_arg_names = ('title', 'parent', 'flags', 'buttons', '_buttons_property')
-    _init = deprecated_init(Gtk.Dialog.__init__,
-                            arg_names=('title', 'transient_for', 'flags',
-                                       'add_buttons', 'buttons'),
-                            ignore=('flags', 'add_buttons'),
-                            deprecated_aliases={'transient_for': 'parent',
-                                                'buttons': '_buttons_property'},
-                            category=PyGTKDeprecationWarning)
+if GTK4:
+    class Dialog(Gtk.Dialog):
+        def add_buttons(self, *args):
+            """
+            The add_buttons() method adds several buttons to the Gtk.Dialog using
+            the button data passed as arguments to the method. This method is the
+            same as calling the Gtk.Dialog.add_button() repeatedly. The button data
+            pairs - button text (or stock ID) and a response ID integer are passed
+            individually. For example:
 
-    def __init__(self, *args, **kwargs):
+            .. code-block:: python
 
-        new_kwargs = kwargs.copy()
-        old_kwargs = dict(zip(self._old_arg_names, args))
-        old_kwargs.update(kwargs)
-
-        # Increment the warning stacklevel for sub-classes which implement their own __init__.
-        stacklevel = 2
-        if self.__class__ != Dialog and self.__class__.__init__ != Dialog.__init__:
-            stacklevel += 1
-
-        # buttons was overloaded by PyGtk but is needed for Gtk.MessageDialog
-        # as a pass through, so type check the argument and give a deprecation
-        # when it is not of type Gtk.ButtonsType
-        add_buttons = old_kwargs.get('buttons', None)
-        if add_buttons is not None and not isinstance(add_buttons, Gtk.ButtonsType):
-            warnings.warn('The "buttons" argument must be a Gtk.ButtonsType enum value. '
-                          'Please use the "add_buttons" method for adding buttons. '
-                          'See: https://wiki.gnome.org/PyGObject/InitializerDeprecations',
-                          PyGTKDeprecationWarning, stacklevel=stacklevel)
-            new_kwargs.pop('buttons', None)
-        else:
-            add_buttons = None
+                dialog.add_buttons(Gtk.STOCK_OPEN, 42, "Close", Gtk.ResponseType.CLOSE)
 
-        flags = old_kwargs.get('flags', 0)
-        if flags:
-            warnings.warn('The "flags" argument for dialog construction is deprecated. '
-                          'Please use initializer keywords: modal=True and/or destroy_with_parent=True. '
-                          'See: https://wiki.gnome.org/PyGObject/InitializerDeprecations',
-                          PyGTKDeprecationWarning, stacklevel=stacklevel)
+            will add "Open" and "Close" buttons to dialog.
+            """
+            def _button(b):
+                while b:
+                    try:
+                        t, r = b[0:2]
+                    except ValueError:
+                        raise ValueError('Must pass an even number of arguments')
+                    b = b[2:]
+                    yield t, r
 
-            if flags & Gtk.DialogFlags.MODAL:
-                new_kwargs['modal'] = True
+            for text, response in _button(args):
+                self.add_button(text, response)
 
-            if flags & Gtk.DialogFlags.DESTROY_WITH_PARENT:
-                new_kwargs['destroy_with_parent'] = True
 
-        self._init(*args, **new_kwargs)
+    Dialog = override(Dialog)
+    __all__.append('Dialog')
+else:
+    class Dialog(Gtk.Dialog, Container):
+        _old_arg_names = ('title', 'parent', 'flags', 'buttons', '_buttons_property')
+        _init = deprecated_init(Gtk.Dialog.__init__,
+                                arg_names=('title', 'transient_for', 'flags',
+                                           'add_buttons', 'buttons'),
+                                ignore=('flags', 'add_buttons'),
+                                deprecated_aliases={'transient_for': 'parent',
+                                                    'buttons': '_buttons_property'},
+                                category=PyGTKDeprecationWarning)
 
-        if add_buttons:
-            self.add_buttons(*add_buttons)
+        def __init__(self, *args, **kwargs):
 
-    def run(self, *args, **kwargs):
-        with register_sigint_fallback(self.destroy):
-            with wakeup_on_signal():
-                return Gtk.Dialog.run(self, *args, **kwargs)
+            new_kwargs = kwargs.copy()
+            old_kwargs = dict(zip(self._old_arg_names, args))
+            old_kwargs.update(kwargs)
+
+            # Increment the warning stacklevel for sub-classes which implement their own __init__.
+            stacklevel = 2
+            if self.__class__ != Dialog and self.__class__.__init__ != Dialog.__init__:
+                stacklevel += 1
+
+            # buttons was overloaded by PyGtk but is needed for Gtk.MessageDialog
+            # as a pass through, so type check the argument and give a deprecation
+            # when it is not of type Gtk.ButtonsType
+            add_buttons = old_kwargs.get('buttons', None)
+            if add_buttons is not None and not isinstance(add_buttons, Gtk.ButtonsType):
+                warnings.warn('The "buttons" argument must be a Gtk.ButtonsType enum value. '
+                              'Please use the "add_buttons" method for adding buttons. '
+                              'See: https://wiki.gnome.org/PyGObject/InitializerDeprecations',
+                              PyGTKDeprecationWarning, stacklevel=stacklevel)
+                new_kwargs.pop('buttons', None)
+            else:
+                add_buttons = None
 
-    action_area = property(lambda dialog: dialog.get_action_area())
-    vbox = property(lambda dialog: dialog.get_content_area())
+            flags = old_kwargs.get('flags', 0)
+            if flags:
+                warnings.warn('The "flags" argument for dialog construction is deprecated. '
+                              'Please use initializer keywords: modal=True and/or destroy_with_parent=True. '
+                              'See: https://wiki.gnome.org/PyGObject/InitializerDeprecations',
+                              PyGTKDeprecationWarning, stacklevel=stacklevel)
 
-    def add_buttons(self, *args):
-        """
-        The add_buttons() method adds several buttons to the Gtk.Dialog using
-        the button data passed as arguments to the method. This method is the
-        same as calling the Gtk.Dialog.add_button() repeatedly. The button data
-        pairs - button text (or stock ID) and a response ID integer are passed
-        individually. For example:
+                if flags & Gtk.DialogFlags.MODAL:
+                    new_kwargs['modal'] = True
 
-        .. code-block:: python
+                if flags & Gtk.DialogFlags.DESTROY_WITH_PARENT:
+                    new_kwargs['destroy_with_parent'] = True
 
-            dialog.add_buttons(Gtk.STOCK_OPEN, 42, "Close", Gtk.ResponseType.CLOSE)
+            self._init(*args, **new_kwargs)
 
-        will add "Open" and "Close" buttons to dialog.
-        """
-        def _button(b):
-            while b:
-                try:
-                    t, r = b[0:2]
-                except ValueError:
-                    raise ValueError('Must pass an even number of arguments')
-                b = b[2:]
-                yield t, r
+            if add_buttons:
+                self.add_buttons(*add_buttons)
+
+        def run(self, *args, **kwargs):
+            with register_sigint_fallback(self.destroy):
+                with wakeup_on_signal():
+                    return Gtk.Dialog.run(self, *args, **kwargs)
+
+        action_area = property(lambda dialog: dialog.get_action_area())
+        vbox = property(lambda dialog: dialog.get_content_area())
+
+        def add_buttons(self, *args):
+            """
+            The add_buttons() method adds several buttons to the Gtk.Dialog using
+            the button data passed as arguments to the method. This method is the
+            same as calling the Gtk.Dialog.add_button() repeatedly. The button data
+            pairs - button text (or stock ID) and a response ID integer are passed
+            individually. For example:
+
+            .. code-block:: python
+
+                dialog.add_buttons(Gtk.STOCK_OPEN, 42, "Close", Gtk.ResponseType.CLOSE)
+
+            will add "Open" and "Close" buttons to dialog.
+            """
+            def _button(b):
+                while b:
+                    try:
+                        t, r = b[0:2]
+                    except ValueError:
+                        raise ValueError('Must pass an even number of arguments')
+                    b = b[2:]
+                    yield t, r
 
-        for text, response in _button(args):
-            self.add_button(text, response)
+            for text, response in _button(args):
+                self.add_button(text, response)
 
 
-Dialog = override(Dialog)
-__all__.append('Dialog')
+    Dialog = override(Dialog)
+    __all__.append('Dialog')
 
 
 class MessageDialog(Gtk.MessageDialog, Dialog):


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]