summaryrefslogtreecommitdiffstats
path: root/Modules/_decimal
diff options
context:
space:
mode:
authorStefan Krah <skrah@bytereef.org>2012-04-10 14:27:58 (GMT)
committerStefan Krah <skrah@bytereef.org>2012-04-10 14:27:58 (GMT)
commitcc74b6ab14b66c2880beacefcd5df44a5a475232 (patch)
tree9bccdb38290c488aa8ef322f9f1184bd4a9e163d /Modules/_decimal
parent9deb1887993b5476fdab8939a61057661e833656 (diff)
downloadcpython-cc74b6ab14b66c2880beacefcd5df44a5a475232.zip
cpython-cc74b6ab14b66c2880beacefcd5df44a5a475232.tar.gz
cpython-cc74b6ab14b66c2880beacefcd5df44a5a475232.tar.bz2
Issue #14478: Cache the hash of a Decimal in the C version.
Diffstat (limited to 'Modules/_decimal')
-rw-r--r--Modules/_decimal/_decimal.c15
1 files changed, 14 insertions, 1 deletions
diff --git a/Modules/_decimal/_decimal.c b/Modules/_decimal/_decimal.c
index d5bb52f..168e8ec 100644
--- a/Modules/_decimal/_decimal.c
+++ b/Modules/_decimal/_decimal.c
@@ -60,6 +60,7 @@
typedef struct {
PyObject_HEAD
+ Py_hash_t hash;
mpd_t dec;
mpd_uint_t data[_Py_DEC_MINALLOC];
} PyDecObject;
@@ -1805,6 +1806,8 @@ PyDecType_New(PyTypeObject *type)
return NULL;
}
+ dec->hash = -1;
+
MPD(dec)->flags = MPD_STATIC|MPD_STATIC_DATA;
MPD(dec)->exp = 0;
MPD(dec)->digits = 0;
@@ -4210,7 +4213,7 @@ dec_floor(PyObject *self, PyObject *dummy UNUSED)
/* Always uses the module context */
static Py_hash_t
-dec_hash(PyObject *v)
+_dec_hash(PyDecObject *v)
{
#if defined(CONFIG_64) && _PyHASH_BITS == 61
/* 2**61 - 1 */
@@ -4323,6 +4326,16 @@ malloc_error:
goto finish;
}
+static Py_hash_t
+dec_hash(PyDecObject *self)
+{
+ if (self->hash == -1) {
+ self->hash = _dec_hash(self);
+ }
+
+ return self->hash;
+}
+
/* __reduce__ */
static PyObject *
dec_reduce(PyObject *self, PyObject *dummy UNUSED)