blob: 7488054c68fcd8bf8e3678265c6e957e5d58129b [file] [log] [blame]
Martin v. Löwise440e472004-06-01 15:22:42 +00001
2/* Generator object interface */
3
Martin v. Löwis4d0d4712010-12-03 20:14:31 +00004#ifndef Py_LIMITED_API
Martin v. Löwise440e472004-06-01 15:22:42 +00005#ifndef Py_GENOBJECT_H
6#define Py_GENOBJECT_H
7#ifdef __cplusplus
8extern "C" {
9#endif
10
Victor Stinnered488662019-05-20 00:14:57 +020011#include "pystate.h" /* _PyErr_StackItem */
12
Yury Selivanov5376ba92015-06-22 12:19:30 -040013/* _PyGenObject_HEAD defines the initial segment of generator
14 and coroutine objects. */
15#define _PyGenObject_HEAD(prefix) \
16 PyObject_HEAD \
17 /* Note: gi_frame can be NULL if the generator is "finished" */ \
Victor Stinner7c59d7c2020-04-28 16:32:48 +020018 PyFrameObject *prefix##_frame; \
Yury Selivanov5376ba92015-06-22 12:19:30 -040019 /* The code object backing the generator */ \
20 PyObject *prefix##_code; \
21 /* List of weak reference. */ \
22 PyObject *prefix##_weakreflist; \
23 /* Name of the generator. */ \
24 PyObject *prefix##_name; \
25 /* Qualified name of the generator. */ \
Mark Shannonae3087c2017-10-22 22:41:51 +010026 PyObject *prefix##_qualname; \
27 _PyErr_StackItem prefix##_exc_state;
Yury Selivanov5376ba92015-06-22 12:19:30 -040028
Martin v. Löwise440e472004-06-01 15:22:42 +000029typedef struct {
Nick Coghlan76e1bb02012-01-14 16:08:08 +100030 /* The gi_ prefix is intended to remind of generator-iterator. */
Yury Selivanov5376ba92015-06-22 12:19:30 -040031 _PyGenObject_HEAD(gi)
Martin v. Löwise440e472004-06-01 15:22:42 +000032} PyGenObject;
33
34PyAPI_DATA(PyTypeObject) PyGen_Type;
35
36#define PyGen_Check(op) PyObject_TypeCheck(op, &PyGen_Type)
Dong-hee Nad905df72020-02-14 02:37:17 +090037#define PyGen_CheckExact(op) Py_IS_TYPE(op, &PyGen_Type)
Martin v. Löwise440e472004-06-01 15:22:42 +000038
Victor Stinner7c59d7c2020-04-28 16:32:48 +020039PyAPI_FUNC(PyObject *) PyGen_New(PyFrameObject *);
40PyAPI_FUNC(PyObject *) PyGen_NewWithQualName(PyFrameObject *,
Victor Stinner40ee3012014-06-16 15:59:28 +020041 PyObject *name, PyObject *qualname);
Serhiy Storchaka24411f82016-11-06 18:44:42 +020042PyAPI_FUNC(int) _PyGen_SetStopIterationValue(PyObject *);
Nick Coghlanc40bc092012-06-17 15:15:49 +100043PyAPI_FUNC(int) _PyGen_FetchStopIterationValue(PyObject **);
Yury Selivanov833c6262016-10-28 18:48:50 -040044PyAPI_FUNC(PyObject *) _PyGen_Send(PyGenObject *, PyObject *);
Yury Selivanovc724bae2016-03-02 11:30:46 -050045PyObject *_PyGen_yf(PyGenObject *);
Antoine Pitrou58720d62013-08-05 23:26:40 +020046PyAPI_FUNC(void) _PyGen_Finalize(PyObject *self);
47
Vladimir Matveev2b053612020-09-18 18:38:38 -070048typedef enum {
49 PYGEN_RETURN = 0,
50 PYGEN_ERROR = -1,
51 PYGEN_NEXT = 1,
52} PySendResult;
53
54/* Sends the value into the generator or the coroutine. Returns:
55 - PYGEN_RETURN (0) if generator has returned.
56 'result' parameter is filled with return value
57 - PYGEN_ERROR (-1) if exception was raised.
58 'result' parameter is NULL
59 - PYGEN_NEXT (1) if generator has yielded.
60 'result' parameter is filled with yielded value. */
61PyAPI_FUNC(PySendResult) PyGen_Send(PyGenObject *, PyObject *, PyObject **);
62
Yury Selivanov5376ba92015-06-22 12:19:30 -040063#ifndef Py_LIMITED_API
64typedef struct {
65 _PyGenObject_HEAD(cr)
Nathaniel J. Smithfc2f4072018-01-21 06:44:07 -080066 PyObject *cr_origin;
Yury Selivanov5376ba92015-06-22 12:19:30 -040067} PyCoroObject;
68
69PyAPI_DATA(PyTypeObject) PyCoro_Type;
70PyAPI_DATA(PyTypeObject) _PyCoroWrapper_Type;
71
Dong-hee Nad905df72020-02-14 02:37:17 +090072#define PyCoro_CheckExact(op) Py_IS_TYPE(op, &PyCoro_Type)
Yury Selivanov5376ba92015-06-22 12:19:30 -040073PyObject *_PyCoro_GetAwaitableIter(PyObject *o);
Victor Stinner7c59d7c2020-04-28 16:32:48 +020074PyAPI_FUNC(PyObject *) PyCoro_New(PyFrameObject *,
Yury Selivanov5376ba92015-06-22 12:19:30 -040075 PyObject *name, PyObject *qualname);
Yury Selivanoveb636452016-09-08 22:01:51 -070076
77/* Asynchronous Generators */
78
79typedef struct {
80 _PyGenObject_HEAD(ag)
81 PyObject *ag_finalizer;
82
83 /* Flag is set to 1 when hooks set up by sys.set_asyncgen_hooks
84 were called on the generator, to avoid calling them more
85 than once. */
86 int ag_hooks_inited;
87
88 /* Flag is set to 1 when aclose() is called for the first time, or
89 when a StopAsyncIteration exception is raised. */
90 int ag_closed;
Yury Selivanovfc4a0442019-09-29 22:59:11 -070091
92 int ag_running_async;
Yury Selivanoveb636452016-09-08 22:01:51 -070093} PyAsyncGenObject;
94
95PyAPI_DATA(PyTypeObject) PyAsyncGen_Type;
96PyAPI_DATA(PyTypeObject) _PyAsyncGenASend_Type;
97PyAPI_DATA(PyTypeObject) _PyAsyncGenWrappedValue_Type;
98PyAPI_DATA(PyTypeObject) _PyAsyncGenAThrow_Type;
99
Victor Stinner7c59d7c2020-04-28 16:32:48 +0200100PyAPI_FUNC(PyObject *) PyAsyncGen_New(PyFrameObject *,
Yury Selivanoveb636452016-09-08 22:01:51 -0700101 PyObject *name, PyObject *qualname);
102
Dong-hee Nad905df72020-02-14 02:37:17 +0900103#define PyAsyncGen_CheckExact(op) Py_IS_TYPE(op, &PyAsyncGen_Type)
Yury Selivanoveb636452016-09-08 22:01:51 -0700104
105PyObject *_PyAsyncGenValueWrapperNew(PyObject *);
106
Yury Selivanov5376ba92015-06-22 12:19:30 -0400107#endif
108
109#undef _PyGenObject_HEAD
Martin v. Löwise440e472004-06-01 15:22:42 +0000110
111#ifdef __cplusplus
112}
113#endif
114#endif /* !Py_GENOBJECT_H */
Martin v. Löwis4d0d4712010-12-03 20:14:31 +0000115#endif /* Py_LIMITED_API */