summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristoph Reiter <reiter.christoph@gmail.com>2020-04-17 18:16:54 +0200
committerChristoph Reiter <reiter.christoph@gmail.com>2020-04-17 18:33:46 +0200
commit1a2bc1d0806ab6178f65125bf0b2283eb3378d4d (patch)
tree245594a7295200a98899ffd17a9b0ca5529a8056
parent4927856945899de09cfe99c052a83aec6e2f3c1a (diff)
downloadpygobject-1a2bc1d0806ab6178f65125bf0b2283eb3378d4d.tar.gz
get/set_focus_on_click: Fix return value, add a test and document why the override is there
Also make it conditional on the Gtk.Widget method existing since that was only added with gtk 3.20 and we support 3.18+.
-rw-r--r--gi/overrides/Gtk.py20
-rw-r--r--tests/test_overrides_gtk.py8
2 files changed, 19 insertions, 9 deletions
diff --git a/gi/overrides/Gtk.py b/gi/overrides/Gtk.py
index b797cf8c..64a5088e 100644
--- a/gi/overrides/Gtk.py
+++ b/gi/overrides/Gtk.py
@@ -1460,15 +1460,17 @@ class Button(Gtk.Button, Container):
else:
self._init(*args, **kwargs)
- def set_focus_on_click(self, focus_on_click):
- # Gtk.Button.set_focus_on_click is deprecated since version 3.20
- # Use Gtk.Widget.set_focus_on_click instead
- Gtk.Widget.set_focus_on_click(self, focus_on_click)
-
- def get_focus_on_click(self):
- # Gtk.Button.get_focus_on_click is deprecated since version 3.20
- # Use Gtk.Widget.get_focus_on_click instead
- Gtk.Widget.get_focus_on_click(self)
+ if hasattr(Gtk.Widget, "set_focus_on_click"):
+ def set_focus_on_click(self, *args, **kwargs):
+ # Gtk.Widget.set_focus_on_click should be used instead but it's
+ # no obvious how because of the shadowed method, so override here
+ return Gtk.Widget.set_focus_on_click(self, *args, **kwargs)
+
+ if hasattr(Gtk.Widget, "get_focus_on_click"):
+ def get_focus_on_click(self, *args, **kwargs):
+ # Gtk.Widget.get_focus_on_click should be used instead but it's
+ # no obvious how because of the shadowed method, so override here
+ return Gtk.Widget.get_focus_on_click(self, *args, **kwargs)
Button = override(Button)
diff --git a/tests/test_overrides_gtk.py b/tests/test_overrides_gtk.py
index 8ed9775e..ff3acba9 100644
--- a/tests/test_overrides_gtk.py
+++ b/tests/test_overrides_gtk.py
@@ -2793,3 +2793,11 @@ class TestContainer(unittest.TestCase):
self.assertEqual(expand, False)
self.assertEqual(fill, False)
self.assertEqual(padding, 21)
+
+
+def test_button_focus_on_click():
+ b = Gtk.Button()
+ b.set_focus_on_click(True)
+ assert b.get_focus_on_click()
+ b.set_focus_on_click(False)
+ assert not b.get_focus_on_click()