]> granicus.if.org Git - python/commitdiff
bpo-35081: Move _PyGC_FINALIZED() back to C API (GH-10626)
authorVictor Stinner <vstinner@redhat.com>
Tue, 20 Nov 2018 23:43:09 +0000 (00:43 +0100)
committerGitHub <noreply@github.com>
Tue, 20 Nov 2018 23:43:09 +0000 (00:43 +0100)
Partially revert commit 1a6be91e6fd65ce9cb88cbbbb193db7e92ec6076,
move back PyGC API from the internal API to the C API:

* _PyGCHead_NEXT(g), _PyGCHead_SET_NEXT(g, p)
* _PyGCHead_PREV(g), _PyGCHead_SET_PREV(g, p)
* _PyGCHead_FINALIZED(g), _PyGCHead_SET_FINALIZED(g)
* _PyGC_FINALIZED(o), _PyGC_SET_FINALIZED(o)
* _PyGC_PREV_MASK_FINALIZED
* _PyGC_PREV_MASK_COLLECTING
* _PyGC_PREV_SHIFT
* _PyGC_PREV_MASK

_PyObject_GC_TRACK(o) and _PyObject_GC_UNTRACK(o) remain in the
internal API.

Include/objimpl.h

index e1946c74560cff1d31eb4fc2a9aa402cf71a2614..b51b751b9c85fbe9d3ad34f9283ca93b7cd4c014 100644 (file)
@@ -288,10 +288,7 @@ typedef struct {
 #define _PyObject_GC_MAY_BE_TRACKED(obj) \
     (PyObject_IS_GC(obj) && \
         (!PyTuple_CheckExact(obj) || _PyObject_GC_IS_TRACKED(obj)))
-#endif
-
 
-#if defined(Py_BUILD_CORE) || defined(Py_BUILD_CORE_BUILTIN)
 
 /* Bit flags for _gc_prev */
 /* Bit 0 is set when tp_finalize is called */
@@ -324,7 +321,10 @@ typedef struct {
     _PyGCHead_FINALIZED(_Py_AS_GC(o))
 #define _PyGC_SET_FINALIZED(o) \
     _PyGCHead_SET_FINALIZED(_Py_AS_GC(o))
+#endif   /* !defined(Py_LIMITED_API) */
 
+
+#if defined(Py_BUILD_CORE) || defined(Py_BUILD_CORE_BUILTIN)
 /* Tell the GC to track this object.
  *
  * NB: While the object is tracked by the collector, it must be safe to call the