diff options
author | Hirokazu Yamamoto <ocean-city@m2.ccsnet.ne.jp> | 2008-11-03 18:10:24 (GMT) |
---|---|---|
committer | Hirokazu Yamamoto <ocean-city@m2.ccsnet.ne.jp> | 2008-11-03 18:10:24 (GMT) |
commit | b2d8142ed1d0748ebbe44f1090ddaf2b6592facc (patch) | |
tree | bb5177355485d5f930b0c78293a739821e31d055 | |
parent | eeed0c78224078322ba5453607e770bad22b32db (diff) | |
download | cpython-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.py | 24 | ||||
-rw-r--r-- | Misc/NEWS | 3 |
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) @@ -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 |