From: Raymond Hettinger Date: Sat, 31 Dec 2016 19:01:59 +0000 (-0700) Subject: Issue #29119: Fix weakref in OrderedDict.move_to_end(). Work by Andra Bogildea. X-Git-Tag: v3.5.3rc1~11 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=b46ea9034349b9d713daff581e624afe07916629;p=python Issue #29119: Fix weakref in OrderedDict.move_to_end(). Work by Andra Bogildea. --- diff --git a/Lib/collections/__init__.py b/Lib/collections/__init__.py index ebe8ee7a83..bea811db7f 100644 --- a/Lib/collections/__init__.py +++ b/Lib/collections/__init__.py @@ -189,6 +189,7 @@ class OrderedDict(dict): link = self.__map[key] link_prev = link.prev link_next = link.next + soft_link = link_next.prev link_prev.next = link_next link_next.prev = link_prev root = self.__root @@ -196,12 +197,14 @@ class OrderedDict(dict): last = root.prev link.prev = last link.next = root - last.next = root.prev = link + root.prev = soft_link + last.next = link else: first = root.next link.prev = root link.next = first - root.next = first.prev = link + first.prev = soft_link + root.next = link def __sizeof__(self): sizeof = _sys.getsizeof diff --git a/Misc/ACKS b/Misc/ACKS index 06c7a93bc0..59b7704b73 100644 --- a/Misc/ACKS +++ b/Misc/ACKS @@ -156,6 +156,7 @@ Finn Bock Paul Boddie Matthew Boedicker Robin Boerdijk +Andra Bogildea David Bolen Wouter Bolsterlee Gawain Bolton diff --git a/Misc/NEWS b/Misc/NEWS index 9aa561fb26..0dd4ef10f5 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -143,6 +143,10 @@ Library - Issue #13051: Fixed recursion errors in large or resized curses.textpad.Textbox. Based on patch by Tycho Andersen. +- Issue #29119: Fix weakrefs in the pure python version of + collections.OrderedDict move_to_end() method. + Contributed by Andra Bogildea. + - Issue #9770: curses.ascii predicates now work correctly with negative integers.