From: Robert Schuppenies Date: Sun, 10 Aug 2008 11:28:17 +0000 (+0000) Subject: Merged revisions 65622 via svnmerge from X-Git-Tag: v3.0b3~126 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=3d1c7dec4af44134390addc25b002dfd22c4c3f8;p=thirdparty%2FPython%2Fcpython.git Merged revisions 65622 via svnmerge from svn+ssh://pythondev@svn.python.org/python/trunk ........ r65622 | robert.schuppenies | 2008-08-10 13:01:53 +0200 (Sun, 10 Aug 2008) | 4 lines Issue #1342811: Fix leak in Tkinter.Menu.delete. Commands associated to menu entries were not deleted. ........ --- diff --git a/Lib/tkinter/__init__.py b/Lib/tkinter/__init__.py index 08c5823ce6a5..b8508a568a02 100644 --- a/Lib/tkinter/__init__.py +++ b/Lib/tkinter/__init__.py @@ -2651,7 +2651,18 @@ class Menu(Widget): self.insert(index, 'separator', cnf or kw) def delete(self, index1, index2=None): """Delete menu items between INDEX1 and INDEX2 (not included).""" + if index2 is None: + index2 = index1 + cmds = [] + for i in range(self.index(index1), self.index(index2)+1): + if 'command' in self.entryconfig(i): + c = str(self.entrycget(i, 'command')) + if c in self._tclCommands: + cmds.append(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 25c72dffa5c5..dfa1a2f21776 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -30,6 +30,9 @@ Core and Builtins Library ------- +- Issue #1342811: Fix leak in Tkinter.Menu.delete. Commands associated to + menu entries were not deleted. + - Remove the TarFileCompat class from tarfile.py. - Issue #2491: os.fdopen is now almost an alias for the built-in open(), and