From 14646337bff978f5eba7f2add21ffbe89e894c7c Mon Sep 17 00:00:00 2001 From: Robert Schuppenies Date: Sun, 10 Aug 2008 11:01:53 +0000 Subject: Issue #1342811: Fix leak in Tkinter.Menu.delete. Commands associated to menu entries were not deleted. --- Lib/lib-tk/Tkinter.py | 10 ++++++++++ Misc/NEWS | 3 +++ 2 files changed, 13 insertions(+) diff --git a/Lib/lib-tk/Tkinter.py b/Lib/lib-tk/Tkinter.py index 7b116d9..00ee2c8 100644 --- a/Lib/lib-tk/Tkinter.py +++ b/Lib/lib-tk/Tkinter.py @@ -2659,7 +2659,17 @@ 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 a2669c6..a197efc 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -41,6 +41,9 @@ Core and Builtins Library ------- +- Issue #1342811: Fix leak in Tkinter.Menu.delete. Commands associated to + menu entries were not deleted. + - Copied the implementation of reduce() to _functools.reduce() to have a version that did not raise a DeprecationWarning under -3. -- cgit v0.12