summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHirokazu Yamamoto <ocean-city@m2.ccsnet.ne.jp>2008-11-03 18:10:24 (GMT)
committerHirokazu Yamamoto <ocean-city@m2.ccsnet.ne.jp>2008-11-03 18:10:24 (GMT)
commitb2d8142ed1d0748ebbe44f1090ddaf2b6592facc (patch)
treebb5177355485d5f930b0c78293a739821e31d055
parenteeed0c78224078322ba5453607e770bad22b32db (diff)
downloadcpython-b2d8142ed1d0748ebbe44f1090ddaf2b6592facc.zip
cpython-b2d8142ed1d0748ebbe44f1090ddaf2b6592facc.tar.gz
cpython-b2d8142ed1d0748ebbe44f1090ddaf2b6592facc.tar.bz2
Merged revisions 67082 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r67082 | hirokazu.yamamoto | 2008-11-04 03:03:06 +0900 | 2 lines Issue #3774: Fixed an error when create a Tkinter menu item without command and then remove it. Written by Guilherme Polo (gpolo). ........
-rw-r--r--Lib/lib-tk/Tkinter.py24
-rw-r--r--Misc/NEWS3
2 files changed, 16 insertions, 11 deletions
diff --git a/Lib/lib-tk/Tkinter.py b/Lib/lib-tk/Tkinter.py
index 9533f8c..8a9d8a4 100644
--- a/Lib/lib-tk/Tkinter.py
+++ b/Lib/lib-tk/Tkinter.py
@@ -1921,6 +1921,8 @@ class BaseWidget(Misc):
cnf = _cnfmerge((cnf, kw))
self.widgetName = widgetName
BaseWidget._setup(self, master, cnf)
+ if self._tclCommands is None:
+ self._tclCommands = []
classes = []
for k in cnf.keys():
if type(k) is ClassType:
@@ -2658,20 +2660,20 @@ class Menu(Widget):
"""Add separator at INDEX."""
self.insert(index, 'separator', cnf or kw)
def delete(self, index1, index2=None):
- """Delete menu items between INDEX1 and INDEX2 (not included)."""
+ """Delete menu items between INDEX1 and INDEX2 (included)."""
if index2 is None:
index2 = index1
- cmds = []
- (num_index1, num_index2) = (self.index(index1), self.index(index2))
- if (num_index1 is not None) and (num_index2 is not None):
- for i in range(num_index1, num_index2 + 1):
- if 'command' in self.entryconfig(i):
- c = str(self.entrycget(i, 'command'))
- if c in self._tclCommands:
- cmds.append(c)
+
+ num_index1, num_index2 = self.index(index1), self.index(index2)
+ if (num_index1 is None) or (num_index2 is None):
+ num_index1, num_index2 = 0, -1
+
+ for i in range(num_index1, num_index2 + 1):
+ if 'command' in self.entryconfig(i):
+ c = str(self.entrycget(i, 'command'))
+ if c:
+ self.deletecommand(c)
self.tk.call(self._w, 'delete', index1, index2)
- for c in cmds:
- self.deletecommand(c)
def entrycget(self, index, option):
"""Return the resource value of an menu item for OPTION at INDEX."""
return self.tk.call(self._w, 'entrycget', index, '-' + option)
diff --git a/Misc/NEWS b/Misc/NEWS
index bb083a2..9030c73 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -38,6 +38,9 @@ Core and Builtins
Library
-------
+- Issue #3774: Fixed an error when create a Tkinter menu item without command
+ and then remove it.
+
- Fixed a modulefinder crash on certain relative imports.
- Issue #4150: Pdb's "up" command now works for generator frames in post-mortem