]> granicus.if.org Git - python/commitdiff
Issue #24570: Right-click for context menus now work on Mac Aqual also.
authorTerry Jan Reedy <tjreedy@udel.edu>
Wed, 23 Sep 2015 01:10:27 +0000 (21:10 -0400)
committerTerry Jan Reedy <tjreedy@udel.edu>
Wed, 23 Sep 2015 01:10:27 +0000 (21:10 -0400)
Patch by Mark Roseman.

Lib/idlelib/EditorWindow.py
Lib/idlelib/PyShell.py

index 496eecdbbb2f816cb239f36305b5188cc8725206..dacb84357aec2b2f8b5ebcf27c7cd7b6b3d6d72b 100644 (file)
@@ -175,13 +175,13 @@ class EditorWindow(object):
         if macosxSupport.isAquaTk():
             # Command-W on editorwindows doesn't work without this.
             text.bind('<<close-window>>', self.close_event)
-            # Some OS X systems have only one mouse button,
-            # so use control-click for pulldown menus there.
-            #  (Note, AquaTk defines <2> as the right button if
-            #   present and the Tk Text widget already binds <2>.)
+            # Some OS X systems have only one mouse button, so use
+            # control-click for popup context menus there. For two
+            # buttons, AquaTk defines <2> as the right button, not <3>.
             text.bind("<Control-Button-1>",self.right_menu_event)
+            text.bind("<2>", self.right_menu_event)
         else:
-            # Elsewhere, use right-click for pulldown menus.
+            # Elsewhere, use right-click for popup menus.
             text.bind("<3>",self.right_menu_event)
         text.bind("<<cut>>", self.cut)
         text.bind("<<copy>>", self.copy)
index 90fc689e9dda18a7d6e038713f06ab7064d5c021..4a68b198dc2e32671b0bdb26d832d27f5e927730 100755 (executable)
@@ -1547,6 +1547,14 @@ def main():
     root.withdraw()
     flist = PyShellFileList(root)
     macosxSupport.setupApp(root, flist)
+    
+    if macosxSupport.isAquaTk():
+        # There are some screwed up <2> class bindings for text
+        # widgets defined in Tk which we need to do away with.
+        # See issue #24801.
+        root.unbind_class('Text', '<B2>')
+        root.unbind_class('Text', '<B2-Motion>')
+        root.unbind_class('Text', '<<PasteSelection>>')
 
     if enable_edit:
         if not (cmd or script):