]> granicus.if.org Git - python/commitdiff
<Home> toggle failing on Tk 8.5, causing IDLE exits. Issue 3851.
authorKurt B. Kaiser <kbk@shore.net>
Fri, 25 Mar 2011 21:48:27 +0000 (17:48 -0400)
committerKurt B. Kaiser <kbk@shore.net>
Fri, 25 Mar 2011 21:48:27 +0000 (17:48 -0400)
Lib/idlelib/EditorWindow.py
Lib/idlelib/NEWS.txt

index 71b768f95a0f339abaf58351bc3290ed01a2a176..935a39f6c29da393a9a2b0e115b76e08f5ad710c 100644 (file)
@@ -310,10 +310,10 @@ class EditorWindow(object):
         if (event.state & 4) != 0 and event.keysym == "Home":
             # state&4==Control. If <Control-Home>, use the Tk binding.
             return
-
         if self.text.index("iomark") and \
            self.text.compare("iomark", "<=", "insert lineend") and \
            self.text.compare("insert linestart", "<=", "iomark"):
+            # In Shell on input line, go to just after prompt
             insertpt = int(self.text.index("iomark").split(".")[1])
         else:
             line = self.text.get("insert linestart", "insert lineend")
@@ -322,30 +322,27 @@ class EditorWindow(object):
                     break
             else:
                 insertpt=len(line)
-
         lineat = int(self.text.index("insert").split('.')[1])
-
         if insertpt == lineat:
             insertpt = 0
-
         dest = "insert linestart+"+str(insertpt)+"c"
-
         if (event.state&1) == 0:
-            # shift not pressed
+            # shift was not pressed
             self.text.tag_remove("sel", "1.0", "end")
         else:
             if not self.text.index("sel.first"):
-                self.text.mark_set("anchor","insert")
-
+                self.text.mark_set("my_anchor", "insert")  # there was no previous selection
+            else:
+                if self.text.compare(self.text.index("sel.first"), "<", self.text.index("insert")):
+                    self.text.mark_set("my_anchor", "sel.first") # extend back
+                else:
+                    self.text.mark_set("my_anchor", "sel.last") # extend forward
             first = self.text.index(dest)
-            last = self.text.index("anchor")
-
+            last = self.text.index("my_anchor")
             if self.text.compare(first,">",last):
                 first,last = last,first
-
             self.text.tag_remove("sel", "1.0", "end")
             self.text.tag_add("sel", first, last)
-
         self.text.mark_set("insert", dest)
         self.text.see("insert")
         return "break"
index 47ff097fa3ee4d8ed10d57cc5d8b7c41fd8a02db..5eac219b2f9884f3b8b50414fd1605d9e7a1d750 100644 (file)
@@ -3,7 +3,10 @@ What's New in IDLE 2.7.2?
 
 *Release date: XX-XX-XXXX*
 
-- <Home> toggle non-functional when NumLock set on Windows.  Issue3851.
+- <Home> toggle failing on Tk 8.5, causing IDLE exits and strange selection
+  behavior. Issue 4676.  Improve selection extension behaviour.
+- <Home> toggle non-functional when NumLock set on Windows.  Issue 3851.
+
 
 What's New in IDLE 2.7?
 =======================