1
0
mirror of https://github.com/django/django.git synced 2025-10-24 22:26:08 +00:00

Ensued that SQL indexes are alwasy created in the same name.

Previous this used Python's builtin hash() function, which has never been guarnteed to be stable across implementations (CPython/Jython/etc.) or 32/64 bitness. However, this in practice it was stable. However, with the impending release of Python 3.3 hash randomizations is enabled by default, which would mean the index name changed between program invocations.
This commit is contained in:
Alex Gaynor
2012-09-07 14:14:06 -04:00
parent a92b81b0e8
commit e4ea536774

View File

@@ -1,3 +1,4 @@
import hashlib
import sys import sys
import time import time
@@ -27,7 +28,10 @@ class BaseDatabaseCreation(object):
Generates a 32-bit digest of a set of arguments that can be used to Generates a 32-bit digest of a set of arguments that can be used to
shorten identifying names. shorten identifying names.
""" """
return '%x' % (abs(hash(args)) % 4294967296) # 2**32 h = hashlib.md5()
for arg in args:
h.update(arg)
return h.hexdigest()[:8]
def sql_create_model(self, model, style, known_models=set()): def sql_create_model(self, model, style, known_models=set()):
""" """