Ashwin Ramaswami <aramaswa...@gmail.com> added the comment:

Makes sense, thanks for the explanation. The risk is that if there is code 
that, say, converts a POST dictionary to a dictionary with numeric keys, that 
code could be exploited. Creating a non-deterministic hash doesn't necessarily 
preclude hash(x) = x for a small enough x either. 

Given that other libraries (NumPy, etc.) rely on the numeric hash staying the 
way it is, it makes sense to keep it as it is. Since when did something that 
seems at first glance to be an implementation detail become more like a 
backwards-incompatible API, though? (For example, the implementation of the 
numeric hash was changed without any backwards-compatibility issues in 
https://bugs.python.org/issue14621). Might there be a better way to clarify 
this distinction for other features in Python?

I think the way forward for this patch is to keep the datetime hash as it is, 
and remove "datetime" in the parts of documentation that enumerate which data 
types have non-deterministic hashes.

----------

_______________________________________
Python tracker <rep...@bugs.python.org>
<https://bugs.python.org/issue29535>
_______________________________________
_______________________________________________
Python-bugs-list mailing list
Unsubscribe: 
https://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com

Reply via email to