DescriptionPython feature request: http://bugs.python.org/issue8699
On python-dev came up an idea [1] to support equality (== and !=) and hashing by functools.partial instances. Van Lindberg provided an implementation written in Python [2]. I've made a very similar implementation in C (in Modules/_functoolsmodule.c). The Python equivalent of my code is in Lib/test/test_functools.py as the PythonPartialCls class. The hashing differs a little from Van Lindberg's implementation: I'm computing the "normal form" of the dict as the sorted list of its items (not as the sorted list of the keys followed by the items). (It was easier to implement this way.)
I haven't made a lot of Python programming in C, so I'm not sure I made everything in the right way (especially the reference counting). I'd appreciate every suggestion, and will try to correct my mistakes.
Thanks!
[1] http://mail.python.org/pipermail/python-dev/2010-May/099981.html
[2] http://mail.python.org/pipermail/python-dev/2010-May/099996.html
Patch Set 1 #Patch Set 2 : Here is a corrected version (using PyList_Sort to sort the list). #Patch Set 3 : Corrected version, with read-only keywords dictionary. #Patch Set 4 : Corrected version, __eq__ now compares the __dict__ of the two instances. #
Total comments: 3
Downloaded from: http://bugs.python.org/file17363/partial_eq_hash_4.diff
MessagesTotal messages: 5
|