#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
# include "pycore_gc.h"
# include "pycore_runtime.h"
#endif
#include "pycore_abstract.h"
#include "pycore_modsupport.h"
PyDoc_STRVAR(gc_enable__doc__,
"enable($module, /)\n"
"--\n"
"\n"
"Enable automatic garbage collection.");
#define GC_ENABLE_METHODDEF …
static PyObject *
gc_enable_impl(PyObject *module);
static PyObject *
gc_enable(PyObject *module, PyObject *Py_UNUSED(ignored))
{ … }
PyDoc_STRVAR(gc_disable__doc__,
"disable($module, /)\n"
"--\n"
"\n"
"Disable automatic garbage collection.");
#define GC_DISABLE_METHODDEF …
static PyObject *
gc_disable_impl(PyObject *module);
static PyObject *
gc_disable(PyObject *module, PyObject *Py_UNUSED(ignored))
{ … }
PyDoc_STRVAR(gc_isenabled__doc__,
"isenabled($module, /)\n"
"--\n"
"\n"
"Returns true if automatic garbage collection is enabled.");
#define GC_ISENABLED_METHODDEF …
static int
gc_isenabled_impl(PyObject *module);
static PyObject *
gc_isenabled(PyObject *module, PyObject *Py_UNUSED(ignored))
{ … }
PyDoc_STRVAR(gc_collect__doc__,
"collect($module, /, generation=2)\n"
"--\n"
"\n"
"Run the garbage collector.\n"
"\n"
"With no arguments, run a full collection. The optional argument\n"
"may be an integer specifying which generation to collect. A ValueError\n"
"is raised if the generation number is invalid.\n"
"\n"
"The number of unreachable objects is returned.");
#define GC_COLLECT_METHODDEF …
static Py_ssize_t
gc_collect_impl(PyObject *module, int generation);
static PyObject *
gc_collect(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
{ … }
PyDoc_STRVAR(gc_set_debug__doc__,
"set_debug($module, flags, /)\n"
"--\n"
"\n"
"Set the garbage collection debugging flags.\n"
"\n"
" flags\n"
" An integer that can have the following bits turned on:\n"
" DEBUG_STATS - Print statistics during collection.\n"
" DEBUG_COLLECTABLE - Print collectable objects found.\n"
" DEBUG_UNCOLLECTABLE - Print unreachable but uncollectable objects\n"
" found.\n"
" DEBUG_SAVEALL - Save objects to gc.garbage rather than freeing them.\n"
" DEBUG_LEAK - Debug leaking programs (everything but STATS).\n"
"\n"
"Debugging information is written to sys.stderr.");
#define GC_SET_DEBUG_METHODDEF …
static PyObject *
gc_set_debug_impl(PyObject *module, int flags);
static PyObject *
gc_set_debug(PyObject *module, PyObject *arg)
{ … }
PyDoc_STRVAR(gc_get_debug__doc__,
"get_debug($module, /)\n"
"--\n"
"\n"
"Get the garbage collection debugging flags.");
#define GC_GET_DEBUG_METHODDEF …
static int
gc_get_debug_impl(PyObject *module);
static PyObject *
gc_get_debug(PyObject *module, PyObject *Py_UNUSED(ignored))
{ … }
PyDoc_STRVAR(gc_set_threshold__doc__,
"set_threshold(threshold0, [threshold1, [threshold2]])\n"
"Set the collection thresholds (the collection frequency).\n"
"\n"
"Setting \'threshold0\' to zero disables collection.");
#define GC_SET_THRESHOLD_METHODDEF …
static PyObject *
gc_set_threshold_impl(PyObject *module, int threshold0, int group_right_1,
int threshold1, int group_right_2, int threshold2);
static PyObject *
gc_set_threshold(PyObject *module, PyObject *args)
{ … }
PyDoc_STRVAR(gc_get_threshold__doc__,
"get_threshold($module, /)\n"
"--\n"
"\n"
"Return the current collection thresholds.");
#define GC_GET_THRESHOLD_METHODDEF …
static PyObject *
gc_get_threshold_impl(PyObject *module);
static PyObject *
gc_get_threshold(PyObject *module, PyObject *Py_UNUSED(ignored))
{ … }
PyDoc_STRVAR(gc_get_count__doc__,
"get_count($module, /)\n"
"--\n"
"\n"
"Return a three-tuple of the current collection counts.");
#define GC_GET_COUNT_METHODDEF …
static PyObject *
gc_get_count_impl(PyObject *module);
static PyObject *
gc_get_count(PyObject *module, PyObject *Py_UNUSED(ignored))
{ … }
PyDoc_STRVAR(gc_get_referrers__doc__,
"get_referrers($module, /, *objs)\n"
"--\n"
"\n"
"Return the list of objects that directly refer to any of \'objs\'.");
#define GC_GET_REFERRERS_METHODDEF …
static PyObject *
gc_get_referrers_impl(PyObject *module, PyObject *args);
static PyObject *
gc_get_referrers(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
{ … }
PyDoc_STRVAR(gc_get_referents__doc__,
"get_referents($module, /, *objs)\n"
"--\n"
"\n"
"Return the list of objects that are directly referred to by \'objs\'.");
#define GC_GET_REFERENTS_METHODDEF …
static PyObject *
gc_get_referents_impl(PyObject *module, PyObject *args);
static PyObject *
gc_get_referents(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
{ … }
PyDoc_STRVAR(gc_get_objects__doc__,
"get_objects($module, /, generation=None)\n"
"--\n"
"\n"
"Return a list of objects tracked by the collector (excluding the list returned).\n"
"\n"
" generation\n"
" Generation to extract the objects from.\n"
"\n"
"If generation is not None, return only the objects tracked by the collector\n"
"that are in that generation.");
#define GC_GET_OBJECTS_METHODDEF …
static PyObject *
gc_get_objects_impl(PyObject *module, Py_ssize_t generation);
static PyObject *
gc_get_objects(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
{ … }
PyDoc_STRVAR(gc_get_stats__doc__,
"get_stats($module, /)\n"
"--\n"
"\n"
"Return a list of dictionaries containing per-generation statistics.");
#define GC_GET_STATS_METHODDEF …
static PyObject *
gc_get_stats_impl(PyObject *module);
static PyObject *
gc_get_stats(PyObject *module, PyObject *Py_UNUSED(ignored))
{ … }
PyDoc_STRVAR(gc_is_tracked__doc__,
"is_tracked($module, obj, /)\n"
"--\n"
"\n"
"Returns true if the object is tracked by the garbage collector.\n"
"\n"
"Simple atomic objects will return false.");
#define GC_IS_TRACKED_METHODDEF …
static int
gc_is_tracked_impl(PyObject *module, PyObject *obj);
static PyObject *
gc_is_tracked(PyObject *module, PyObject *obj)
{ … }
PyDoc_STRVAR(gc_is_finalized__doc__,
"is_finalized($module, obj, /)\n"
"--\n"
"\n"
"Returns true if the object has been already finalized by the GC.");
#define GC_IS_FINALIZED_METHODDEF …
static int
gc_is_finalized_impl(PyObject *module, PyObject *obj);
static PyObject *
gc_is_finalized(PyObject *module, PyObject *obj)
{ … }
PyDoc_STRVAR(gc_freeze__doc__,
"freeze($module, /)\n"
"--\n"
"\n"
"Freeze all current tracked objects and ignore them for future collections.\n"
"\n"
"This can be used before a POSIX fork() call to make the gc copy-on-write friendly.\n"
"Note: collection before a POSIX fork() call may free pages for future allocation\n"
"which can cause copy-on-write.");
#define GC_FREEZE_METHODDEF …
static PyObject *
gc_freeze_impl(PyObject *module);
static PyObject *
gc_freeze(PyObject *module, PyObject *Py_UNUSED(ignored))
{ … }
PyDoc_STRVAR(gc_unfreeze__doc__,
"unfreeze($module, /)\n"
"--\n"
"\n"
"Unfreeze all objects in the permanent generation.\n"
"\n"
"Put all objects in the permanent generation back into oldest generation.");
#define GC_UNFREEZE_METHODDEF …
static PyObject *
gc_unfreeze_impl(PyObject *module);
static PyObject *
gc_unfreeze(PyObject *module, PyObject *Py_UNUSED(ignored))
{ … }
PyDoc_STRVAR(gc_get_freeze_count__doc__,
"get_freeze_count($module, /)\n"
"--\n"
"\n"
"Return the number of objects in the permanent generation.");
#define GC_GET_FREEZE_COUNT_METHODDEF …
static Py_ssize_t
gc_get_freeze_count_impl(PyObject *module);
static PyObject *
gc_get_freeze_count(PyObject *module, PyObject *Py_UNUSED(ignored))
{ … }