blob: 4fd2ea0720ac27457753c92bdc8cf6d20d9d6326 [file] [log] [blame]
Serhiy Storchaka93260282017-02-04 11:19:59 +02001/*[clinic input]
2preserve
3[clinic start generated code]*/
4
5PyDoc_STRVAR(gc_enable__doc__,
6"enable($module, /)\n"
7"--\n"
8"\n"
9"Enable automatic garbage collection.");
10
11#define GC_ENABLE_METHODDEF \
12 {"enable", (PyCFunction)gc_enable, METH_NOARGS, gc_enable__doc__},
13
14static PyObject *
15gc_enable_impl(PyObject *module);
16
17static PyObject *
18gc_enable(PyObject *module, PyObject *Py_UNUSED(ignored))
19{
20 return gc_enable_impl(module);
21}
22
23PyDoc_STRVAR(gc_disable__doc__,
24"disable($module, /)\n"
25"--\n"
26"\n"
27"Disable automatic garbage collection.");
28
29#define GC_DISABLE_METHODDEF \
30 {"disable", (PyCFunction)gc_disable, METH_NOARGS, gc_disable__doc__},
31
32static PyObject *
33gc_disable_impl(PyObject *module);
34
35static PyObject *
36gc_disable(PyObject *module, PyObject *Py_UNUSED(ignored))
37{
38 return gc_disable_impl(module);
39}
40
41PyDoc_STRVAR(gc_isenabled__doc__,
42"isenabled($module, /)\n"
43"--\n"
44"\n"
45"Returns true if automatic garbage collection is enabled.");
46
47#define GC_ISENABLED_METHODDEF \
48 {"isenabled", (PyCFunction)gc_isenabled, METH_NOARGS, gc_isenabled__doc__},
49
50static int
51gc_isenabled_impl(PyObject *module);
52
53static PyObject *
54gc_isenabled(PyObject *module, PyObject *Py_UNUSED(ignored))
55{
56 PyObject *return_value = NULL;
57 int _return_value;
58
59 _return_value = gc_isenabled_impl(module);
60 if ((_return_value == -1) && PyErr_Occurred()) {
61 goto exit;
62 }
63 return_value = PyBool_FromLong((long)_return_value);
64
65exit:
66 return return_value;
67}
68
69PyDoc_STRVAR(gc_collect__doc__,
70"collect($module, /, generation=2)\n"
71"--\n"
72"\n"
73"Run the garbage collector.\n"
74"\n"
75"With no arguments, run a full collection. The optional argument\n"
76"may be an integer specifying which generation to collect. A ValueError\n"
77"is raised if the generation number is invalid.\n"
78"\n"
79"The number of unreachable objects is returned.");
80
81#define GC_COLLECT_METHODDEF \
Serhiy Storchaka4a934d42018-11-27 11:27:36 +020082 {"collect", (PyCFunction)(void(*)(void))gc_collect, METH_FASTCALL|METH_KEYWORDS, gc_collect__doc__},
Serhiy Storchaka93260282017-02-04 11:19:59 +020083
84static Py_ssize_t
85gc_collect_impl(PyObject *module, int generation);
86
87static PyObject *
Serhiy Storchakaa5552f02017-12-15 13:11:11 +020088gc_collect(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
Serhiy Storchaka93260282017-02-04 11:19:59 +020089{
90 PyObject *return_value = NULL;
91 static const char * const _keywords[] = {"generation", NULL};
92 static _PyArg_Parser _parser = {"|i:collect", _keywords, 0};
93 int generation = NUM_GENERATIONS - 1;
94 Py_ssize_t _return_value;
95
96 if (!_PyArg_ParseStackAndKeywords(args, nargs, kwnames, &_parser,
97 &generation)) {
98 goto exit;
99 }
100 _return_value = gc_collect_impl(module, generation);
101 if ((_return_value == -1) && PyErr_Occurred()) {
102 goto exit;
103 }
104 return_value = PyLong_FromSsize_t(_return_value);
105
106exit:
107 return return_value;
108}
109
110PyDoc_STRVAR(gc_set_debug__doc__,
111"set_debug($module, flags, /)\n"
112"--\n"
113"\n"
114"Set the garbage collection debugging flags.\n"
115"\n"
116" flags\n"
117" An integer that can have the following bits turned on:\n"
118" DEBUG_STATS - Print statistics during collection.\n"
119" DEBUG_COLLECTABLE - Print collectable objects found.\n"
120" DEBUG_UNCOLLECTABLE - Print unreachable but uncollectable objects\n"
121" found.\n"
122" DEBUG_SAVEALL - Save objects to gc.garbage rather than freeing them.\n"
123" DEBUG_LEAK - Debug leaking programs (everything but STATS).\n"
124"\n"
125"Debugging information is written to sys.stderr.");
126
127#define GC_SET_DEBUG_METHODDEF \
128 {"set_debug", (PyCFunction)gc_set_debug, METH_O, gc_set_debug__doc__},
129
130static PyObject *
131gc_set_debug_impl(PyObject *module, int flags);
132
133static PyObject *
134gc_set_debug(PyObject *module, PyObject *arg)
135{
136 PyObject *return_value = NULL;
137 int flags;
138
Serhiy Storchaka32d96a22018-12-25 13:23:47 +0200139 if (PyFloat_Check(arg)) {
140 PyErr_SetString(PyExc_TypeError,
141 "integer argument expected, got float" );
142 goto exit;
143 }
144 flags = _PyLong_AsInt(arg);
145 if (flags == -1 && PyErr_Occurred()) {
Serhiy Storchaka93260282017-02-04 11:19:59 +0200146 goto exit;
147 }
148 return_value = gc_set_debug_impl(module, flags);
149
150exit:
151 return return_value;
152}
153
154PyDoc_STRVAR(gc_get_debug__doc__,
155"get_debug($module, /)\n"
156"--\n"
157"\n"
158"Get the garbage collection debugging flags.");
159
160#define GC_GET_DEBUG_METHODDEF \
161 {"get_debug", (PyCFunction)gc_get_debug, METH_NOARGS, gc_get_debug__doc__},
162
163static int
164gc_get_debug_impl(PyObject *module);
165
166static PyObject *
167gc_get_debug(PyObject *module, PyObject *Py_UNUSED(ignored))
168{
169 PyObject *return_value = NULL;
170 int _return_value;
171
172 _return_value = gc_get_debug_impl(module);
173 if ((_return_value == -1) && PyErr_Occurred()) {
174 goto exit;
175 }
176 return_value = PyLong_FromLong((long)_return_value);
177
178exit:
179 return return_value;
180}
181
182PyDoc_STRVAR(gc_get_threshold__doc__,
183"get_threshold($module, /)\n"
184"--\n"
185"\n"
186"Return the current collection thresholds.");
187
188#define GC_GET_THRESHOLD_METHODDEF \
189 {"get_threshold", (PyCFunction)gc_get_threshold, METH_NOARGS, gc_get_threshold__doc__},
190
191static PyObject *
192gc_get_threshold_impl(PyObject *module);
193
194static PyObject *
195gc_get_threshold(PyObject *module, PyObject *Py_UNUSED(ignored))
196{
197 return gc_get_threshold_impl(module);
198}
199
200PyDoc_STRVAR(gc_get_count__doc__,
201"get_count($module, /)\n"
202"--\n"
203"\n"
204"Return a three-tuple of the current collection counts.");
205
206#define GC_GET_COUNT_METHODDEF \
207 {"get_count", (PyCFunction)gc_get_count, METH_NOARGS, gc_get_count__doc__},
208
209static PyObject *
210gc_get_count_impl(PyObject *module);
211
212static PyObject *
213gc_get_count(PyObject *module, PyObject *Py_UNUSED(ignored))
214{
215 return gc_get_count_impl(module);
216}
217
218PyDoc_STRVAR(gc_get_objects__doc__,
219"get_objects($module, /)\n"
220"--\n"
221"\n"
222"Return a list of objects tracked by the collector (excluding the list returned).");
223
224#define GC_GET_OBJECTS_METHODDEF \
225 {"get_objects", (PyCFunction)gc_get_objects, METH_NOARGS, gc_get_objects__doc__},
226
227static PyObject *
228gc_get_objects_impl(PyObject *module);
229
230static PyObject *
231gc_get_objects(PyObject *module, PyObject *Py_UNUSED(ignored))
232{
233 return gc_get_objects_impl(module);
234}
235
236PyDoc_STRVAR(gc_get_stats__doc__,
237"get_stats($module, /)\n"
238"--\n"
239"\n"
240"Return a list of dictionaries containing per-generation statistics.");
241
242#define GC_GET_STATS_METHODDEF \
243 {"get_stats", (PyCFunction)gc_get_stats, METH_NOARGS, gc_get_stats__doc__},
244
245static PyObject *
246gc_get_stats_impl(PyObject *module);
247
248static PyObject *
249gc_get_stats(PyObject *module, PyObject *Py_UNUSED(ignored))
250{
251 return gc_get_stats_impl(module);
252}
253
254PyDoc_STRVAR(gc_is_tracked__doc__,
255"is_tracked($module, obj, /)\n"
256"--\n"
257"\n"
258"Returns true if the object is tracked by the garbage collector.\n"
259"\n"
260"Simple atomic objects will return false.");
261
262#define GC_IS_TRACKED_METHODDEF \
263 {"is_tracked", (PyCFunction)gc_is_tracked, METH_O, gc_is_tracked__doc__},
brainfvckc75edab2017-10-16 12:49:41 -0700264
265PyDoc_STRVAR(gc_freeze__doc__,
266"freeze($module, /)\n"
267"--\n"
268"\n"
269"Freeze all current tracked objects and ignore them for future collections.\n"
270"\n"
271"This can be used before a POSIX fork() call to make the gc copy-on-write friendly.\n"
272"Note: collection before a POSIX fork() call may free pages for future allocation\n"
273"which can cause copy-on-write.");
274
275#define GC_FREEZE_METHODDEF \
276 {"freeze", (PyCFunction)gc_freeze, METH_NOARGS, gc_freeze__doc__},
277
278static PyObject *
279gc_freeze_impl(PyObject *module);
280
281static PyObject *
282gc_freeze(PyObject *module, PyObject *Py_UNUSED(ignored))
283{
284 return gc_freeze_impl(module);
285}
286
287PyDoc_STRVAR(gc_unfreeze__doc__,
288"unfreeze($module, /)\n"
289"--\n"
290"\n"
291"Unfreeze all objects in the permanent generation.\n"
292"\n"
293"Put all objects in the permanent generation back into oldest generation.");
294
295#define GC_UNFREEZE_METHODDEF \
296 {"unfreeze", (PyCFunction)gc_unfreeze, METH_NOARGS, gc_unfreeze__doc__},
297
298static PyObject *
299gc_unfreeze_impl(PyObject *module);
300
301static PyObject *
302gc_unfreeze(PyObject *module, PyObject *Py_UNUSED(ignored))
303{
304 return gc_unfreeze_impl(module);
305}
306
307PyDoc_STRVAR(gc_get_freeze_count__doc__,
308"get_freeze_count($module, /)\n"
309"--\n"
310"\n"
311"Return the number of objects in the permanent generation.");
312
313#define GC_GET_FREEZE_COUNT_METHODDEF \
314 {"get_freeze_count", (PyCFunction)gc_get_freeze_count, METH_NOARGS, gc_get_freeze_count__doc__},
315
Victor Stinner05d68a82018-01-18 11:15:25 +0100316static Py_ssize_t
brainfvckc75edab2017-10-16 12:49:41 -0700317gc_get_freeze_count_impl(PyObject *module);
318
319static PyObject *
320gc_get_freeze_count(PyObject *module, PyObject *Py_UNUSED(ignored))
321{
322 PyObject *return_value = NULL;
Victor Stinner05d68a82018-01-18 11:15:25 +0100323 Py_ssize_t _return_value;
brainfvckc75edab2017-10-16 12:49:41 -0700324
325 _return_value = gc_get_freeze_count_impl(module);
326 if ((_return_value == -1) && PyErr_Occurred()) {
327 goto exit;
328 }
Victor Stinner05d68a82018-01-18 11:15:25 +0100329 return_value = PyLong_FromSsize_t(_return_value);
brainfvckc75edab2017-10-16 12:49:41 -0700330
331exit:
332 return return_value;
333}
Serhiy Storchaka32d96a22018-12-25 13:23:47 +0200334/*[clinic end generated code: output=5aa5fdc259503d5f input=a9049054013a1b77]*/