mirror of
https://github.com/python/cpython.git
synced 2025-10-24 02:13:49 +00:00
bpo-46850: Remove _PyEval_GetCoroutineOriginTrackingDepth() (GH-32018)
Remove the private undocumented function _PyEval_GetCoroutineOriginTrackingDepth() from the C API. Call the public sys.get_coroutine_origin_tracking_depth() function instead. Change the internal function _PyEval_SetCoroutineOriginTrackingDepth(): * Remove the 'tstate' parameter; * Add return value and raises an exception if depth is negative; * No longer export the function: call the public sys.set_coroutine_origin_tracking_depth() function instead. Uniformize also function declarations in pycore_ceval.h.
This commit is contained in:
parent
332b04bac3
commit
9087243e2c
5 changed files with 25 additions and 17 deletions
|
@ -8,7 +8,6 @@ PyAPI_FUNC(void) PyEval_SetProfile(Py_tracefunc, PyObject *);
|
||||||
PyAPI_DATA(int) _PyEval_SetProfile(PyThreadState *tstate, Py_tracefunc func, PyObject *arg);
|
PyAPI_DATA(int) _PyEval_SetProfile(PyThreadState *tstate, Py_tracefunc func, PyObject *arg);
|
||||||
PyAPI_FUNC(void) PyEval_SetTrace(Py_tracefunc, PyObject *);
|
PyAPI_FUNC(void) PyEval_SetTrace(Py_tracefunc, PyObject *);
|
||||||
PyAPI_FUNC(int) _PyEval_SetTrace(PyThreadState *tstate, Py_tracefunc func, PyObject *arg);
|
PyAPI_FUNC(int) _PyEval_SetTrace(PyThreadState *tstate, Py_tracefunc func, PyObject *arg);
|
||||||
PyAPI_FUNC(int) _PyEval_GetCoroutineOriginTrackingDepth(void);
|
|
||||||
|
|
||||||
/* Helper to look up a builtin object */
|
/* Helper to look up a builtin object */
|
||||||
PyAPI_FUNC(PyObject *) _PyEval_GetBuiltin(PyObject *);
|
PyAPI_FUNC(PyObject *) _PyEval_GetBuiltin(PyObject *);
|
||||||
|
|
|
@ -33,9 +33,6 @@ PyAPI_FUNC(void) _PyEval_SignalAsyncExc(PyInterpreterState *interp);
|
||||||
#ifdef HAVE_FORK
|
#ifdef HAVE_FORK
|
||||||
extern PyStatus _PyEval_ReInitThreads(PyThreadState *tstate);
|
extern PyStatus _PyEval_ReInitThreads(PyThreadState *tstate);
|
||||||
#endif
|
#endif
|
||||||
PyAPI_FUNC(void) _PyEval_SetCoroutineOriginTrackingDepth(
|
|
||||||
PyThreadState *tstate,
|
|
||||||
int new_depth);
|
|
||||||
|
|
||||||
// Used by sys.get_asyncgen_hooks()
|
// Used by sys.get_asyncgen_hooks()
|
||||||
extern PyObject* _PyEval_GetAsyncGenFirstiter(void);
|
extern PyObject* _PyEval_GetAsyncGenFirstiter(void);
|
||||||
|
@ -45,11 +42,16 @@ extern PyObject* _PyEval_GetAsyncGenFinalizer(void);
|
||||||
extern int _PyEval_SetAsyncGenFirstiter(PyObject *);
|
extern int _PyEval_SetAsyncGenFirstiter(PyObject *);
|
||||||
extern int _PyEval_SetAsyncGenFinalizer(PyObject *);
|
extern int _PyEval_SetAsyncGenFinalizer(PyObject *);
|
||||||
|
|
||||||
void _PyEval_Fini(void);
|
// Used by sys.get_coroutine_origin_tracking_depth()
|
||||||
|
// and sys.set_coroutine_origin_tracking_depth()
|
||||||
|
extern int _PyEval_GetCoroutineOriginTrackingDepth(void);
|
||||||
|
extern int _PyEval_SetCoroutineOriginTrackingDepth(int depth);
|
||||||
|
|
||||||
|
extern void _PyEval_Fini(void);
|
||||||
|
|
||||||
|
|
||||||
extern PyObject* _PyEval_GetBuiltins(PyThreadState *tstate);
|
extern PyObject* _PyEval_GetBuiltins(PyThreadState *tstate);
|
||||||
extern PyObject *_PyEval_BuiltinsFromGlobals(
|
extern PyObject* _PyEval_BuiltinsFromGlobals(
|
||||||
PyThreadState *tstate,
|
PyThreadState *tstate,
|
||||||
PyObject *globals);
|
PyObject *globals);
|
||||||
|
|
||||||
|
@ -63,7 +65,7 @@ _PyEval_EvalFrame(PyThreadState *tstate, struct _PyInterpreterFrame *frame, int
|
||||||
return tstate->interp->eval_frame(tstate, frame, throwflag);
|
return tstate->interp->eval_frame(tstate, frame, throwflag);
|
||||||
}
|
}
|
||||||
|
|
||||||
extern PyObject *
|
extern PyObject*
|
||||||
_PyEval_Vector(PyThreadState *tstate,
|
_PyEval_Vector(PyThreadState *tstate,
|
||||||
PyFunctionObject *func, PyObject *locals,
|
PyFunctionObject *func, PyObject *locals,
|
||||||
PyObject* const* args, size_t argcount,
|
PyObject* const* args, size_t argcount,
|
||||||
|
@ -124,9 +126,9 @@ static inline void _Py_LeaveRecursiveCall_inline(void) {
|
||||||
|
|
||||||
#define Py_LeaveRecursiveCall() _Py_LeaveRecursiveCall_inline()
|
#define Py_LeaveRecursiveCall() _Py_LeaveRecursiveCall_inline()
|
||||||
|
|
||||||
struct _PyInterpreterFrame *_PyEval_GetFrame(void);
|
extern struct _PyInterpreterFrame* _PyEval_GetFrame(void);
|
||||||
|
|
||||||
PyObject *_Py_MakeCoro(PyFunctionObject *func);
|
extern PyObject* _Py_MakeCoro(PyFunctionObject *func);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,4 @@
|
||||||
|
Remove the private undocumented function
|
||||||
|
``_PyEval_GetCoroutineOriginTrackingDepth()`` from the C API. Call the
|
||||||
|
public :func:`sys.get_coroutine_origin_tracking_depth` function instead.
|
||||||
|
Patch by Victor Stinner.
|
|
@ -6852,13 +6852,19 @@ PyEval_SetTrace(Py_tracefunc func, PyObject *arg)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
int
|
||||||
_PyEval_SetCoroutineOriginTrackingDepth(PyThreadState *tstate, int new_depth)
|
_PyEval_SetCoroutineOriginTrackingDepth(int depth)
|
||||||
{
|
{
|
||||||
assert(new_depth >= 0);
|
PyThreadState *tstate = _PyThreadState_GET();
|
||||||
tstate->coroutine_origin_tracking_depth = new_depth;
|
if (depth < 0) {
|
||||||
|
_PyErr_SetString(tstate, PyExc_ValueError, "depth must be >= 0");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
tstate->coroutine_origin_tracking_depth = depth;
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int
|
int
|
||||||
_PyEval_GetCoroutineOriginTrackingDepth(void)
|
_PyEval_GetCoroutineOriginTrackingDepth(void)
|
||||||
{
|
{
|
||||||
|
|
|
@ -1186,12 +1186,9 @@ static PyObject *
|
||||||
sys_set_coroutine_origin_tracking_depth_impl(PyObject *module, int depth)
|
sys_set_coroutine_origin_tracking_depth_impl(PyObject *module, int depth)
|
||||||
/*[clinic end generated code: output=0a2123c1cc6759c5 input=a1d0a05f89d2c426]*/
|
/*[clinic end generated code: output=0a2123c1cc6759c5 input=a1d0a05f89d2c426]*/
|
||||||
{
|
{
|
||||||
PyThreadState *tstate = _PyThreadState_GET();
|
if (_PyEval_SetCoroutineOriginTrackingDepth(depth) < 0) {
|
||||||
if (depth < 0) {
|
|
||||||
_PyErr_SetString(tstate, PyExc_ValueError, "depth must be >= 0");
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
_PyEval_SetCoroutineOriginTrackingDepth(tstate, depth);
|
|
||||||
Py_RETURN_NONE;
|
Py_RETURN_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue