mirror of https://github.com/python/cpython
Added _Fini() routines to free up some memory
This commit is contained in:
parent
971a7aaeac
commit
fbbd57e4ca
|
@ -590,3 +590,9 @@ PyTypeObject PyFloat_Type = {
|
|||
0, /*tp_as_mapping*/
|
||||
(hashfunc)float_hash, /*tp_hash*/
|
||||
};
|
||||
|
||||
void
|
||||
PyFloat_Fini()
|
||||
{
|
||||
/* XXX Alas, the free list is not easily and safely freeable */
|
||||
}
|
||||
|
|
|
@ -790,3 +790,20 @@ PyTypeObject PyInt_Type = {
|
|||
0, /*tp_as_mapping*/
|
||||
(hashfunc)int_hash, /*tp_hash*/
|
||||
};
|
||||
|
||||
void
|
||||
PyInt_Fini()
|
||||
{
|
||||
#if NSMALLNEGINTS + NSMALLPOSINTS > 0
|
||||
int i;
|
||||
PyIntObject **p;
|
||||
|
||||
i = NSMALLNEGINTS + NSMALLPOSINTS;
|
||||
p = small_ints;
|
||||
while (--i >= 0) {
|
||||
Py_XDECREF(*p);
|
||||
*p++ = NULL;
|
||||
}
|
||||
#endif
|
||||
/* XXX Alas, the free list is not easily and safely freeable */
|
||||
}
|
||||
|
|
|
@ -74,7 +74,8 @@ PyTuple_New(size)
|
|||
#ifdef COUNT_ALLOCS
|
||||
fast_tuple_allocs++;
|
||||
#endif
|
||||
} else
|
||||
}
|
||||
else
|
||||
#endif
|
||||
{
|
||||
op = (PyTupleObject *) malloc(
|
||||
|
@ -467,3 +468,25 @@ _PyTuple_Resize(pv, newsize, last_is_sticky)
|
|||
sv->ob_size = newsize;
|
||||
return 0;
|
||||
}
|
||||
|
||||
void
|
||||
PyTuple_Fini()
|
||||
{
|
||||
#if MAXSAVESIZE > 0
|
||||
int i;
|
||||
|
||||
Py_XDECREF(free_tuples[0]);
|
||||
free_tuples[0] = NULL;
|
||||
|
||||
for (i = 1; i < MAXSAVESIZE; i++) {
|
||||
PyTupleObject *p, *q;
|
||||
p = free_tuples[i];
|
||||
free_tuples[i] = NULL;
|
||||
while (p) {
|
||||
q = p;
|
||||
p = (PyTupleObject *)(p->ob_item[0]);
|
||||
PyMem_DEL(q);
|
||||
}
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue