blob: 96ed329b0d99524f4b0592bd55a9ce2ccf0ab6f0 [file] [log] [blame]
Guido van Rossumf70e43a1991-02-19 12:39:46 +00001
Guido van Rossum3f5da241990-12-20 15:06:42 +00002/* Execute compiled code */
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003
Guido van Rossum681d79a1995-07-18 14:51:37 +00004/* XXX TO DO:
Guido van Rossum681d79a1995-07-18 14:51:37 +00005 XXX speed up searching for keywords by using a dictionary
Guido van Rossum681d79a1995-07-18 14:51:37 +00006 XXX document it!
7 */
8
Thomas Wouters477c8d52006-05-27 19:21:47 +00009/* enable more aggressive intra-module optimizations, where available */
10#define PY_LOCAL_AGGRESSIVE
11
Guido van Rossumb209a111997-04-29 18:18:01 +000012#include "Python.h"
Victor Stinner4d231bc2019-11-14 13:36:21 +010013#include "pycore_call.h"
Victor Stinner09532fe2019-05-10 23:39:09 +020014#include "pycore_ceval.h"
Inada Naoki91234a12019-06-03 21:30:58 +090015#include "pycore_code.h"
Victor Stinnerbcda8f12018-11-21 22:27:47 +010016#include "pycore_object.h"
Victor Stinner438a12d2019-05-24 17:01:38 +020017#include "pycore_pyerrors.h"
18#include "pycore_pylifecycle.h"
Victor Stinner621cebe2018-11-12 16:53:38 +010019#include "pycore_pystate.h"
Victor Stinnerec13b932018-11-25 23:56:17 +010020#include "pycore_tupleobject.h"
Guido van Rossum10dc2e81990-11-18 17:27:39 +000021
Jeremy Hylton3e0055f2005-10-20 19:59:25 +000022#include "code.h"
Benjamin Peterson025e9eb2015-05-05 20:16:41 -040023#include "dictobject.h"
Guido van Rossum3f5da241990-12-20 15:06:42 +000024#include "frameobject.h"
Guido van Rossum10dc2e81990-11-18 17:27:39 +000025#include "opcode.h"
Łukasz Langaa785c872016-09-09 17:37:37 -070026#include "pydtrace.h"
Benjamin Peterson025e9eb2015-05-05 20:16:41 -040027#include "setobject.h"
Tim Peters6d6c1a32001-08-02 04:15:00 +000028#include "structmember.h"
Guido van Rossum10dc2e81990-11-18 17:27:39 +000029
Guido van Rossumc6004111993-11-05 10:22:19 +000030#include <ctype.h>
31
Guido van Rossum408027e1996-12-30 16:17:54 +000032#ifdef Py_DEBUG
Guido van Rossum96a42c81992-01-12 02:29:51 +000033/* For debugging the interpreter: */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000034#define LLTRACE 1 /* Low-level trace feature */
35#define CHECKEXC 1 /* Double-check exception checking */
Guido van Rossum10dc2e81990-11-18 17:27:39 +000036#endif
37
Victor Stinner5c75f372019-04-17 23:02:26 +020038#if !defined(Py_BUILD_CORE)
39# error "ceval.c must be build with Py_BUILD_CORE define for best performance"
40#endif
41
Guido van Rossum5b722181993-03-30 17:46:03 +000042
Guido van Rossum374a9221991-04-04 10:40:29 +000043/* Forward declarations */
Victor Stinner09532fe2019-05-10 23:39:09 +020044Py_LOCAL_INLINE(PyObject *) call_function(
45 PyThreadState *tstate, PyObject ***pp_stack,
46 Py_ssize_t oparg, PyObject *kwnames);
47static PyObject * do_call_core(
48 PyThreadState *tstate, PyObject *func,
49 PyObject *callargs, PyObject *kwdict);
Jeremy Hylton52820442001-01-03 23:52:36 +000050
Guido van Rossum0a066c01992-03-27 17:29:15 +000051#ifdef LLTRACE
Guido van Rossumc2e20742006-02-27 22:32:47 +000052static int lltrace;
Victor Stinner438a12d2019-05-24 17:01:38 +020053static int prtrace(PyThreadState *, PyObject *, const char *);
Guido van Rossum0a066c01992-03-27 17:29:15 +000054#endif
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +010055static int call_trace(Py_tracefunc, PyObject *,
56 PyThreadState *, PyFrameObject *,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000057 int, PyObject *);
Amaury Forgeot d'Arcf05149a2007-11-13 01:05:30 +000058static int call_trace_protected(Py_tracefunc, PyObject *,
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +010059 PyThreadState *, PyFrameObject *,
60 int, PyObject *);
61static void call_exc_trace(Py_tracefunc, PyObject *,
62 PyThreadState *, PyFrameObject *);
Tim Peters8a5c3c72004-04-05 19:36:21 +000063static int maybe_call_line_trace(Py_tracefunc, PyObject *,
Eric Snow2ebc5ce2017-09-07 23:51:28 -060064 PyThreadState *, PyFrameObject *,
65 int *, int *, int *);
Łukasz Langaa785c872016-09-09 17:37:37 -070066static void maybe_dtrace_line(PyFrameObject *, int *, int *, int *);
67static void dtrace_function_entry(PyFrameObject *);
68static void dtrace_function_return(PyFrameObject *);
Michael W. Hudsondd32a912002-08-15 14:59:02 +000069
Victor Stinner438a12d2019-05-24 17:01:38 +020070static PyObject * cmp_outcome(PyThreadState *, int, PyObject *, PyObject *);
71static PyObject * import_name(PyThreadState *, PyFrameObject *,
72 PyObject *, PyObject *, PyObject *);
73static PyObject * import_from(PyThreadState *, PyObject *, PyObject *);
74static int import_all_from(PyThreadState *, PyObject *, PyObject *);
75static void format_exc_check_arg(PyThreadState *, PyObject *, const char *, PyObject *);
76static void format_exc_unbound(PyThreadState *tstate, PyCodeObject *co, int oparg);
77static PyObject * unicode_concatenate(PyThreadState *, PyObject *, PyObject *,
Serhiy Storchakaab874002016-09-11 13:48:15 +030078 PyFrameObject *, const _Py_CODEUNIT *);
Victor Stinner438a12d2019-05-24 17:01:38 +020079static PyObject * special_lookup(PyThreadState *, PyObject *, _Py_Identifier *);
80static int check_args_iterable(PyThreadState *, PyObject *func, PyObject *vararg);
81static void format_kwargs_error(PyThreadState *, PyObject *func, PyObject *kwargs);
Mark Shannonfee55262019-11-21 09:11:43 +000082static void format_awaitable_error(PyThreadState *, PyTypeObject *, int, int);
Guido van Rossum374a9221991-04-04 10:40:29 +000083
Paul Prescode68140d2000-08-30 20:25:01 +000084#define NAME_ERROR_MSG \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000085 "name '%.200s' is not defined"
Paul Prescode68140d2000-08-30 20:25:01 +000086#define UNBOUNDLOCAL_ERROR_MSG \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000087 "local variable '%.200s' referenced before assignment"
Jeremy Hyltonc76770c2001-04-13 16:51:46 +000088#define UNBOUNDFREE_ERROR_MSG \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000089 "free variable '%.200s' referenced before assignment" \
90 " in enclosing scope"
Guido van Rossum374a9221991-04-04 10:40:29 +000091
Guido van Rossum950361c1997-01-24 13:49:28 +000092/* Dynamic execution profile */
93#ifdef DYNAMIC_EXECUTION_PROFILE
94#ifdef DXPAIRS
95static long dxpairs[257][256];
96#define dxp dxpairs[256]
97#else
98static long dxp[256];
99#endif
100#endif
101
Inada Naoki91234a12019-06-03 21:30:58 +0900102/* per opcode cache */
Inada Naokieddef862019-06-04 07:38:10 +0900103#ifdef Py_DEBUG
104// --with-pydebug is used to find memory leak. opcache makes it harder.
105// So we disable opcache when Py_DEBUG is defined.
106// See bpo-37146
107#define OPCACHE_MIN_RUNS 0 /* disable opcache */
108#else
Inada Naoki91234a12019-06-03 21:30:58 +0900109#define OPCACHE_MIN_RUNS 1024 /* create opcache when code executed this time */
Inada Naokieddef862019-06-04 07:38:10 +0900110#endif
Inada Naoki91234a12019-06-03 21:30:58 +0900111#define OPCACHE_STATS 0 /* Enable stats */
112
113#if OPCACHE_STATS
114static size_t opcache_code_objects = 0;
115static size_t opcache_code_objects_extra_mem = 0;
116
117static size_t opcache_global_opts = 0;
118static size_t opcache_global_hits = 0;
119static size_t opcache_global_misses = 0;
120#endif
121
Victor Stinnere225beb2019-06-03 18:14:24 +0200122#define GIL_REQUEST _Py_atomic_load_relaxed(&ceval->gil_drop_request)
Inada Naoki91234a12019-06-03 21:30:58 +0900123
Jeffrey Yasskin39370832010-05-03 19:29:34 +0000124/* This can set eval_breaker to 0 even though gil_drop_request became
125 1. We believe this is all right because the eval loop will release
126 the GIL eventually anyway. */
Victor Stinnere225beb2019-06-03 18:14:24 +0200127#define COMPUTE_EVAL_BREAKER(ceval) \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000128 _Py_atomic_store_relaxed( \
Victor Stinnere225beb2019-06-03 18:14:24 +0200129 &(ceval)->eval_breaker, \
130 GIL_REQUEST | \
131 _Py_atomic_load_relaxed(&(ceval)->signals_pending) | \
132 _Py_atomic_load_relaxed(&(ceval)->pending.calls_to_do) | \
133 (ceval)->pending.async_exc)
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000134
Victor Stinnere225beb2019-06-03 18:14:24 +0200135#define SET_GIL_DROP_REQUEST(ceval) \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000136 do { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200137 _Py_atomic_store_relaxed(&(ceval)->gil_drop_request, 1); \
138 _Py_atomic_store_relaxed(&(ceval)->eval_breaker, 1); \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000139 } while (0)
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000140
Victor Stinnere225beb2019-06-03 18:14:24 +0200141#define RESET_GIL_DROP_REQUEST(ceval) \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000142 do { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200143 _Py_atomic_store_relaxed(&(ceval)->gil_drop_request, 0); \
144 COMPUTE_EVAL_BREAKER(ceval); \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000145 } while (0)
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000146
Jeffrey Yasskin39370832010-05-03 19:29:34 +0000147/* Pending calls are only modified under pending_lock */
Victor Stinnere225beb2019-06-03 18:14:24 +0200148#define SIGNAL_PENDING_CALLS(ceval) \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000149 do { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200150 _Py_atomic_store_relaxed(&(ceval)->pending.calls_to_do, 1); \
151 _Py_atomic_store_relaxed(&(ceval)->eval_breaker, 1); \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000152 } while (0)
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000153
Victor Stinnere225beb2019-06-03 18:14:24 +0200154#define UNSIGNAL_PENDING_CALLS(ceval) \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000155 do { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200156 _Py_atomic_store_relaxed(&(ceval)->pending.calls_to_do, 0); \
157 COMPUTE_EVAL_BREAKER(ceval); \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000158 } while (0)
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000159
Victor Stinnere225beb2019-06-03 18:14:24 +0200160#define SIGNAL_PENDING_SIGNALS(ceval) \
Eric Snowfdf282d2019-01-11 14:26:55 -0700161 do { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200162 _Py_atomic_store_relaxed(&(ceval)->signals_pending, 1); \
163 _Py_atomic_store_relaxed(&(ceval)->eval_breaker, 1); \
Eric Snowfdf282d2019-01-11 14:26:55 -0700164 } while (0)
165
Victor Stinnere225beb2019-06-03 18:14:24 +0200166#define UNSIGNAL_PENDING_SIGNALS(ceval) \
Eric Snowfdf282d2019-01-11 14:26:55 -0700167 do { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200168 _Py_atomic_store_relaxed(&(ceval)->signals_pending, 0); \
169 COMPUTE_EVAL_BREAKER(ceval); \
Eric Snowfdf282d2019-01-11 14:26:55 -0700170 } while (0)
171
Victor Stinnere225beb2019-06-03 18:14:24 +0200172#define SIGNAL_ASYNC_EXC(ceval) \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000173 do { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200174 (ceval)->pending.async_exc = 1; \
175 _Py_atomic_store_relaxed(&(ceval)->eval_breaker, 1); \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000176 } while (0)
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000177
Victor Stinnere225beb2019-06-03 18:14:24 +0200178#define UNSIGNAL_ASYNC_EXC(ceval) \
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600179 do { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200180 (ceval)->pending.async_exc = 0; \
181 COMPUTE_EVAL_BREAKER(ceval); \
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600182 } while (0)
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000183
184
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000185#ifdef HAVE_ERRNO_H
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000186#include <errno.h>
Guido van Rossum2571cc81999-04-07 16:07:23 +0000187#endif
Guido van Rossum49b56061998-10-01 20:42:43 +0000188#include "pythread.h"
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000189#include "ceval_gil.h"
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000190
Tim Peters7f468f22004-10-11 02:40:51 +0000191int
192PyEval_ThreadsInitialized(void)
193{
Victor Stinner01b1cc12019-11-20 02:27:56 +0100194 _PyRuntimeState *runtime = &_PyRuntime;
195 return gil_created(&runtime->ceval.gil);
Tim Peters7f468f22004-10-11 02:40:51 +0000196}
197
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000198void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000199PyEval_InitThreads(void)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000200{
Victor Stinner09532fe2019-05-10 23:39:09 +0200201 _PyRuntimeState *runtime = &_PyRuntime;
Victor Stinnere225beb2019-06-03 18:14:24 +0200202 struct _ceval_runtime_state *ceval = &runtime->ceval;
203 struct _gil_runtime_state *gil = &ceval->gil;
Victor Stinner09532fe2019-05-10 23:39:09 +0200204 if (gil_created(gil)) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000205 return;
Victor Stinnera7126792019-03-19 14:19:38 +0100206 }
207
Inada Naoki001fee12019-02-20 10:00:09 +0900208 PyThread_init_thread();
Victor Stinner09532fe2019-05-10 23:39:09 +0200209 create_gil(gil);
210 PyThreadState *tstate = _PyRuntimeState_GetThreadState(runtime);
Victor Stinnere225beb2019-06-03 18:14:24 +0200211 take_gil(ceval, tstate);
Eric Snow8479a342019-03-08 23:44:33 -0700212
Victor Stinnere225beb2019-06-03 18:14:24 +0200213 struct _pending_calls *pending = &ceval->pending;
214 pending->lock = PyThread_allocate_lock();
215 if (pending->lock == NULL) {
216 Py_FatalError("Can't initialize threads for pending calls");
217 }
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000218}
Guido van Rossumff4949e1992-08-05 19:58:53 +0000219
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000220void
Victor Stinnere225beb2019-06-03 18:14:24 +0200221_PyEval_FiniThreads(struct _ceval_runtime_state *ceval)
Antoine Pitrou1df15362010-09-13 14:16:46 +0000222{
Victor Stinnere225beb2019-06-03 18:14:24 +0200223 struct _gil_runtime_state *gil = &ceval->gil;
Victor Stinner09532fe2019-05-10 23:39:09 +0200224 if (!gil_created(gil)) {
Antoine Pitrou1df15362010-09-13 14:16:46 +0000225 return;
Victor Stinnera7126792019-03-19 14:19:38 +0100226 }
227
Victor Stinner09532fe2019-05-10 23:39:09 +0200228 destroy_gil(gil);
229 assert(!gil_created(gil));
Victor Stinner99fcc612019-04-29 13:04:07 +0200230
Victor Stinnere225beb2019-06-03 18:14:24 +0200231 struct _pending_calls *pending = &ceval->pending;
232 if (pending->lock != NULL) {
233 PyThread_free_lock(pending->lock);
234 pending->lock = NULL;
235 }
Antoine Pitrou1df15362010-09-13 14:16:46 +0000236}
237
Joannah Nanjekyef781d202019-04-29 04:38:45 -0400238static inline void
Victor Stinner01b1cc12019-11-20 02:27:56 +0100239exit_thread_if_finalizing(PyThreadState *tstate)
Joannah Nanjekyef781d202019-04-29 04:38:45 -0400240{
Victor Stinner01b1cc12019-11-20 02:27:56 +0100241 _PyRuntimeState *runtime = tstate->interp->runtime;
Victor Stinnere225beb2019-06-03 18:14:24 +0200242 /* _Py_Finalizing is protected by the GIL */
Victor Stinner09532fe2019-05-10 23:39:09 +0200243 if (runtime->finalizing != NULL && !_Py_CURRENTLY_FINALIZING(runtime, tstate)) {
Victor Stinnere225beb2019-06-03 18:14:24 +0200244 drop_gil(&runtime->ceval, tstate);
Joannah Nanjekyef781d202019-04-29 04:38:45 -0400245 PyThread_exit_thread();
Joannah Nanjekyef781d202019-04-29 04:38:45 -0400246 }
247}
248
Antoine Pitrou1df15362010-09-13 14:16:46 +0000249void
Inada Naoki91234a12019-06-03 21:30:58 +0900250_PyEval_Fini(void)
251{
252#if OPCACHE_STATS
253 fprintf(stderr, "-- Opcode cache number of objects = %zd\n",
254 opcache_code_objects);
255
256 fprintf(stderr, "-- Opcode cache total extra mem = %zd\n",
257 opcache_code_objects_extra_mem);
258
259 fprintf(stderr, "\n");
260
261 fprintf(stderr, "-- Opcode cache LOAD_GLOBAL hits = %zd (%d%%)\n",
262 opcache_global_hits,
263 (int) (100.0 * opcache_global_hits /
264 (opcache_global_hits + opcache_global_misses)));
265
266 fprintf(stderr, "-- Opcode cache LOAD_GLOBAL misses = %zd (%d%%)\n",
267 opcache_global_misses,
268 (int) (100.0 * opcache_global_misses /
269 (opcache_global_hits + opcache_global_misses)));
270
271 fprintf(stderr, "-- Opcode cache LOAD_GLOBAL opts = %zd\n",
272 opcache_global_opts);
273
274 fprintf(stderr, "\n");
275#endif
276}
277
278void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000279PyEval_AcquireLock(void)
Guido van Rossum25ce5661997-08-02 03:10:38 +0000280{
Victor Stinner09532fe2019-05-10 23:39:09 +0200281 _PyRuntimeState *runtime = &_PyRuntime;
Victor Stinnere225beb2019-06-03 18:14:24 +0200282 struct _ceval_runtime_state *ceval = &runtime->ceval;
Victor Stinner09532fe2019-05-10 23:39:09 +0200283 PyThreadState *tstate = _PyRuntimeState_GetThreadState(runtime);
284 if (tstate == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000285 Py_FatalError("PyEval_AcquireLock: current thread state is NULL");
Victor Stinner09532fe2019-05-10 23:39:09 +0200286 }
Victor Stinnere225beb2019-06-03 18:14:24 +0200287 take_gil(ceval, tstate);
Victor Stinner01b1cc12019-11-20 02:27:56 +0100288 exit_thread_if_finalizing(tstate);
Guido van Rossum25ce5661997-08-02 03:10:38 +0000289}
290
291void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000292PyEval_ReleaseLock(void)
Guido van Rossum25ce5661997-08-02 03:10:38 +0000293{
Victor Stinner09532fe2019-05-10 23:39:09 +0200294 _PyRuntimeState *runtime = &_PyRuntime;
Victor Stinnere225beb2019-06-03 18:14:24 +0200295 PyThreadState *tstate = _PyRuntimeState_GetThreadState(runtime);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000296 /* This function must succeed when the current thread state is NULL.
Victor Stinner50b48572018-11-01 01:51:40 +0100297 We therefore avoid PyThreadState_Get() which dumps a fatal error
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000298 in debug mode.
299 */
Victor Stinnere225beb2019-06-03 18:14:24 +0200300 drop_gil(&runtime->ceval, tstate);
Guido van Rossum25ce5661997-08-02 03:10:38 +0000301}
302
303void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000304PyEval_AcquireThread(PyThreadState *tstate)
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000305{
Victor Stinner09532fe2019-05-10 23:39:09 +0200306 if (tstate == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000307 Py_FatalError("PyEval_AcquireThread: NULL new thread state");
Victor Stinner09532fe2019-05-10 23:39:09 +0200308 }
Victor Stinnere225beb2019-06-03 18:14:24 +0200309
Victor Stinner01b1cc12019-11-20 02:27:56 +0100310 _PyRuntimeState *runtime = tstate->interp->runtime;
Victor Stinnere225beb2019-06-03 18:14:24 +0200311 struct _ceval_runtime_state *ceval = &runtime->ceval;
Victor Stinner09532fe2019-05-10 23:39:09 +0200312
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000313 /* Check someone has called PyEval_InitThreads() to create the lock */
Victor Stinnere225beb2019-06-03 18:14:24 +0200314 assert(gil_created(&ceval->gil));
315 take_gil(ceval, tstate);
Victor Stinner01b1cc12019-11-20 02:27:56 +0100316 exit_thread_if_finalizing(tstate);
Victor Stinner09532fe2019-05-10 23:39:09 +0200317 if (_PyThreadState_Swap(&runtime->gilstate, tstate) != NULL) {
318 Py_FatalError("PyEval_AcquireThread: non-NULL old thread state");
319 }
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000320}
321
322void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000323PyEval_ReleaseThread(PyThreadState *tstate)
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000324{
Victor Stinner09532fe2019-05-10 23:39:09 +0200325 if (tstate == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000326 Py_FatalError("PyEval_ReleaseThread: NULL thread state");
Victor Stinner09532fe2019-05-10 23:39:09 +0200327 }
328
Victor Stinner01b1cc12019-11-20 02:27:56 +0100329 _PyRuntimeState *runtime = tstate->interp->runtime;
Victor Stinner09532fe2019-05-10 23:39:09 +0200330 PyThreadState *new_tstate = _PyThreadState_Swap(&runtime->gilstate, NULL);
331 if (new_tstate != tstate) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000332 Py_FatalError("PyEval_ReleaseThread: wrong thread state");
Victor Stinner09532fe2019-05-10 23:39:09 +0200333 }
Victor Stinnere225beb2019-06-03 18:14:24 +0200334 drop_gil(&runtime->ceval, tstate);
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000335}
Guido van Rossumfee3a2d2000-08-27 17:34:07 +0000336
Antoine Pitrouf7ecfac2017-05-28 11:35:14 +0200337/* This function is called from PyOS_AfterFork_Child to destroy all threads
338 * which are not running in the child process, and clear internal locks
339 * which might be held by those threads.
340 */
Guido van Rossumfee3a2d2000-08-27 17:34:07 +0000341
342void
Victor Stinnerd5d9e812019-05-13 12:35:37 +0200343_PyEval_ReInitThreads(_PyRuntimeState *runtime)
Guido van Rossumfee3a2d2000-08-27 17:34:07 +0000344{
Victor Stinnere225beb2019-06-03 18:14:24 +0200345 struct _ceval_runtime_state *ceval = &runtime->ceval;
346 if (!gil_created(&ceval->gil)) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000347 return;
Victor Stinner09532fe2019-05-10 23:39:09 +0200348 }
Victor Stinnere225beb2019-06-03 18:14:24 +0200349 recreate_gil(&ceval->gil);
Victor Stinner09532fe2019-05-10 23:39:09 +0200350 PyThreadState *current_tstate = _PyRuntimeState_GetThreadState(runtime);
Victor Stinnere225beb2019-06-03 18:14:24 +0200351 take_gil(ceval, current_tstate);
Eric Snow8479a342019-03-08 23:44:33 -0700352
Victor Stinnere225beb2019-06-03 18:14:24 +0200353 struct _pending_calls *pending = &ceval->pending;
Victor Stinner09532fe2019-05-10 23:39:09 +0200354 pending->lock = PyThread_allocate_lock();
355 if (pending->lock == NULL) {
Eric Snow8479a342019-03-08 23:44:33 -0700356 Py_FatalError("Can't initialize threads for pending calls");
357 }
Jesse Nollera8513972008-07-17 16:49:17 +0000358
Antoine Pitrou8408cea2013-05-05 23:47:09 +0200359 /* Destroy all threads except the current one */
Victor Stinner0fd2c302019-06-04 03:15:09 +0200360 _PyThreadState_DeleteExcept(runtime, current_tstate);
Guido van Rossumfee3a2d2000-08-27 17:34:07 +0000361}
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000362
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000363/* This function is used to signal that async exceptions are waiting to be
Zackery Spytzeef05962018-09-29 10:07:11 -0600364 raised. */
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000365
366void
Victor Stinnere225beb2019-06-03 18:14:24 +0200367_PyEval_SignalAsyncExc(struct _ceval_runtime_state *ceval)
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000368{
Victor Stinnere225beb2019-06-03 18:14:24 +0200369 SIGNAL_ASYNC_EXC(ceval);
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000370}
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000371
Guido van Rossum2fca21f71997-07-18 23:56:58 +0000372PyThreadState *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000373PyEval_SaveThread(void)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000374{
Victor Stinner09532fe2019-05-10 23:39:09 +0200375 _PyRuntimeState *runtime = &_PyRuntime;
Victor Stinnere225beb2019-06-03 18:14:24 +0200376 struct _ceval_runtime_state *ceval = &runtime->ceval;
Victor Stinner09532fe2019-05-10 23:39:09 +0200377 PyThreadState *tstate = _PyThreadState_Swap(&runtime->gilstate, NULL);
378 if (tstate == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000379 Py_FatalError("PyEval_SaveThread: NULL tstate");
Victor Stinner09532fe2019-05-10 23:39:09 +0200380 }
Victor Stinnere225beb2019-06-03 18:14:24 +0200381 assert(gil_created(&ceval->gil));
382 drop_gil(ceval, tstate);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000383 return tstate;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000384}
385
386void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000387PyEval_RestoreThread(PyThreadState *tstate)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000388{
Victor Stinner01b1cc12019-11-20 02:27:56 +0100389 _PyRuntimeState *runtime = tstate->interp->runtime;
Victor Stinner0fd2c302019-06-04 03:15:09 +0200390 struct _ceval_runtime_state *ceval = &runtime->ceval;
391
Victor Stinner09532fe2019-05-10 23:39:09 +0200392 if (tstate == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000393 Py_FatalError("PyEval_RestoreThread: NULL tstate");
Victor Stinner09532fe2019-05-10 23:39:09 +0200394 }
Victor Stinnere225beb2019-06-03 18:14:24 +0200395 assert(gil_created(&ceval->gil));
Victor Stinner2914bb32018-01-29 11:57:45 +0100396
397 int err = errno;
Victor Stinnere225beb2019-06-03 18:14:24 +0200398 take_gil(ceval, tstate);
Victor Stinner01b1cc12019-11-20 02:27:56 +0100399 exit_thread_if_finalizing(tstate);
Victor Stinner2914bb32018-01-29 11:57:45 +0100400 errno = err;
401
Victor Stinner09532fe2019-05-10 23:39:09 +0200402 _PyThreadState_Swap(&runtime->gilstate, tstate);
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000403}
404
405
Guido van Rossuma9672091994-09-14 13:31:22 +0000406/* Mechanism whereby asynchronously executing callbacks (e.g. UNIX
407 signal handlers or Mac I/O completion routines) can schedule calls
408 to a function to be called synchronously.
409 The synchronous function is called with one void* argument.
410 It should return 0 for success or -1 for failure -- failure should
411 be accompanied by an exception.
412
413 If registry succeeds, the registry function returns 0; if it fails
414 (e.g. due to too many pending calls) it returns -1 (without setting
415 an exception condition).
416
417 Note that because registry may occur from within signal handlers,
418 or other asynchronous events, calling malloc() is unsafe!
419
Guido van Rossuma9672091994-09-14 13:31:22 +0000420 Any thread can schedule pending calls, but only the main thread
421 will execute them.
Benjamin Petersone5bf3832009-01-17 23:43:58 +0000422 There is no facility to schedule calls to a particular thread, but
423 that should be easy to change, should that ever be required. In
424 that case, the static variables here should go into the python
425 threadstate.
Benjamin Petersone5bf3832009-01-17 23:43:58 +0000426*/
Guido van Rossuma9672091994-09-14 13:31:22 +0000427
Antoine Pitrouc08177a2017-06-28 23:29:29 +0200428void
Victor Stinnere225beb2019-06-03 18:14:24 +0200429_PyEval_SignalReceived(struct _ceval_runtime_state *ceval)
Antoine Pitrouc08177a2017-06-28 23:29:29 +0200430{
431 /* bpo-30703: Function called when the C signal handler of Python gets a
432 signal. We cannot queue a callback using Py_AddPendingCall() since
433 that function is not async-signal-safe. */
Victor Stinnere225beb2019-06-03 18:14:24 +0200434 SIGNAL_PENDING_SIGNALS(ceval);
Antoine Pitrouc08177a2017-06-28 23:29:29 +0200435}
436
Eric Snow5be45a62019-03-08 22:47:07 -0700437/* Push one item onto the queue while holding the lock. */
438static int
Victor Stinnere225beb2019-06-03 18:14:24 +0200439_push_pending_call(struct _pending_calls *pending,
Eric Snow842a2f02019-03-15 15:47:51 -0600440 int (*func)(void *), void *arg)
Eric Snow5be45a62019-03-08 22:47:07 -0700441{
Eric Snow842a2f02019-03-15 15:47:51 -0600442 int i = pending->last;
Eric Snow5be45a62019-03-08 22:47:07 -0700443 int j = (i + 1) % NPENDINGCALLS;
Eric Snow842a2f02019-03-15 15:47:51 -0600444 if (j == pending->first) {
Eric Snow5be45a62019-03-08 22:47:07 -0700445 return -1; /* Queue full */
446 }
Eric Snow842a2f02019-03-15 15:47:51 -0600447 pending->calls[i].func = func;
448 pending->calls[i].arg = arg;
449 pending->last = j;
Eric Snow5be45a62019-03-08 22:47:07 -0700450 return 0;
451}
452
453/* Pop one item off the queue while holding the lock. */
454static void
Victor Stinnere225beb2019-06-03 18:14:24 +0200455_pop_pending_call(struct _pending_calls *pending,
Eric Snow842a2f02019-03-15 15:47:51 -0600456 int (**func)(void *), void **arg)
Eric Snow5be45a62019-03-08 22:47:07 -0700457{
Eric Snow842a2f02019-03-15 15:47:51 -0600458 int i = pending->first;
459 if (i == pending->last) {
Eric Snow5be45a62019-03-08 22:47:07 -0700460 return; /* Queue empty */
461 }
462
Eric Snow842a2f02019-03-15 15:47:51 -0600463 *func = pending->calls[i].func;
464 *arg = pending->calls[i].arg;
465 pending->first = (i + 1) % NPENDINGCALLS;
Eric Snow5be45a62019-03-08 22:47:07 -0700466}
467
Antoine Pitroua6a4dc82017-09-07 18:56:24 +0200468/* This implementation is thread-safe. It allows
Benjamin Petersone5bf3832009-01-17 23:43:58 +0000469 scheduling to be made from any thread, and even from an executing
470 callback.
471 */
472
Benjamin Petersone5bf3832009-01-17 23:43:58 +0000473int
Victor Stinner438a12d2019-05-24 17:01:38 +0200474_PyEval_AddPendingCall(PyThreadState *tstate,
Victor Stinnere225beb2019-06-03 18:14:24 +0200475 struct _ceval_runtime_state *ceval,
Victor Stinner09532fe2019-05-10 23:39:09 +0200476 int (*func)(void *), void *arg)
Benjamin Petersone5bf3832009-01-17 23:43:58 +0000477{
Victor Stinnere225beb2019-06-03 18:14:24 +0200478 struct _pending_calls *pending = &ceval->pending;
Eric Snow842a2f02019-03-15 15:47:51 -0600479
480 PyThread_acquire_lock(pending->lock, WAIT_LOCK);
481 if (pending->finishing) {
482 PyThread_release_lock(pending->lock);
483
484 PyObject *exc, *val, *tb;
Victor Stinner438a12d2019-05-24 17:01:38 +0200485 _PyErr_Fetch(tstate, &exc, &val, &tb);
486 _PyErr_SetString(tstate, PyExc_SystemError,
Eric Snow842a2f02019-03-15 15:47:51 -0600487 "Py_AddPendingCall: cannot add pending calls "
488 "(Python shutting down)");
Victor Stinner438a12d2019-05-24 17:01:38 +0200489 _PyErr_Print(tstate);
490 _PyErr_Restore(tstate, exc, val, tb);
Eric Snow842a2f02019-03-15 15:47:51 -0600491 return -1;
492 }
Victor Stinnere225beb2019-06-03 18:14:24 +0200493 int result = _push_pending_call(pending, func, arg);
Eric Snow842a2f02019-03-15 15:47:51 -0600494 PyThread_release_lock(pending->lock);
Eric Snow5be45a62019-03-08 22:47:07 -0700495
Victor Stinnere225beb2019-06-03 18:14:24 +0200496 /* signal main loop */
497 SIGNAL_PENDING_CALLS(ceval);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000498 return result;
Benjamin Petersone5bf3832009-01-17 23:43:58 +0000499}
500
Victor Stinner09532fe2019-05-10 23:39:09 +0200501int
502Py_AddPendingCall(int (*func)(void *), void *arg)
503{
Victor Stinner438a12d2019-05-24 17:01:38 +0200504 _PyRuntimeState *runtime = &_PyRuntime;
505 PyThreadState *tstate = _PyRuntimeState_GetThreadState(runtime);
Victor Stinnere225beb2019-06-03 18:14:24 +0200506 return _PyEval_AddPendingCall(tstate, &runtime->ceval, func, arg);
Victor Stinner09532fe2019-05-10 23:39:09 +0200507}
508
Eric Snowfdf282d2019-01-11 14:26:55 -0700509static int
Victor Stinner09532fe2019-05-10 23:39:09 +0200510handle_signals(_PyRuntimeState *runtime)
Eric Snowfdf282d2019-01-11 14:26:55 -0700511{
Eric Snow5be45a62019-03-08 22:47:07 -0700512 /* Only handle signals on main thread. PyEval_InitThreads must
513 * have been called already.
514 */
Victor Stinner09532fe2019-05-10 23:39:09 +0200515 if (PyThread_get_thread_ident() != runtime->main_thread) {
Eric Snowfdf282d2019-01-11 14:26:55 -0700516 return 0;
517 }
Eric Snow64d6cc82019-02-23 15:40:43 -0700518 /*
519 * Ensure that the thread isn't currently running some other
520 * interpreter.
521 */
Victor Stinner09532fe2019-05-10 23:39:09 +0200522 PyInterpreterState *interp = _PyRuntimeState_GetThreadState(runtime)->interp;
523 if (interp != runtime->interpreters.main) {
Eric Snow64d6cc82019-02-23 15:40:43 -0700524 return 0;
525 }
Eric Snowfdf282d2019-01-11 14:26:55 -0700526
Victor Stinnere225beb2019-06-03 18:14:24 +0200527 struct _ceval_runtime_state *ceval = &runtime->ceval;
528 UNSIGNAL_PENDING_SIGNALS(ceval);
Eric Snow64d6cc82019-02-23 15:40:43 -0700529 if (_PyErr_CheckSignals() < 0) {
Victor Stinnere225beb2019-06-03 18:14:24 +0200530 SIGNAL_PENDING_SIGNALS(ceval); /* We're not done yet */
Eric Snowfdf282d2019-01-11 14:26:55 -0700531 return -1;
532 }
533 return 0;
534}
535
536static int
Victor Stinnere225beb2019-06-03 18:14:24 +0200537make_pending_calls(_PyRuntimeState *runtime)
Benjamin Petersone5bf3832009-01-17 23:43:58 +0000538{
Eric Snow6a150bc2019-06-01 15:39:46 -0600539 static int busy = 0;
Eric Snowb75b1a352019-04-12 10:20:10 -0600540
Victor Stinnere225beb2019-06-03 18:14:24 +0200541 /* only service pending calls on main thread */
542 if (PyThread_get_thread_ident() != runtime->main_thread) {
543 return 0;
544 }
545
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000546 /* don't perform recursive pending calls */
Eric Snowfdf282d2019-01-11 14:26:55 -0700547 if (busy) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000548 return 0;
Eric Snowfdf282d2019-01-11 14:26:55 -0700549 }
Charles-François Natalif23339a2011-07-23 18:15:43 +0200550 busy = 1;
Victor Stinnere225beb2019-06-03 18:14:24 +0200551 struct _ceval_runtime_state *ceval = &runtime->ceval;
Antoine Pitrouc08177a2017-06-28 23:29:29 +0200552 /* unsignal before starting to call callbacks, so that any callback
553 added in-between re-signals */
Victor Stinnere225beb2019-06-03 18:14:24 +0200554 UNSIGNAL_PENDING_CALLS(ceval);
Eric Snowfdf282d2019-01-11 14:26:55 -0700555 int res = 0;
Antoine Pitrouc08177a2017-06-28 23:29:29 +0200556
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000557 /* perform a bounded number of calls, in case of recursion */
Victor Stinnere225beb2019-06-03 18:14:24 +0200558 struct _pending_calls *pending = &ceval->pending;
Eric Snowfdf282d2019-01-11 14:26:55 -0700559 for (int i=0; i<NPENDINGCALLS; i++) {
Eric Snow5be45a62019-03-08 22:47:07 -0700560 int (*func)(void *) = NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000561 void *arg = NULL;
562
563 /* pop one item off the queue while holding the lock */
Eric Snow842a2f02019-03-15 15:47:51 -0600564 PyThread_acquire_lock(pending->lock, WAIT_LOCK);
Victor Stinnere225beb2019-06-03 18:14:24 +0200565 _pop_pending_call(pending, &func, &arg);
Eric Snow842a2f02019-03-15 15:47:51 -0600566 PyThread_release_lock(pending->lock);
Eric Snow5be45a62019-03-08 22:47:07 -0700567
Victor Stinner4d61e6e2019-03-04 14:21:28 +0100568 /* having released the lock, perform the callback */
Eric Snow5be45a62019-03-08 22:47:07 -0700569 if (func == NULL) {
Victor Stinner4d61e6e2019-03-04 14:21:28 +0100570 break;
Eric Snow5be45a62019-03-08 22:47:07 -0700571 }
Eric Snowfdf282d2019-01-11 14:26:55 -0700572 res = func(arg);
573 if (res) {
Antoine Pitrouc08177a2017-06-28 23:29:29 +0200574 goto error;
575 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000576 }
Antoine Pitrouc08177a2017-06-28 23:29:29 +0200577
Charles-François Natalif23339a2011-07-23 18:15:43 +0200578 busy = 0;
Eric Snowfdf282d2019-01-11 14:26:55 -0700579 return res;
Antoine Pitrouc08177a2017-06-28 23:29:29 +0200580
581error:
582 busy = 0;
Victor Stinnere225beb2019-06-03 18:14:24 +0200583 SIGNAL_PENDING_CALLS(ceval);
Eric Snowfdf282d2019-01-11 14:26:55 -0700584 return res;
585}
586
Eric Snow842a2f02019-03-15 15:47:51 -0600587void
Victor Stinnere225beb2019-06-03 18:14:24 +0200588_Py_FinishPendingCalls(_PyRuntimeState *runtime)
Eric Snow842a2f02019-03-15 15:47:51 -0600589{
Eric Snow842a2f02019-03-15 15:47:51 -0600590 assert(PyGILState_Check());
591
Victor Stinnere225beb2019-06-03 18:14:24 +0200592 PyThreadState *tstate = _PyRuntimeState_GetThreadState(runtime);
593 struct _pending_calls *pending = &runtime->ceval.pending;
Victor Stinner09532fe2019-05-10 23:39:09 +0200594
Eric Snow842a2f02019-03-15 15:47:51 -0600595 PyThread_acquire_lock(pending->lock, WAIT_LOCK);
596 pending->finishing = 1;
597 PyThread_release_lock(pending->lock);
598
599 if (!_Py_atomic_load_relaxed(&(pending->calls_to_do))) {
600 return;
601 }
602
Victor Stinnere225beb2019-06-03 18:14:24 +0200603 if (make_pending_calls(runtime) < 0) {
604 PyObject *exc, *val, *tb;
605 _PyErr_Fetch(tstate, &exc, &val, &tb);
606 PyErr_BadInternalCall();
607 _PyErr_ChainExceptions(exc, val, tb);
608 _PyErr_Print(tstate);
Eric Snow842a2f02019-03-15 15:47:51 -0600609 }
610}
611
Eric Snowfdf282d2019-01-11 14:26:55 -0700612/* Py_MakePendingCalls() is a simple wrapper for the sake
613 of backward-compatibility. */
614int
615Py_MakePendingCalls(void)
616{
617 assert(PyGILState_Check());
618
619 /* Python signal handler doesn't really queue a callback: it only signals
620 that a signal was received, see _PyEval_SignalReceived(). */
Victor Stinner09532fe2019-05-10 23:39:09 +0200621 _PyRuntimeState *runtime = &_PyRuntime;
622 int res = handle_signals(runtime);
Eric Snowfdf282d2019-01-11 14:26:55 -0700623 if (res != 0) {
624 return res;
625 }
626
Victor Stinnere225beb2019-06-03 18:14:24 +0200627 res = make_pending_calls(runtime);
Eric Snowb75b1a352019-04-12 10:20:10 -0600628 if (res != 0) {
629 return res;
630 }
631
632 return 0;
Benjamin Petersone5bf3832009-01-17 23:43:58 +0000633}
634
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000635/* The interpreter's recursion limit */
636
Hye-Shik Changb6fa2812005-04-04 15:49:02 +0000637#ifndef Py_DEFAULT_RECURSION_LIMIT
638#define Py_DEFAULT_RECURSION_LIMIT 1000
639#endif
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600640
Eric Snow05351c12017-09-05 21:43:08 -0700641int _Py_CheckRecursionLimit = Py_DEFAULT_RECURSION_LIMIT;
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000642
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600643void
Victor Stinnere225beb2019-06-03 18:14:24 +0200644_PyEval_Initialize(struct _ceval_runtime_state *state)
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600645{
Victor Stinnere225beb2019-06-03 18:14:24 +0200646 state->recursion_limit = Py_DEFAULT_RECURSION_LIMIT;
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600647 _Py_CheckRecursionLimit = Py_DEFAULT_RECURSION_LIMIT;
Victor Stinnere225beb2019-06-03 18:14:24 +0200648 _gil_initialize(&state->gil);
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600649}
650
Vladimir Marangozov7bd25be2000-09-01 11:07:19 +0000651int
652Py_GetRecursionLimit(void)
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000653{
Victor Stinner01b1cc12019-11-20 02:27:56 +0100654 struct _ceval_runtime_state *ceval = &_PyRuntime.ceval;
655 return ceval->recursion_limit;
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000656}
657
Vladimir Marangozov7bd25be2000-09-01 11:07:19 +0000658void
659Py_SetRecursionLimit(int new_limit)
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000660{
Victor Stinnere225beb2019-06-03 18:14:24 +0200661 struct _ceval_runtime_state *ceval = &_PyRuntime.ceval;
662 ceval->recursion_limit = new_limit;
663 _Py_CheckRecursionLimit = ceval->recursion_limit;
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000664}
665
Victor Stinnerbe434dc2019-11-05 00:51:22 +0100666/* The function _Py_EnterRecursiveCall() only calls _Py_CheckRecursiveCall()
Armin Rigo2b3eb402003-10-28 12:05:48 +0000667 if the recursion_depth reaches _Py_CheckRecursionLimit.
668 If USE_STACKCHECK, the macro decrements _Py_CheckRecursionLimit
669 to guarantee that _Py_CheckRecursiveCall() is regularly called.
670 Without USE_STACKCHECK, there is no need for this. */
671int
Victor Stinnerbe434dc2019-11-05 00:51:22 +0100672_Py_CheckRecursiveCall(PyThreadState *tstate, const char *where)
Armin Rigo2b3eb402003-10-28 12:05:48 +0000673{
Victor Stinner01b1cc12019-11-20 02:27:56 +0100674 _PyRuntimeState *runtime = tstate->interp->runtime;
Victor Stinner09532fe2019-05-10 23:39:09 +0200675 int recursion_limit = runtime->ceval.recursion_limit;
Armin Rigo2b3eb402003-10-28 12:05:48 +0000676
677#ifdef USE_STACKCHECK
pdox18967932017-10-25 23:03:01 -0700678 tstate->stackcheck_counter = 0;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000679 if (PyOS_CheckStack()) {
680 --tstate->recursion_depth;
Victor Stinner438a12d2019-05-24 17:01:38 +0200681 _PyErr_SetString(tstate, PyExc_MemoryError, "Stack overflow");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000682 return -1;
683 }
pdox18967932017-10-25 23:03:01 -0700684 /* Needed for ABI backwards-compatibility (see bpo-31857) */
Eric Snow05351c12017-09-05 21:43:08 -0700685 _Py_CheckRecursionLimit = recursion_limit;
pdox18967932017-10-25 23:03:01 -0700686#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000687 if (tstate->recursion_critical)
688 /* Somebody asked that we don't check for recursion. */
689 return 0;
690 if (tstate->overflowed) {
691 if (tstate->recursion_depth > recursion_limit + 50) {
692 /* Overflowing while handling an overflow. Give up. */
693 Py_FatalError("Cannot recover from stack overflow.");
694 }
695 return 0;
696 }
697 if (tstate->recursion_depth > recursion_limit) {
698 --tstate->recursion_depth;
699 tstate->overflowed = 1;
Victor Stinner438a12d2019-05-24 17:01:38 +0200700 _PyErr_Format(tstate, PyExc_RecursionError,
701 "maximum recursion depth exceeded%s",
702 where);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000703 return -1;
704 }
705 return 0;
Armin Rigo2b3eb402003-10-28 12:05:48 +0000706}
707
Victor Stinner09532fe2019-05-10 23:39:09 +0200708static int do_raise(PyThreadState *tstate, PyObject *exc, PyObject *cause);
Victor Stinner438a12d2019-05-24 17:01:38 +0200709static int unpack_iterable(PyThreadState *, PyObject *, int, int, PyObject **);
Guido van Rossum1aa14831997-01-21 05:34:20 +0000710
Victor Stinnere225beb2019-06-03 18:14:24 +0200711#define _Py_TracingPossible(ceval) ((ceval)->tracing_possible)
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000712
Guido van Rossum374a9221991-04-04 10:40:29 +0000713
Guido van Rossumb209a111997-04-29 18:18:01 +0000714PyObject *
Martin v. Löwis4d0d4712010-12-03 20:14:31 +0000715PyEval_EvalCode(PyObject *co, PyObject *globals, PyObject *locals)
Guido van Rossum681d79a1995-07-18 14:51:37 +0000716{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000717 return PyEval_EvalCodeEx(co,
718 globals, locals,
719 (PyObject **)NULL, 0,
720 (PyObject **)NULL, 0,
721 (PyObject **)NULL, 0,
722 NULL, NULL);
Guido van Rossum681d79a1995-07-18 14:51:37 +0000723}
724
725
726/* Interpreter main loop */
727
Martin v. Löwis8d97e332004-06-27 15:43:12 +0000728PyObject *
Victor Stinnerb9e68122019-11-14 12:20:46 +0100729PyEval_EvalFrame(PyFrameObject *f)
730{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000731 /* This is for backward compatibility with extension modules that
732 used this API; core interpreter code should call
733 PyEval_EvalFrameEx() */
Victor Stinnerb9e68122019-11-14 12:20:46 +0100734 PyThreadState *tstate = _PyThreadState_GET();
735 return _PyEval_EvalFrame(tstate, f, 0);
Phillip J. Eby0d6615f2005-08-02 00:46:46 +0000736}
737
738PyObject *
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000739PyEval_EvalFrameEx(PyFrameObject *f, int throwflag)
Guido van Rossum374a9221991-04-04 10:40:29 +0000740{
Victor Stinnerb9e68122019-11-14 12:20:46 +0100741 PyThreadState *tstate = _PyThreadState_GET();
742 return _PyEval_EvalFrame(tstate, f, throwflag);
Brett Cannon3cebf932016-09-05 15:33:46 -0700743}
744
Victor Stinnerc6944e72016-11-11 02:13:35 +0100745PyObject* _Py_HOT_FUNCTION
Brett Cannon3cebf932016-09-05 15:33:46 -0700746_PyEval_EvalFrameDefault(PyFrameObject *f, int throwflag)
747{
Guido van Rossum950361c1997-01-24 13:49:28 +0000748#ifdef DXPAIRS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000749 int lastopcode = 0;
Guido van Rossum950361c1997-01-24 13:49:28 +0000750#endif
Antoine Pitrou9ed5f272013-08-13 20:18:52 +0200751 PyObject **stack_pointer; /* Next free slot in value stack */
Serhiy Storchakaab874002016-09-11 13:48:15 +0300752 const _Py_CODEUNIT *next_instr;
Antoine Pitrou9ed5f272013-08-13 20:18:52 +0200753 int opcode; /* Current opcode */
754 int oparg; /* Current opcode argument, if any */
Antoine Pitrou9ed5f272013-08-13 20:18:52 +0200755 PyObject **fastlocals, **freevars;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000756 PyObject *retval = NULL; /* Return value */
Victor Stinner09532fe2019-05-10 23:39:09 +0200757 _PyRuntimeState * const runtime = &_PyRuntime;
758 PyThreadState * const tstate = _PyRuntimeState_GetThreadState(runtime);
Victor Stinnere225beb2019-06-03 18:14:24 +0200759 struct _ceval_runtime_state * const ceval = &runtime->ceval;
760 _Py_atomic_int * const eval_breaker = &ceval->eval_breaker;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000761 PyCodeObject *co;
Michael W. Hudsondd32a912002-08-15 14:59:02 +0000762
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000763 /* when tracing we set things up so that
Michael W. Hudsondd32a912002-08-15 14:59:02 +0000764
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000765 not (instr_lb <= current_bytecode_offset < instr_ub)
Michael W. Hudsondd32a912002-08-15 14:59:02 +0000766
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000767 is true when the line being executed has changed. The
768 initial values are such as to make this false the first
769 time it is tested. */
770 int instr_ub = -1, instr_lb = 0, instr_prev = -1;
Michael W. Hudsondd32a912002-08-15 14:59:02 +0000771
Serhiy Storchakaab874002016-09-11 13:48:15 +0300772 const _Py_CODEUNIT *first_instr;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000773 PyObject *names;
774 PyObject *consts;
Inada Naoki91234a12019-06-03 21:30:58 +0900775 _PyOpcache *co_opcache;
Guido van Rossum374a9221991-04-04 10:40:29 +0000776
Brett Cannon368b4b72012-04-02 12:17:59 -0400777#ifdef LLTRACE
Victor Stinner3c1e4812012-03-26 22:10:51 +0200778 _Py_IDENTIFIER(__ltrace__);
Brett Cannon368b4b72012-04-02 12:17:59 -0400779#endif
Victor Stinner3c1e4812012-03-26 22:10:51 +0200780
Antoine Pitroub52ec782009-01-25 16:34:23 +0000781/* Computed GOTOs, or
782 the-optimization-commonly-but-improperly-known-as-"threaded code"
783 using gcc's labels-as-values extension
784 (http://gcc.gnu.org/onlinedocs/gcc/Labels-as-Values.html).
785
786 The traditional bytecode evaluation loop uses a "switch" statement, which
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000787 decent compilers will optimize as a single indirect branch instruction
Antoine Pitroub52ec782009-01-25 16:34:23 +0000788 combined with a lookup table of jump addresses. However, since the
789 indirect jump instruction is shared by all opcodes, the CPU will have a
790 hard time making the right prediction for where to jump next (actually,
791 it will be always wrong except in the uncommon case of a sequence of
792 several identical opcodes).
793
794 "Threaded code" in contrast, uses an explicit jump table and an explicit
795 indirect jump instruction at the end of each opcode. Since the jump
796 instruction is at a different address for each opcode, the CPU will make a
797 separate prediction for each of these instructions, which is equivalent to
798 predicting the second opcode of each opcode pair. These predictions have
799 a much better chance to turn out valid, especially in small bytecode loops.
800
801 A mispredicted branch on a modern CPU flushes the whole pipeline and
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000802 can cost several CPU cycles (depending on the pipeline depth),
Antoine Pitroub52ec782009-01-25 16:34:23 +0000803 and potentially many more instructions (depending on the pipeline width).
804 A correctly predicted branch, however, is nearly free.
805
806 At the time of this writing, the "threaded code" version is up to 15-20%
807 faster than the normal "switch" version, depending on the compiler and the
808 CPU architecture.
809
810 We disable the optimization if DYNAMIC_EXECUTION_PROFILE is defined,
811 because it would render the measurements invalid.
812
813
814 NOTE: care must be taken that the compiler doesn't try to "optimize" the
815 indirect jumps by sharing them between all opcodes. Such optimizations
816 can be disabled on gcc by using the -fno-gcse flag (or possibly
817 -fno-crossjumping).
818*/
819
Antoine Pitrou042b1282010-08-13 21:15:58 +0000820#ifdef DYNAMIC_EXECUTION_PROFILE
Antoine Pitroub52ec782009-01-25 16:34:23 +0000821#undef USE_COMPUTED_GOTOS
Antoine Pitrou042b1282010-08-13 21:15:58 +0000822#define USE_COMPUTED_GOTOS 0
Antoine Pitroub52ec782009-01-25 16:34:23 +0000823#endif
824
Antoine Pitrou042b1282010-08-13 21:15:58 +0000825#ifdef HAVE_COMPUTED_GOTOS
826 #ifndef USE_COMPUTED_GOTOS
827 #define USE_COMPUTED_GOTOS 1
828 #endif
829#else
830 #if defined(USE_COMPUTED_GOTOS) && USE_COMPUTED_GOTOS
831 #error "Computed gotos are not supported on this compiler."
832 #endif
833 #undef USE_COMPUTED_GOTOS
834 #define USE_COMPUTED_GOTOS 0
835#endif
836
837#if USE_COMPUTED_GOTOS
Antoine Pitroub52ec782009-01-25 16:34:23 +0000838/* Import the static jump table */
839#include "opcode_targets.h"
840
Antoine Pitroub52ec782009-01-25 16:34:23 +0000841#define TARGET(op) \
Benjamin Petersonddd19492018-09-16 22:38:02 -0700842 op: \
843 TARGET_##op
Antoine Pitroub52ec782009-01-25 16:34:23 +0000844
Antoine Pitroub52ec782009-01-25 16:34:23 +0000845#ifdef LLTRACE
846#define FAST_DISPATCH() \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000847 { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200848 if (!lltrace && !_Py_TracingPossible(ceval) && !PyDTrace_LINE_ENABLED()) { \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000849 f->f_lasti = INSTR_OFFSET(); \
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +0300850 NEXTOPARG(); \
Serhiy Storchakab0f80b02016-05-24 09:15:14 +0300851 goto *opcode_targets[opcode]; \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000852 } \
853 goto fast_next_opcode; \
854 }
Antoine Pitroub52ec782009-01-25 16:34:23 +0000855#else
856#define FAST_DISPATCH() \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000857 { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200858 if (!_Py_TracingPossible(ceval) && !PyDTrace_LINE_ENABLED()) { \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000859 f->f_lasti = INSTR_OFFSET(); \
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +0300860 NEXTOPARG(); \
Serhiy Storchakab0f80b02016-05-24 09:15:14 +0300861 goto *opcode_targets[opcode]; \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000862 } \
863 goto fast_next_opcode; \
864 }
Antoine Pitroub52ec782009-01-25 16:34:23 +0000865#endif
866
Victor Stinner09532fe2019-05-10 23:39:09 +0200867#define DISPATCH() \
868 { \
869 if (!_Py_atomic_load_relaxed(eval_breaker)) { \
870 FAST_DISPATCH(); \
871 } \
872 continue; \
873 }
874
Antoine Pitroub52ec782009-01-25 16:34:23 +0000875#else
Benjamin Petersonddd19492018-09-16 22:38:02 -0700876#define TARGET(op) op
Antoine Pitroub52ec782009-01-25 16:34:23 +0000877#define FAST_DISPATCH() goto fast_next_opcode
Victor Stinner09532fe2019-05-10 23:39:09 +0200878#define DISPATCH() continue
Antoine Pitroub52ec782009-01-25 16:34:23 +0000879#endif
880
881
Neal Norwitza81d2202002-07-14 00:27:26 +0000882/* Tuple access macros */
883
884#ifndef Py_DEBUG
885#define GETITEM(v, i) PyTuple_GET_ITEM((PyTupleObject *)(v), (i))
886#else
887#define GETITEM(v, i) PyTuple_GetItem((v), (i))
888#endif
889
Guido van Rossum374a9221991-04-04 10:40:29 +0000890/* Code access macros */
891
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +0300892/* The integer overflow is checked by an assertion below. */
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600893#define INSTR_OFFSET() \
894 (sizeof(_Py_CODEUNIT) * (int)(next_instr - first_instr))
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +0300895#define NEXTOPARG() do { \
Serhiy Storchakaab874002016-09-11 13:48:15 +0300896 _Py_CODEUNIT word = *next_instr; \
897 opcode = _Py_OPCODE(word); \
898 oparg = _Py_OPARG(word); \
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +0300899 next_instr++; \
900 } while (0)
Serhiy Storchakaab874002016-09-11 13:48:15 +0300901#define JUMPTO(x) (next_instr = first_instr + (x) / sizeof(_Py_CODEUNIT))
902#define JUMPBY(x) (next_instr += (x) / sizeof(_Py_CODEUNIT))
Guido van Rossum374a9221991-04-04 10:40:29 +0000903
Raymond Hettingerf606f872003-03-16 03:11:04 +0000904/* OpCode prediction macros
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000905 Some opcodes tend to come in pairs thus making it possible to
906 predict the second code when the first is run. For example,
Serhiy Storchakada9c5132016-06-27 18:58:57 +0300907 COMPARE_OP is often followed by POP_JUMP_IF_FALSE or POP_JUMP_IF_TRUE.
Raymond Hettingerf606f872003-03-16 03:11:04 +0000908
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000909 Verifying the prediction costs a single high-speed test of a register
910 variable against a constant. If the pairing was good, then the
911 processor's own internal branch predication has a high likelihood of
912 success, resulting in a nearly zero-overhead transition to the
913 next opcode. A successful prediction saves a trip through the eval-loop
Serhiy Storchakab0f80b02016-05-24 09:15:14 +0300914 including its unpredictable switch-case branch. Combined with the
915 processor's internal branch prediction, a successful PREDICT has the
916 effect of making the two opcodes run as if they were a single new opcode
917 with the bodies combined.
Raymond Hettingerf606f872003-03-16 03:11:04 +0000918
Georg Brandl86b2fb92008-07-16 03:43:04 +0000919 If collecting opcode statistics, your choices are to either keep the
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000920 predictions turned-on and interpret the results as if some opcodes
921 had been combined or turn-off predictions so that the opcode frequency
922 counter updates for both opcodes.
Antoine Pitroub52ec782009-01-25 16:34:23 +0000923
924 Opcode prediction is disabled with threaded code, since the latter allows
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000925 the CPU to record separate branch prediction information for each
926 opcode.
Antoine Pitroub52ec782009-01-25 16:34:23 +0000927
Raymond Hettingerf606f872003-03-16 03:11:04 +0000928*/
929
Antoine Pitrou042b1282010-08-13 21:15:58 +0000930#if defined(DYNAMIC_EXECUTION_PROFILE) || USE_COMPUTED_GOTOS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000931#define PREDICT(op) if (0) goto PRED_##op
Raymond Hettingera7216982004-02-08 19:59:27 +0000932#else
Serhiy Storchakab0f80b02016-05-24 09:15:14 +0300933#define PREDICT(op) \
934 do{ \
Serhiy Storchakaab874002016-09-11 13:48:15 +0300935 _Py_CODEUNIT word = *next_instr; \
936 opcode = _Py_OPCODE(word); \
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +0300937 if (opcode == op){ \
Serhiy Storchakaab874002016-09-11 13:48:15 +0300938 oparg = _Py_OPARG(word); \
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +0300939 next_instr++; \
Serhiy Storchakab0f80b02016-05-24 09:15:14 +0300940 goto PRED_##op; \
941 } \
942 } while(0)
Antoine Pitroub52ec782009-01-25 16:34:23 +0000943#endif
Serhiy Storchakab0f80b02016-05-24 09:15:14 +0300944#define PREDICTED(op) PRED_##op:
Antoine Pitroub52ec782009-01-25 16:34:23 +0000945
Raymond Hettingerf606f872003-03-16 03:11:04 +0000946
Guido van Rossum374a9221991-04-04 10:40:29 +0000947/* Stack manipulation macros */
948
Martin v. Löwis18e16552006-02-15 17:27:45 +0000949/* The stack can grow at most MAXINT deep, as co_nlocals and
950 co_stacksize are ints. */
Stefan Krahb7e10102010-06-23 18:42:39 +0000951#define STACK_LEVEL() ((int)(stack_pointer - f->f_valuestack))
952#define EMPTY() (STACK_LEVEL() == 0)
953#define TOP() (stack_pointer[-1])
954#define SECOND() (stack_pointer[-2])
955#define THIRD() (stack_pointer[-3])
956#define FOURTH() (stack_pointer[-4])
957#define PEEK(n) (stack_pointer[-(n)])
958#define SET_TOP(v) (stack_pointer[-1] = (v))
959#define SET_SECOND(v) (stack_pointer[-2] = (v))
960#define SET_THIRD(v) (stack_pointer[-3] = (v))
961#define SET_FOURTH(v) (stack_pointer[-4] = (v))
962#define SET_VALUE(n, v) (stack_pointer[-(n)] = (v))
963#define BASIC_STACKADJ(n) (stack_pointer += n)
964#define BASIC_PUSH(v) (*stack_pointer++ = (v))
965#define BASIC_POP() (*--stack_pointer)
Guido van Rossum374a9221991-04-04 10:40:29 +0000966
Guido van Rossum96a42c81992-01-12 02:29:51 +0000967#ifdef LLTRACE
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000968#define PUSH(v) { (void)(BASIC_PUSH(v), \
Victor Stinner438a12d2019-05-24 17:01:38 +0200969 lltrace && prtrace(tstate, TOP(), "push")); \
Stefan Krahb7e10102010-06-23 18:42:39 +0000970 assert(STACK_LEVEL() <= co->co_stacksize); }
Victor Stinner438a12d2019-05-24 17:01:38 +0200971#define POP() ((void)(lltrace && prtrace(tstate, TOP(), "pop")), \
Stefan Krahb7e10102010-06-23 18:42:39 +0000972 BASIC_POP())
costypetrisor8ed317f2018-07-31 20:55:14 +0000973#define STACK_GROW(n) do { \
974 assert(n >= 0); \
975 (void)(BASIC_STACKADJ(n), \
Victor Stinner438a12d2019-05-24 17:01:38 +0200976 lltrace && prtrace(tstate, TOP(), "stackadj")); \
costypetrisor8ed317f2018-07-31 20:55:14 +0000977 assert(STACK_LEVEL() <= co->co_stacksize); \
978 } while (0)
979#define STACK_SHRINK(n) do { \
980 assert(n >= 0); \
Victor Stinner438a12d2019-05-24 17:01:38 +0200981 (void)(lltrace && prtrace(tstate, TOP(), "stackadj")); \
costypetrisor8ed317f2018-07-31 20:55:14 +0000982 (void)(BASIC_STACKADJ(-n)); \
983 assert(STACK_LEVEL() <= co->co_stacksize); \
984 } while (0)
Christian Heimes0449f632007-12-15 01:27:15 +0000985#define EXT_POP(STACK_POINTER) ((void)(lltrace && \
Victor Stinner438a12d2019-05-24 17:01:38 +0200986 prtrace(tstate, (STACK_POINTER)[-1], "ext_pop")), \
Stefan Krahb7e10102010-06-23 18:42:39 +0000987 *--(STACK_POINTER))
Guido van Rossum374a9221991-04-04 10:40:29 +0000988#else
Stefan Krahb7e10102010-06-23 18:42:39 +0000989#define PUSH(v) BASIC_PUSH(v)
990#define POP() BASIC_POP()
costypetrisor8ed317f2018-07-31 20:55:14 +0000991#define STACK_GROW(n) BASIC_STACKADJ(n)
992#define STACK_SHRINK(n) BASIC_STACKADJ(-n)
Guido van Rossumc2e20742006-02-27 22:32:47 +0000993#define EXT_POP(STACK_POINTER) (*--(STACK_POINTER))
Guido van Rossum374a9221991-04-04 10:40:29 +0000994#endif
995
Guido van Rossum681d79a1995-07-18 14:51:37 +0000996/* Local variable macros */
997
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000998#define GETLOCAL(i) (fastlocals[i])
Guido van Rossumcfbf1a32002-03-28 20:17:52 +0000999
1000/* The SETLOCAL() macro must not DECREF the local variable in-place and
1001 then store the new value; it must copy the old value to a temporary
1002 value, then store the new value, and then DECREF the temporary value.
1003 This is because it is possible that during the DECREF the frame is
1004 accessed by other code (e.g. a __del__ method or gc.collect()) and the
1005 variable would be pointing to already-freed memory. */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001006#define SETLOCAL(i, value) do { PyObject *tmp = GETLOCAL(i); \
Stefan Krahb7e10102010-06-23 18:42:39 +00001007 GETLOCAL(i) = value; \
1008 Py_XDECREF(tmp); } while (0)
Guido van Rossum681d79a1995-07-18 14:51:37 +00001009
Benjamin Petersoneec3d712008-06-11 15:59:43 +00001010
1011#define UNWIND_BLOCK(b) \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001012 while (STACK_LEVEL() > (b)->b_level) { \
1013 PyObject *v = POP(); \
1014 Py_XDECREF(v); \
1015 }
Benjamin Petersoneec3d712008-06-11 15:59:43 +00001016
1017#define UNWIND_EXCEPT_HANDLER(b) \
Serhiy Storchakab0f80b02016-05-24 09:15:14 +03001018 do { \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001019 PyObject *type, *value, *traceback; \
Mark Shannonae3087c2017-10-22 22:41:51 +01001020 _PyErr_StackItem *exc_info; \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001021 assert(STACK_LEVEL() >= (b)->b_level + 3); \
1022 while (STACK_LEVEL() > (b)->b_level + 3) { \
1023 value = POP(); \
1024 Py_XDECREF(value); \
1025 } \
Mark Shannonae3087c2017-10-22 22:41:51 +01001026 exc_info = tstate->exc_info; \
1027 type = exc_info->exc_type; \
1028 value = exc_info->exc_value; \
1029 traceback = exc_info->exc_traceback; \
1030 exc_info->exc_type = POP(); \
1031 exc_info->exc_value = POP(); \
1032 exc_info->exc_traceback = POP(); \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001033 Py_XDECREF(type); \
1034 Py_XDECREF(value); \
1035 Py_XDECREF(traceback); \
Serhiy Storchakab0f80b02016-05-24 09:15:14 +03001036 } while(0)
Benjamin Petersoneec3d712008-06-11 15:59:43 +00001037
Inada Naoki91234a12019-06-03 21:30:58 +09001038 /* macros for opcode cache */
1039#define OPCACHE_CHECK() \
1040 do { \
1041 co_opcache = NULL; \
1042 if (co->co_opcache != NULL) { \
1043 unsigned char co_opt_offset = \
1044 co->co_opcache_map[next_instr - first_instr]; \
1045 if (co_opt_offset > 0) { \
1046 assert(co_opt_offset <= co->co_opcache_size); \
1047 co_opcache = &co->co_opcache[co_opt_offset - 1]; \
1048 assert(co_opcache != NULL); \
Inada Naoki91234a12019-06-03 21:30:58 +09001049 } \
1050 } \
1051 } while (0)
1052
1053#if OPCACHE_STATS
1054
1055#define OPCACHE_STAT_GLOBAL_HIT() \
1056 do { \
1057 if (co->co_opcache != NULL) opcache_global_hits++; \
1058 } while (0)
1059
1060#define OPCACHE_STAT_GLOBAL_MISS() \
1061 do { \
1062 if (co->co_opcache != NULL) opcache_global_misses++; \
1063 } while (0)
1064
1065#define OPCACHE_STAT_GLOBAL_OPT() \
1066 do { \
1067 if (co->co_opcache != NULL) opcache_global_opts++; \
1068 } while (0)
1069
1070#else /* OPCACHE_STATS */
1071
1072#define OPCACHE_STAT_GLOBAL_HIT()
1073#define OPCACHE_STAT_GLOBAL_MISS()
1074#define OPCACHE_STAT_GLOBAL_OPT()
1075
1076#endif
1077
Guido van Rossuma027efa1997-05-05 20:56:21 +00001078/* Start of code */
1079
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001080 /* push frame */
Victor Stinnerbe434dc2019-11-05 00:51:22 +01001081 if (_Py_EnterRecursiveCall(tstate, "")) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001082 return NULL;
Victor Stinnerbe434dc2019-11-05 00:51:22 +01001083 }
Guido van Rossum8861b741996-07-30 16:49:37 +00001084
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001085 tstate->frame = f;
Tim Peters5ca576e2001-06-18 22:08:13 +00001086
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001087 if (tstate->use_tracing) {
1088 if (tstate->c_tracefunc != NULL) {
1089 /* tstate->c_tracefunc, if defined, is a
1090 function that will be called on *every* entry
1091 to a code block. Its return value, if not
1092 None, is a function that will be called at
1093 the start of each executed line of code.
1094 (Actually, the function must return itself
1095 in order to continue tracing.) The trace
1096 functions are called with three arguments:
1097 a pointer to the current frame, a string
1098 indicating why the function is called, and
1099 an argument which depends on the situation.
1100 The global trace function is also called
1101 whenever an exception is detected. */
1102 if (call_trace_protected(tstate->c_tracefunc,
1103 tstate->c_traceobj,
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01001104 tstate, f, PyTrace_CALL, Py_None)) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001105 /* Trace function raised an error */
1106 goto exit_eval_frame;
1107 }
1108 }
1109 if (tstate->c_profilefunc != NULL) {
1110 /* Similar for c_profilefunc, except it needn't
1111 return itself and isn't called for "line" events */
1112 if (call_trace_protected(tstate->c_profilefunc,
1113 tstate->c_profileobj,
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01001114 tstate, f, PyTrace_CALL, Py_None)) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001115 /* Profile function raised an error */
1116 goto exit_eval_frame;
1117 }
1118 }
1119 }
Neil Schemenauer6c0f2002001-09-04 19:03:35 +00001120
Łukasz Langaa785c872016-09-09 17:37:37 -07001121 if (PyDTrace_FUNCTION_ENTRY_ENABLED())
1122 dtrace_function_entry(f);
1123
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001124 co = f->f_code;
1125 names = co->co_names;
1126 consts = co->co_consts;
1127 fastlocals = f->f_localsplus;
1128 freevars = f->f_localsplus + co->co_nlocals;
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +03001129 assert(PyBytes_Check(co->co_code));
1130 assert(PyBytes_GET_SIZE(co->co_code) <= INT_MAX);
Serhiy Storchakaab874002016-09-11 13:48:15 +03001131 assert(PyBytes_GET_SIZE(co->co_code) % sizeof(_Py_CODEUNIT) == 0);
1132 assert(_Py_IS_ALIGNED(PyBytes_AS_STRING(co->co_code), sizeof(_Py_CODEUNIT)));
1133 first_instr = (_Py_CODEUNIT *) PyBytes_AS_STRING(co->co_code);
Serhiy Storchakab0f80b02016-05-24 09:15:14 +03001134 /*
1135 f->f_lasti refers to the index of the last instruction,
1136 unless it's -1 in which case next_instr should be first_instr.
Michael W. Hudson019a78e2002-11-08 12:53:11 +00001137
Serhiy Storchakab0f80b02016-05-24 09:15:14 +03001138 YIELD_FROM sets f_lasti to itself, in order to repeatedly yield
Benjamin Peterson2afe6ae2012-03-15 15:37:39 -05001139 multiple values.
Thomas Wouters902d6eb2007-01-09 23:18:33 +00001140
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001141 When the PREDICT() macros are enabled, some opcode pairs follow in
1142 direct succession without updating f->f_lasti. A successful
1143 prediction effectively links the two codes together as if they
1144 were a single new opcode; accordingly,f->f_lasti will point to
1145 the first code in the pair (for instance, GET_ITER followed by
1146 FOR_ITER is effectively a single opcode and f->f_lasti will point
Serhiy Storchakab0f80b02016-05-24 09:15:14 +03001147 to the beginning of the combined pair.)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001148 */
Serhiy Storchakaab874002016-09-11 13:48:15 +03001149 assert(f->f_lasti >= -1);
Serhiy Storchakab0f80b02016-05-24 09:15:14 +03001150 next_instr = first_instr;
1151 if (f->f_lasti >= 0) {
Serhiy Storchakaab874002016-09-11 13:48:15 +03001152 assert(f->f_lasti % sizeof(_Py_CODEUNIT) == 0);
1153 next_instr += f->f_lasti / sizeof(_Py_CODEUNIT) + 1;
Serhiy Storchakab0f80b02016-05-24 09:15:14 +03001154 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001155 stack_pointer = f->f_stacktop;
1156 assert(stack_pointer != NULL);
1157 f->f_stacktop = NULL; /* remains NULL unless yield suspends frame */
Antoine Pitrou58720d62013-08-05 23:26:40 +02001158 f->f_executing = 1;
Michael W. Hudson019a78e2002-11-08 12:53:11 +00001159
Inada Naoki91234a12019-06-03 21:30:58 +09001160 if (co->co_opcache_flag < OPCACHE_MIN_RUNS) {
1161 co->co_opcache_flag++;
1162 if (co->co_opcache_flag == OPCACHE_MIN_RUNS) {
1163 if (_PyCode_InitOpcache(co) < 0) {
1164 return NULL;
1165 }
1166#if OPCACHE_STATS
1167 opcache_code_objects_extra_mem +=
1168 PyBytes_Size(co->co_code) / sizeof(_Py_CODEUNIT) +
1169 sizeof(_PyOpcache) * co->co_opcache_size;
1170 opcache_code_objects++;
1171#endif
1172 }
1173 }
Benjamin Petersoneec3d712008-06-11 15:59:43 +00001174
Tim Peters5ca576e2001-06-18 22:08:13 +00001175#ifdef LLTRACE
Victor Stinner3c1e4812012-03-26 22:10:51 +02001176 lltrace = _PyDict_GetItemId(f->f_globals, &PyId___ltrace__) != NULL;
Tim Peters5ca576e2001-06-18 22:08:13 +00001177#endif
Guido van Rossumac7be682001-01-17 15:42:30 +00001178
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001179 if (throwflag) /* support for generator.throw() */
1180 goto error;
Thomas Wouters477c8d52006-05-27 19:21:47 +00001181
Victor Stinnerace47d72013-07-18 01:41:08 +02001182#ifdef Py_DEBUG
1183 /* PyEval_EvalFrameEx() must not be called with an exception set,
Victor Stinnera8cb5152017-01-18 14:12:51 +01001184 because it can clear it (directly or indirectly) and so the
Martin Panter9955a372015-10-07 10:26:23 +00001185 caller loses its exception */
Victor Stinner438a12d2019-05-24 17:01:38 +02001186 assert(!_PyErr_Occurred(tstate));
Victor Stinnerace47d72013-07-18 01:41:08 +02001187#endif
1188
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02001189main_loop:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001190 for (;;) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001191 assert(stack_pointer >= f->f_valuestack); /* else underflow */
1192 assert(STACK_LEVEL() <= co->co_stacksize); /* else overflow */
Victor Stinner438a12d2019-05-24 17:01:38 +02001193 assert(!_PyErr_Occurred(tstate));
Michael W. Hudsondd32a912002-08-15 14:59:02 +00001194
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001195 /* Do periodic things. Doing this every time through
1196 the loop would add too much overhead, so we do it
1197 only every Nth instruction. We also do it if
1198 ``pendingcalls_to_do'' is set, i.e. when an asynchronous
1199 event needs attention (e.g. a signal handler or
1200 async I/O handler); see Py_AddPendingCall() and
1201 Py_MakePendingCalls() above. */
Guido van Rossumac7be682001-01-17 15:42:30 +00001202
Eric Snow7bda9de2019-03-08 17:25:54 -07001203 if (_Py_atomic_load_relaxed(eval_breaker)) {
Serhiy Storchaka3f4d90d2018-07-09 15:40:14 +03001204 opcode = _Py_OPCODE(*next_instr);
1205 if (opcode == SETUP_FINALLY ||
1206 opcode == SETUP_WITH ||
1207 opcode == BEFORE_ASYNC_WITH ||
1208 opcode == YIELD_FROM) {
1209 /* Few cases where we skip running signal handlers and other
Nathaniel J. Smithab4413a2017-05-17 13:33:23 -07001210 pending calls:
Serhiy Storchaka3f4d90d2018-07-09 15:40:14 +03001211 - If we're about to enter the 'with:'. It will prevent
1212 emitting a resource warning in the common idiom
1213 'with open(path) as file:'.
1214 - If we're about to enter the 'async with:'.
1215 - If we're about to enter the 'try:' of a try/finally (not
Nathaniel J. Smithab4413a2017-05-17 13:33:23 -07001216 *very* useful, but might help in some cases and it's
1217 traditional)
1218 - If we're resuming a chain of nested 'yield from' or
1219 'await' calls, then each frame is parked with YIELD_FROM
1220 as its next opcode. If the user hit control-C we want to
1221 wait until we've reached the innermost frame before
1222 running the signal handler and raising KeyboardInterrupt
1223 (see bpo-30039).
1224 */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001225 goto fast_next_opcode;
1226 }
Eric Snowfdf282d2019-01-11 14:26:55 -07001227
Victor Stinnere225beb2019-06-03 18:14:24 +02001228 if (_Py_atomic_load_relaxed(&ceval->signals_pending)) {
Victor Stinner09532fe2019-05-10 23:39:09 +02001229 if (handle_signals(runtime) != 0) {
Eric Snowfdf282d2019-01-11 14:26:55 -07001230 goto error;
1231 }
1232 }
Victor Stinnere225beb2019-06-03 18:14:24 +02001233 if (_Py_atomic_load_relaxed(&ceval->pending.calls_to_do)) {
1234 if (make_pending_calls(runtime) != 0) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001235 goto error;
Eric Snowfdf282d2019-01-11 14:26:55 -07001236 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001237 }
Eric Snowfdf282d2019-01-11 14:26:55 -07001238
Victor Stinnere225beb2019-06-03 18:14:24 +02001239 if (_Py_atomic_load_relaxed(&ceval->gil_drop_request)) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001240 /* Give another thread a chance */
Victor Stinner09532fe2019-05-10 23:39:09 +02001241 if (_PyThreadState_Swap(&runtime->gilstate, NULL) != tstate) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001242 Py_FatalError("ceval: tstate mix-up");
Victor Stinner09532fe2019-05-10 23:39:09 +02001243 }
Victor Stinnere225beb2019-06-03 18:14:24 +02001244 drop_gil(ceval, tstate);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001245
1246 /* Other threads may run now */
1247
Victor Stinnere225beb2019-06-03 18:14:24 +02001248 take_gil(ceval, tstate);
Benjamin Peterson17548dd2014-06-16 22:59:07 -07001249
1250 /* Check if we should make a quick exit. */
Victor Stinner01b1cc12019-11-20 02:27:56 +01001251 exit_thread_if_finalizing(tstate);
Benjamin Peterson17548dd2014-06-16 22:59:07 -07001252
Victor Stinner09532fe2019-05-10 23:39:09 +02001253 if (_PyThreadState_Swap(&runtime->gilstate, tstate) != NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001254 Py_FatalError("ceval: orphan tstate");
Victor Stinner09532fe2019-05-10 23:39:09 +02001255 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001256 }
1257 /* Check for asynchronous exceptions. */
1258 if (tstate->async_exc != NULL) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001259 PyObject *exc = tstate->async_exc;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001260 tstate->async_exc = NULL;
Victor Stinnere225beb2019-06-03 18:14:24 +02001261 UNSIGNAL_ASYNC_EXC(ceval);
Victor Stinner438a12d2019-05-24 17:01:38 +02001262 _PyErr_SetNone(tstate, exc);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001263 Py_DECREF(exc);
1264 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001265 }
1266 }
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001267
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001268 fast_next_opcode:
1269 f->f_lasti = INSTR_OFFSET();
Guido van Rossumac7be682001-01-17 15:42:30 +00001270
Łukasz Langaa785c872016-09-09 17:37:37 -07001271 if (PyDTrace_LINE_ENABLED())
1272 maybe_dtrace_line(f, &instr_lb, &instr_ub, &instr_prev);
1273
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001274 /* line-by-line tracing support */
Michael W. Hudson019a78e2002-11-08 12:53:11 +00001275
Victor Stinnere225beb2019-06-03 18:14:24 +02001276 if (_Py_TracingPossible(ceval) &&
Benjamin Peterson51f46162013-01-23 08:38:47 -05001277 tstate->c_tracefunc != NULL && !tstate->tracing) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001278 int err;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001279 /* see maybe_call_line_trace
1280 for expository comments */
1281 f->f_stacktop = stack_pointer;
Tim Peters8a5c3c72004-04-05 19:36:21 +00001282
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001283 err = maybe_call_line_trace(tstate->c_tracefunc,
1284 tstate->c_traceobj,
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01001285 tstate, f,
1286 &instr_lb, &instr_ub, &instr_prev);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001287 /* Reload possibly changed frame fields */
1288 JUMPTO(f->f_lasti);
1289 if (f->f_stacktop != NULL) {
1290 stack_pointer = f->f_stacktop;
1291 f->f_stacktop = NULL;
1292 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001293 if (err)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001294 /* trace function raised an exception */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001295 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001296 }
Michael W. Hudson019a78e2002-11-08 12:53:11 +00001297
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001298 /* Extract opcode and argument */
Michael W. Hudson019a78e2002-11-08 12:53:11 +00001299
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +03001300 NEXTOPARG();
Stefan Krahb7e10102010-06-23 18:42:39 +00001301 dispatch_opcode:
Guido van Rossum950361c1997-01-24 13:49:28 +00001302#ifdef DYNAMIC_EXECUTION_PROFILE
1303#ifdef DXPAIRS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001304 dxpairs[lastopcode][opcode]++;
1305 lastopcode = opcode;
Guido van Rossum950361c1997-01-24 13:49:28 +00001306#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001307 dxp[opcode]++;
Guido van Rossum950361c1997-01-24 13:49:28 +00001308#endif
Guido van Rossum374a9221991-04-04 10:40:29 +00001309
Guido van Rossum96a42c81992-01-12 02:29:51 +00001310#ifdef LLTRACE
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001311 /* Instruction tracing */
Guido van Rossumac7be682001-01-17 15:42:30 +00001312
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001313 if (lltrace) {
1314 if (HAS_ARG(opcode)) {
1315 printf("%d: %d, %d\n",
1316 f->f_lasti, opcode, oparg);
1317 }
1318 else {
1319 printf("%d: %d\n",
1320 f->f_lasti, opcode);
1321 }
1322 }
Guido van Rossum374a9221991-04-04 10:40:29 +00001323#endif
Michael W. Hudsondd32a912002-08-15 14:59:02 +00001324
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001325 switch (opcode) {
Guido van Rossumac7be682001-01-17 15:42:30 +00001326
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001327 /* BEWARE!
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02001328 It is essential that any operation that fails must goto error
1329 and that all operation that succeed call [FAST_]DISPATCH() ! */
Guido van Rossumac7be682001-01-17 15:42:30 +00001330
Benjamin Petersonddd19492018-09-16 22:38:02 -07001331 case TARGET(NOP): {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001332 FAST_DISPATCH();
Benjamin Petersonddd19492018-09-16 22:38:02 -07001333 }
Raymond Hettinger9c18e812004-06-21 16:31:15 +00001334
Benjamin Petersonddd19492018-09-16 22:38:02 -07001335 case TARGET(LOAD_FAST): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001336 PyObject *value = GETLOCAL(oparg);
1337 if (value == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02001338 format_exc_check_arg(tstate, PyExc_UnboundLocalError,
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001339 UNBOUNDLOCAL_ERROR_MSG,
1340 PyTuple_GetItem(co->co_varnames, oparg));
1341 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001342 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001343 Py_INCREF(value);
1344 PUSH(value);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001345 FAST_DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001346 }
1347
Benjamin Petersonddd19492018-09-16 22:38:02 -07001348 case TARGET(LOAD_CONST): {
1349 PREDICTED(LOAD_CONST);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001350 PyObject *value = GETITEM(consts, oparg);
1351 Py_INCREF(value);
1352 PUSH(value);
1353 FAST_DISPATCH();
1354 }
Neil Schemenauer63543862002-02-17 19:10:14 +00001355
Benjamin Petersonddd19492018-09-16 22:38:02 -07001356 case TARGET(STORE_FAST): {
1357 PREDICTED(STORE_FAST);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001358 PyObject *value = POP();
1359 SETLOCAL(oparg, value);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001360 FAST_DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001361 }
Neil Schemenauer63543862002-02-17 19:10:14 +00001362
Benjamin Petersonddd19492018-09-16 22:38:02 -07001363 case TARGET(POP_TOP): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001364 PyObject *value = POP();
1365 Py_DECREF(value);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001366 FAST_DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001367 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001368
Benjamin Petersonddd19492018-09-16 22:38:02 -07001369 case TARGET(ROT_TWO): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001370 PyObject *top = TOP();
1371 PyObject *second = SECOND();
1372 SET_TOP(second);
1373 SET_SECOND(top);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001374 FAST_DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001375 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001376
Benjamin Petersonddd19492018-09-16 22:38:02 -07001377 case TARGET(ROT_THREE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001378 PyObject *top = TOP();
1379 PyObject *second = SECOND();
1380 PyObject *third = THIRD();
1381 SET_TOP(second);
1382 SET_SECOND(third);
1383 SET_THIRD(top);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001384 FAST_DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001385 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001386
Benjamin Petersonddd19492018-09-16 22:38:02 -07001387 case TARGET(ROT_FOUR): {
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02001388 PyObject *top = TOP();
1389 PyObject *second = SECOND();
1390 PyObject *third = THIRD();
1391 PyObject *fourth = FOURTH();
1392 SET_TOP(second);
1393 SET_SECOND(third);
1394 SET_THIRD(fourth);
1395 SET_FOURTH(top);
1396 FAST_DISPATCH();
1397 }
1398
Benjamin Petersonddd19492018-09-16 22:38:02 -07001399 case TARGET(DUP_TOP): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001400 PyObject *top = TOP();
1401 Py_INCREF(top);
1402 PUSH(top);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001403 FAST_DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001404 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001405
Benjamin Petersonddd19492018-09-16 22:38:02 -07001406 case TARGET(DUP_TOP_TWO): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001407 PyObject *top = TOP();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001408 PyObject *second = SECOND();
Benjamin Petersonf208df32012-10-12 11:37:56 -04001409 Py_INCREF(top);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001410 Py_INCREF(second);
costypetrisor8ed317f2018-07-31 20:55:14 +00001411 STACK_GROW(2);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001412 SET_TOP(top);
1413 SET_SECOND(second);
Antoine Pitrou74a69fa2010-09-04 18:43:52 +00001414 FAST_DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001415 }
Thomas Wouters434d0822000-08-24 20:11:32 +00001416
Benjamin Petersonddd19492018-09-16 22:38:02 -07001417 case TARGET(UNARY_POSITIVE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001418 PyObject *value = TOP();
1419 PyObject *res = PyNumber_Positive(value);
1420 Py_DECREF(value);
1421 SET_TOP(res);
1422 if (res == NULL)
1423 goto error;
1424 DISPATCH();
1425 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001426
Benjamin Petersonddd19492018-09-16 22:38:02 -07001427 case TARGET(UNARY_NEGATIVE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001428 PyObject *value = TOP();
1429 PyObject *res = PyNumber_Negative(value);
1430 Py_DECREF(value);
1431 SET_TOP(res);
1432 if (res == NULL)
1433 goto error;
1434 DISPATCH();
1435 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001436
Benjamin Petersonddd19492018-09-16 22:38:02 -07001437 case TARGET(UNARY_NOT): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001438 PyObject *value = TOP();
1439 int err = PyObject_IsTrue(value);
1440 Py_DECREF(value);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001441 if (err == 0) {
1442 Py_INCREF(Py_True);
1443 SET_TOP(Py_True);
1444 DISPATCH();
1445 }
1446 else if (err > 0) {
1447 Py_INCREF(Py_False);
1448 SET_TOP(Py_False);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001449 DISPATCH();
1450 }
costypetrisor8ed317f2018-07-31 20:55:14 +00001451 STACK_SHRINK(1);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001452 goto error;
1453 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001454
Benjamin Petersonddd19492018-09-16 22:38:02 -07001455 case TARGET(UNARY_INVERT): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001456 PyObject *value = TOP();
1457 PyObject *res = PyNumber_Invert(value);
1458 Py_DECREF(value);
1459 SET_TOP(res);
1460 if (res == NULL)
1461 goto error;
1462 DISPATCH();
1463 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001464
Benjamin Petersonddd19492018-09-16 22:38:02 -07001465 case TARGET(BINARY_POWER): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001466 PyObject *exp = POP();
1467 PyObject *base = TOP();
1468 PyObject *res = PyNumber_Power(base, exp, Py_None);
1469 Py_DECREF(base);
1470 Py_DECREF(exp);
1471 SET_TOP(res);
1472 if (res == NULL)
1473 goto error;
1474 DISPATCH();
1475 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001476
Benjamin Petersonddd19492018-09-16 22:38:02 -07001477 case TARGET(BINARY_MULTIPLY): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001478 PyObject *right = POP();
1479 PyObject *left = TOP();
1480 PyObject *res = PyNumber_Multiply(left, right);
1481 Py_DECREF(left);
1482 Py_DECREF(right);
1483 SET_TOP(res);
1484 if (res == NULL)
1485 goto error;
1486 DISPATCH();
1487 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001488
Benjamin Petersonddd19492018-09-16 22:38:02 -07001489 case TARGET(BINARY_MATRIX_MULTIPLY): {
Benjamin Petersond51374e2014-04-09 23:55:56 -04001490 PyObject *right = POP();
1491 PyObject *left = TOP();
1492 PyObject *res = PyNumber_MatrixMultiply(left, right);
1493 Py_DECREF(left);
1494 Py_DECREF(right);
1495 SET_TOP(res);
1496 if (res == NULL)
1497 goto error;
1498 DISPATCH();
1499 }
1500
Benjamin Petersonddd19492018-09-16 22:38:02 -07001501 case TARGET(BINARY_TRUE_DIVIDE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001502 PyObject *divisor = POP();
1503 PyObject *dividend = TOP();
1504 PyObject *quotient = PyNumber_TrueDivide(dividend, divisor);
1505 Py_DECREF(dividend);
1506 Py_DECREF(divisor);
1507 SET_TOP(quotient);
1508 if (quotient == NULL)
1509 goto error;
1510 DISPATCH();
1511 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001512
Benjamin Petersonddd19492018-09-16 22:38:02 -07001513 case TARGET(BINARY_FLOOR_DIVIDE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001514 PyObject *divisor = POP();
1515 PyObject *dividend = TOP();
1516 PyObject *quotient = PyNumber_FloorDivide(dividend, divisor);
1517 Py_DECREF(dividend);
1518 Py_DECREF(divisor);
1519 SET_TOP(quotient);
1520 if (quotient == NULL)
1521 goto error;
1522 DISPATCH();
1523 }
Guido van Rossum4668b002001-08-08 05:00:18 +00001524
Benjamin Petersonddd19492018-09-16 22:38:02 -07001525 case TARGET(BINARY_MODULO): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001526 PyObject *divisor = POP();
1527 PyObject *dividend = TOP();
Martijn Pietersd7e64332017-02-23 13:38:04 +00001528 PyObject *res;
1529 if (PyUnicode_CheckExact(dividend) && (
1530 !PyUnicode_Check(divisor) || PyUnicode_CheckExact(divisor))) {
1531 // fast path; string formatting, but not if the RHS is a str subclass
1532 // (see issue28598)
1533 res = PyUnicode_Format(dividend, divisor);
1534 } else {
1535 res = PyNumber_Remainder(dividend, divisor);
1536 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001537 Py_DECREF(divisor);
1538 Py_DECREF(dividend);
1539 SET_TOP(res);
1540 if (res == NULL)
1541 goto error;
1542 DISPATCH();
1543 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001544
Benjamin Petersonddd19492018-09-16 22:38:02 -07001545 case TARGET(BINARY_ADD): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001546 PyObject *right = POP();
1547 PyObject *left = TOP();
1548 PyObject *sum;
Victor Stinnerd65f42a2016-10-20 12:18:10 +02001549 /* NOTE(haypo): Please don't try to micro-optimize int+int on
1550 CPython using bytecode, it is simply worthless.
1551 See http://bugs.python.org/issue21955 and
1552 http://bugs.python.org/issue10044 for the discussion. In short,
1553 no patch shown any impact on a realistic benchmark, only a minor
1554 speedup on microbenchmarks. */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001555 if (PyUnicode_CheckExact(left) &&
1556 PyUnicode_CheckExact(right)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02001557 sum = unicode_concatenate(tstate, left, right, f, next_instr);
Martin Panter95f53c12016-07-18 08:23:26 +00001558 /* unicode_concatenate consumed the ref to left */
Victor Stinnerd2a915d2011-10-02 20:34:20 +02001559 }
1560 else {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001561 sum = PyNumber_Add(left, right);
1562 Py_DECREF(left);
Victor Stinnerd2a915d2011-10-02 20:34:20 +02001563 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001564 Py_DECREF(right);
1565 SET_TOP(sum);
1566 if (sum == NULL)
1567 goto error;
1568 DISPATCH();
1569 }
1570
Benjamin Petersonddd19492018-09-16 22:38:02 -07001571 case TARGET(BINARY_SUBTRACT): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001572 PyObject *right = POP();
1573 PyObject *left = TOP();
1574 PyObject *diff = PyNumber_Subtract(left, right);
1575 Py_DECREF(right);
1576 Py_DECREF(left);
1577 SET_TOP(diff);
1578 if (diff == NULL)
1579 goto error;
1580 DISPATCH();
1581 }
1582
Benjamin Petersonddd19492018-09-16 22:38:02 -07001583 case TARGET(BINARY_SUBSCR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001584 PyObject *sub = POP();
1585 PyObject *container = TOP();
1586 PyObject *res = PyObject_GetItem(container, sub);
1587 Py_DECREF(container);
1588 Py_DECREF(sub);
1589 SET_TOP(res);
1590 if (res == NULL)
1591 goto error;
1592 DISPATCH();
1593 }
1594
Benjamin Petersonddd19492018-09-16 22:38:02 -07001595 case TARGET(BINARY_LSHIFT): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001596 PyObject *right = POP();
1597 PyObject *left = TOP();
1598 PyObject *res = PyNumber_Lshift(left, right);
1599 Py_DECREF(left);
1600 Py_DECREF(right);
1601 SET_TOP(res);
1602 if (res == NULL)
1603 goto error;
1604 DISPATCH();
1605 }
1606
Benjamin Petersonddd19492018-09-16 22:38:02 -07001607 case TARGET(BINARY_RSHIFT): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001608 PyObject *right = POP();
1609 PyObject *left = TOP();
1610 PyObject *res = PyNumber_Rshift(left, right);
1611 Py_DECREF(left);
1612 Py_DECREF(right);
1613 SET_TOP(res);
1614 if (res == NULL)
1615 goto error;
1616 DISPATCH();
1617 }
1618
Benjamin Petersonddd19492018-09-16 22:38:02 -07001619 case TARGET(BINARY_AND): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001620 PyObject *right = POP();
1621 PyObject *left = TOP();
1622 PyObject *res = PyNumber_And(left, right);
1623 Py_DECREF(left);
1624 Py_DECREF(right);
1625 SET_TOP(res);
1626 if (res == NULL)
1627 goto error;
1628 DISPATCH();
1629 }
1630
Benjamin Petersonddd19492018-09-16 22:38:02 -07001631 case TARGET(BINARY_XOR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001632 PyObject *right = POP();
1633 PyObject *left = TOP();
1634 PyObject *res = PyNumber_Xor(left, right);
1635 Py_DECREF(left);
1636 Py_DECREF(right);
1637 SET_TOP(res);
1638 if (res == NULL)
1639 goto error;
1640 DISPATCH();
1641 }
1642
Benjamin Petersonddd19492018-09-16 22:38:02 -07001643 case TARGET(BINARY_OR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001644 PyObject *right = POP();
1645 PyObject *left = TOP();
1646 PyObject *res = PyNumber_Or(left, right);
1647 Py_DECREF(left);
1648 Py_DECREF(right);
1649 SET_TOP(res);
1650 if (res == NULL)
1651 goto error;
1652 DISPATCH();
1653 }
1654
Benjamin Petersonddd19492018-09-16 22:38:02 -07001655 case TARGET(LIST_APPEND): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001656 PyObject *v = POP();
1657 PyObject *list = PEEK(oparg);
1658 int err;
1659 err = PyList_Append(list, v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001660 Py_DECREF(v);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001661 if (err != 0)
1662 goto error;
1663 PREDICT(JUMP_ABSOLUTE);
1664 DISPATCH();
1665 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001666
Benjamin Petersonddd19492018-09-16 22:38:02 -07001667 case TARGET(SET_ADD): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001668 PyObject *v = POP();
Raymond Hettinger41862222016-10-15 19:03:06 -07001669 PyObject *set = PEEK(oparg);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001670 int err;
1671 err = PySet_Add(set, v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001672 Py_DECREF(v);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001673 if (err != 0)
1674 goto error;
1675 PREDICT(JUMP_ABSOLUTE);
1676 DISPATCH();
1677 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001678
Benjamin Petersonddd19492018-09-16 22:38:02 -07001679 case TARGET(INPLACE_POWER): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001680 PyObject *exp = POP();
1681 PyObject *base = TOP();
1682 PyObject *res = PyNumber_InPlacePower(base, exp, Py_None);
1683 Py_DECREF(base);
1684 Py_DECREF(exp);
1685 SET_TOP(res);
1686 if (res == NULL)
1687 goto error;
1688 DISPATCH();
1689 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001690
Benjamin Petersonddd19492018-09-16 22:38:02 -07001691 case TARGET(INPLACE_MULTIPLY): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001692 PyObject *right = POP();
1693 PyObject *left = TOP();
1694 PyObject *res = PyNumber_InPlaceMultiply(left, right);
1695 Py_DECREF(left);
1696 Py_DECREF(right);
1697 SET_TOP(res);
1698 if (res == NULL)
1699 goto error;
1700 DISPATCH();
1701 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001702
Benjamin Petersonddd19492018-09-16 22:38:02 -07001703 case TARGET(INPLACE_MATRIX_MULTIPLY): {
Benjamin Petersond51374e2014-04-09 23:55:56 -04001704 PyObject *right = POP();
1705 PyObject *left = TOP();
1706 PyObject *res = PyNumber_InPlaceMatrixMultiply(left, right);
1707 Py_DECREF(left);
1708 Py_DECREF(right);
1709 SET_TOP(res);
1710 if (res == NULL)
1711 goto error;
1712 DISPATCH();
1713 }
1714
Benjamin Petersonddd19492018-09-16 22:38:02 -07001715 case TARGET(INPLACE_TRUE_DIVIDE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001716 PyObject *divisor = POP();
1717 PyObject *dividend = TOP();
1718 PyObject *quotient = PyNumber_InPlaceTrueDivide(dividend, divisor);
1719 Py_DECREF(dividend);
1720 Py_DECREF(divisor);
1721 SET_TOP(quotient);
1722 if (quotient == NULL)
1723 goto error;
1724 DISPATCH();
1725 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001726
Benjamin Petersonddd19492018-09-16 22:38:02 -07001727 case TARGET(INPLACE_FLOOR_DIVIDE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001728 PyObject *divisor = POP();
1729 PyObject *dividend = TOP();
1730 PyObject *quotient = PyNumber_InPlaceFloorDivide(dividend, divisor);
1731 Py_DECREF(dividend);
1732 Py_DECREF(divisor);
1733 SET_TOP(quotient);
1734 if (quotient == NULL)
1735 goto error;
1736 DISPATCH();
1737 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001738
Benjamin Petersonddd19492018-09-16 22:38:02 -07001739 case TARGET(INPLACE_MODULO): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001740 PyObject *right = POP();
1741 PyObject *left = TOP();
1742 PyObject *mod = PyNumber_InPlaceRemainder(left, right);
1743 Py_DECREF(left);
1744 Py_DECREF(right);
1745 SET_TOP(mod);
1746 if (mod == NULL)
1747 goto error;
1748 DISPATCH();
1749 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001750
Benjamin Petersonddd19492018-09-16 22:38:02 -07001751 case TARGET(INPLACE_ADD): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001752 PyObject *right = POP();
1753 PyObject *left = TOP();
1754 PyObject *sum;
1755 if (PyUnicode_CheckExact(left) && PyUnicode_CheckExact(right)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02001756 sum = unicode_concatenate(tstate, left, right, f, next_instr);
Martin Panter95f53c12016-07-18 08:23:26 +00001757 /* unicode_concatenate consumed the ref to left */
Victor Stinnerd2a915d2011-10-02 20:34:20 +02001758 }
1759 else {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001760 sum = PyNumber_InPlaceAdd(left, right);
1761 Py_DECREF(left);
Victor Stinnerd2a915d2011-10-02 20:34:20 +02001762 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001763 Py_DECREF(right);
1764 SET_TOP(sum);
1765 if (sum == NULL)
1766 goto error;
1767 DISPATCH();
1768 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001769
Benjamin Petersonddd19492018-09-16 22:38:02 -07001770 case TARGET(INPLACE_SUBTRACT): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001771 PyObject *right = POP();
1772 PyObject *left = TOP();
1773 PyObject *diff = PyNumber_InPlaceSubtract(left, right);
1774 Py_DECREF(left);
1775 Py_DECREF(right);
1776 SET_TOP(diff);
1777 if (diff == NULL)
1778 goto error;
1779 DISPATCH();
1780 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001781
Benjamin Petersonddd19492018-09-16 22:38:02 -07001782 case TARGET(INPLACE_LSHIFT): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001783 PyObject *right = POP();
1784 PyObject *left = TOP();
1785 PyObject *res = PyNumber_InPlaceLshift(left, right);
1786 Py_DECREF(left);
1787 Py_DECREF(right);
1788 SET_TOP(res);
1789 if (res == NULL)
1790 goto error;
1791 DISPATCH();
1792 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001793
Benjamin Petersonddd19492018-09-16 22:38:02 -07001794 case TARGET(INPLACE_RSHIFT): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001795 PyObject *right = POP();
1796 PyObject *left = TOP();
1797 PyObject *res = PyNumber_InPlaceRshift(left, right);
1798 Py_DECREF(left);
1799 Py_DECREF(right);
1800 SET_TOP(res);
1801 if (res == NULL)
1802 goto error;
1803 DISPATCH();
1804 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001805
Benjamin Petersonddd19492018-09-16 22:38:02 -07001806 case TARGET(INPLACE_AND): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001807 PyObject *right = POP();
1808 PyObject *left = TOP();
1809 PyObject *res = PyNumber_InPlaceAnd(left, right);
1810 Py_DECREF(left);
1811 Py_DECREF(right);
1812 SET_TOP(res);
1813 if (res == NULL)
1814 goto error;
1815 DISPATCH();
1816 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001817
Benjamin Petersonddd19492018-09-16 22:38:02 -07001818 case TARGET(INPLACE_XOR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001819 PyObject *right = POP();
1820 PyObject *left = TOP();
1821 PyObject *res = PyNumber_InPlaceXor(left, right);
1822 Py_DECREF(left);
1823 Py_DECREF(right);
1824 SET_TOP(res);
1825 if (res == NULL)
1826 goto error;
1827 DISPATCH();
1828 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001829
Benjamin Petersonddd19492018-09-16 22:38:02 -07001830 case TARGET(INPLACE_OR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001831 PyObject *right = POP();
1832 PyObject *left = TOP();
1833 PyObject *res = PyNumber_InPlaceOr(left, right);
1834 Py_DECREF(left);
1835 Py_DECREF(right);
1836 SET_TOP(res);
1837 if (res == NULL)
1838 goto error;
1839 DISPATCH();
1840 }
Thomas Wouters434d0822000-08-24 20:11:32 +00001841
Benjamin Petersonddd19492018-09-16 22:38:02 -07001842 case TARGET(STORE_SUBSCR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001843 PyObject *sub = TOP();
1844 PyObject *container = SECOND();
1845 PyObject *v = THIRD();
1846 int err;
costypetrisor8ed317f2018-07-31 20:55:14 +00001847 STACK_SHRINK(3);
Martin Panter95f53c12016-07-18 08:23:26 +00001848 /* container[sub] = v */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001849 err = PyObject_SetItem(container, sub, v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001850 Py_DECREF(v);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001851 Py_DECREF(container);
1852 Py_DECREF(sub);
1853 if (err != 0)
1854 goto error;
1855 DISPATCH();
1856 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001857
Benjamin Petersonddd19492018-09-16 22:38:02 -07001858 case TARGET(DELETE_SUBSCR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001859 PyObject *sub = TOP();
1860 PyObject *container = SECOND();
1861 int err;
costypetrisor8ed317f2018-07-31 20:55:14 +00001862 STACK_SHRINK(2);
Martin Panter95f53c12016-07-18 08:23:26 +00001863 /* del container[sub] */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001864 err = PyObject_DelItem(container, sub);
1865 Py_DECREF(container);
1866 Py_DECREF(sub);
1867 if (err != 0)
1868 goto error;
1869 DISPATCH();
1870 }
Barry Warsaw23c9ec82000-08-21 15:44:01 +00001871
Benjamin Petersonddd19492018-09-16 22:38:02 -07001872 case TARGET(PRINT_EXPR): {
Victor Stinnercab75e32013-11-06 22:38:37 +01001873 _Py_IDENTIFIER(displayhook);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001874 PyObject *value = POP();
Victor Stinnercab75e32013-11-06 22:38:37 +01001875 PyObject *hook = _PySys_GetObjectId(&PyId_displayhook);
Benjamin Petersonfe1bcb62012-10-12 11:40:01 -04001876 PyObject *res;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001877 if (hook == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02001878 _PyErr_SetString(tstate, PyExc_RuntimeError,
1879 "lost sys.displayhook");
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001880 Py_DECREF(value);
1881 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001882 }
Jeroen Demeyer196a5302019-07-04 12:31:34 +02001883 res = _PyObject_CallOneArg(hook, value);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001884 Py_DECREF(value);
1885 if (res == NULL)
1886 goto error;
1887 Py_DECREF(res);
1888 DISPATCH();
1889 }
Moshe Zadkaf68f2fe2001-01-11 05:41:27 +00001890
Benjamin Petersonddd19492018-09-16 22:38:02 -07001891 case TARGET(RAISE_VARARGS): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001892 PyObject *cause = NULL, *exc = NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001893 switch (oparg) {
1894 case 2:
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001895 cause = POP(); /* cause */
Stefan Krahf432a322017-08-21 13:09:59 +02001896 /* fall through */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001897 case 1:
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001898 exc = POP(); /* exc */
Stefan Krahf432a322017-08-21 13:09:59 +02001899 /* fall through */
1900 case 0:
Victor Stinner09532fe2019-05-10 23:39:09 +02001901 if (do_raise(tstate, exc, cause)) {
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02001902 goto exception_unwind;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001903 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001904 break;
1905 default:
Victor Stinner438a12d2019-05-24 17:01:38 +02001906 _PyErr_SetString(tstate, PyExc_SystemError,
1907 "bad RAISE_VARARGS oparg");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001908 break;
1909 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001910 goto error;
1911 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001912
Benjamin Petersonddd19492018-09-16 22:38:02 -07001913 case TARGET(RETURN_VALUE): {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001914 retval = POP();
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02001915 assert(f->f_iblock == 0);
Pablo Galindof00828a2019-05-09 16:52:02 +01001916 goto exit_returning;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001917 }
Guido van Rossumdb3165e1993-10-18 17:06:59 +00001918
Benjamin Petersonddd19492018-09-16 22:38:02 -07001919 case TARGET(GET_AITER): {
Yury Selivanov6ef05902015-05-28 11:21:31 -04001920 unaryfunc getter = NULL;
Yury Selivanov75445082015-05-11 22:57:16 -04001921 PyObject *iter = NULL;
Yury Selivanov75445082015-05-11 22:57:16 -04001922 PyObject *obj = TOP();
1923 PyTypeObject *type = Py_TYPE(obj);
1924
Yury Selivanova6f6edb2016-06-09 15:08:31 -04001925 if (type->tp_as_async != NULL) {
Yury Selivanov75445082015-05-11 22:57:16 -04001926 getter = type->tp_as_async->am_aiter;
Yury Selivanova6f6edb2016-06-09 15:08:31 -04001927 }
Yury Selivanov75445082015-05-11 22:57:16 -04001928
1929 if (getter != NULL) {
1930 iter = (*getter)(obj);
1931 Py_DECREF(obj);
1932 if (iter == NULL) {
1933 SET_TOP(NULL);
1934 goto error;
1935 }
1936 }
1937 else {
1938 SET_TOP(NULL);
Victor Stinner438a12d2019-05-24 17:01:38 +02001939 _PyErr_Format(tstate, PyExc_TypeError,
1940 "'async for' requires an object with "
1941 "__aiter__ method, got %.100s",
1942 type->tp_name);
Yury Selivanov75445082015-05-11 22:57:16 -04001943 Py_DECREF(obj);
1944 goto error;
1945 }
1946
Yury Selivanovfaa135a2017-10-06 02:08:57 -04001947 if (Py_TYPE(iter)->tp_as_async == NULL ||
1948 Py_TYPE(iter)->tp_as_async->am_anext == NULL) {
Yury Selivanov75445082015-05-11 22:57:16 -04001949
Yury Selivanov398ff912017-03-02 22:20:00 -05001950 SET_TOP(NULL);
Victor Stinner438a12d2019-05-24 17:01:38 +02001951 _PyErr_Format(tstate, PyExc_TypeError,
1952 "'async for' received an object from __aiter__ "
1953 "that does not implement __anext__: %.100s",
1954 Py_TYPE(iter)->tp_name);
Yury Selivanov75445082015-05-11 22:57:16 -04001955 Py_DECREF(iter);
1956 goto error;
Yury Selivanova6f6edb2016-06-09 15:08:31 -04001957 }
1958
Yury Selivanovfaa135a2017-10-06 02:08:57 -04001959 SET_TOP(iter);
Yury Selivanov75445082015-05-11 22:57:16 -04001960 DISPATCH();
1961 }
1962
Benjamin Petersonddd19492018-09-16 22:38:02 -07001963 case TARGET(GET_ANEXT): {
Yury Selivanov6ef05902015-05-28 11:21:31 -04001964 unaryfunc getter = NULL;
Yury Selivanov75445082015-05-11 22:57:16 -04001965 PyObject *next_iter = NULL;
1966 PyObject *awaitable = NULL;
1967 PyObject *aiter = TOP();
1968 PyTypeObject *type = Py_TYPE(aiter);
1969
Yury Selivanoveb636452016-09-08 22:01:51 -07001970 if (PyAsyncGen_CheckExact(aiter)) {
1971 awaitable = type->tp_as_async->am_anext(aiter);
1972 if (awaitable == NULL) {
Yury Selivanov75445082015-05-11 22:57:16 -04001973 goto error;
1974 }
Yury Selivanoveb636452016-09-08 22:01:51 -07001975 } else {
1976 if (type->tp_as_async != NULL){
1977 getter = type->tp_as_async->am_anext;
1978 }
Yury Selivanov75445082015-05-11 22:57:16 -04001979
Yury Selivanoveb636452016-09-08 22:01:51 -07001980 if (getter != NULL) {
1981 next_iter = (*getter)(aiter);
1982 if (next_iter == NULL) {
1983 goto error;
1984 }
1985 }
1986 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02001987 _PyErr_Format(tstate, PyExc_TypeError,
1988 "'async for' requires an iterator with "
1989 "__anext__ method, got %.100s",
1990 type->tp_name);
Yury Selivanoveb636452016-09-08 22:01:51 -07001991 goto error;
1992 }
Yury Selivanov75445082015-05-11 22:57:16 -04001993
Yury Selivanoveb636452016-09-08 22:01:51 -07001994 awaitable = _PyCoro_GetAwaitableIter(next_iter);
1995 if (awaitable == NULL) {
Yury Selivanov398ff912017-03-02 22:20:00 -05001996 _PyErr_FormatFromCause(
Yury Selivanoveb636452016-09-08 22:01:51 -07001997 PyExc_TypeError,
1998 "'async for' received an invalid object "
1999 "from __anext__: %.100s",
2000 Py_TYPE(next_iter)->tp_name);
2001
2002 Py_DECREF(next_iter);
2003 goto error;
2004 } else {
2005 Py_DECREF(next_iter);
2006 }
2007 }
Yury Selivanov75445082015-05-11 22:57:16 -04002008
2009 PUSH(awaitable);
Serhiy Storchakada9c5132016-06-27 18:58:57 +03002010 PREDICT(LOAD_CONST);
Yury Selivanov75445082015-05-11 22:57:16 -04002011 DISPATCH();
2012 }
2013
Benjamin Petersonddd19492018-09-16 22:38:02 -07002014 case TARGET(GET_AWAITABLE): {
2015 PREDICTED(GET_AWAITABLE);
Yury Selivanov75445082015-05-11 22:57:16 -04002016 PyObject *iterable = TOP();
Yury Selivanov5376ba92015-06-22 12:19:30 -04002017 PyObject *iter = _PyCoro_GetAwaitableIter(iterable);
Yury Selivanov75445082015-05-11 22:57:16 -04002018
Serhiy Storchakaa68f2f02018-04-03 01:41:38 +03002019 if (iter == NULL) {
Mark Shannonfee55262019-11-21 09:11:43 +00002020 int opcode_at_minus_3 = 0;
2021 if ((next_instr - first_instr) > 2) {
2022 opcode_at_minus_3 = _Py_OPCODE(next_instr[-3]);
2023 }
Victor Stinner438a12d2019-05-24 17:01:38 +02002024 format_awaitable_error(tstate, Py_TYPE(iterable),
Mark Shannonfee55262019-11-21 09:11:43 +00002025 opcode_at_minus_3,
Serhiy Storchakaa68f2f02018-04-03 01:41:38 +03002026 _Py_OPCODE(next_instr[-2]));
2027 }
2028
Yury Selivanov75445082015-05-11 22:57:16 -04002029 Py_DECREF(iterable);
2030
Yury Selivanovc724bae2016-03-02 11:30:46 -05002031 if (iter != NULL && PyCoro_CheckExact(iter)) {
2032 PyObject *yf = _PyGen_yf((PyGenObject*)iter);
2033 if (yf != NULL) {
2034 /* `iter` is a coroutine object that is being
2035 awaited, `yf` is a pointer to the current awaitable
2036 being awaited on. */
2037 Py_DECREF(yf);
2038 Py_CLEAR(iter);
Victor Stinner438a12d2019-05-24 17:01:38 +02002039 _PyErr_SetString(tstate, PyExc_RuntimeError,
2040 "coroutine is being awaited already");
Yury Selivanovc724bae2016-03-02 11:30:46 -05002041 /* The code below jumps to `error` if `iter` is NULL. */
2042 }
2043 }
2044
Yury Selivanov75445082015-05-11 22:57:16 -04002045 SET_TOP(iter); /* Even if it's NULL */
2046
2047 if (iter == NULL) {
2048 goto error;
2049 }
2050
Serhiy Storchakada9c5132016-06-27 18:58:57 +03002051 PREDICT(LOAD_CONST);
Yury Selivanov75445082015-05-11 22:57:16 -04002052 DISPATCH();
2053 }
2054
Benjamin Petersonddd19492018-09-16 22:38:02 -07002055 case TARGET(YIELD_FROM): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002056 PyObject *v = POP();
Raymond Hettinger15f44ab2016-08-30 10:47:49 -07002057 PyObject *receiver = TOP();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002058 int err;
Raymond Hettinger15f44ab2016-08-30 10:47:49 -07002059 if (PyGen_CheckExact(receiver) || PyCoro_CheckExact(receiver)) {
2060 retval = _PyGen_Send((PyGenObject *)receiver, v);
Benjamin Peterson2afe6ae2012-03-15 15:37:39 -05002061 } else {
Benjamin Peterson302e7902012-03-20 23:17:04 -04002062 _Py_IDENTIFIER(send);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002063 if (v == Py_None)
Raymond Hettinger15f44ab2016-08-30 10:47:49 -07002064 retval = Py_TYPE(receiver)->tp_iternext(receiver);
Benjamin Peterson2afe6ae2012-03-15 15:37:39 -05002065 else
Jeroen Demeyer59ad1102019-07-11 10:59:05 +02002066 retval = _PyObject_CallMethodIdOneArg(receiver, &PyId_send, v);
Benjamin Peterson2afe6ae2012-03-15 15:37:39 -05002067 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002068 Py_DECREF(v);
2069 if (retval == NULL) {
Benjamin Peterson2afe6ae2012-03-15 15:37:39 -05002070 PyObject *val;
Guido van Rossum8820c232013-11-21 11:30:06 -08002071 if (tstate->c_tracefunc != NULL
Victor Stinner438a12d2019-05-24 17:01:38 +02002072 && _PyErr_ExceptionMatches(tstate, PyExc_StopIteration))
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01002073 call_exc_trace(tstate->c_tracefunc, tstate->c_traceobj, tstate, f);
Nick Coghlanc40bc092012-06-17 15:15:49 +10002074 err = _PyGen_FetchStopIterationValue(&val);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002075 if (err < 0)
2076 goto error;
Raymond Hettinger15f44ab2016-08-30 10:47:49 -07002077 Py_DECREF(receiver);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002078 SET_TOP(val);
2079 DISPATCH();
Nick Coghlan1f7ce622012-01-13 21:43:40 +10002080 }
Martin Panter95f53c12016-07-18 08:23:26 +00002081 /* receiver remains on stack, retval is value to be yielded */
Nick Coghlan1f7ce622012-01-13 21:43:40 +10002082 f->f_stacktop = stack_pointer;
Benjamin Peterson2afe6ae2012-03-15 15:37:39 -05002083 /* and repeat... */
Victor Stinnerf7d199f2016-11-24 22:33:01 +01002084 assert(f->f_lasti >= (int)sizeof(_Py_CODEUNIT));
Serhiy Storchakaab874002016-09-11 13:48:15 +03002085 f->f_lasti -= sizeof(_Py_CODEUNIT);
Pablo Galindof00828a2019-05-09 16:52:02 +01002086 goto exit_yielding;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002087 }
Nick Coghlan1f7ce622012-01-13 21:43:40 +10002088
Benjamin Petersonddd19492018-09-16 22:38:02 -07002089 case TARGET(YIELD_VALUE): {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002090 retval = POP();
Yury Selivanoveb636452016-09-08 22:01:51 -07002091
2092 if (co->co_flags & CO_ASYNC_GENERATOR) {
2093 PyObject *w = _PyAsyncGenValueWrapperNew(retval);
2094 Py_DECREF(retval);
2095 if (w == NULL) {
2096 retval = NULL;
2097 goto error;
2098 }
2099 retval = w;
2100 }
2101
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002102 f->f_stacktop = stack_pointer;
Pablo Galindof00828a2019-05-09 16:52:02 +01002103 goto exit_yielding;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002104 }
Tim Peters5ca576e2001-06-18 22:08:13 +00002105
Benjamin Petersonddd19492018-09-16 22:38:02 -07002106 case TARGET(POP_EXCEPT): {
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02002107 PyObject *type, *value, *traceback;
2108 _PyErr_StackItem *exc_info;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002109 PyTryBlock *b = PyFrame_BlockPop(f);
2110 if (b->b_type != EXCEPT_HANDLER) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002111 _PyErr_SetString(tstate, PyExc_SystemError,
2112 "popped block is not an except handler");
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002113 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002114 }
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02002115 assert(STACK_LEVEL() >= (b)->b_level + 3 &&
2116 STACK_LEVEL() <= (b)->b_level + 4);
2117 exc_info = tstate->exc_info;
2118 type = exc_info->exc_type;
2119 value = exc_info->exc_value;
2120 traceback = exc_info->exc_traceback;
2121 exc_info->exc_type = POP();
2122 exc_info->exc_value = POP();
2123 exc_info->exc_traceback = POP();
2124 Py_XDECREF(type);
2125 Py_XDECREF(value);
2126 Py_XDECREF(traceback);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002127 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002128 }
Benjamin Petersoneec3d712008-06-11 15:59:43 +00002129
Benjamin Petersonddd19492018-09-16 22:38:02 -07002130 case TARGET(POP_BLOCK): {
2131 PREDICTED(POP_BLOCK);
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02002132 PyFrame_BlockPop(f);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002133 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002134 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002135
Mark Shannonfee55262019-11-21 09:11:43 +00002136 case TARGET(RERAISE): {
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02002137 PyObject *exc = POP();
Mark Shannonfee55262019-11-21 09:11:43 +00002138 PyObject *val = POP();
2139 PyObject *tb = POP();
2140 assert(PyExceptionClass_Check(exc));
2141 PyErr_Restore(exc, val, tb);
2142 goto exception_unwind;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002143 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002144
Benjamin Petersonddd19492018-09-16 22:38:02 -07002145 case TARGET(END_ASYNC_FOR): {
Serhiy Storchaka702f8f32018-03-23 14:34:35 +02002146 PyObject *exc = POP();
2147 assert(PyExceptionClass_Check(exc));
2148 if (PyErr_GivenExceptionMatches(exc, PyExc_StopAsyncIteration)) {
2149 PyTryBlock *b = PyFrame_BlockPop(f);
2150 assert(b->b_type == EXCEPT_HANDLER);
2151 Py_DECREF(exc);
2152 UNWIND_EXCEPT_HANDLER(b);
2153 Py_DECREF(POP());
2154 JUMPBY(oparg);
2155 FAST_DISPATCH();
2156 }
2157 else {
2158 PyObject *val = POP();
2159 PyObject *tb = POP();
Victor Stinner438a12d2019-05-24 17:01:38 +02002160 _PyErr_Restore(tstate, exc, val, tb);
Serhiy Storchaka702f8f32018-03-23 14:34:35 +02002161 goto exception_unwind;
2162 }
2163 }
2164
Zackery Spytzce6a0702019-08-25 03:44:09 -06002165 case TARGET(LOAD_ASSERTION_ERROR): {
2166 PyObject *value = PyExc_AssertionError;
2167 Py_INCREF(value);
2168 PUSH(value);
2169 FAST_DISPATCH();
2170 }
2171
Benjamin Petersonddd19492018-09-16 22:38:02 -07002172 case TARGET(LOAD_BUILD_CLASS): {
Victor Stinner3c1e4812012-03-26 22:10:51 +02002173 _Py_IDENTIFIER(__build_class__);
Victor Stinnerb0b22422012-04-19 00:57:45 +02002174
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002175 PyObject *bc;
Victor Stinnerb0b22422012-04-19 00:57:45 +02002176 if (PyDict_CheckExact(f->f_builtins)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002177 bc = _PyDict_GetItemIdWithError(f->f_builtins, &PyId___build_class__);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002178 if (bc == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002179 if (!_PyErr_Occurred(tstate)) {
2180 _PyErr_SetString(tstate, PyExc_NameError,
2181 "__build_class__ not found");
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002182 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002183 goto error;
Victor Stinnerb0b22422012-04-19 00:57:45 +02002184 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002185 Py_INCREF(bc);
Victor Stinnerb0b22422012-04-19 00:57:45 +02002186 }
2187 else {
2188 PyObject *build_class_str = _PyUnicode_FromId(&PyId___build_class__);
2189 if (build_class_str == NULL)
Serhiy Storchaka70b72f02016-11-08 23:12:46 +02002190 goto error;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002191 bc = PyObject_GetItem(f->f_builtins, build_class_str);
2192 if (bc == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002193 if (_PyErr_ExceptionMatches(tstate, PyExc_KeyError))
2194 _PyErr_SetString(tstate, PyExc_NameError,
2195 "__build_class__ not found");
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002196 goto error;
Victor Stinnerb0b22422012-04-19 00:57:45 +02002197 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002198 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002199 PUSH(bc);
Benjamin Peterson00f86f22012-10-10 14:10:33 -04002200 DISPATCH();
Victor Stinner3c1e4812012-03-26 22:10:51 +02002201 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002202
Benjamin Petersonddd19492018-09-16 22:38:02 -07002203 case TARGET(STORE_NAME): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002204 PyObject *name = GETITEM(names, oparg);
2205 PyObject *v = POP();
2206 PyObject *ns = f->f_locals;
2207 int err;
2208 if (ns == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002209 _PyErr_Format(tstate, PyExc_SystemError,
2210 "no locals found when storing %R", name);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002211 Py_DECREF(v);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002212 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002213 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002214 if (PyDict_CheckExact(ns))
2215 err = PyDict_SetItem(ns, name, v);
2216 else
2217 err = PyObject_SetItem(ns, name, v);
2218 Py_DECREF(v);
2219 if (err != 0)
2220 goto error;
2221 DISPATCH();
2222 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002223
Benjamin Petersonddd19492018-09-16 22:38:02 -07002224 case TARGET(DELETE_NAME): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002225 PyObject *name = GETITEM(names, oparg);
2226 PyObject *ns = f->f_locals;
2227 int err;
2228 if (ns == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002229 _PyErr_Format(tstate, PyExc_SystemError,
2230 "no locals when deleting %R", name);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002231 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002232 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002233 err = PyObject_DelItem(ns, name);
2234 if (err != 0) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002235 format_exc_check_arg(tstate, PyExc_NameError,
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002236 NAME_ERROR_MSG,
2237 name);
2238 goto error;
2239 }
2240 DISPATCH();
2241 }
Guido van Rossum04691fc1992-08-12 15:35:34 +00002242
Benjamin Petersonddd19492018-09-16 22:38:02 -07002243 case TARGET(UNPACK_SEQUENCE): {
2244 PREDICTED(UNPACK_SEQUENCE);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002245 PyObject *seq = POP(), *item, **items;
2246 if (PyTuple_CheckExact(seq) &&
2247 PyTuple_GET_SIZE(seq) == oparg) {
2248 items = ((PyTupleObject *)seq)->ob_item;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002249 while (oparg--) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002250 item = items[oparg];
2251 Py_INCREF(item);
2252 PUSH(item);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002253 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002254 } else if (PyList_CheckExact(seq) &&
2255 PyList_GET_SIZE(seq) == oparg) {
2256 items = ((PyListObject *)seq)->ob_item;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002257 while (oparg--) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002258 item = items[oparg];
2259 Py_INCREF(item);
2260 PUSH(item);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002261 }
Victor Stinner438a12d2019-05-24 17:01:38 +02002262 } else if (unpack_iterable(tstate, seq, oparg, -1,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002263 stack_pointer + oparg)) {
costypetrisor8ed317f2018-07-31 20:55:14 +00002264 STACK_GROW(oparg);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002265 } else {
2266 /* unpack_iterable() raised an exception */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002267 Py_DECREF(seq);
2268 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002269 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002270 Py_DECREF(seq);
Benjamin Peterson00f86f22012-10-10 14:10:33 -04002271 DISPATCH();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002272 }
Guido van Rossum0368b722007-05-11 16:50:42 +00002273
Benjamin Petersonddd19492018-09-16 22:38:02 -07002274 case TARGET(UNPACK_EX): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002275 int totalargs = 1 + (oparg & 0xFF) + (oparg >> 8);
2276 PyObject *seq = POP();
2277
Victor Stinner438a12d2019-05-24 17:01:38 +02002278 if (unpack_iterable(tstate, seq, oparg & 0xFF, oparg >> 8,
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002279 stack_pointer + totalargs)) {
2280 stack_pointer += totalargs;
2281 } else {
2282 Py_DECREF(seq);
2283 goto error;
2284 }
2285 Py_DECREF(seq);
2286 DISPATCH();
2287 }
2288
Benjamin Petersonddd19492018-09-16 22:38:02 -07002289 case TARGET(STORE_ATTR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002290 PyObject *name = GETITEM(names, oparg);
2291 PyObject *owner = TOP();
2292 PyObject *v = SECOND();
2293 int err;
costypetrisor8ed317f2018-07-31 20:55:14 +00002294 STACK_SHRINK(2);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002295 err = PyObject_SetAttr(owner, name, v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002296 Py_DECREF(v);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002297 Py_DECREF(owner);
2298 if (err != 0)
2299 goto error;
2300 DISPATCH();
2301 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002302
Benjamin Petersonddd19492018-09-16 22:38:02 -07002303 case TARGET(DELETE_ATTR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002304 PyObject *name = GETITEM(names, oparg);
2305 PyObject *owner = POP();
2306 int err;
2307 err = PyObject_SetAttr(owner, name, (PyObject *)NULL);
2308 Py_DECREF(owner);
2309 if (err != 0)
2310 goto error;
2311 DISPATCH();
2312 }
2313
Benjamin Petersonddd19492018-09-16 22:38:02 -07002314 case TARGET(STORE_GLOBAL): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002315 PyObject *name = GETITEM(names, oparg);
2316 PyObject *v = POP();
2317 int err;
2318 err = PyDict_SetItem(f->f_globals, name, v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002319 Py_DECREF(v);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002320 if (err != 0)
2321 goto error;
2322 DISPATCH();
2323 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002324
Benjamin Petersonddd19492018-09-16 22:38:02 -07002325 case TARGET(DELETE_GLOBAL): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002326 PyObject *name = GETITEM(names, oparg);
2327 int err;
2328 err = PyDict_DelItem(f->f_globals, name);
2329 if (err != 0) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002330 if (_PyErr_ExceptionMatches(tstate, PyExc_KeyError)) {
2331 format_exc_check_arg(tstate, PyExc_NameError,
2332 NAME_ERROR_MSG, name);
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002333 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002334 goto error;
Benjamin Peterson00f86f22012-10-10 14:10:33 -04002335 }
2336 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002337 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002338
Benjamin Petersonddd19492018-09-16 22:38:02 -07002339 case TARGET(LOAD_NAME): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002340 PyObject *name = GETITEM(names, oparg);
2341 PyObject *locals = f->f_locals;
2342 PyObject *v;
2343 if (locals == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002344 _PyErr_Format(tstate, PyExc_SystemError,
2345 "no locals when loading %R", name);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002346 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002347 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002348 if (PyDict_CheckExact(locals)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002349 v = PyDict_GetItemWithError(locals, name);
2350 if (v != NULL) {
2351 Py_INCREF(v);
2352 }
Victor Stinner438a12d2019-05-24 17:01:38 +02002353 else if (_PyErr_Occurred(tstate)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002354 goto error;
2355 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002356 }
2357 else {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002358 v = PyObject_GetItem(locals, name);
Victor Stinnere20310f2015-11-05 13:56:58 +01002359 if (v == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002360 if (!_PyErr_ExceptionMatches(tstate, PyExc_KeyError))
Benjamin Peterson92722792012-12-15 12:51:05 -05002361 goto error;
Victor Stinner438a12d2019-05-24 17:01:38 +02002362 _PyErr_Clear(tstate);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002363 }
2364 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002365 if (v == NULL) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002366 v = PyDict_GetItemWithError(f->f_globals, name);
2367 if (v != NULL) {
2368 Py_INCREF(v);
2369 }
Victor Stinner438a12d2019-05-24 17:01:38 +02002370 else if (_PyErr_Occurred(tstate)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002371 goto error;
2372 }
2373 else {
Victor Stinnerb0b22422012-04-19 00:57:45 +02002374 if (PyDict_CheckExact(f->f_builtins)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002375 v = PyDict_GetItemWithError(f->f_builtins, name);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002376 if (v == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002377 if (!_PyErr_Occurred(tstate)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002378 format_exc_check_arg(
Victor Stinner438a12d2019-05-24 17:01:38 +02002379 tstate, PyExc_NameError,
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002380 NAME_ERROR_MSG, name);
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002381 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002382 goto error;
Victor Stinnerb0b22422012-04-19 00:57:45 +02002383 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002384 Py_INCREF(v);
Victor Stinnerb0b22422012-04-19 00:57:45 +02002385 }
2386 else {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002387 v = PyObject_GetItem(f->f_builtins, name);
2388 if (v == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002389 if (_PyErr_ExceptionMatches(tstate, PyExc_KeyError)) {
Victor Stinnerb0b22422012-04-19 00:57:45 +02002390 format_exc_check_arg(
Victor Stinner438a12d2019-05-24 17:01:38 +02002391 tstate, PyExc_NameError,
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002392 NAME_ERROR_MSG, name);
Victor Stinner438a12d2019-05-24 17:01:38 +02002393 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002394 goto error;
Victor Stinnerb0b22422012-04-19 00:57:45 +02002395 }
Benjamin Peterson20f9c3c2010-07-20 22:39:34 +00002396 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002397 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002398 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002399 PUSH(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002400 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002401 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002402
Benjamin Petersonddd19492018-09-16 22:38:02 -07002403 case TARGET(LOAD_GLOBAL): {
Inada Naoki91234a12019-06-03 21:30:58 +09002404 PyObject *name;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002405 PyObject *v;
Victor Stinnerb0b22422012-04-19 00:57:45 +02002406 if (PyDict_CheckExact(f->f_globals)
Victor Stinnerb4efc962015-11-20 09:24:02 +01002407 && PyDict_CheckExact(f->f_builtins))
2408 {
Inada Naoki91234a12019-06-03 21:30:58 +09002409 OPCACHE_CHECK();
2410 if (co_opcache != NULL && co_opcache->optimized > 0) {
2411 _PyOpcache_LoadGlobal *lg = &co_opcache->u.lg;
2412
2413 if (lg->globals_ver ==
2414 ((PyDictObject *)f->f_globals)->ma_version_tag
2415 && lg->builtins_ver ==
2416 ((PyDictObject *)f->f_builtins)->ma_version_tag)
2417 {
2418 PyObject *ptr = lg->ptr;
2419 OPCACHE_STAT_GLOBAL_HIT();
2420 assert(ptr != NULL);
2421 Py_INCREF(ptr);
2422 PUSH(ptr);
2423 DISPATCH();
2424 }
2425 }
2426
2427 name = GETITEM(names, oparg);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002428 v = _PyDict_LoadGlobal((PyDictObject *)f->f_globals,
Benjamin Peterson7d95e402012-04-23 11:24:50 -04002429 (PyDictObject *)f->f_builtins,
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002430 name);
2431 if (v == NULL) {
Victor Stinnerb4efc962015-11-20 09:24:02 +01002432 if (!_PyErr_OCCURRED()) {
2433 /* _PyDict_LoadGlobal() returns NULL without raising
2434 * an exception if the key doesn't exist */
Victor Stinner438a12d2019-05-24 17:01:38 +02002435 format_exc_check_arg(tstate, PyExc_NameError,
Ezio Melotti04a29552013-03-03 15:12:44 +02002436 NAME_ERROR_MSG, name);
Victor Stinnerb4efc962015-11-20 09:24:02 +01002437 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002438 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002439 }
Inada Naoki91234a12019-06-03 21:30:58 +09002440
2441 if (co_opcache != NULL) {
2442 _PyOpcache_LoadGlobal *lg = &co_opcache->u.lg;
2443
2444 if (co_opcache->optimized == 0) {
2445 /* Wasn't optimized before. */
2446 OPCACHE_STAT_GLOBAL_OPT();
2447 } else {
2448 OPCACHE_STAT_GLOBAL_MISS();
2449 }
2450
2451 co_opcache->optimized = 1;
2452 lg->globals_ver =
2453 ((PyDictObject *)f->f_globals)->ma_version_tag;
2454 lg->builtins_ver =
2455 ((PyDictObject *)f->f_builtins)->ma_version_tag;
2456 lg->ptr = v; /* borrowed */
2457 }
2458
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002459 Py_INCREF(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002460 }
Benjamin Peterson7d95e402012-04-23 11:24:50 -04002461 else {
2462 /* Slow-path if globals or builtins is not a dict */
Victor Stinnerb4efc962015-11-20 09:24:02 +01002463
2464 /* namespace 1: globals */
Inada Naoki91234a12019-06-03 21:30:58 +09002465 name = GETITEM(names, oparg);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002466 v = PyObject_GetItem(f->f_globals, name);
2467 if (v == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002468 if (!_PyErr_ExceptionMatches(tstate, PyExc_KeyError)) {
Victor Stinner60a1d3c2015-11-05 13:55:20 +01002469 goto error;
Victor Stinner438a12d2019-05-24 17:01:38 +02002470 }
2471 _PyErr_Clear(tstate);
Victor Stinner60a1d3c2015-11-05 13:55:20 +01002472
Victor Stinnerb4efc962015-11-20 09:24:02 +01002473 /* namespace 2: builtins */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002474 v = PyObject_GetItem(f->f_builtins, name);
2475 if (v == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002476 if (_PyErr_ExceptionMatches(tstate, PyExc_KeyError)) {
Benjamin Peterson7d95e402012-04-23 11:24:50 -04002477 format_exc_check_arg(
Victor Stinner438a12d2019-05-24 17:01:38 +02002478 tstate, PyExc_NameError,
Ezio Melotti04a29552013-03-03 15:12:44 +02002479 NAME_ERROR_MSG, name);
Victor Stinner438a12d2019-05-24 17:01:38 +02002480 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002481 goto error;
Benjamin Peterson7d95e402012-04-23 11:24:50 -04002482 }
2483 }
2484 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002485 PUSH(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002486 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002487 }
Guido van Rossum681d79a1995-07-18 14:51:37 +00002488
Benjamin Petersonddd19492018-09-16 22:38:02 -07002489 case TARGET(DELETE_FAST): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002490 PyObject *v = GETLOCAL(oparg);
2491 if (v != NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002492 SETLOCAL(oparg, NULL);
2493 DISPATCH();
2494 }
2495 format_exc_check_arg(
Victor Stinner438a12d2019-05-24 17:01:38 +02002496 tstate, PyExc_UnboundLocalError,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002497 UNBOUNDLOCAL_ERROR_MSG,
2498 PyTuple_GetItem(co->co_varnames, oparg)
2499 );
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002500 goto error;
2501 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002502
Benjamin Petersonddd19492018-09-16 22:38:02 -07002503 case TARGET(DELETE_DEREF): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002504 PyObject *cell = freevars[oparg];
Raymond Hettingerc32f9db2016-11-12 04:10:35 -05002505 PyObject *oldobj = PyCell_GET(cell);
2506 if (oldobj != NULL) {
2507 PyCell_SET(cell, NULL);
2508 Py_DECREF(oldobj);
Benjamin Peterson00ebe2c2010-09-10 22:02:31 +00002509 DISPATCH();
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00002510 }
Victor Stinner438a12d2019-05-24 17:01:38 +02002511 format_exc_unbound(tstate, co, oparg);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002512 goto error;
2513 }
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00002514
Benjamin Petersonddd19492018-09-16 22:38:02 -07002515 case TARGET(LOAD_CLOSURE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002516 PyObject *cell = freevars[oparg];
2517 Py_INCREF(cell);
2518 PUSH(cell);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002519 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002520 }
Jeremy Hylton64949cb2001-01-25 20:06:59 +00002521
Benjamin Petersonddd19492018-09-16 22:38:02 -07002522 case TARGET(LOAD_CLASSDEREF): {
Benjamin Peterson3b0431d2013-04-30 09:41:40 -04002523 PyObject *name, *value, *locals = f->f_locals;
Victor Stinnerd3dfd0e2013-05-16 23:48:01 +02002524 Py_ssize_t idx;
Benjamin Peterson3b0431d2013-04-30 09:41:40 -04002525 assert(locals);
2526 assert(oparg >= PyTuple_GET_SIZE(co->co_cellvars));
2527 idx = oparg - PyTuple_GET_SIZE(co->co_cellvars);
2528 assert(idx >= 0 && idx < PyTuple_GET_SIZE(co->co_freevars));
2529 name = PyTuple_GET_ITEM(co->co_freevars, idx);
2530 if (PyDict_CheckExact(locals)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002531 value = PyDict_GetItemWithError(locals, name);
2532 if (value != NULL) {
2533 Py_INCREF(value);
2534 }
Victor Stinner438a12d2019-05-24 17:01:38 +02002535 else if (_PyErr_Occurred(tstate)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002536 goto error;
2537 }
Benjamin Peterson3b0431d2013-04-30 09:41:40 -04002538 }
2539 else {
2540 value = PyObject_GetItem(locals, name);
Victor Stinnere20310f2015-11-05 13:56:58 +01002541 if (value == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002542 if (!_PyErr_ExceptionMatches(tstate, PyExc_KeyError)) {
Benjamin Peterson3b0431d2013-04-30 09:41:40 -04002543 goto error;
Victor Stinner438a12d2019-05-24 17:01:38 +02002544 }
2545 _PyErr_Clear(tstate);
Benjamin Peterson3b0431d2013-04-30 09:41:40 -04002546 }
2547 }
2548 if (!value) {
2549 PyObject *cell = freevars[oparg];
2550 value = PyCell_GET(cell);
2551 if (value == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002552 format_exc_unbound(tstate, co, oparg);
Benjamin Peterson3b0431d2013-04-30 09:41:40 -04002553 goto error;
2554 }
2555 Py_INCREF(value);
2556 }
2557 PUSH(value);
2558 DISPATCH();
2559 }
2560
Benjamin Petersonddd19492018-09-16 22:38:02 -07002561 case TARGET(LOAD_DEREF): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002562 PyObject *cell = freevars[oparg];
2563 PyObject *value = PyCell_GET(cell);
2564 if (value == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002565 format_exc_unbound(tstate, co, oparg);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002566 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002567 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002568 Py_INCREF(value);
2569 PUSH(value);
2570 DISPATCH();
2571 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002572
Benjamin Petersonddd19492018-09-16 22:38:02 -07002573 case TARGET(STORE_DEREF): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002574 PyObject *v = POP();
2575 PyObject *cell = freevars[oparg];
Raymond Hettingerb2b15432016-11-11 04:32:11 -08002576 PyObject *oldobj = PyCell_GET(cell);
2577 PyCell_SET(cell, v);
2578 Py_XDECREF(oldobj);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002579 DISPATCH();
2580 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002581
Benjamin Petersonddd19492018-09-16 22:38:02 -07002582 case TARGET(BUILD_STRING): {
Serhiy Storchakaea525a22016-09-06 22:07:53 +03002583 PyObject *str;
2584 PyObject *empty = PyUnicode_New(0, 0);
2585 if (empty == NULL) {
2586 goto error;
2587 }
2588 str = _PyUnicode_JoinArray(empty, stack_pointer - oparg, oparg);
2589 Py_DECREF(empty);
2590 if (str == NULL)
2591 goto error;
2592 while (--oparg >= 0) {
2593 PyObject *item = POP();
2594 Py_DECREF(item);
2595 }
2596 PUSH(str);
2597 DISPATCH();
2598 }
2599
Benjamin Petersonddd19492018-09-16 22:38:02 -07002600 case TARGET(BUILD_TUPLE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002601 PyObject *tup = PyTuple_New(oparg);
2602 if (tup == NULL)
2603 goto error;
2604 while (--oparg >= 0) {
2605 PyObject *item = POP();
2606 PyTuple_SET_ITEM(tup, oparg, item);
2607 }
2608 PUSH(tup);
2609 DISPATCH();
2610 }
2611
Benjamin Petersonddd19492018-09-16 22:38:02 -07002612 case TARGET(BUILD_LIST): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002613 PyObject *list = PyList_New(oparg);
2614 if (list == NULL)
2615 goto error;
2616 while (--oparg >= 0) {
2617 PyObject *item = POP();
2618 PyList_SET_ITEM(list, oparg, item);
2619 }
2620 PUSH(list);
2621 DISPATCH();
2622 }
2623
Benjamin Petersonddd19492018-09-16 22:38:02 -07002624 case TARGET(BUILD_TUPLE_UNPACK_WITH_CALL):
2625 case TARGET(BUILD_TUPLE_UNPACK):
2626 case TARGET(BUILD_LIST_UNPACK): {
Serhiy Storchaka73442852016-10-02 10:33:46 +03002627 int convert_to_tuple = opcode != BUILD_LIST_UNPACK;
Victor Stinner74319ae2016-08-25 00:04:09 +02002628 Py_ssize_t i;
Serhiy Storchakab7281052016-09-12 00:52:40 +03002629 PyObject *sum = PyList_New(0);
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002630 PyObject *return_value;
Victor Stinnerf9b760f2016-09-09 10:17:08 -07002631
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002632 if (sum == NULL)
2633 goto error;
2634
2635 for (i = oparg; i > 0; i--) {
2636 PyObject *none_val;
2637
2638 none_val = _PyList_Extend((PyListObject *)sum, PEEK(i));
2639 if (none_val == NULL) {
Serhiy Storchaka73442852016-10-02 10:33:46 +03002640 if (opcode == BUILD_TUPLE_UNPACK_WITH_CALL &&
Victor Stinner438a12d2019-05-24 17:01:38 +02002641 _PyErr_ExceptionMatches(tstate, PyExc_TypeError))
Serhiy Storchaka25e4f772017-08-03 11:37:15 +03002642 {
Victor Stinner438a12d2019-05-24 17:01:38 +02002643 check_args_iterable(tstate, PEEK(1 + oparg), PEEK(i));
Serhiy Storchaka73442852016-10-02 10:33:46 +03002644 }
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002645 Py_DECREF(sum);
2646 goto error;
2647 }
2648 Py_DECREF(none_val);
2649 }
2650
2651 if (convert_to_tuple) {
2652 return_value = PyList_AsTuple(sum);
2653 Py_DECREF(sum);
2654 if (return_value == NULL)
2655 goto error;
2656 }
2657 else {
2658 return_value = sum;
2659 }
2660
2661 while (oparg--)
2662 Py_DECREF(POP());
2663 PUSH(return_value);
2664 DISPATCH();
2665 }
2666
Benjamin Petersonddd19492018-09-16 22:38:02 -07002667 case TARGET(BUILD_SET): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002668 PyObject *set = PySet_New(NULL);
2669 int err = 0;
Raymond Hettinger4c483ad2016-09-08 14:45:40 -07002670 int i;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002671 if (set == NULL)
2672 goto error;
Raymond Hettinger4c483ad2016-09-08 14:45:40 -07002673 for (i = oparg; i > 0; i--) {
2674 PyObject *item = PEEK(i);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002675 if (err == 0)
2676 err = PySet_Add(set, item);
2677 Py_DECREF(item);
2678 }
costypetrisor8ed317f2018-07-31 20:55:14 +00002679 STACK_SHRINK(oparg);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002680 if (err != 0) {
2681 Py_DECREF(set);
2682 goto error;
2683 }
2684 PUSH(set);
2685 DISPATCH();
2686 }
2687
Benjamin Petersonddd19492018-09-16 22:38:02 -07002688 case TARGET(BUILD_SET_UNPACK): {
Victor Stinner74319ae2016-08-25 00:04:09 +02002689 Py_ssize_t i;
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002690 PyObject *sum = PySet_New(NULL);
2691 if (sum == NULL)
2692 goto error;
2693
2694 for (i = oparg; i > 0; i--) {
2695 if (_PySet_Update(sum, PEEK(i)) < 0) {
2696 Py_DECREF(sum);
2697 goto error;
2698 }
2699 }
2700
2701 while (oparg--)
2702 Py_DECREF(POP());
2703 PUSH(sum);
2704 DISPATCH();
2705 }
2706
Benjamin Petersonddd19492018-09-16 22:38:02 -07002707 case TARGET(BUILD_MAP): {
Victor Stinner74319ae2016-08-25 00:04:09 +02002708 Py_ssize_t i;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002709 PyObject *map = _PyDict_NewPresized((Py_ssize_t)oparg);
2710 if (map == NULL)
2711 goto error;
Benjamin Petersond5d77aa2015-07-05 10:37:25 -05002712 for (i = oparg; i > 0; i--) {
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002713 int err;
Benjamin Petersond5d77aa2015-07-05 10:37:25 -05002714 PyObject *key = PEEK(2*i);
2715 PyObject *value = PEEK(2*i - 1);
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002716 err = PyDict_SetItem(map, key, value);
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002717 if (err != 0) {
2718 Py_DECREF(map);
2719 goto error;
2720 }
2721 }
Benjamin Petersond5d77aa2015-07-05 10:37:25 -05002722
2723 while (oparg--) {
2724 Py_DECREF(POP());
2725 Py_DECREF(POP());
2726 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002727 PUSH(map);
2728 DISPATCH();
2729 }
2730
Benjamin Petersonddd19492018-09-16 22:38:02 -07002731 case TARGET(SETUP_ANNOTATIONS): {
Yury Selivanovf8cb8a12016-09-08 20:50:03 -07002732 _Py_IDENTIFIER(__annotations__);
2733 int err;
2734 PyObject *ann_dict;
2735 if (f->f_locals == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002736 _PyErr_Format(tstate, PyExc_SystemError,
2737 "no locals found when setting up annotations");
Yury Selivanovf8cb8a12016-09-08 20:50:03 -07002738 goto error;
2739 }
2740 /* check if __annotations__ in locals()... */
2741 if (PyDict_CheckExact(f->f_locals)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002742 ann_dict = _PyDict_GetItemIdWithError(f->f_locals,
Yury Selivanovf8cb8a12016-09-08 20:50:03 -07002743 &PyId___annotations__);
2744 if (ann_dict == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002745 if (_PyErr_Occurred(tstate)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002746 goto error;
2747 }
Yury Selivanovf8cb8a12016-09-08 20:50:03 -07002748 /* ...if not, create a new one */
2749 ann_dict = PyDict_New();
2750 if (ann_dict == NULL) {
2751 goto error;
2752 }
2753 err = _PyDict_SetItemId(f->f_locals,
2754 &PyId___annotations__, ann_dict);
2755 Py_DECREF(ann_dict);
2756 if (err != 0) {
2757 goto error;
2758 }
2759 }
2760 }
2761 else {
2762 /* do the same if locals() is not a dict */
2763 PyObject *ann_str = _PyUnicode_FromId(&PyId___annotations__);
2764 if (ann_str == NULL) {
Serhiy Storchaka4678b2f2016-11-08 23:13:36 +02002765 goto error;
Yury Selivanovf8cb8a12016-09-08 20:50:03 -07002766 }
2767 ann_dict = PyObject_GetItem(f->f_locals, ann_str);
2768 if (ann_dict == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002769 if (!_PyErr_ExceptionMatches(tstate, PyExc_KeyError)) {
Yury Selivanovf8cb8a12016-09-08 20:50:03 -07002770 goto error;
2771 }
Victor Stinner438a12d2019-05-24 17:01:38 +02002772 _PyErr_Clear(tstate);
Yury Selivanovf8cb8a12016-09-08 20:50:03 -07002773 ann_dict = PyDict_New();
2774 if (ann_dict == NULL) {
2775 goto error;
2776 }
2777 err = PyObject_SetItem(f->f_locals, ann_str, ann_dict);
2778 Py_DECREF(ann_dict);
2779 if (err != 0) {
2780 goto error;
2781 }
2782 }
2783 else {
2784 Py_DECREF(ann_dict);
2785 }
2786 }
2787 DISPATCH();
2788 }
2789
Benjamin Petersonddd19492018-09-16 22:38:02 -07002790 case TARGET(BUILD_CONST_KEY_MAP): {
Victor Stinner74319ae2016-08-25 00:04:09 +02002791 Py_ssize_t i;
Serhiy Storchaka6a7506a2016-06-12 00:39:41 +03002792 PyObject *map;
2793 PyObject *keys = TOP();
2794 if (!PyTuple_CheckExact(keys) ||
2795 PyTuple_GET_SIZE(keys) != (Py_ssize_t)oparg) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002796 _PyErr_SetString(tstate, PyExc_SystemError,
2797 "bad BUILD_CONST_KEY_MAP keys argument");
Serhiy Storchaka6a7506a2016-06-12 00:39:41 +03002798 goto error;
2799 }
2800 map = _PyDict_NewPresized((Py_ssize_t)oparg);
2801 if (map == NULL) {
2802 goto error;
2803 }
2804 for (i = oparg; i > 0; i--) {
2805 int err;
2806 PyObject *key = PyTuple_GET_ITEM(keys, oparg - i);
2807 PyObject *value = PEEK(i + 1);
2808 err = PyDict_SetItem(map, key, value);
2809 if (err != 0) {
2810 Py_DECREF(map);
2811 goto error;
2812 }
2813 }
2814
2815 Py_DECREF(POP());
2816 while (oparg--) {
2817 Py_DECREF(POP());
2818 }
2819 PUSH(map);
2820 DISPATCH();
2821 }
2822
Benjamin Petersonddd19492018-09-16 22:38:02 -07002823 case TARGET(BUILD_MAP_UNPACK): {
Victor Stinner74319ae2016-08-25 00:04:09 +02002824 Py_ssize_t i;
Serhiy Storchakab7281052016-09-12 00:52:40 +03002825 PyObject *sum = PyDict_New();
Victor Stinnerf9b760f2016-09-09 10:17:08 -07002826 if (sum == NULL)
2827 goto error;
2828
2829 for (i = oparg; i > 0; i--) {
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002830 PyObject *arg = PEEK(i);
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002831 if (PyDict_Update(sum, arg) < 0) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002832 if (_PyErr_ExceptionMatches(tstate, PyExc_AttributeError)) {
2833 _PyErr_Format(tstate, PyExc_TypeError,
2834 "'%.200s' object is not a mapping",
2835 arg->ob_type->tp_name);
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002836 }
2837 Py_DECREF(sum);
2838 goto error;
2839 }
2840 }
2841
Victor Stinnerf9b760f2016-09-09 10:17:08 -07002842 while (oparg--)
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002843 Py_DECREF(POP());
2844 PUSH(sum);
2845 DISPATCH();
2846 }
2847
Benjamin Petersonddd19492018-09-16 22:38:02 -07002848 case TARGET(BUILD_MAP_UNPACK_WITH_CALL): {
Serhiy Storchakae036ef82016-10-02 11:06:43 +03002849 Py_ssize_t i;
2850 PyObject *sum = PyDict_New();
2851 if (sum == NULL)
2852 goto error;
2853
2854 for (i = oparg; i > 0; i--) {
2855 PyObject *arg = PEEK(i);
2856 if (_PyDict_MergeEx(sum, arg, 2) < 0) {
Serhiy Storchakae036ef82016-10-02 11:06:43 +03002857 Py_DECREF(sum);
Victor Stinner438a12d2019-05-24 17:01:38 +02002858 format_kwargs_error(tstate, PEEK(2 + oparg), arg);
Serhiy Storchakae036ef82016-10-02 11:06:43 +03002859 goto error;
2860 }
2861 }
2862
2863 while (oparg--)
2864 Py_DECREF(POP());
2865 PUSH(sum);
Brandt Bucherf185a732019-09-28 17:12:49 -07002866 PREDICT(CALL_FUNCTION_EX);
Serhiy Storchakae036ef82016-10-02 11:06:43 +03002867 DISPATCH();
2868 }
2869
Benjamin Petersonddd19492018-09-16 22:38:02 -07002870 case TARGET(MAP_ADD): {
Jörn Heisslerc8a35412019-06-22 16:40:55 +02002871 PyObject *value = TOP();
2872 PyObject *key = SECOND();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002873 PyObject *map;
2874 int err;
costypetrisor8ed317f2018-07-31 20:55:14 +00002875 STACK_SHRINK(2);
Raymond Hettinger41862222016-10-15 19:03:06 -07002876 map = PEEK(oparg); /* dict */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002877 assert(PyDict_CheckExact(map));
Martin Panter95f53c12016-07-18 08:23:26 +00002878 err = PyDict_SetItem(map, key, value); /* map[key] = value */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002879 Py_DECREF(value);
2880 Py_DECREF(key);
2881 if (err != 0)
2882 goto error;
2883 PREDICT(JUMP_ABSOLUTE);
2884 DISPATCH();
2885 }
2886
Benjamin Petersonddd19492018-09-16 22:38:02 -07002887 case TARGET(LOAD_ATTR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002888 PyObject *name = GETITEM(names, oparg);
2889 PyObject *owner = TOP();
2890 PyObject *res = PyObject_GetAttr(owner, name);
2891 Py_DECREF(owner);
2892 SET_TOP(res);
2893 if (res == NULL)
2894 goto error;
2895 DISPATCH();
2896 }
2897
Benjamin Petersonddd19492018-09-16 22:38:02 -07002898 case TARGET(COMPARE_OP): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002899 PyObject *right = POP();
2900 PyObject *left = TOP();
Victor Stinner438a12d2019-05-24 17:01:38 +02002901 PyObject *res = cmp_outcome(tstate, oparg, left, right);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002902 Py_DECREF(left);
2903 Py_DECREF(right);
2904 SET_TOP(res);
2905 if (res == NULL)
2906 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002907 PREDICT(POP_JUMP_IF_FALSE);
2908 PREDICT(POP_JUMP_IF_TRUE);
2909 DISPATCH();
Victor Stinner3c1e4812012-03-26 22:10:51 +02002910 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002911
Benjamin Petersonddd19492018-09-16 22:38:02 -07002912 case TARGET(IMPORT_NAME): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002913 PyObject *name = GETITEM(names, oparg);
Serhiy Storchaka133138a2016-08-02 22:51:21 +03002914 PyObject *fromlist = POP();
2915 PyObject *level = TOP();
2916 PyObject *res;
Victor Stinner438a12d2019-05-24 17:01:38 +02002917 res = import_name(tstate, f, name, fromlist, level);
Serhiy Storchaka133138a2016-08-02 22:51:21 +03002918 Py_DECREF(level);
2919 Py_DECREF(fromlist);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002920 SET_TOP(res);
2921 if (res == NULL)
2922 goto error;
2923 DISPATCH();
2924 }
2925
Benjamin Petersonddd19492018-09-16 22:38:02 -07002926 case TARGET(IMPORT_STAR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002927 PyObject *from = POP(), *locals;
2928 int err;
Matthias Bussonnier160edb42017-02-25 21:58:05 -08002929 if (PyFrame_FastToLocalsWithError(f) < 0) {
2930 Py_DECREF(from);
Victor Stinner41bb43a2013-10-29 01:19:37 +01002931 goto error;
Matthias Bussonnier160edb42017-02-25 21:58:05 -08002932 }
Victor Stinner41bb43a2013-10-29 01:19:37 +01002933
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002934 locals = f->f_locals;
2935 if (locals == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002936 _PyErr_SetString(tstate, PyExc_SystemError,
2937 "no locals found during 'import *'");
Matthias Bussonnier160edb42017-02-25 21:58:05 -08002938 Py_DECREF(from);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002939 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002940 }
Victor Stinner438a12d2019-05-24 17:01:38 +02002941 err = import_all_from(tstate, locals, from);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002942 PyFrame_LocalsToFast(f, 0);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002943 Py_DECREF(from);
2944 if (err != 0)
2945 goto error;
2946 DISPATCH();
2947 }
Guido van Rossum25831651993-05-19 14:50:45 +00002948
Benjamin Petersonddd19492018-09-16 22:38:02 -07002949 case TARGET(IMPORT_FROM): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002950 PyObject *name = GETITEM(names, oparg);
2951 PyObject *from = TOP();
2952 PyObject *res;
Victor Stinner438a12d2019-05-24 17:01:38 +02002953 res = import_from(tstate, from, name);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002954 PUSH(res);
2955 if (res == NULL)
2956 goto error;
2957 DISPATCH();
2958 }
Thomas Wouters52152252000-08-17 22:55:00 +00002959
Benjamin Petersonddd19492018-09-16 22:38:02 -07002960 case TARGET(JUMP_FORWARD): {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002961 JUMPBY(oparg);
2962 FAST_DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002963 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002964
Benjamin Petersonddd19492018-09-16 22:38:02 -07002965 case TARGET(POP_JUMP_IF_FALSE): {
2966 PREDICTED(POP_JUMP_IF_FALSE);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002967 PyObject *cond = POP();
2968 int err;
2969 if (cond == Py_True) {
2970 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002971 FAST_DISPATCH();
2972 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002973 if (cond == Py_False) {
2974 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002975 JUMPTO(oparg);
2976 FAST_DISPATCH();
2977 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002978 err = PyObject_IsTrue(cond);
2979 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002980 if (err > 0)
Adrian Wielgosik50c28502017-06-23 13:35:41 -07002981 ;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002982 else if (err == 0)
2983 JUMPTO(oparg);
2984 else
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002985 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002986 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002987 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002988
Benjamin Petersonddd19492018-09-16 22:38:02 -07002989 case TARGET(POP_JUMP_IF_TRUE): {
2990 PREDICTED(POP_JUMP_IF_TRUE);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002991 PyObject *cond = POP();
2992 int err;
2993 if (cond == Py_False) {
2994 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002995 FAST_DISPATCH();
2996 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002997 if (cond == Py_True) {
2998 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002999 JUMPTO(oparg);
3000 FAST_DISPATCH();
3001 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003002 err = PyObject_IsTrue(cond);
3003 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003004 if (err > 0) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003005 JUMPTO(oparg);
3006 }
3007 else if (err == 0)
3008 ;
3009 else
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003010 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003011 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003012 }
Jeffrey Yasskin9de7ec72009-02-25 02:25:04 +00003013
Benjamin Petersonddd19492018-09-16 22:38:02 -07003014 case TARGET(JUMP_IF_FALSE_OR_POP): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003015 PyObject *cond = TOP();
3016 int err;
3017 if (cond == Py_True) {
costypetrisor8ed317f2018-07-31 20:55:14 +00003018 STACK_SHRINK(1);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003019 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003020 FAST_DISPATCH();
3021 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003022 if (cond == Py_False) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003023 JUMPTO(oparg);
3024 FAST_DISPATCH();
3025 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003026 err = PyObject_IsTrue(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003027 if (err > 0) {
costypetrisor8ed317f2018-07-31 20:55:14 +00003028 STACK_SHRINK(1);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003029 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003030 }
3031 else if (err == 0)
3032 JUMPTO(oparg);
3033 else
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003034 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003035 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003036 }
Jeffrey Yasskin9de7ec72009-02-25 02:25:04 +00003037
Benjamin Petersonddd19492018-09-16 22:38:02 -07003038 case TARGET(JUMP_IF_TRUE_OR_POP): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003039 PyObject *cond = TOP();
3040 int err;
3041 if (cond == Py_False) {
costypetrisor8ed317f2018-07-31 20:55:14 +00003042 STACK_SHRINK(1);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003043 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003044 FAST_DISPATCH();
3045 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003046 if (cond == Py_True) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003047 JUMPTO(oparg);
3048 FAST_DISPATCH();
3049 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003050 err = PyObject_IsTrue(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003051 if (err > 0) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003052 JUMPTO(oparg);
3053 }
3054 else if (err == 0) {
costypetrisor8ed317f2018-07-31 20:55:14 +00003055 STACK_SHRINK(1);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003056 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003057 }
3058 else
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003059 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003060 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003061 }
Guido van Rossumac7be682001-01-17 15:42:30 +00003062
Benjamin Petersonddd19492018-09-16 22:38:02 -07003063 case TARGET(JUMP_ABSOLUTE): {
3064 PREDICTED(JUMP_ABSOLUTE);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003065 JUMPTO(oparg);
Guido van Rossum58da9312007-11-10 23:39:45 +00003066#if FAST_LOOPS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003067 /* Enabling this path speeds-up all while and for-loops by bypassing
3068 the per-loop checks for signals. By default, this should be turned-off
3069 because it prevents detection of a control-break in tight loops like
3070 "while 1: pass". Compile with this option turned-on when you need
3071 the speed-up and do not need break checking inside tight loops (ones
3072 that contain only instructions ending with FAST_DISPATCH).
3073 */
3074 FAST_DISPATCH();
Guido van Rossum58da9312007-11-10 23:39:45 +00003075#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003076 DISPATCH();
Guido van Rossum58da9312007-11-10 23:39:45 +00003077#endif
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003078 }
Guido van Rossumac7be682001-01-17 15:42:30 +00003079
Benjamin Petersonddd19492018-09-16 22:38:02 -07003080 case TARGET(GET_ITER): {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003081 /* before: [obj]; after [getiter(obj)] */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003082 PyObject *iterable = TOP();
Yury Selivanov5376ba92015-06-22 12:19:30 -04003083 PyObject *iter = PyObject_GetIter(iterable);
3084 Py_DECREF(iterable);
3085 SET_TOP(iter);
3086 if (iter == NULL)
3087 goto error;
3088 PREDICT(FOR_ITER);
Serhiy Storchakada9c5132016-06-27 18:58:57 +03003089 PREDICT(CALL_FUNCTION);
Yury Selivanov5376ba92015-06-22 12:19:30 -04003090 DISPATCH();
3091 }
3092
Benjamin Petersonddd19492018-09-16 22:38:02 -07003093 case TARGET(GET_YIELD_FROM_ITER): {
Yury Selivanov5376ba92015-06-22 12:19:30 -04003094 /* before: [obj]; after [getiter(obj)] */
3095 PyObject *iterable = TOP();
Yury Selivanov75445082015-05-11 22:57:16 -04003096 PyObject *iter;
Yury Selivanov5376ba92015-06-22 12:19:30 -04003097 if (PyCoro_CheckExact(iterable)) {
3098 /* `iterable` is a coroutine */
3099 if (!(co->co_flags & (CO_COROUTINE | CO_ITERABLE_COROUTINE))) {
3100 /* and it is used in a 'yield from' expression of a
3101 regular generator. */
3102 Py_DECREF(iterable);
3103 SET_TOP(NULL);
Victor Stinner438a12d2019-05-24 17:01:38 +02003104 _PyErr_SetString(tstate, PyExc_TypeError,
3105 "cannot 'yield from' a coroutine object "
3106 "in a non-coroutine generator");
Yury Selivanov5376ba92015-06-22 12:19:30 -04003107 goto error;
3108 }
3109 }
3110 else if (!PyGen_CheckExact(iterable)) {
Yury Selivanov75445082015-05-11 22:57:16 -04003111 /* `iterable` is not a generator. */
3112 iter = PyObject_GetIter(iterable);
3113 Py_DECREF(iterable);
3114 SET_TOP(iter);
3115 if (iter == NULL)
3116 goto error;
3117 }
Serhiy Storchakada9c5132016-06-27 18:58:57 +03003118 PREDICT(LOAD_CONST);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003119 DISPATCH();
3120 }
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00003121
Benjamin Petersonddd19492018-09-16 22:38:02 -07003122 case TARGET(FOR_ITER): {
3123 PREDICTED(FOR_ITER);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003124 /* before: [iter]; after: [iter, iter()] *or* [] */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003125 PyObject *iter = TOP();
3126 PyObject *next = (*iter->ob_type->tp_iternext)(iter);
3127 if (next != NULL) {
3128 PUSH(next);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003129 PREDICT(STORE_FAST);
3130 PREDICT(UNPACK_SEQUENCE);
3131 DISPATCH();
3132 }
Victor Stinner438a12d2019-05-24 17:01:38 +02003133 if (_PyErr_Occurred(tstate)) {
3134 if (!_PyErr_ExceptionMatches(tstate, PyExc_StopIteration)) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003135 goto error;
Victor Stinner438a12d2019-05-24 17:01:38 +02003136 }
3137 else if (tstate->c_tracefunc != NULL) {
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01003138 call_exc_trace(tstate->c_tracefunc, tstate->c_traceobj, tstate, f);
Victor Stinner438a12d2019-05-24 17:01:38 +02003139 }
3140 _PyErr_Clear(tstate);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003141 }
3142 /* iterator ended normally */
costypetrisor8ed317f2018-07-31 20:55:14 +00003143 STACK_SHRINK(1);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003144 Py_DECREF(iter);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003145 JUMPBY(oparg);
Serhiy Storchakada9c5132016-06-27 18:58:57 +03003146 PREDICT(POP_BLOCK);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003147 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003148 }
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00003149
Benjamin Petersonddd19492018-09-16 22:38:02 -07003150 case TARGET(SETUP_FINALLY): {
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02003151 PyFrame_BlockSetup(f, SETUP_FINALLY, INSTR_OFFSET() + oparg,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003152 STACK_LEVEL());
3153 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003154 }
Guido van Rossumac7be682001-01-17 15:42:30 +00003155
Benjamin Petersonddd19492018-09-16 22:38:02 -07003156 case TARGET(BEFORE_ASYNC_WITH): {
Yury Selivanov75445082015-05-11 22:57:16 -04003157 _Py_IDENTIFIER(__aexit__);
3158 _Py_IDENTIFIER(__aenter__);
3159
3160 PyObject *mgr = TOP();
Victor Stinner438a12d2019-05-24 17:01:38 +02003161 PyObject *exit = special_lookup(tstate, mgr, &PyId___aexit__),
Yury Selivanov75445082015-05-11 22:57:16 -04003162 *enter;
3163 PyObject *res;
3164 if (exit == NULL)
3165 goto error;
3166 SET_TOP(exit);
Victor Stinner438a12d2019-05-24 17:01:38 +02003167 enter = special_lookup(tstate, mgr, &PyId___aenter__);
Yury Selivanov75445082015-05-11 22:57:16 -04003168 Py_DECREF(mgr);
3169 if (enter == NULL)
3170 goto error;
Victor Stinnerf17c3de2016-12-06 18:46:19 +01003171 res = _PyObject_CallNoArg(enter);
Yury Selivanov75445082015-05-11 22:57:16 -04003172 Py_DECREF(enter);
3173 if (res == NULL)
3174 goto error;
3175 PUSH(res);
Serhiy Storchakada9c5132016-06-27 18:58:57 +03003176 PREDICT(GET_AWAITABLE);
Yury Selivanov75445082015-05-11 22:57:16 -04003177 DISPATCH();
3178 }
3179
Benjamin Petersonddd19492018-09-16 22:38:02 -07003180 case TARGET(SETUP_ASYNC_WITH): {
Yury Selivanov75445082015-05-11 22:57:16 -04003181 PyObject *res = POP();
3182 /* Setup the finally block before pushing the result
3183 of __aenter__ on the stack. */
3184 PyFrame_BlockSetup(f, SETUP_FINALLY, INSTR_OFFSET() + oparg,
3185 STACK_LEVEL());
3186 PUSH(res);
3187 DISPATCH();
3188 }
3189
Benjamin Petersonddd19492018-09-16 22:38:02 -07003190 case TARGET(SETUP_WITH): {
Benjamin Petersonce798522012-01-22 11:24:29 -05003191 _Py_IDENTIFIER(__exit__);
3192 _Py_IDENTIFIER(__enter__);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003193 PyObject *mgr = TOP();
Victor Stinner438a12d2019-05-24 17:01:38 +02003194 PyObject *enter = special_lookup(tstate, mgr, &PyId___enter__);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003195 PyObject *res;
Victor Stinner438a12d2019-05-24 17:01:38 +02003196 if (enter == NULL) {
Raymond Hettingera3fec152016-11-21 17:24:23 -08003197 goto error;
Victor Stinner438a12d2019-05-24 17:01:38 +02003198 }
3199 PyObject *exit = special_lookup(tstate, mgr, &PyId___exit__);
Raymond Hettinger64e2f9a2016-11-22 11:50:40 -08003200 if (exit == NULL) {
3201 Py_DECREF(enter);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003202 goto error;
Raymond Hettinger64e2f9a2016-11-22 11:50:40 -08003203 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003204 SET_TOP(exit);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003205 Py_DECREF(mgr);
Victor Stinnerf17c3de2016-12-06 18:46:19 +01003206 res = _PyObject_CallNoArg(enter);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003207 Py_DECREF(enter);
3208 if (res == NULL)
3209 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003210 /* Setup the finally block before pushing the result
3211 of __enter__ on the stack. */
3212 PyFrame_BlockSetup(f, SETUP_FINALLY, INSTR_OFFSET() + oparg,
3213 STACK_LEVEL());
Benjamin Peterson876b2f22009-06-28 03:18:59 +00003214
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003215 PUSH(res);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003216 DISPATCH();
3217 }
Benjamin Peterson876b2f22009-06-28 03:18:59 +00003218
Mark Shannonfee55262019-11-21 09:11:43 +00003219 case TARGET(WITH_EXCEPT_START): {
3220 /* At the top of the stack are 7 values:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003221 - (TOP, SECOND, THIRD) = exc_info()
Mark Shannonfee55262019-11-21 09:11:43 +00003222 - (FOURTH, FIFTH, SIXTH) = previous exception for EXCEPT_HANDLER
3223 - SEVENTH: the context.__exit__ bound method
3224 We call SEVENTH(TOP, SECOND, THIRD).
3225 Then we push again the TOP exception and the __exit__
3226 return value.
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003227 */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003228 PyObject *exit_func;
Victor Stinner842cfff2016-12-01 14:45:31 +01003229 PyObject *exc, *val, *tb, *res;
3230
Victor Stinner842cfff2016-12-01 14:45:31 +01003231 exc = TOP();
Mark Shannonfee55262019-11-21 09:11:43 +00003232 val = SECOND();
3233 tb = THIRD();
3234 assert(exc != Py_None);
3235 assert(!PyLong_Check(exc));
3236 exit_func = PEEK(7);
Jeroen Demeyer469d1a72019-07-03 12:52:21 +02003237 PyObject *stack[4] = {NULL, exc, val, tb};
3238 res = _PyObject_Vectorcall(exit_func, stack + 1,
3239 3 | PY_VECTORCALL_ARGUMENTS_OFFSET, NULL);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003240 if (res == NULL)
3241 goto error;
Amaury Forgeot d'Arc10b24e82008-12-10 23:49:33 +00003242
Yury Selivanov75445082015-05-11 22:57:16 -04003243 PUSH(res);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003244 DISPATCH();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003245 }
Guido van Rossumc2e20742006-02-27 22:32:47 +00003246
Benjamin Petersonddd19492018-09-16 22:38:02 -07003247 case TARGET(LOAD_METHOD): {
Andreyb021ba52019-04-29 14:33:26 +10003248 /* Designed to work in tandem with CALL_METHOD. */
Yury Selivanovf2392132016-12-13 19:03:51 -05003249 PyObject *name = GETITEM(names, oparg);
3250 PyObject *obj = TOP();
3251 PyObject *meth = NULL;
3252
3253 int meth_found = _PyObject_GetMethod(obj, name, &meth);
3254
Yury Selivanovf2392132016-12-13 19:03:51 -05003255 if (meth == NULL) {
3256 /* Most likely attribute wasn't found. */
Yury Selivanovf2392132016-12-13 19:03:51 -05003257 goto error;
3258 }
3259
3260 if (meth_found) {
INADA Naoki015bce62017-01-16 17:23:30 +09003261 /* We can bypass temporary bound method object.
3262 meth is unbound method and obj is self.
Victor Stinnera8cb5152017-01-18 14:12:51 +01003263
INADA Naoki015bce62017-01-16 17:23:30 +09003264 meth | self | arg1 | ... | argN
3265 */
3266 SET_TOP(meth);
3267 PUSH(obj); // self
Yury Selivanovf2392132016-12-13 19:03:51 -05003268 }
3269 else {
INADA Naoki015bce62017-01-16 17:23:30 +09003270 /* meth is not an unbound method (but a regular attr, or
3271 something was returned by a descriptor protocol). Set
3272 the second element of the stack to NULL, to signal
Yury Selivanovf2392132016-12-13 19:03:51 -05003273 CALL_METHOD that it's not a method call.
INADA Naoki015bce62017-01-16 17:23:30 +09003274
3275 NULL | meth | arg1 | ... | argN
Yury Selivanovf2392132016-12-13 19:03:51 -05003276 */
INADA Naoki015bce62017-01-16 17:23:30 +09003277 SET_TOP(NULL);
Yury Selivanovf2392132016-12-13 19:03:51 -05003278 Py_DECREF(obj);
INADA Naoki015bce62017-01-16 17:23:30 +09003279 PUSH(meth);
Yury Selivanovf2392132016-12-13 19:03:51 -05003280 }
3281 DISPATCH();
3282 }
3283
Benjamin Petersonddd19492018-09-16 22:38:02 -07003284 case TARGET(CALL_METHOD): {
Yury Selivanovf2392132016-12-13 19:03:51 -05003285 /* Designed to work in tamdem with LOAD_METHOD. */
INADA Naoki015bce62017-01-16 17:23:30 +09003286 PyObject **sp, *res, *meth;
Yury Selivanovf2392132016-12-13 19:03:51 -05003287
3288 sp = stack_pointer;
3289
INADA Naoki015bce62017-01-16 17:23:30 +09003290 meth = PEEK(oparg + 2);
3291 if (meth == NULL) {
3292 /* `meth` is NULL when LOAD_METHOD thinks that it's not
3293 a method call.
Yury Selivanovf2392132016-12-13 19:03:51 -05003294
3295 Stack layout:
3296
INADA Naoki015bce62017-01-16 17:23:30 +09003297 ... | NULL | callable | arg1 | ... | argN
3298 ^- TOP()
3299 ^- (-oparg)
3300 ^- (-oparg-1)
3301 ^- (-oparg-2)
Yury Selivanovf2392132016-12-13 19:03:51 -05003302
Ville Skyttä49b27342017-08-03 09:00:59 +03003303 `callable` will be POPed by call_function.
INADA Naoki015bce62017-01-16 17:23:30 +09003304 NULL will will be POPed manually later.
Yury Selivanovf2392132016-12-13 19:03:51 -05003305 */
Victor Stinner09532fe2019-05-10 23:39:09 +02003306 res = call_function(tstate, &sp, oparg, NULL);
Yury Selivanovf2392132016-12-13 19:03:51 -05003307 stack_pointer = sp;
INADA Naoki015bce62017-01-16 17:23:30 +09003308 (void)POP(); /* POP the NULL. */
Yury Selivanovf2392132016-12-13 19:03:51 -05003309 }
3310 else {
3311 /* This is a method call. Stack layout:
3312
INADA Naoki015bce62017-01-16 17:23:30 +09003313 ... | method | self | arg1 | ... | argN
Yury Selivanovf2392132016-12-13 19:03:51 -05003314 ^- TOP()
3315 ^- (-oparg)
INADA Naoki015bce62017-01-16 17:23:30 +09003316 ^- (-oparg-1)
3317 ^- (-oparg-2)
Yury Selivanovf2392132016-12-13 19:03:51 -05003318
INADA Naoki015bce62017-01-16 17:23:30 +09003319 `self` and `method` will be POPed by call_function.
Yury Selivanovf2392132016-12-13 19:03:51 -05003320 We'll be passing `oparg + 1` to call_function, to
INADA Naoki015bce62017-01-16 17:23:30 +09003321 make it accept the `self` as a first argument.
Yury Selivanovf2392132016-12-13 19:03:51 -05003322 */
Victor Stinner09532fe2019-05-10 23:39:09 +02003323 res = call_function(tstate, &sp, oparg + 1, NULL);
Yury Selivanovf2392132016-12-13 19:03:51 -05003324 stack_pointer = sp;
3325 }
3326
3327 PUSH(res);
3328 if (res == NULL)
3329 goto error;
3330 DISPATCH();
3331 }
3332
Benjamin Petersonddd19492018-09-16 22:38:02 -07003333 case TARGET(CALL_FUNCTION): {
3334 PREDICTED(CALL_FUNCTION);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003335 PyObject **sp, *res;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003336 sp = stack_pointer;
Victor Stinner09532fe2019-05-10 23:39:09 +02003337 res = call_function(tstate, &sp, oparg, NULL);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003338 stack_pointer = sp;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003339 PUSH(res);
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003340 if (res == NULL) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003341 goto error;
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003342 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003343 DISPATCH();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003344 }
Guido van Rossumac7be682001-01-17 15:42:30 +00003345
Benjamin Petersonddd19492018-09-16 22:38:02 -07003346 case TARGET(CALL_FUNCTION_KW): {
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003347 PyObject **sp, *res, *names;
3348
3349 names = POP();
Jeroen Demeyer05677862019-08-16 12:41:27 +02003350 assert(PyTuple_Check(names));
3351 assert(PyTuple_GET_SIZE(names) <= oparg);
3352 /* We assume without checking that names contains only strings */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003353 sp = stack_pointer;
Victor Stinner09532fe2019-05-10 23:39:09 +02003354 res = call_function(tstate, &sp, oparg, names);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003355 stack_pointer = sp;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003356 PUSH(res);
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003357 Py_DECREF(names);
3358
3359 if (res == NULL) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003360 goto error;
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003361 }
3362 DISPATCH();
3363 }
3364
Benjamin Petersonddd19492018-09-16 22:38:02 -07003365 case TARGET(CALL_FUNCTION_EX): {
Brandt Bucherf185a732019-09-28 17:12:49 -07003366 PREDICTED(CALL_FUNCTION_EX);
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003367 PyObject *func, *callargs, *kwargs = NULL, *result;
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003368 if (oparg & 0x01) {
3369 kwargs = POP();
Serhiy Storchakab7281052016-09-12 00:52:40 +03003370 if (!PyDict_CheckExact(kwargs)) {
3371 PyObject *d = PyDict_New();
3372 if (d == NULL)
3373 goto error;
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02003374 if (_PyDict_MergeEx(d, kwargs, 2) < 0) {
Serhiy Storchakab7281052016-09-12 00:52:40 +03003375 Py_DECREF(d);
Victor Stinner438a12d2019-05-24 17:01:38 +02003376 format_kwargs_error(tstate, SECOND(), kwargs);
Victor Stinnereece2222016-09-12 11:16:37 +02003377 Py_DECREF(kwargs);
Serhiy Storchakab7281052016-09-12 00:52:40 +03003378 goto error;
3379 }
3380 Py_DECREF(kwargs);
3381 kwargs = d;
3382 }
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003383 assert(PyDict_CheckExact(kwargs));
3384 }
3385 callargs = POP();
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003386 func = TOP();
Serhiy Storchaka63dc5482016-09-22 19:41:20 +03003387 if (!PyTuple_CheckExact(callargs)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02003388 if (check_args_iterable(tstate, func, callargs) < 0) {
Victor Stinnereece2222016-09-12 11:16:37 +02003389 Py_DECREF(callargs);
Serhiy Storchakab7281052016-09-12 00:52:40 +03003390 goto error;
3391 }
3392 Py_SETREF(callargs, PySequence_Tuple(callargs));
3393 if (callargs == NULL) {
3394 goto error;
3395 }
3396 }
Serhiy Storchaka63dc5482016-09-22 19:41:20 +03003397 assert(PyTuple_CheckExact(callargs));
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003398
Victor Stinner09532fe2019-05-10 23:39:09 +02003399 result = do_call_core(tstate, func, callargs, kwargs);
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003400 Py_DECREF(func);
3401 Py_DECREF(callargs);
3402 Py_XDECREF(kwargs);
3403
3404 SET_TOP(result);
3405 if (result == NULL) {
3406 goto error;
3407 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003408 DISPATCH();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003409 }
Guido van Rossumac7be682001-01-17 15:42:30 +00003410
Benjamin Petersonddd19492018-09-16 22:38:02 -07003411 case TARGET(MAKE_FUNCTION): {
Serhiy Storchaka64204de2016-06-12 17:36:24 +03003412 PyObject *qualname = POP();
3413 PyObject *codeobj = POP();
3414 PyFunctionObject *func = (PyFunctionObject *)
3415 PyFunction_NewWithQualName(codeobj, f->f_globals, qualname);
Guido van Rossum4f72a782006-10-27 23:31:49 +00003416
Serhiy Storchaka64204de2016-06-12 17:36:24 +03003417 Py_DECREF(codeobj);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003418 Py_DECREF(qualname);
Serhiy Storchaka64204de2016-06-12 17:36:24 +03003419 if (func == NULL) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003420 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003421 }
Neal Norwitzc1505362006-12-28 06:47:50 +00003422
Serhiy Storchaka64204de2016-06-12 17:36:24 +03003423 if (oparg & 0x08) {
3424 assert(PyTuple_CheckExact(TOP()));
3425 func ->func_closure = POP();
3426 }
3427 if (oparg & 0x04) {
3428 assert(PyDict_CheckExact(TOP()));
3429 func->func_annotations = POP();
3430 }
3431 if (oparg & 0x02) {
3432 assert(PyDict_CheckExact(TOP()));
3433 func->func_kwdefaults = POP();
3434 }
3435 if (oparg & 0x01) {
3436 assert(PyTuple_CheckExact(TOP()));
3437 func->func_defaults = POP();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003438 }
Neal Norwitzc1505362006-12-28 06:47:50 +00003439
Serhiy Storchaka64204de2016-06-12 17:36:24 +03003440 PUSH((PyObject *)func);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003441 DISPATCH();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003442 }
Guido van Rossum8861b741996-07-30 16:49:37 +00003443
Benjamin Petersonddd19492018-09-16 22:38:02 -07003444 case TARGET(BUILD_SLICE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003445 PyObject *start, *stop, *step, *slice;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003446 if (oparg == 3)
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003447 step = POP();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003448 else
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003449 step = NULL;
3450 stop = POP();
3451 start = TOP();
3452 slice = PySlice_New(start, stop, step);
3453 Py_DECREF(start);
3454 Py_DECREF(stop);
3455 Py_XDECREF(step);
3456 SET_TOP(slice);
3457 if (slice == NULL)
3458 goto error;
3459 DISPATCH();
3460 }
Guido van Rossum8861b741996-07-30 16:49:37 +00003461
Benjamin Petersonddd19492018-09-16 22:38:02 -07003462 case TARGET(FORMAT_VALUE): {
Eric V. Smitha78c7952015-11-03 12:45:05 -05003463 /* Handles f-string value formatting. */
3464 PyObject *result;
3465 PyObject *fmt_spec;
3466 PyObject *value;
3467 PyObject *(*conv_fn)(PyObject *);
3468 int which_conversion = oparg & FVC_MASK;
3469 int have_fmt_spec = (oparg & FVS_MASK) == FVS_HAVE_SPEC;
3470
3471 fmt_spec = have_fmt_spec ? POP() : NULL;
Eric V. Smith135d5f42016-02-05 18:23:08 -05003472 value = POP();
Eric V. Smitha78c7952015-11-03 12:45:05 -05003473
3474 /* See if any conversion is specified. */
3475 switch (which_conversion) {
Eric V. Smith9a4135e2019-05-08 16:28:48 -04003476 case FVC_NONE: conv_fn = NULL; break;
Eric V. Smitha78c7952015-11-03 12:45:05 -05003477 case FVC_STR: conv_fn = PyObject_Str; break;
3478 case FVC_REPR: conv_fn = PyObject_Repr; break;
3479 case FVC_ASCII: conv_fn = PyObject_ASCII; break;
Eric V. Smith9a4135e2019-05-08 16:28:48 -04003480 default:
Victor Stinner438a12d2019-05-24 17:01:38 +02003481 _PyErr_Format(tstate, PyExc_SystemError,
3482 "unexpected conversion flag %d",
3483 which_conversion);
Eric V. Smith9a4135e2019-05-08 16:28:48 -04003484 goto error;
Eric V. Smitha78c7952015-11-03 12:45:05 -05003485 }
3486
3487 /* If there's a conversion function, call it and replace
3488 value with that result. Otherwise, just use value,
3489 without conversion. */
Eric V. Smitheb588a12016-02-05 18:26:20 -05003490 if (conv_fn != NULL) {
Eric V. Smitha78c7952015-11-03 12:45:05 -05003491 result = conv_fn(value);
3492 Py_DECREF(value);
Eric V. Smitheb588a12016-02-05 18:26:20 -05003493 if (result == NULL) {
Eric V. Smitha78c7952015-11-03 12:45:05 -05003494 Py_XDECREF(fmt_spec);
3495 goto error;
3496 }
3497 value = result;
3498 }
3499
3500 /* If value is a unicode object, and there's no fmt_spec,
3501 then we know the result of format(value) is value
3502 itself. In that case, skip calling format(). I plan to
3503 move this optimization in to PyObject_Format()
3504 itself. */
3505 if (PyUnicode_CheckExact(value) && fmt_spec == NULL) {
3506 /* Do nothing, just transfer ownership to result. */
3507 result = value;
3508 } else {
3509 /* Actually call format(). */
3510 result = PyObject_Format(value, fmt_spec);
3511 Py_DECREF(value);
3512 Py_XDECREF(fmt_spec);
Eric V. Smitheb588a12016-02-05 18:26:20 -05003513 if (result == NULL) {
Eric V. Smitha78c7952015-11-03 12:45:05 -05003514 goto error;
Eric V. Smitheb588a12016-02-05 18:26:20 -05003515 }
Eric V. Smitha78c7952015-11-03 12:45:05 -05003516 }
3517
Eric V. Smith135d5f42016-02-05 18:23:08 -05003518 PUSH(result);
Eric V. Smitha78c7952015-11-03 12:45:05 -05003519 DISPATCH();
3520 }
3521
Benjamin Petersonddd19492018-09-16 22:38:02 -07003522 case TARGET(EXTENDED_ARG): {
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +03003523 int oldoparg = oparg;
3524 NEXTOPARG();
3525 oparg |= oldoparg << 8;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003526 goto dispatch_opcode;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003527 }
Guido van Rossum8861b741996-07-30 16:49:37 +00003528
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04003529
Antoine Pitrou042b1282010-08-13 21:15:58 +00003530#if USE_COMPUTED_GOTOS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003531 _unknown_opcode:
Antoine Pitroub52ec782009-01-25 16:34:23 +00003532#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003533 default:
3534 fprintf(stderr,
3535 "XXX lineno: %d, opcode: %d\n",
3536 PyFrame_GetLineNumber(f),
3537 opcode);
Victor Stinner438a12d2019-05-24 17:01:38 +02003538 _PyErr_SetString(tstate, PyExc_SystemError, "unknown opcode");
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003539 goto error;
Guido van Rossum04691fc1992-08-12 15:35:34 +00003540
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003541 } /* switch */
Guido van Rossum374a9221991-04-04 10:40:29 +00003542
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003543 /* This should never be reached. Every opcode should end with DISPATCH()
3544 or goto error. */
Barry Warsawb2e57942017-09-14 18:13:16 -07003545 Py_UNREACHABLE();
Guido van Rossumac7be682001-01-17 15:42:30 +00003546
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003547error:
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003548 /* Double-check exception status. */
Victor Stinner365b6932013-07-12 00:11:58 +02003549#ifdef NDEBUG
Victor Stinner438a12d2019-05-24 17:01:38 +02003550 if (!_PyErr_Occurred(tstate)) {
3551 _PyErr_SetString(tstate, PyExc_SystemError,
3552 "error return without exception set");
3553 }
Victor Stinner365b6932013-07-12 00:11:58 +02003554#else
Victor Stinner438a12d2019-05-24 17:01:38 +02003555 assert(_PyErr_Occurred(tstate));
Victor Stinner365b6932013-07-12 00:11:58 +02003556#endif
Guido van Rossum374a9221991-04-04 10:40:29 +00003557
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003558 /* Log traceback info. */
3559 PyTraceBack_Here(f);
Guido van Rossumac7be682001-01-17 15:42:30 +00003560
Benjamin Peterson51f46162013-01-23 08:38:47 -05003561 if (tstate->c_tracefunc != NULL)
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01003562 call_exc_trace(tstate->c_tracefunc, tstate->c_traceobj,
3563 tstate, f);
Guido van Rossumac7be682001-01-17 15:42:30 +00003564
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02003565exception_unwind:
3566 /* Unwind stacks if an exception occurred */
3567 while (f->f_iblock > 0) {
3568 /* Pop the current block. */
3569 PyTryBlock *b = &f->f_blockstack[--f->f_iblock];
Jeremy Hylton3faa52e2001-02-01 22:48:12 +00003570
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003571 if (b->b_type == EXCEPT_HANDLER) {
3572 UNWIND_EXCEPT_HANDLER(b);
3573 continue;
3574 }
3575 UNWIND_BLOCK(b);
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02003576 if (b->b_type == SETUP_FINALLY) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003577 PyObject *exc, *val, *tb;
3578 int handler = b->b_handler;
Mark Shannonae3087c2017-10-22 22:41:51 +01003579 _PyErr_StackItem *exc_info = tstate->exc_info;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003580 /* Beware, this invalidates all b->b_* fields */
3581 PyFrame_BlockSetup(f, EXCEPT_HANDLER, -1, STACK_LEVEL());
Mark Shannonae3087c2017-10-22 22:41:51 +01003582 PUSH(exc_info->exc_traceback);
3583 PUSH(exc_info->exc_value);
3584 if (exc_info->exc_type != NULL) {
3585 PUSH(exc_info->exc_type);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003586 }
3587 else {
3588 Py_INCREF(Py_None);
3589 PUSH(Py_None);
3590 }
Victor Stinner438a12d2019-05-24 17:01:38 +02003591 _PyErr_Fetch(tstate, &exc, &val, &tb);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003592 /* Make the raw exception data
3593 available to the handler,
3594 so a program can emulate the
3595 Python main loop. */
Victor Stinner438a12d2019-05-24 17:01:38 +02003596 _PyErr_NormalizeException(tstate, &exc, &val, &tb);
Victor Stinner7eab0d02013-07-15 21:16:27 +02003597 if (tb != NULL)
3598 PyException_SetTraceback(val, tb);
3599 else
3600 PyException_SetTraceback(val, Py_None);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003601 Py_INCREF(exc);
Mark Shannonae3087c2017-10-22 22:41:51 +01003602 exc_info->exc_type = exc;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003603 Py_INCREF(val);
Mark Shannonae3087c2017-10-22 22:41:51 +01003604 exc_info->exc_value = val;
3605 exc_info->exc_traceback = tb;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003606 if (tb == NULL)
3607 tb = Py_None;
3608 Py_INCREF(tb);
3609 PUSH(tb);
3610 PUSH(val);
3611 PUSH(exc);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003612 JUMPTO(handler);
Mark Shannonfee55262019-11-21 09:11:43 +00003613 if (_Py_TracingPossible(ceval)) {
3614 /* Make sure that we trace line after exception */
3615 instr_prev = INT_MAX;
3616 }
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02003617 /* Resume normal execution */
3618 goto main_loop;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003619 }
3620 } /* unwind stack */
Guido van Rossum374a9221991-04-04 10:40:29 +00003621
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02003622 /* End the loop as we still have an error */
3623 break;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003624 } /* main loop */
Guido van Rossumac7be682001-01-17 15:42:30 +00003625
Pablo Galindof00828a2019-05-09 16:52:02 +01003626 assert(retval == NULL);
Victor Stinner438a12d2019-05-24 17:01:38 +02003627 assert(_PyErr_Occurred(tstate));
Pablo Galindof00828a2019-05-09 16:52:02 +01003628
3629exit_returning:
3630
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003631 /* Pop remaining stack entries. */
3632 while (!EMPTY()) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003633 PyObject *o = POP();
3634 Py_XDECREF(o);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003635 }
Guido van Rossum35974fb2001-12-06 21:28:18 +00003636
Pablo Galindof00828a2019-05-09 16:52:02 +01003637exit_yielding:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003638 if (tstate->use_tracing) {
Benjamin Peterson51f46162013-01-23 08:38:47 -05003639 if (tstate->c_tracefunc) {
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02003640 if (call_trace_protected(tstate->c_tracefunc, tstate->c_traceobj,
3641 tstate, f, PyTrace_RETURN, retval)) {
3642 Py_CLEAR(retval);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003643 }
3644 }
3645 if (tstate->c_profilefunc) {
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02003646 if (call_trace_protected(tstate->c_profilefunc, tstate->c_profileobj,
3647 tstate, f, PyTrace_RETURN, retval)) {
Serhiy Storchaka505ff752014-02-09 13:33:53 +02003648 Py_CLEAR(retval);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003649 }
3650 }
3651 }
Guido van Rossuma4240131997-01-21 21:18:36 +00003652
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003653 /* pop frame */
Thomas Woutersce272b62007-09-19 21:19:28 +00003654exit_eval_frame:
Łukasz Langaa785c872016-09-09 17:37:37 -07003655 if (PyDTrace_FUNCTION_RETURN_ENABLED())
3656 dtrace_function_return(f);
Victor Stinnerbe434dc2019-11-05 00:51:22 +01003657 _Py_LeaveRecursiveCall(tstate);
Antoine Pitrou58720d62013-08-05 23:26:40 +02003658 f->f_executing = 0;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003659 tstate->frame = f->f_back;
Guido van Rossumac7be682001-01-17 15:42:30 +00003660
Victor Stinner17269092019-11-05 01:22:12 +01003661 return _Py_CheckFunctionResult(tstate, NULL, retval, "PyEval_EvalFrameEx");
Guido van Rossum374a9221991-04-04 10:40:29 +00003662}
3663
Benjamin Petersonb204a422011-06-05 22:04:07 -05003664static void
Victor Stinner438a12d2019-05-24 17:01:38 +02003665format_missing(PyThreadState *tstate, const char *kind,
3666 PyCodeObject *co, PyObject *names)
Benjamin Petersone109c702011-06-24 09:37:26 -05003667{
3668 int err;
3669 Py_ssize_t len = PyList_GET_SIZE(names);
3670 PyObject *name_str, *comma, *tail, *tmp;
3671
3672 assert(PyList_CheckExact(names));
3673 assert(len >= 1);
3674 /* Deal with the joys of natural language. */
3675 switch (len) {
3676 case 1:
3677 name_str = PyList_GET_ITEM(names, 0);
3678 Py_INCREF(name_str);
3679 break;
3680 case 2:
3681 name_str = PyUnicode_FromFormat("%U and %U",
3682 PyList_GET_ITEM(names, len - 2),
3683 PyList_GET_ITEM(names, len - 1));
3684 break;
3685 default:
3686 tail = PyUnicode_FromFormat(", %U, and %U",
3687 PyList_GET_ITEM(names, len - 2),
3688 PyList_GET_ITEM(names, len - 1));
Benjamin Petersond1ab6082012-06-01 11:18:22 -07003689 if (tail == NULL)
3690 return;
Benjamin Petersone109c702011-06-24 09:37:26 -05003691 /* Chop off the last two objects in the list. This shouldn't actually
3692 fail, but we can't be too careful. */
3693 err = PyList_SetSlice(names, len - 2, len, NULL);
3694 if (err == -1) {
3695 Py_DECREF(tail);
3696 return;
3697 }
3698 /* Stitch everything up into a nice comma-separated list. */
3699 comma = PyUnicode_FromString(", ");
3700 if (comma == NULL) {
3701 Py_DECREF(tail);
3702 return;
3703 }
3704 tmp = PyUnicode_Join(comma, names);
3705 Py_DECREF(comma);
3706 if (tmp == NULL) {
3707 Py_DECREF(tail);
3708 return;
3709 }
3710 name_str = PyUnicode_Concat(tmp, tail);
3711 Py_DECREF(tmp);
3712 Py_DECREF(tail);
3713 break;
3714 }
3715 if (name_str == NULL)
3716 return;
Victor Stinner438a12d2019-05-24 17:01:38 +02003717 _PyErr_Format(tstate, PyExc_TypeError,
3718 "%U() missing %i required %s argument%s: %U",
3719 co->co_name,
3720 len,
3721 kind,
3722 len == 1 ? "" : "s",
3723 name_str);
Benjamin Petersone109c702011-06-24 09:37:26 -05003724 Py_DECREF(name_str);
3725}
3726
3727static void
Victor Stinner438a12d2019-05-24 17:01:38 +02003728missing_arguments(PyThreadState *tstate, PyCodeObject *co,
3729 Py_ssize_t missing, Py_ssize_t defcount,
Benjamin Petersone109c702011-06-24 09:37:26 -05003730 PyObject **fastlocals)
3731{
Victor Stinner74319ae2016-08-25 00:04:09 +02003732 Py_ssize_t i, j = 0;
3733 Py_ssize_t start, end;
3734 int positional = (defcount != -1);
Benjamin Petersone109c702011-06-24 09:37:26 -05003735 const char *kind = positional ? "positional" : "keyword-only";
3736 PyObject *missing_names;
3737
3738 /* Compute the names of the arguments that are missing. */
3739 missing_names = PyList_New(missing);
3740 if (missing_names == NULL)
3741 return;
3742 if (positional) {
3743 start = 0;
Pablo Galindocd74e662019-06-01 18:08:04 +01003744 end = co->co_argcount - defcount;
Benjamin Petersone109c702011-06-24 09:37:26 -05003745 }
3746 else {
Pablo Galindocd74e662019-06-01 18:08:04 +01003747 start = co->co_argcount;
Benjamin Petersone109c702011-06-24 09:37:26 -05003748 end = start + co->co_kwonlyargcount;
3749 }
3750 for (i = start; i < end; i++) {
3751 if (GETLOCAL(i) == NULL) {
3752 PyObject *raw = PyTuple_GET_ITEM(co->co_varnames, i);
3753 PyObject *name = PyObject_Repr(raw);
3754 if (name == NULL) {
3755 Py_DECREF(missing_names);
3756 return;
3757 }
3758 PyList_SET_ITEM(missing_names, j++, name);
3759 }
3760 }
3761 assert(j == missing);
Victor Stinner438a12d2019-05-24 17:01:38 +02003762 format_missing(tstate, kind, co, missing_names);
Benjamin Petersone109c702011-06-24 09:37:26 -05003763 Py_DECREF(missing_names);
3764}
3765
3766static void
Victor Stinner438a12d2019-05-24 17:01:38 +02003767too_many_positional(PyThreadState *tstate, PyCodeObject *co,
3768 Py_ssize_t given, Py_ssize_t defcount,
Victor Stinner74319ae2016-08-25 00:04:09 +02003769 PyObject **fastlocals)
Benjamin Petersonb204a422011-06-05 22:04:07 -05003770{
3771 int plural;
Victor Stinner74319ae2016-08-25 00:04:09 +02003772 Py_ssize_t kwonly_given = 0;
3773 Py_ssize_t i;
Benjamin Petersonb204a422011-06-05 22:04:07 -05003774 PyObject *sig, *kwonly_sig;
Victor Stinner74319ae2016-08-25 00:04:09 +02003775 Py_ssize_t co_argcount = co->co_argcount;
Benjamin Petersonb204a422011-06-05 22:04:07 -05003776
Benjamin Petersone109c702011-06-24 09:37:26 -05003777 assert((co->co_flags & CO_VARARGS) == 0);
3778 /* Count missing keyword-only args. */
Pablo Galindocd74e662019-06-01 18:08:04 +01003779 for (i = co_argcount; i < co_argcount + co->co_kwonlyargcount; i++) {
Victor Stinner74319ae2016-08-25 00:04:09 +02003780 if (GETLOCAL(i) != NULL) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05003781 kwonly_given++;
Victor Stinner74319ae2016-08-25 00:04:09 +02003782 }
3783 }
Benjamin Petersone109c702011-06-24 09:37:26 -05003784 if (defcount) {
Pablo Galindocd74e662019-06-01 18:08:04 +01003785 Py_ssize_t atleast = co_argcount - defcount;
Benjamin Petersonb204a422011-06-05 22:04:07 -05003786 plural = 1;
Pablo Galindocd74e662019-06-01 18:08:04 +01003787 sig = PyUnicode_FromFormat("from %zd to %zd", atleast, co_argcount);
Benjamin Petersonb204a422011-06-05 22:04:07 -05003788 }
3789 else {
Pablo Galindocd74e662019-06-01 18:08:04 +01003790 plural = (co_argcount != 1);
3791 sig = PyUnicode_FromFormat("%zd", co_argcount);
Benjamin Petersonb204a422011-06-05 22:04:07 -05003792 }
3793 if (sig == NULL)
3794 return;
3795 if (kwonly_given) {
Victor Stinner74319ae2016-08-25 00:04:09 +02003796 const char *format = " positional argument%s (and %zd keyword-only argument%s)";
3797 kwonly_sig = PyUnicode_FromFormat(format,
3798 given != 1 ? "s" : "",
3799 kwonly_given,
3800 kwonly_given != 1 ? "s" : "");
Benjamin Petersonb204a422011-06-05 22:04:07 -05003801 if (kwonly_sig == NULL) {
3802 Py_DECREF(sig);
3803 return;
3804 }
3805 }
3806 else {
3807 /* This will not fail. */
3808 kwonly_sig = PyUnicode_FromString("");
Benjamin Petersone109c702011-06-24 09:37:26 -05003809 assert(kwonly_sig != NULL);
Benjamin Petersonb204a422011-06-05 22:04:07 -05003810 }
Victor Stinner438a12d2019-05-24 17:01:38 +02003811 _PyErr_Format(tstate, PyExc_TypeError,
3812 "%U() takes %U positional argument%s but %zd%U %s given",
3813 co->co_name,
3814 sig,
3815 plural ? "s" : "",
3816 given,
3817 kwonly_sig,
3818 given == 1 && !kwonly_given ? "was" : "were");
Benjamin Petersonb204a422011-06-05 22:04:07 -05003819 Py_DECREF(sig);
3820 Py_DECREF(kwonly_sig);
3821}
3822
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003823static int
Victor Stinner438a12d2019-05-24 17:01:38 +02003824positional_only_passed_as_keyword(PyThreadState *tstate, PyCodeObject *co,
3825 Py_ssize_t kwcount, PyObject* const* kwnames)
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003826{
3827 int posonly_conflicts = 0;
3828 PyObject* posonly_names = PyList_New(0);
3829
3830 for(int k=0; k < co->co_posonlyargcount; k++){
3831 PyObject* posonly_name = PyTuple_GET_ITEM(co->co_varnames, k);
3832
3833 for (int k2=0; k2<kwcount; k2++){
3834 /* Compare the pointers first and fallback to PyObject_RichCompareBool*/
3835 PyObject* kwname = kwnames[k2];
3836 if (kwname == posonly_name){
3837 if(PyList_Append(posonly_names, kwname) != 0) {
3838 goto fail;
3839 }
3840 posonly_conflicts++;
3841 continue;
3842 }
3843
3844 int cmp = PyObject_RichCompareBool(posonly_name, kwname, Py_EQ);
3845
3846 if ( cmp > 0) {
3847 if(PyList_Append(posonly_names, kwname) != 0) {
3848 goto fail;
3849 }
3850 posonly_conflicts++;
3851 } else if (cmp < 0) {
3852 goto fail;
3853 }
3854
3855 }
3856 }
3857 if (posonly_conflicts) {
3858 PyObject* comma = PyUnicode_FromString(", ");
3859 if (comma == NULL) {
3860 goto fail;
3861 }
3862 PyObject* error_names = PyUnicode_Join(comma, posonly_names);
3863 Py_DECREF(comma);
3864 if (error_names == NULL) {
3865 goto fail;
3866 }
Victor Stinner438a12d2019-05-24 17:01:38 +02003867 _PyErr_Format(tstate, PyExc_TypeError,
3868 "%U() got some positional-only arguments passed"
3869 " as keyword arguments: '%U'",
3870 co->co_name, error_names);
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003871 Py_DECREF(error_names);
3872 goto fail;
3873 }
3874
3875 Py_DECREF(posonly_names);
3876 return 0;
3877
3878fail:
3879 Py_XDECREF(posonly_names);
3880 return 1;
3881
3882}
3883
Guido van Rossumc2e20742006-02-27 22:32:47 +00003884/* This is gonna seem *real weird*, but if you put some other code between
Marcel Plch3a9ccee2018-04-06 23:22:04 +02003885 PyEval_EvalFrame() and _PyEval_EvalFrameDefault() you will need to adjust
Guido van Rossumc2e20742006-02-27 22:32:47 +00003886 the test in the if statements in Misc/gdbinit (pystack and pystackv). */
Skip Montanaro786ea6b2004-03-01 15:44:05 +00003887
Victor Stinnerc22bfaa2017-02-12 19:27:05 +01003888PyObject *
Victor Stinnerb5e170f2019-11-16 01:03:22 +01003889_PyEval_EvalCode(PyThreadState *tstate,
3890 PyObject *_co, PyObject *globals, PyObject *locals,
Serhiy Storchakaa5552f02017-12-15 13:11:11 +02003891 PyObject *const *args, Py_ssize_t argcount,
3892 PyObject *const *kwnames, PyObject *const *kwargs,
Serhiy Storchakab7281052016-09-12 00:52:40 +03003893 Py_ssize_t kwcount, int kwstep,
Serhiy Storchakaa5552f02017-12-15 13:11:11 +02003894 PyObject *const *defs, Py_ssize_t defcount,
Victor Stinner74319ae2016-08-25 00:04:09 +02003895 PyObject *kwdefs, PyObject *closure,
Victor Stinner40ee3012014-06-16 15:59:28 +02003896 PyObject *name, PyObject *qualname)
Tim Peters5ca576e2001-06-18 22:08:13 +00003897{
Victor Stinnerb5e170f2019-11-16 01:03:22 +01003898 assert(tstate != NULL);
3899
Martin v. Löwis4d0d4712010-12-03 20:14:31 +00003900 PyCodeObject* co = (PyCodeObject*)_co;
Antoine Pitrou9ed5f272013-08-13 20:18:52 +02003901 PyFrameObject *f;
3902 PyObject *retval = NULL;
3903 PyObject **fastlocals, **freevars;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003904 PyObject *x, *u;
Pablo Galindocd74e662019-06-01 18:08:04 +01003905 const Py_ssize_t total_args = co->co_argcount + co->co_kwonlyargcount;
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003906 Py_ssize_t i, j, n;
Victor Stinnerc7020012016-08-16 23:40:29 +02003907 PyObject *kwdict;
Tim Peters5ca576e2001-06-18 22:08:13 +00003908
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003909 if (globals == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02003910 _PyErr_SetString(tstate, PyExc_SystemError,
3911 "PyEval_EvalCodeEx: NULL globals");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003912 return NULL;
3913 }
Tim Peters5ca576e2001-06-18 22:08:13 +00003914
Victor Stinnerc7020012016-08-16 23:40:29 +02003915 /* Create the frame */
INADA Naoki5a625d02016-12-24 20:19:08 +09003916 f = _PyFrame_New_NoTrack(tstate, co, globals, locals);
Victor Stinnerc7020012016-08-16 23:40:29 +02003917 if (f == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003918 return NULL;
Victor Stinnerc7020012016-08-16 23:40:29 +02003919 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003920 fastlocals = f->f_localsplus;
3921 freevars = f->f_localsplus + co->co_nlocals;
Tim Peters5ca576e2001-06-18 22:08:13 +00003922
Victor Stinnerc7020012016-08-16 23:40:29 +02003923 /* Create a dictionary for keyword parameters (**kwags) */
Benjamin Petersonb204a422011-06-05 22:04:07 -05003924 if (co->co_flags & CO_VARKEYWORDS) {
3925 kwdict = PyDict_New();
3926 if (kwdict == NULL)
3927 goto fail;
3928 i = total_args;
Victor Stinnerc7020012016-08-16 23:40:29 +02003929 if (co->co_flags & CO_VARARGS) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05003930 i++;
Victor Stinnerc7020012016-08-16 23:40:29 +02003931 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05003932 SETLOCAL(i, kwdict);
3933 }
Victor Stinnerc7020012016-08-16 23:40:29 +02003934 else {
3935 kwdict = NULL;
3936 }
3937
Pablo Galindocd74e662019-06-01 18:08:04 +01003938 /* Copy all positional arguments into local variables */
3939 if (argcount > co->co_argcount) {
3940 n = co->co_argcount;
Victor Stinnerc7020012016-08-16 23:40:29 +02003941 }
3942 else {
3943 n = argcount;
3944 }
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003945 for (j = 0; j < n; j++) {
3946 x = args[j];
3947 Py_INCREF(x);
3948 SETLOCAL(j, x);
3949 }
3950
Victor Stinnerc7020012016-08-16 23:40:29 +02003951 /* Pack other positional arguments into the *args argument */
Benjamin Petersonb204a422011-06-05 22:04:07 -05003952 if (co->co_flags & CO_VARARGS) {
Sergey Fedoseev234531b2019-02-25 21:59:12 +05003953 u = _PyTuple_FromArray(args + n, argcount - n);
Victor Stinnerc7020012016-08-16 23:40:29 +02003954 if (u == NULL) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05003955 goto fail;
Victor Stinnerc7020012016-08-16 23:40:29 +02003956 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05003957 SETLOCAL(total_args, u);
Benjamin Petersonb204a422011-06-05 22:04:07 -05003958 }
Victor Stinnerc7020012016-08-16 23:40:29 +02003959
Serhiy Storchakab7281052016-09-12 00:52:40 +03003960 /* Handle keyword arguments passed as two strided arrays */
3961 kwcount *= kwstep;
3962 for (i = 0; i < kwcount; i += kwstep) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05003963 PyObject **co_varnames;
Serhiy Storchakab7281052016-09-12 00:52:40 +03003964 PyObject *keyword = kwnames[i];
3965 PyObject *value = kwargs[i];
Victor Stinner17061a92016-08-16 23:39:42 +02003966 Py_ssize_t j;
Victor Stinnerc7020012016-08-16 23:40:29 +02003967
Benjamin Petersonb204a422011-06-05 22:04:07 -05003968 if (keyword == NULL || !PyUnicode_Check(keyword)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02003969 _PyErr_Format(tstate, PyExc_TypeError,
3970 "%U() keywords must be strings",
3971 co->co_name);
Benjamin Petersonb204a422011-06-05 22:04:07 -05003972 goto fail;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003973 }
Victor Stinnerc7020012016-08-16 23:40:29 +02003974
Benjamin Petersonb204a422011-06-05 22:04:07 -05003975 /* Speed hack: do raw pointer compares. As names are
3976 normally interned this should almost always hit. */
3977 co_varnames = ((PyTupleObject *)(co->co_varnames))->ob_item;
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003978 for (j = co->co_posonlyargcount; j < total_args; j++) {
Victor Stinner6fea7f72016-08-22 23:17:30 +02003979 PyObject *name = co_varnames[j];
3980 if (name == keyword) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05003981 goto kw_found;
Victor Stinner6fea7f72016-08-22 23:17:30 +02003982 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05003983 }
Victor Stinnerc7020012016-08-16 23:40:29 +02003984
Benjamin Petersonb204a422011-06-05 22:04:07 -05003985 /* Slow fallback, just in case */
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003986 for (j = co->co_posonlyargcount; j < total_args; j++) {
Victor Stinner6fea7f72016-08-22 23:17:30 +02003987 PyObject *name = co_varnames[j];
3988 int cmp = PyObject_RichCompareBool( keyword, name, Py_EQ);
3989 if (cmp > 0) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05003990 goto kw_found;
Victor Stinner6fea7f72016-08-22 23:17:30 +02003991 }
3992 else if (cmp < 0) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003993 goto fail;
Victor Stinner6fea7f72016-08-22 23:17:30 +02003994 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05003995 }
Victor Stinnerc7020012016-08-16 23:40:29 +02003996
Victor Stinner231d1f32017-01-11 02:12:06 +01003997 assert(j >= total_args);
3998 if (kwdict == NULL) {
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003999
Victor Stinner438a12d2019-05-24 17:01:38 +02004000 if (co->co_posonlyargcount
4001 && positional_only_passed_as_keyword(tstate, co,
4002 kwcount, kwnames))
4003 {
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01004004 goto fail;
4005 }
4006
Victor Stinner438a12d2019-05-24 17:01:38 +02004007 _PyErr_Format(tstate, PyExc_TypeError,
4008 "%U() got an unexpected keyword argument '%S'",
4009 co->co_name, keyword);
Benjamin Petersonb204a422011-06-05 22:04:07 -05004010 goto fail;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004011 }
Victor Stinnerc7020012016-08-16 23:40:29 +02004012
Christian Heimes0bd447f2013-07-20 14:48:10 +02004013 if (PyDict_SetItem(kwdict, keyword, value) == -1) {
4014 goto fail;
4015 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05004016 continue;
Victor Stinnerc7020012016-08-16 23:40:29 +02004017
Benjamin Petersonb204a422011-06-05 22:04:07 -05004018 kw_found:
4019 if (GETLOCAL(j) != NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004020 _PyErr_Format(tstate, PyExc_TypeError,
4021 "%U() got multiple values for argument '%S'",
4022 co->co_name, keyword);
Benjamin Petersonb204a422011-06-05 22:04:07 -05004023 goto fail;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004024 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05004025 Py_INCREF(value);
4026 SETLOCAL(j, value);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004027 }
Victor Stinnerc7020012016-08-16 23:40:29 +02004028
4029 /* Check the number of positional arguments */
Pablo Galindocd74e662019-06-01 18:08:04 +01004030 if ((argcount > co->co_argcount) && !(co->co_flags & CO_VARARGS)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004031 too_many_positional(tstate, co, argcount, defcount, fastlocals);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004032 goto fail;
4033 }
Victor Stinnerc7020012016-08-16 23:40:29 +02004034
4035 /* Add missing positional arguments (copy default values from defs) */
Pablo Galindocd74e662019-06-01 18:08:04 +01004036 if (argcount < co->co_argcount) {
4037 Py_ssize_t m = co->co_argcount - defcount;
Victor Stinner17061a92016-08-16 23:39:42 +02004038 Py_ssize_t missing = 0;
4039 for (i = argcount; i < m; i++) {
4040 if (GETLOCAL(i) == NULL) {
Benjamin Petersone109c702011-06-24 09:37:26 -05004041 missing++;
Victor Stinner17061a92016-08-16 23:39:42 +02004042 }
4043 }
Benjamin Petersone109c702011-06-24 09:37:26 -05004044 if (missing) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004045 missing_arguments(tstate, co, missing, defcount, fastlocals);
Benjamin Petersone109c702011-06-24 09:37:26 -05004046 goto fail;
Benjamin Petersonb204a422011-06-05 22:04:07 -05004047 }
4048 if (n > m)
4049 i = n - m;
4050 else
4051 i = 0;
4052 for (; i < defcount; i++) {
4053 if (GETLOCAL(m+i) == NULL) {
4054 PyObject *def = defs[i];
4055 Py_INCREF(def);
4056 SETLOCAL(m+i, def);
4057 }
4058 }
4059 }
Victor Stinnerc7020012016-08-16 23:40:29 +02004060
4061 /* Add missing keyword arguments (copy default values from kwdefs) */
Benjamin Petersonb204a422011-06-05 22:04:07 -05004062 if (co->co_kwonlyargcount > 0) {
Victor Stinner17061a92016-08-16 23:39:42 +02004063 Py_ssize_t missing = 0;
Pablo Galindocd74e662019-06-01 18:08:04 +01004064 for (i = co->co_argcount; i < total_args; i++) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05004065 PyObject *name;
4066 if (GETLOCAL(i) != NULL)
4067 continue;
4068 name = PyTuple_GET_ITEM(co->co_varnames, i);
4069 if (kwdefs != NULL) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02004070 PyObject *def = PyDict_GetItemWithError(kwdefs, name);
Benjamin Petersonb204a422011-06-05 22:04:07 -05004071 if (def) {
4072 Py_INCREF(def);
4073 SETLOCAL(i, def);
4074 continue;
4075 }
Victor Stinner438a12d2019-05-24 17:01:38 +02004076 else if (_PyErr_Occurred(tstate)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02004077 goto fail;
4078 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05004079 }
Benjamin Petersone109c702011-06-24 09:37:26 -05004080 missing++;
4081 }
4082 if (missing) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004083 missing_arguments(tstate, co, missing, -1, fastlocals);
Benjamin Petersonb204a422011-06-05 22:04:07 -05004084 goto fail;
4085 }
4086 }
4087
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004088 /* Allocate and initialize storage for cell vars, and copy free
Benjamin Peterson90037602011-06-25 22:54:45 -05004089 vars into frame. */
4090 for (i = 0; i < PyTuple_GET_SIZE(co->co_cellvars); ++i) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004091 PyObject *c;
Serhiy Storchaka5bb8b912016-12-16 19:19:02 +02004092 Py_ssize_t arg;
Benjamin Peterson90037602011-06-25 22:54:45 -05004093 /* Possibly account for the cell variable being an argument. */
4094 if (co->co_cell2arg != NULL &&
Guido van Rossum6832c812013-05-10 08:47:42 -07004095 (arg = co->co_cell2arg[i]) != CO_CELL_NOT_AN_ARG) {
Benjamin Peterson90037602011-06-25 22:54:45 -05004096 c = PyCell_New(GETLOCAL(arg));
Benjamin Peterson159ae412013-05-12 18:16:06 -05004097 /* Clear the local copy. */
4098 SETLOCAL(arg, NULL);
Guido van Rossum6832c812013-05-10 08:47:42 -07004099 }
4100 else {
Benjamin Peterson90037602011-06-25 22:54:45 -05004101 c = PyCell_New(NULL);
Guido van Rossum6832c812013-05-10 08:47:42 -07004102 }
Benjamin Peterson159ae412013-05-12 18:16:06 -05004103 if (c == NULL)
4104 goto fail;
Benjamin Peterson90037602011-06-25 22:54:45 -05004105 SETLOCAL(co->co_nlocals + i, c);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004106 }
Victor Stinnerc7020012016-08-16 23:40:29 +02004107
4108 /* Copy closure variables to free variables */
Benjamin Peterson90037602011-06-25 22:54:45 -05004109 for (i = 0; i < PyTuple_GET_SIZE(co->co_freevars); ++i) {
4110 PyObject *o = PyTuple_GET_ITEM(closure, i);
4111 Py_INCREF(o);
4112 freevars[PyTuple_GET_SIZE(co->co_cellvars) + i] = o;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004113 }
Tim Peters5ca576e2001-06-18 22:08:13 +00004114
Yury Selivanoveb636452016-09-08 22:01:51 -07004115 /* Handle generator/coroutine/asynchronous generator */
4116 if (co->co_flags & (CO_GENERATOR | CO_COROUTINE | CO_ASYNC_GENERATOR)) {
Yury Selivanov75445082015-05-11 22:57:16 -04004117 PyObject *gen;
Yury Selivanov5376ba92015-06-22 12:19:30 -04004118 int is_coro = co->co_flags & CO_COROUTINE;
Yury Selivanov94c22632015-06-04 10:16:51 -04004119
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004120 /* Don't need to keep the reference to f_back, it will be set
4121 * when the generator is resumed. */
Serhiy Storchaka505ff752014-02-09 13:33:53 +02004122 Py_CLEAR(f->f_back);
Neil Schemenauer2b13ce82001-06-21 02:41:10 +00004123
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004124 /* Create a new generator that owns the ready to run frame
4125 * and return that as the value. */
Yury Selivanov5376ba92015-06-22 12:19:30 -04004126 if (is_coro) {
4127 gen = PyCoro_New(f, name, qualname);
Yury Selivanoveb636452016-09-08 22:01:51 -07004128 } else if (co->co_flags & CO_ASYNC_GENERATOR) {
4129 gen = PyAsyncGen_New(f, name, qualname);
Yury Selivanov5376ba92015-06-22 12:19:30 -04004130 } else {
4131 gen = PyGen_NewWithQualName(f, name, qualname);
4132 }
INADA Naoki6a3cedf2016-12-26 18:01:46 +09004133 if (gen == NULL) {
Yury Selivanov75445082015-05-11 22:57:16 -04004134 return NULL;
INADA Naoki6a3cedf2016-12-26 18:01:46 +09004135 }
INADA Naoki9c157762016-12-26 18:52:46 +09004136
INADA Naoki6a3cedf2016-12-26 18:01:46 +09004137 _PyObject_GC_TRACK(f);
Yury Selivanov75445082015-05-11 22:57:16 -04004138
Yury Selivanov75445082015-05-11 22:57:16 -04004139 return gen;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004140 }
Tim Peters5ca576e2001-06-18 22:08:13 +00004141
Victor Stinnerb9e68122019-11-14 12:20:46 +01004142 retval = _PyEval_EvalFrame(tstate, f, 0);
Tim Peters5ca576e2001-06-18 22:08:13 +00004143
Thomas Woutersce272b62007-09-19 21:19:28 +00004144fail: /* Jump here from prelude on failure */
Tim Peters5ca576e2001-06-18 22:08:13 +00004145
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004146 /* decref'ing the frame can cause __del__ methods to get invoked,
4147 which can call back into Python. While we're done with the
4148 current Python frame (f), the associated C stack is still in use,
4149 so recursion_depth must be boosted for the duration.
4150 */
INADA Naoki5a625d02016-12-24 20:19:08 +09004151 if (Py_REFCNT(f) > 1) {
4152 Py_DECREF(f);
4153 _PyObject_GC_TRACK(f);
4154 }
4155 else {
4156 ++tstate->recursion_depth;
4157 Py_DECREF(f);
4158 --tstate->recursion_depth;
4159 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004160 return retval;
Tim Peters5ca576e2001-06-18 22:08:13 +00004161}
4162
Victor Stinnerb5e170f2019-11-16 01:03:22 +01004163
4164PyObject *
4165_PyEval_EvalCodeWithName(PyObject *_co, PyObject *globals, PyObject *locals,
4166 PyObject *const *args, Py_ssize_t argcount,
4167 PyObject *const *kwnames, PyObject *const *kwargs,
4168 Py_ssize_t kwcount, int kwstep,
4169 PyObject *const *defs, Py_ssize_t defcount,
4170 PyObject *kwdefs, PyObject *closure,
4171 PyObject *name, PyObject *qualname)
4172{
4173 PyThreadState *tstate = _PyThreadState_GET();
4174 return _PyEval_EvalCode(tstate, _co, globals, locals,
4175 args, argcount,
4176 kwnames, kwargs,
4177 kwcount, kwstep,
4178 defs, defcount,
4179 kwdefs, closure,
4180 name, qualname);
4181}
4182
Victor Stinner40ee3012014-06-16 15:59:28 +02004183PyObject *
4184PyEval_EvalCodeEx(PyObject *_co, PyObject *globals, PyObject *locals,
Serhiy Storchakaa5552f02017-12-15 13:11:11 +02004185 PyObject *const *args, int argcount,
4186 PyObject *const *kws, int kwcount,
4187 PyObject *const *defs, int defcount,
4188 PyObject *kwdefs, PyObject *closure)
Victor Stinner40ee3012014-06-16 15:59:28 +02004189{
4190 return _PyEval_EvalCodeWithName(_co, globals, locals,
Victor Stinner9be7e7b2016-08-19 16:11:43 +02004191 args, argcount,
Zackery Spytzc6ea8972017-07-31 08:24:37 -06004192 kws, kws != NULL ? kws + 1 : NULL,
4193 kwcount, 2,
Victor Stinner9be7e7b2016-08-19 16:11:43 +02004194 defs, defcount,
4195 kwdefs, closure,
Victor Stinner40ee3012014-06-16 15:59:28 +02004196 NULL, NULL);
4197}
Tim Peters5ca576e2001-06-18 22:08:13 +00004198
Benjamin Peterson876b2f22009-06-28 03:18:59 +00004199static PyObject *
Victor Stinner438a12d2019-05-24 17:01:38 +02004200special_lookup(PyThreadState *tstate, PyObject *o, _Py_Identifier *id)
Benjamin Peterson876b2f22009-06-28 03:18:59 +00004201{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004202 PyObject *res;
Benjamin Petersonce798522012-01-22 11:24:29 -05004203 res = _PyObject_LookupSpecial(o, id);
Victor Stinner438a12d2019-05-24 17:01:38 +02004204 if (res == NULL && !_PyErr_Occurred(tstate)) {
4205 _PyErr_SetObject(tstate, PyExc_AttributeError, id->object);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004206 return NULL;
4207 }
4208 return res;
Benjamin Peterson876b2f22009-06-28 03:18:59 +00004209}
4210
4211
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00004212/* Logic for the raise statement (too complicated for inlining).
4213 This *consumes* a reference count to each of its arguments. */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04004214static int
Victor Stinner09532fe2019-05-10 23:39:09 +02004215do_raise(PyThreadState *tstate, PyObject *exc, PyObject *cause)
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00004216{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004217 PyObject *type = NULL, *value = NULL;
Collin Winter828f04a2007-08-31 00:04:24 +00004218
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004219 if (exc == NULL) {
4220 /* Reraise */
Mark Shannonae3087c2017-10-22 22:41:51 +01004221 _PyErr_StackItem *exc_info = _PyErr_GetTopmostException(tstate);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004222 PyObject *tb;
Mark Shannonae3087c2017-10-22 22:41:51 +01004223 type = exc_info->exc_type;
4224 value = exc_info->exc_value;
4225 tb = exc_info->exc_traceback;
Victor Stinnereec93312016-08-18 18:13:10 +02004226 if (type == Py_None || type == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004227 _PyErr_SetString(tstate, PyExc_RuntimeError,
4228 "No active exception to reraise");
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04004229 return 0;
4230 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004231 Py_XINCREF(type);
4232 Py_XINCREF(value);
4233 Py_XINCREF(tb);
Victor Stinner438a12d2019-05-24 17:01:38 +02004234 _PyErr_Restore(tstate, type, value, tb);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04004235 return 1;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004236 }
Guido van Rossumac7be682001-01-17 15:42:30 +00004237
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004238 /* We support the following forms of raise:
4239 raise
Collin Winter828f04a2007-08-31 00:04:24 +00004240 raise <instance>
4241 raise <type> */
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00004242
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004243 if (PyExceptionClass_Check(exc)) {
4244 type = exc;
Victor Stinnera5ed5f02016-12-06 18:45:50 +01004245 value = _PyObject_CallNoArg(exc);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004246 if (value == NULL)
4247 goto raise_error;
Benjamin Peterson5afa03a2011-07-15 14:09:26 -05004248 if (!PyExceptionInstance_Check(value)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004249 _PyErr_Format(tstate, PyExc_TypeError,
4250 "calling %R should have returned an instance of "
4251 "BaseException, not %R",
4252 type, Py_TYPE(value));
4253 goto raise_error;
Benjamin Peterson5afa03a2011-07-15 14:09:26 -05004254 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004255 }
4256 else if (PyExceptionInstance_Check(exc)) {
4257 value = exc;
4258 type = PyExceptionInstance_Class(exc);
4259 Py_INCREF(type);
4260 }
4261 else {
4262 /* Not something you can raise. You get an exception
4263 anyway, just not what you specified :-) */
4264 Py_DECREF(exc);
Victor Stinner438a12d2019-05-24 17:01:38 +02004265 _PyErr_SetString(tstate, PyExc_TypeError,
4266 "exceptions must derive from BaseException");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004267 goto raise_error;
4268 }
Collin Winter828f04a2007-08-31 00:04:24 +00004269
Serhiy Storchakac0191582016-09-27 11:37:10 +03004270 assert(type != NULL);
4271 assert(value != NULL);
4272
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004273 if (cause) {
4274 PyObject *fixed_cause;
4275 if (PyExceptionClass_Check(cause)) {
Victor Stinnera5ed5f02016-12-06 18:45:50 +01004276 fixed_cause = _PyObject_CallNoArg(cause);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004277 if (fixed_cause == NULL)
4278 goto raise_error;
Benjamin Petersond5a1c442012-05-14 22:09:31 -07004279 Py_DECREF(cause);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004280 }
Benjamin Petersond5a1c442012-05-14 22:09:31 -07004281 else if (PyExceptionInstance_Check(cause)) {
4282 fixed_cause = cause;
4283 }
4284 else if (cause == Py_None) {
4285 Py_DECREF(cause);
4286 fixed_cause = NULL;
4287 }
4288 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02004289 _PyErr_SetString(tstate, PyExc_TypeError,
4290 "exception causes must derive from "
4291 "BaseException");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004292 goto raise_error;
4293 }
Benjamin Petersond5a1c442012-05-14 22:09:31 -07004294 PyException_SetCause(value, fixed_cause);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004295 }
Collin Winter828f04a2007-08-31 00:04:24 +00004296
Victor Stinner438a12d2019-05-24 17:01:38 +02004297 _PyErr_SetObject(tstate, type, value);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004298 /* PyErr_SetObject incref's its arguments */
Serhiy Storchakac0191582016-09-27 11:37:10 +03004299 Py_DECREF(value);
4300 Py_DECREF(type);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04004301 return 0;
Collin Winter828f04a2007-08-31 00:04:24 +00004302
4303raise_error:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004304 Py_XDECREF(value);
4305 Py_XDECREF(type);
4306 Py_XDECREF(cause);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04004307 return 0;
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00004308}
4309
Tim Petersd6d010b2001-06-21 02:49:55 +00004310/* Iterate v argcnt times and store the results on the stack (via decreasing
Guido van Rossum0368b722007-05-11 16:50:42 +00004311 sp). Return 1 for success, 0 if error.
Antoine Pitrou9a2310d2008-07-25 22:39:39 +00004312
Guido van Rossum0368b722007-05-11 16:50:42 +00004313 If argcntafter == -1, do a simple unpack. If it is >= 0, do an unpack
4314 with a variable target.
4315*/
Tim Petersd6d010b2001-06-21 02:49:55 +00004316
Barry Warsawe42b18f1997-08-25 22:13:04 +00004317static int
Victor Stinner438a12d2019-05-24 17:01:38 +02004318unpack_iterable(PyThreadState *tstate, PyObject *v,
4319 int argcnt, int argcntafter, PyObject **sp)
Barry Warsawe42b18f1997-08-25 22:13:04 +00004320{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004321 int i = 0, j = 0;
4322 Py_ssize_t ll = 0;
4323 PyObject *it; /* iter(v) */
4324 PyObject *w;
4325 PyObject *l = NULL; /* variable list */
Guido van Rossumac7be682001-01-17 15:42:30 +00004326
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004327 assert(v != NULL);
Tim Petersd6d010b2001-06-21 02:49:55 +00004328
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004329 it = PyObject_GetIter(v);
Serhiy Storchaka13a6c092017-12-26 12:30:41 +02004330 if (it == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004331 if (_PyErr_ExceptionMatches(tstate, PyExc_TypeError) &&
Serhiy Storchaka13a6c092017-12-26 12:30:41 +02004332 v->ob_type->tp_iter == NULL && !PySequence_Check(v))
4333 {
Victor Stinner438a12d2019-05-24 17:01:38 +02004334 _PyErr_Format(tstate, PyExc_TypeError,
4335 "cannot unpack non-iterable %.200s object",
4336 v->ob_type->tp_name);
Serhiy Storchaka13a6c092017-12-26 12:30:41 +02004337 }
4338 return 0;
4339 }
Tim Petersd6d010b2001-06-21 02:49:55 +00004340
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004341 for (; i < argcnt; i++) {
4342 w = PyIter_Next(it);
4343 if (w == NULL) {
4344 /* Iterator done, via error or exhaustion. */
Victor Stinner438a12d2019-05-24 17:01:38 +02004345 if (!_PyErr_Occurred(tstate)) {
R David Murray4171bbe2015-04-15 17:08:45 -04004346 if (argcntafter == -1) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004347 _PyErr_Format(tstate, PyExc_ValueError,
4348 "not enough values to unpack "
4349 "(expected %d, got %d)",
4350 argcnt, i);
R David Murray4171bbe2015-04-15 17:08:45 -04004351 }
4352 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02004353 _PyErr_Format(tstate, PyExc_ValueError,
4354 "not enough values to unpack "
4355 "(expected at least %d, got %d)",
4356 argcnt + argcntafter, i);
R David Murray4171bbe2015-04-15 17:08:45 -04004357 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004358 }
4359 goto Error;
4360 }
4361 *--sp = w;
4362 }
Tim Petersd6d010b2001-06-21 02:49:55 +00004363
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004364 if (argcntafter == -1) {
4365 /* We better have exhausted the iterator now. */
4366 w = PyIter_Next(it);
4367 if (w == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004368 if (_PyErr_Occurred(tstate))
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004369 goto Error;
4370 Py_DECREF(it);
4371 return 1;
4372 }
4373 Py_DECREF(w);
Victor Stinner438a12d2019-05-24 17:01:38 +02004374 _PyErr_Format(tstate, PyExc_ValueError,
4375 "too many values to unpack (expected %d)",
4376 argcnt);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004377 goto Error;
4378 }
Guido van Rossum0368b722007-05-11 16:50:42 +00004379
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004380 l = PySequence_List(it);
4381 if (l == NULL)
4382 goto Error;
4383 *--sp = l;
4384 i++;
Guido van Rossum0368b722007-05-11 16:50:42 +00004385
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004386 ll = PyList_GET_SIZE(l);
4387 if (ll < argcntafter) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004388 _PyErr_Format(tstate, PyExc_ValueError,
R David Murray4171bbe2015-04-15 17:08:45 -04004389 "not enough values to unpack (expected at least %d, got %zd)",
4390 argcnt + argcntafter, argcnt + ll);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004391 goto Error;
4392 }
Guido van Rossum0368b722007-05-11 16:50:42 +00004393
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004394 /* Pop the "after-variable" args off the list. */
4395 for (j = argcntafter; j > 0; j--, i++) {
4396 *--sp = PyList_GET_ITEM(l, ll - j);
4397 }
4398 /* Resize the list. */
4399 Py_SIZE(l) = ll - argcntafter;
4400 Py_DECREF(it);
4401 return 1;
Guido van Rossum0368b722007-05-11 16:50:42 +00004402
Tim Petersd6d010b2001-06-21 02:49:55 +00004403Error:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004404 for (; i > 0; i--, sp++)
4405 Py_DECREF(*sp);
4406 Py_XDECREF(it);
4407 return 0;
Barry Warsawe42b18f1997-08-25 22:13:04 +00004408}
4409
4410
Guido van Rossum96a42c81992-01-12 02:29:51 +00004411#ifdef LLTRACE
Guido van Rossum3f5da241990-12-20 15:06:42 +00004412static int
Victor Stinner438a12d2019-05-24 17:01:38 +02004413prtrace(PyThreadState *tstate, PyObject *v, const char *str)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00004414{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004415 printf("%s ", str);
Victor Stinner438a12d2019-05-24 17:01:38 +02004416 if (PyObject_Print(v, stdout, 0) != 0) {
4417 /* Don't know what else to do */
4418 _PyErr_Clear(tstate);
4419 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004420 printf("\n");
4421 return 1;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00004422}
Guido van Rossum3f5da241990-12-20 15:06:42 +00004423#endif
Guido van Rossum10dc2e81990-11-18 17:27:39 +00004424
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00004425static void
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004426call_exc_trace(Py_tracefunc func, PyObject *self,
4427 PyThreadState *tstate, PyFrameObject *f)
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00004428{
Victor Stinneraaa8ed82013-07-10 13:57:55 +02004429 PyObject *type, *value, *traceback, *orig_traceback, *arg;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004430 int err;
Victor Stinner438a12d2019-05-24 17:01:38 +02004431 _PyErr_Fetch(tstate, &type, &value, &orig_traceback);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004432 if (value == NULL) {
4433 value = Py_None;
4434 Py_INCREF(value);
4435 }
Victor Stinner438a12d2019-05-24 17:01:38 +02004436 _PyErr_NormalizeException(tstate, &type, &value, &orig_traceback);
Antoine Pitrou89335212013-11-23 14:05:23 +01004437 traceback = (orig_traceback != NULL) ? orig_traceback : Py_None;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004438 arg = PyTuple_Pack(3, type, value, traceback);
4439 if (arg == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004440 _PyErr_Restore(tstate, type, value, orig_traceback);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004441 return;
4442 }
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004443 err = call_trace(func, self, tstate, f, PyTrace_EXCEPTION, arg);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004444 Py_DECREF(arg);
Victor Stinner438a12d2019-05-24 17:01:38 +02004445 if (err == 0) {
4446 _PyErr_Restore(tstate, type, value, orig_traceback);
4447 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004448 else {
4449 Py_XDECREF(type);
4450 Py_XDECREF(value);
Victor Stinneraaa8ed82013-07-10 13:57:55 +02004451 Py_XDECREF(orig_traceback);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004452 }
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00004453}
4454
Amaury Forgeot d'Arcf05149a2007-11-13 01:05:30 +00004455static int
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004456call_trace_protected(Py_tracefunc func, PyObject *obj,
4457 PyThreadState *tstate, PyFrameObject *frame,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004458 int what, PyObject *arg)
Fred Drake4ec5d562001-10-04 19:26:43 +00004459{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004460 PyObject *type, *value, *traceback;
4461 int err;
Victor Stinner438a12d2019-05-24 17:01:38 +02004462 _PyErr_Fetch(tstate, &type, &value, &traceback);
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004463 err = call_trace(func, obj, tstate, frame, what, arg);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004464 if (err == 0)
4465 {
Victor Stinner438a12d2019-05-24 17:01:38 +02004466 _PyErr_Restore(tstate, type, value, traceback);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004467 return 0;
4468 }
4469 else {
4470 Py_XDECREF(type);
4471 Py_XDECREF(value);
4472 Py_XDECREF(traceback);
4473 return -1;
4474 }
Fred Drake4ec5d562001-10-04 19:26:43 +00004475}
4476
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00004477static int
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004478call_trace(Py_tracefunc func, PyObject *obj,
4479 PyThreadState *tstate, PyFrameObject *frame,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004480 int what, PyObject *arg)
Guido van Rossum96a42c81992-01-12 02:29:51 +00004481{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004482 int result;
4483 if (tstate->tracing)
4484 return 0;
4485 tstate->tracing++;
4486 tstate->use_tracing = 0;
4487 result = func(obj, frame, what, arg);
4488 tstate->use_tracing = ((tstate->c_tracefunc != NULL)
4489 || (tstate->c_profilefunc != NULL));
4490 tstate->tracing--;
4491 return result;
Guido van Rossum96a42c81992-01-12 02:29:51 +00004492}
4493
Guido van Rossuma12fe4e2003-04-09 19:06:21 +00004494PyObject *
4495_PyEval_CallTracing(PyObject *func, PyObject *args)
4496{
Victor Stinner50b48572018-11-01 01:51:40 +01004497 PyThreadState *tstate = _PyThreadState_GET();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004498 int save_tracing = tstate->tracing;
4499 int save_use_tracing = tstate->use_tracing;
4500 PyObject *result;
Guido van Rossuma12fe4e2003-04-09 19:06:21 +00004501
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004502 tstate->tracing = 0;
4503 tstate->use_tracing = ((tstate->c_tracefunc != NULL)
4504 || (tstate->c_profilefunc != NULL));
4505 result = PyObject_Call(func, args, NULL);
4506 tstate->tracing = save_tracing;
4507 tstate->use_tracing = save_use_tracing;
4508 return result;
Guido van Rossuma12fe4e2003-04-09 19:06:21 +00004509}
4510
Alexandre Vassalotti7b82b402009-07-21 04:30:03 +00004511/* See Objects/lnotab_notes.txt for a description of how tracing works. */
Michael W. Hudson006c7522002-11-08 13:08:46 +00004512static int
Tim Peters8a5c3c72004-04-05 19:36:21 +00004513maybe_call_line_trace(Py_tracefunc func, PyObject *obj,
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004514 PyThreadState *tstate, PyFrameObject *frame,
4515 int *instr_lb, int *instr_ub, int *instr_prev)
Michael W. Hudsondd32a912002-08-15 14:59:02 +00004516{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004517 int result = 0;
4518 int line = frame->f_lineno;
Michael W. Hudson006c7522002-11-08 13:08:46 +00004519
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004520 /* If the last instruction executed isn't in the current
4521 instruction window, reset the window.
4522 */
4523 if (frame->f_lasti < *instr_lb || frame->f_lasti >= *instr_ub) {
4524 PyAddrPair bounds;
4525 line = _PyCode_CheckLineNumber(frame->f_code, frame->f_lasti,
4526 &bounds);
4527 *instr_lb = bounds.ap_lower;
4528 *instr_ub = bounds.ap_upper;
4529 }
Nick Coghlan5a851672017-09-08 10:14:16 +10004530 /* If the last instruction falls at the start of a line or if it
4531 represents a jump backwards, update the frame's line number and
4532 then call the trace function if we're tracing source lines.
4533 */
4534 if ((frame->f_lasti == *instr_lb || frame->f_lasti < *instr_prev)) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004535 frame->f_lineno = line;
Nick Coghlan5a851672017-09-08 10:14:16 +10004536 if (frame->f_trace_lines) {
4537 result = call_trace(func, obj, tstate, frame, PyTrace_LINE, Py_None);
4538 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004539 }
George King20faa682017-10-18 17:44:22 -07004540 /* Always emit an opcode event if we're tracing all opcodes. */
4541 if (frame->f_trace_opcodes) {
4542 result = call_trace(func, obj, tstate, frame, PyTrace_OPCODE, Py_None);
4543 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004544 *instr_prev = frame->f_lasti;
4545 return result;
Michael W. Hudsondd32a912002-08-15 14:59:02 +00004546}
4547
Fred Drake5755ce62001-06-27 19:19:46 +00004548void
4549PyEval_SetProfile(Py_tracefunc func, PyObject *arg)
Fred Draked0838392001-06-16 21:02:31 +00004550{
Steve Dowerb82e17e2019-05-23 08:45:22 -07004551 if (PySys_Audit("sys.setprofile", NULL) < 0) {
4552 return;
4553 }
4554
Victor Stinner50b48572018-11-01 01:51:40 +01004555 PyThreadState *tstate = _PyThreadState_GET();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004556 PyObject *temp = tstate->c_profileobj;
4557 Py_XINCREF(arg);
4558 tstate->c_profilefunc = NULL;
4559 tstate->c_profileobj = NULL;
4560 /* Must make sure that tracing is not ignored if 'temp' is freed */
4561 tstate->use_tracing = tstate->c_tracefunc != NULL;
4562 Py_XDECREF(temp);
4563 tstate->c_profilefunc = func;
4564 tstate->c_profileobj = arg;
4565 /* Flag that tracing or profiling is turned on */
4566 tstate->use_tracing = (func != NULL) || (tstate->c_tracefunc != NULL);
Fred Drake5755ce62001-06-27 19:19:46 +00004567}
4568
4569void
4570PyEval_SetTrace(Py_tracefunc func, PyObject *arg)
4571{
Steve Dowerb82e17e2019-05-23 08:45:22 -07004572 if (PySys_Audit("sys.settrace", NULL) < 0) {
4573 return;
4574 }
4575
Victor Stinner09532fe2019-05-10 23:39:09 +02004576 _PyRuntimeState *runtime = &_PyRuntime;
4577 PyThreadState *tstate = _PyRuntimeState_GetThreadState(runtime);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004578 PyObject *temp = tstate->c_traceobj;
Victor Stinner09532fe2019-05-10 23:39:09 +02004579 runtime->ceval.tracing_possible += (func != NULL) - (tstate->c_tracefunc != NULL);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004580 Py_XINCREF(arg);
4581 tstate->c_tracefunc = NULL;
4582 tstate->c_traceobj = NULL;
4583 /* Must make sure that profiling is not ignored if 'temp' is freed */
4584 tstate->use_tracing = tstate->c_profilefunc != NULL;
4585 Py_XDECREF(temp);
4586 tstate->c_tracefunc = func;
4587 tstate->c_traceobj = arg;
4588 /* Flag that tracing or profiling is turned on */
4589 tstate->use_tracing = ((func != NULL)
4590 || (tstate->c_profilefunc != NULL));
Fred Draked0838392001-06-16 21:02:31 +00004591}
4592
Yury Selivanov75445082015-05-11 22:57:16 -04004593void
Victor Stinner838f2642019-06-13 22:41:23 +02004594_PyEval_SetCoroutineOriginTrackingDepth(PyThreadState *tstate, int new_depth)
Nathaniel J. Smithfc2f4072018-01-21 06:44:07 -08004595{
4596 assert(new_depth >= 0);
Nathaniel J. Smithfc2f4072018-01-21 06:44:07 -08004597 tstate->coroutine_origin_tracking_depth = new_depth;
4598}
4599
4600int
4601_PyEval_GetCoroutineOriginTrackingDepth(void)
4602{
Victor Stinner50b48572018-11-01 01:51:40 +01004603 PyThreadState *tstate = _PyThreadState_GET();
Nathaniel J. Smithfc2f4072018-01-21 06:44:07 -08004604 return tstate->coroutine_origin_tracking_depth;
4605}
4606
4607void
Yury Selivanoveb636452016-09-08 22:01:51 -07004608_PyEval_SetAsyncGenFirstiter(PyObject *firstiter)
4609{
Victor Stinner50b48572018-11-01 01:51:40 +01004610 PyThreadState *tstate = _PyThreadState_GET();
Steve Dowerb82e17e2019-05-23 08:45:22 -07004611
4612 if (PySys_Audit("sys.set_asyncgen_hook_firstiter", NULL) < 0) {
4613 return;
4614 }
4615
Yury Selivanoveb636452016-09-08 22:01:51 -07004616 Py_XINCREF(firstiter);
4617 Py_XSETREF(tstate->async_gen_firstiter, firstiter);
4618}
4619
4620PyObject *
4621_PyEval_GetAsyncGenFirstiter(void)
4622{
Victor Stinner50b48572018-11-01 01:51:40 +01004623 PyThreadState *tstate = _PyThreadState_GET();
Yury Selivanoveb636452016-09-08 22:01:51 -07004624 return tstate->async_gen_firstiter;
4625}
4626
4627void
4628_PyEval_SetAsyncGenFinalizer(PyObject *finalizer)
4629{
Victor Stinner50b48572018-11-01 01:51:40 +01004630 PyThreadState *tstate = _PyThreadState_GET();
Steve Dowerb82e17e2019-05-23 08:45:22 -07004631
4632 if (PySys_Audit("sys.set_asyncgen_hook_finalizer", NULL) < 0) {
4633 return;
4634 }
4635
Yury Selivanoveb636452016-09-08 22:01:51 -07004636 Py_XINCREF(finalizer);
4637 Py_XSETREF(tstate->async_gen_finalizer, finalizer);
4638}
4639
4640PyObject *
4641_PyEval_GetAsyncGenFinalizer(void)
4642{
Victor Stinner50b48572018-11-01 01:51:40 +01004643 PyThreadState *tstate = _PyThreadState_GET();
Yury Selivanoveb636452016-09-08 22:01:51 -07004644 return tstate->async_gen_finalizer;
4645}
4646
Victor Stinner438a12d2019-05-24 17:01:38 +02004647static PyFrameObject *
4648_PyEval_GetFrame(PyThreadState *tstate)
4649{
Victor Stinner01b1cc12019-11-20 02:27:56 +01004650 _PyRuntimeState *runtime = tstate->interp->runtime;
4651 return runtime->gilstate.getframe(tstate);
Victor Stinner438a12d2019-05-24 17:01:38 +02004652}
4653
4654PyFrameObject *
4655PyEval_GetFrame(void)
4656{
4657 PyThreadState *tstate = _PyThreadState_GET();
4658 return _PyEval_GetFrame(tstate);
4659}
4660
Guido van Rossumb209a111997-04-29 18:18:01 +00004661PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00004662PyEval_GetBuiltins(void)
Guido van Rossum6135a871995-01-09 17:53:26 +00004663{
Victor Stinner438a12d2019-05-24 17:01:38 +02004664 PyThreadState *tstate = _PyThreadState_GET();
4665 PyFrameObject *current_frame = _PyEval_GetFrame(tstate);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004666 if (current_frame == NULL)
Victor Stinner438a12d2019-05-24 17:01:38 +02004667 return tstate->interp->builtins;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004668 else
4669 return current_frame->f_builtins;
Guido van Rossum6135a871995-01-09 17:53:26 +00004670}
4671
Serhiy Storchakabb86bf42018-12-11 08:28:18 +02004672/* Convenience function to get a builtin from its name */
4673PyObject *
4674_PyEval_GetBuiltinId(_Py_Identifier *name)
4675{
Victor Stinner438a12d2019-05-24 17:01:38 +02004676 PyThreadState *tstate = _PyThreadState_GET();
Serhiy Storchakabb86bf42018-12-11 08:28:18 +02004677 PyObject *attr = _PyDict_GetItemIdWithError(PyEval_GetBuiltins(), name);
4678 if (attr) {
4679 Py_INCREF(attr);
4680 }
Victor Stinner438a12d2019-05-24 17:01:38 +02004681 else if (!_PyErr_Occurred(tstate)) {
4682 _PyErr_SetObject(tstate, PyExc_AttributeError, _PyUnicode_FromId(name));
Serhiy Storchakabb86bf42018-12-11 08:28:18 +02004683 }
4684 return attr;
4685}
4686
Guido van Rossumb209a111997-04-29 18:18:01 +00004687PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00004688PyEval_GetLocals(void)
Guido van Rossum5b722181993-03-30 17:46:03 +00004689{
Victor Stinner438a12d2019-05-24 17:01:38 +02004690 PyThreadState *tstate = _PyThreadState_GET();
4691 PyFrameObject *current_frame = _PyEval_GetFrame(tstate);
Victor Stinner41bb43a2013-10-29 01:19:37 +01004692 if (current_frame == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004693 _PyErr_SetString(tstate, PyExc_SystemError, "frame does not exist");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004694 return NULL;
Victor Stinner41bb43a2013-10-29 01:19:37 +01004695 }
4696
Victor Stinner438a12d2019-05-24 17:01:38 +02004697 if (PyFrame_FastToLocalsWithError(current_frame) < 0) {
Victor Stinner41bb43a2013-10-29 01:19:37 +01004698 return NULL;
Victor Stinner438a12d2019-05-24 17:01:38 +02004699 }
Victor Stinner41bb43a2013-10-29 01:19:37 +01004700
4701 assert(current_frame->f_locals != NULL);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004702 return current_frame->f_locals;
Guido van Rossum5b722181993-03-30 17:46:03 +00004703}
4704
Guido van Rossumb209a111997-04-29 18:18:01 +00004705PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00004706PyEval_GetGlobals(void)
Guido van Rossum3f5da241990-12-20 15:06:42 +00004707{
Victor Stinner438a12d2019-05-24 17:01:38 +02004708 PyThreadState *tstate = _PyThreadState_GET();
4709 PyFrameObject *current_frame = _PyEval_GetFrame(tstate);
4710 if (current_frame == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004711 return NULL;
Victor Stinner438a12d2019-05-24 17:01:38 +02004712 }
Victor Stinner41bb43a2013-10-29 01:19:37 +01004713
4714 assert(current_frame->f_globals != NULL);
4715 return current_frame->f_globals;
Guido van Rossum3f5da241990-12-20 15:06:42 +00004716}
4717
Guido van Rossum6135a871995-01-09 17:53:26 +00004718int
Tim Peters5ba58662001-07-16 02:29:45 +00004719PyEval_MergeCompilerFlags(PyCompilerFlags *cf)
Jeremy Hylton061d1062001-03-22 02:32:48 +00004720{
Victor Stinner438a12d2019-05-24 17:01:38 +02004721 PyThreadState *tstate = _PyThreadState_GET();
4722 PyFrameObject *current_frame = _PyEval_GetFrame(tstate);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004723 int result = cf->cf_flags != 0;
Tim Peters5ba58662001-07-16 02:29:45 +00004724
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004725 if (current_frame != NULL) {
4726 const int codeflags = current_frame->f_code->co_flags;
4727 const int compilerflags = codeflags & PyCF_MASK;
4728 if (compilerflags) {
4729 result = 1;
4730 cf->cf_flags |= compilerflags;
4731 }
Neil Schemenauerc24ea082002-03-22 23:53:36 +00004732#if 0 /* future keyword */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004733 if (codeflags & CO_GENERATOR_ALLOWED) {
4734 result = 1;
4735 cf->cf_flags |= CO_GENERATOR_ALLOWED;
4736 }
Neil Schemenauerc24ea082002-03-22 23:53:36 +00004737#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004738 }
4739 return result;
Jeremy Hylton061d1062001-03-22 02:32:48 +00004740}
4741
Guido van Rossum3f5da241990-12-20 15:06:42 +00004742
Jeremy Hyltonaf68c872005-12-10 18:50:16 +00004743const char *
Tim Peters6d6c1a32001-08-02 04:15:00 +00004744PyEval_GetFuncName(PyObject *func)
Jeremy Hylton512a2372001-04-11 13:52:29 +00004745{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004746 if (PyMethod_Check(func))
4747 return PyEval_GetFuncName(PyMethod_GET_FUNCTION(func));
4748 else if (PyFunction_Check(func))
Serhiy Storchaka06515832016-11-20 09:13:07 +02004749 return PyUnicode_AsUTF8(((PyFunctionObject*)func)->func_name);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004750 else if (PyCFunction_Check(func))
4751 return ((PyCFunctionObject*)func)->m_ml->ml_name;
4752 else
4753 return func->ob_type->tp_name;
Jeremy Hylton512a2372001-04-11 13:52:29 +00004754}
4755
Jeremy Hyltonaf68c872005-12-10 18:50:16 +00004756const char *
Tim Peters6d6c1a32001-08-02 04:15:00 +00004757PyEval_GetFuncDesc(PyObject *func)
Jeremy Hylton512a2372001-04-11 13:52:29 +00004758{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004759 if (PyMethod_Check(func))
4760 return "()";
4761 else if (PyFunction_Check(func))
4762 return "()";
4763 else if (PyCFunction_Check(func))
4764 return "()";
4765 else
4766 return " object";
Jeremy Hylton512a2372001-04-11 13:52:29 +00004767}
4768
Armin Rigo1c2d7e52005-09-20 18:34:01 +00004769#define C_TRACE(x, call) \
Nicholas Bastind858a772004-06-25 23:31:06 +00004770if (tstate->use_tracing && tstate->c_profilefunc) { \
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004771 if (call_trace(tstate->c_profilefunc, tstate->c_profileobj, \
4772 tstate, tstate->frame, \
4773 PyTrace_C_CALL, func)) { \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004774 x = NULL; \
4775 } \
4776 else { \
4777 x = call; \
4778 if (tstate->c_profilefunc != NULL) { \
4779 if (x == NULL) { \
4780 call_trace_protected(tstate->c_profilefunc, \
4781 tstate->c_profileobj, \
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004782 tstate, tstate->frame, \
4783 PyTrace_C_EXCEPTION, func); \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004784 /* XXX should pass (type, value, tb) */ \
4785 } else { \
4786 if (call_trace(tstate->c_profilefunc, \
4787 tstate->c_profileobj, \
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004788 tstate, tstate->frame, \
4789 PyTrace_C_RETURN, func)) { \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004790 Py_DECREF(x); \
4791 x = NULL; \
4792 } \
4793 } \
4794 } \
4795 } \
Nicholas Bastind858a772004-06-25 23:31:06 +00004796} else { \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004797 x = call; \
4798 }
Nicholas Bastinc69ebe82004-03-24 21:57:10 +00004799
Jeroen Demeyeraacc77f2019-05-29 20:31:52 +02004800
4801static PyObject *
4802trace_call_function(PyThreadState *tstate,
4803 PyObject *func,
4804 PyObject **args, Py_ssize_t nargs,
4805 PyObject *kwnames)
4806{
4807 PyObject *x;
4808 if (PyCFunction_Check(func)) {
Jeroen Demeyer0d722f32019-07-05 14:48:24 +02004809 C_TRACE(x, _PyObject_Vectorcall(func, args, nargs, kwnames));
Jeroen Demeyeraacc77f2019-05-29 20:31:52 +02004810 return x;
4811 }
4812 else if (Py_TYPE(func) == &PyMethodDescr_Type && nargs > 0) {
4813 /* We need to create a temporary bound method as argument
4814 for profiling.
4815
4816 If nargs == 0, then this cannot work because we have no
4817 "self". In any case, the call itself would raise
4818 TypeError (foo needs an argument), so we just skip
4819 profiling. */
4820 PyObject *self = args[0];
4821 func = Py_TYPE(func)->tp_descr_get(func, self, (PyObject*)Py_TYPE(self));
4822 if (func == NULL) {
4823 return NULL;
4824 }
Jeroen Demeyer0d722f32019-07-05 14:48:24 +02004825 C_TRACE(x, _PyObject_Vectorcall(func,
4826 args+1, nargs-1,
4827 kwnames));
Jeroen Demeyeraacc77f2019-05-29 20:31:52 +02004828 Py_DECREF(func);
4829 return x;
4830 }
4831 return _PyObject_Vectorcall(func, args, nargs | PY_VECTORCALL_ARGUMENTS_OFFSET, kwnames);
4832}
4833
Victor Stinner415c5102017-01-11 00:54:57 +01004834/* Issue #29227: Inline call_function() into _PyEval_EvalFrameDefault()
4835 to reduce the stack consumption. */
4836Py_LOCAL_INLINE(PyObject *) _Py_HOT_FUNCTION
Victor Stinner09532fe2019-05-10 23:39:09 +02004837call_function(PyThreadState *tstate, PyObject ***pp_stack, Py_ssize_t oparg, PyObject *kwnames)
Jeremy Hyltone8c04322002-08-16 17:47:26 +00004838{
Victor Stinnerf9b760f2016-09-09 10:17:08 -07004839 PyObject **pfunc = (*pp_stack) - oparg - 1;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004840 PyObject *func = *pfunc;
4841 PyObject *x, *w;
Victor Stinnerd8735722016-09-09 12:36:44 -07004842 Py_ssize_t nkwargs = (kwnames == NULL) ? 0 : PyTuple_GET_SIZE(kwnames);
4843 Py_ssize_t nargs = oparg - nkwargs;
INADA Naoki5566bbb2017-02-03 07:43:03 +09004844 PyObject **stack = (*pp_stack) - nargs - nkwargs;
Jeremy Hyltone8c04322002-08-16 17:47:26 +00004845
Jeroen Demeyeraacc77f2019-05-29 20:31:52 +02004846 if (tstate->use_tracing) {
4847 x = trace_call_function(tstate, func, stack, nargs, kwnames);
INADA Naoki5566bbb2017-02-03 07:43:03 +09004848 }
Victor Stinner4a7cc882015-03-06 23:35:27 +01004849 else {
Jeroen Demeyeraacc77f2019-05-29 20:31:52 +02004850 x = _PyObject_Vectorcall(func, stack, nargs | PY_VECTORCALL_ARGUMENTS_OFFSET, kwnames);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004851 }
Tim Peters8a5c3c72004-04-05 19:36:21 +00004852
Victor Stinner438a12d2019-05-24 17:01:38 +02004853 assert((x != NULL) ^ (_PyErr_Occurred(tstate) != NULL));
Victor Stinnerf9b760f2016-09-09 10:17:08 -07004854
Victor Stinnerc22bfaa2017-02-12 19:27:05 +01004855 /* Clear the stack of the function object. */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004856 while ((*pp_stack) > pfunc) {
4857 w = EXT_POP(*pp_stack);
4858 Py_DECREF(w);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004859 }
Victor Stinnerace47d72013-07-18 01:41:08 +02004860
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004861 return x;
Jeremy Hyltone8c04322002-08-16 17:47:26 +00004862}
4863
Jeremy Hylton52820442001-01-03 23:52:36 +00004864static PyObject *
Victor Stinner09532fe2019-05-10 23:39:09 +02004865do_call_core(PyThreadState *tstate, PyObject *func, PyObject *callargs, PyObject *kwdict)
Jeremy Hylton52820442001-01-03 23:52:36 +00004866{
jdemeyere89de732018-09-19 12:06:20 +02004867 PyObject *result;
4868
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004869 if (PyCFunction_Check(func)) {
Jeroen Demeyer7a6873c2019-09-11 13:01:01 +02004870 C_TRACE(result, PyObject_Call(func, callargs, kwdict));
Victor Stinnerf9b760f2016-09-09 10:17:08 -07004871 return result;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004872 }
jdemeyere89de732018-09-19 12:06:20 +02004873 else if (Py_TYPE(func) == &PyMethodDescr_Type) {
jdemeyere89de732018-09-19 12:06:20 +02004874 Py_ssize_t nargs = PyTuple_GET_SIZE(callargs);
4875 if (nargs > 0 && tstate->use_tracing) {
4876 /* We need to create a temporary bound method as argument
4877 for profiling.
4878
4879 If nargs == 0, then this cannot work because we have no
4880 "self". In any case, the call itself would raise
4881 TypeError (foo needs an argument), so we just skip
4882 profiling. */
4883 PyObject *self = PyTuple_GET_ITEM(callargs, 0);
4884 func = Py_TYPE(func)->tp_descr_get(func, self, (PyObject*)Py_TYPE(self));
4885 if (func == NULL) {
4886 return NULL;
4887 }
4888
Victor Stinner4d231bc2019-11-14 13:36:21 +01004889 C_TRACE(result, _PyObject_FastCallDictTstate(
4890 tstate, func,
4891 &_PyTuple_ITEMS(callargs)[1],
4892 nargs - 1,
4893 kwdict));
jdemeyere89de732018-09-19 12:06:20 +02004894 Py_DECREF(func);
4895 return result;
4896 }
Victor Stinner74319ae2016-08-25 00:04:09 +02004897 }
jdemeyere89de732018-09-19 12:06:20 +02004898 return PyObject_Call(func, callargs, kwdict);
Jeremy Hylton52820442001-01-03 23:52:36 +00004899}
4900
Serhiy Storchaka483405b2015-02-17 10:14:30 +02004901/* Extract a slice index from a PyLong or an object with the
Guido van Rossum38fff8c2006-03-07 18:50:55 +00004902 nb_index slot defined, and store in *pi.
4903 Silently reduce values larger than PY_SSIZE_T_MAX to PY_SSIZE_T_MAX,
Xiang Zhang2ddf5a12017-05-10 18:19:41 +08004904 and silently boost values less than PY_SSIZE_T_MIN to PY_SSIZE_T_MIN.
Martin v. Löwisdde99d22006-02-17 15:57:41 +00004905 Return 0 on error, 1 on success.
Tim Peterscb479e72001-12-16 19:11:44 +00004906*/
Guido van Rossum20c6add2000-05-08 14:06:50 +00004907int
Martin v. Löwis18e16552006-02-15 17:27:45 +00004908_PyEval_SliceIndex(PyObject *v, Py_ssize_t *pi)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00004909{
Victor Stinner438a12d2019-05-24 17:01:38 +02004910 PyThreadState *tstate = _PyThreadState_GET();
Serhiy Storchakad4edfc92017-03-30 18:29:23 +03004911 if (v != Py_None) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004912 Py_ssize_t x;
4913 if (PyIndex_Check(v)) {
4914 x = PyNumber_AsSsize_t(v, NULL);
Victor Stinner438a12d2019-05-24 17:01:38 +02004915 if (x == -1 && _PyErr_Occurred(tstate))
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004916 return 0;
4917 }
4918 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02004919 _PyErr_SetString(tstate, PyExc_TypeError,
4920 "slice indices must be integers or "
4921 "None or have an __index__ method");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004922 return 0;
4923 }
4924 *pi = x;
4925 }
4926 return 1;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00004927}
4928
Serhiy Storchaka80ec8362017-03-19 19:37:40 +02004929int
Serhiy Storchakad4edfc92017-03-30 18:29:23 +03004930_PyEval_SliceIndexNotNone(PyObject *v, Py_ssize_t *pi)
Serhiy Storchaka80ec8362017-03-19 19:37:40 +02004931{
Victor Stinner438a12d2019-05-24 17:01:38 +02004932 PyThreadState *tstate = _PyThreadState_GET();
Serhiy Storchakad4edfc92017-03-30 18:29:23 +03004933 Py_ssize_t x;
4934 if (PyIndex_Check(v)) {
4935 x = PyNumber_AsSsize_t(v, NULL);
Victor Stinner438a12d2019-05-24 17:01:38 +02004936 if (x == -1 && _PyErr_Occurred(tstate))
Serhiy Storchakad4edfc92017-03-30 18:29:23 +03004937 return 0;
4938 }
4939 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02004940 _PyErr_SetString(tstate, PyExc_TypeError,
4941 "slice indices must be integers or "
4942 "have an __index__ method");
Serhiy Storchakad4edfc92017-03-30 18:29:23 +03004943 return 0;
4944 }
4945 *pi = x;
4946 return 1;
Serhiy Storchaka80ec8362017-03-19 19:37:40 +02004947}
4948
4949
Guido van Rossum486364b2007-06-30 05:01:58 +00004950#define CANNOT_CATCH_MSG "catching classes that do not inherit from "\
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004951 "BaseException is not allowed"
Brett Cannonf74225d2007-02-26 21:10:16 +00004952
Guido van Rossumb209a111997-04-29 18:18:01 +00004953static PyObject *
Victor Stinner438a12d2019-05-24 17:01:38 +02004954cmp_outcome(PyThreadState *tstate, int op, PyObject *v, PyObject *w)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00004955{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004956 int res = 0;
4957 switch (op) {
4958 case PyCmp_IS:
4959 res = (v == w);
4960 break;
4961 case PyCmp_IS_NOT:
4962 res = (v != w);
4963 break;
4964 case PyCmp_IN:
4965 res = PySequence_Contains(w, v);
4966 if (res < 0)
4967 return NULL;
4968 break;
4969 case PyCmp_NOT_IN:
4970 res = PySequence_Contains(w, v);
4971 if (res < 0)
4972 return NULL;
4973 res = !res;
4974 break;
4975 case PyCmp_EXC_MATCH:
4976 if (PyTuple_Check(w)) {
4977 Py_ssize_t i, length;
4978 length = PyTuple_Size(w);
4979 for (i = 0; i < length; i += 1) {
4980 PyObject *exc = PyTuple_GET_ITEM(w, i);
4981 if (!PyExceptionClass_Check(exc)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004982 _PyErr_SetString(tstate, PyExc_TypeError,
4983 CANNOT_CATCH_MSG);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004984 return NULL;
4985 }
4986 }
4987 }
4988 else {
4989 if (!PyExceptionClass_Check(w)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004990 _PyErr_SetString(tstate, PyExc_TypeError,
4991 CANNOT_CATCH_MSG);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004992 return NULL;
4993 }
4994 }
4995 res = PyErr_GivenExceptionMatches(v, w);
4996 break;
4997 default:
4998 return PyObject_RichCompare(v, w, op);
4999 }
5000 v = res ? Py_True : Py_False;
5001 Py_INCREF(v);
5002 return v;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00005003}
5004
Thomas Wouters52152252000-08-17 22:55:00 +00005005static PyObject *
Victor Stinner438a12d2019-05-24 17:01:38 +02005006import_name(PyThreadState *tstate, PyFrameObject *f,
5007 PyObject *name, PyObject *fromlist, PyObject *level)
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005008{
5009 _Py_IDENTIFIER(__import__);
Victor Stinnerdf142fd2016-08-20 00:44:42 +02005010 PyObject *import_func, *res;
5011 PyObject* stack[5];
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005012
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02005013 import_func = _PyDict_GetItemIdWithError(f->f_builtins, &PyId___import__);
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005014 if (import_func == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005015 if (!_PyErr_Occurred(tstate)) {
5016 _PyErr_SetString(tstate, PyExc_ImportError, "__import__ not found");
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02005017 }
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005018 return NULL;
5019 }
5020
5021 /* Fast path for not overloaded __import__. */
Victor Stinner438a12d2019-05-24 17:01:38 +02005022 if (import_func == tstate->interp->import_func) {
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005023 int ilevel = _PyLong_AsInt(level);
Victor Stinner438a12d2019-05-24 17:01:38 +02005024 if (ilevel == -1 && _PyErr_Occurred(tstate)) {
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005025 return NULL;
5026 }
5027 res = PyImport_ImportModuleLevelObject(
5028 name,
5029 f->f_globals,
5030 f->f_locals == NULL ? Py_None : f->f_locals,
5031 fromlist,
5032 ilevel);
5033 return res;
5034 }
5035
5036 Py_INCREF(import_func);
Victor Stinnerdf142fd2016-08-20 00:44:42 +02005037
5038 stack[0] = name;
5039 stack[1] = f->f_globals;
5040 stack[2] = f->f_locals == NULL ? Py_None : f->f_locals;
5041 stack[3] = fromlist;
5042 stack[4] = level;
Victor Stinner559bb6a2016-08-22 22:48:54 +02005043 res = _PyObject_FastCall(import_func, stack, 5);
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005044 Py_DECREF(import_func);
5045 return res;
5046}
5047
5048static PyObject *
Victor Stinner438a12d2019-05-24 17:01:38 +02005049import_from(PyThreadState *tstate, PyObject *v, PyObject *name)
Guido van Rossume9736fc1990-11-18 17:33:06 +00005050{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005051 PyObject *x;
Antoine Pitrou0373a102014-10-13 20:19:45 +02005052 _Py_IDENTIFIER(__name__);
Xiang Zhang4830f582017-03-21 11:13:42 +08005053 PyObject *fullmodname, *pkgname, *pkgpath, *pkgname_or_unknown, *errmsg;
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00005054
Serhiy Storchakaf320be72018-01-25 10:49:40 +02005055 if (_PyObject_LookupAttr(v, name, &x) != 0) {
Antoine Pitrou0373a102014-10-13 20:19:45 +02005056 return x;
Serhiy Storchakaf320be72018-01-25 10:49:40 +02005057 }
Antoine Pitrou0373a102014-10-13 20:19:45 +02005058 /* Issue #17636: in case this failed because of a circular relative
5059 import, try to fallback on reading the module directly from
5060 sys.modules. */
Antoine Pitrou0373a102014-10-13 20:19:45 +02005061 pkgname = _PyObject_GetAttrId(v, &PyId___name__);
Brett Cannon3008bc02015-08-11 18:01:31 -07005062 if (pkgname == NULL) {
5063 goto error;
5064 }
Oren Milman6db70332017-09-19 14:23:01 +03005065 if (!PyUnicode_Check(pkgname)) {
5066 Py_CLEAR(pkgname);
5067 goto error;
5068 }
Antoine Pitrou0373a102014-10-13 20:19:45 +02005069 fullmodname = PyUnicode_FromFormat("%U.%U", pkgname, name);
Brett Cannon3008bc02015-08-11 18:01:31 -07005070 if (fullmodname == NULL) {
Xiang Zhang4830f582017-03-21 11:13:42 +08005071 Py_DECREF(pkgname);
Antoine Pitrou0373a102014-10-13 20:19:45 +02005072 return NULL;
Brett Cannon3008bc02015-08-11 18:01:31 -07005073 }
Eric Snow3f9eee62017-09-15 16:35:20 -06005074 x = PyImport_GetModule(fullmodname);
Antoine Pitrou0373a102014-10-13 20:19:45 +02005075 Py_DECREF(fullmodname);
Victor Stinner438a12d2019-05-24 17:01:38 +02005076 if (x == NULL && !_PyErr_Occurred(tstate)) {
Brett Cannon3008bc02015-08-11 18:01:31 -07005077 goto error;
5078 }
Matthias Bussonnier1bc15642017-02-22 07:06:50 -08005079 Py_DECREF(pkgname);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005080 return x;
Brett Cannon3008bc02015-08-11 18:01:31 -07005081 error:
Matthias Bussonnierbc4bed42017-02-14 16:05:25 -08005082 pkgpath = PyModule_GetFilenameObject(v);
Matthias Bussonnier1bc15642017-02-22 07:06:50 -08005083 if (pkgname == NULL) {
5084 pkgname_or_unknown = PyUnicode_FromString("<unknown module name>");
5085 if (pkgname_or_unknown == NULL) {
5086 Py_XDECREF(pkgpath);
5087 return NULL;
5088 }
5089 } else {
5090 pkgname_or_unknown = pkgname;
5091 }
Matthias Bussonnierbc4bed42017-02-14 16:05:25 -08005092
5093 if (pkgpath == NULL || !PyUnicode_Check(pkgpath)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005094 _PyErr_Clear(tstate);
Xiang Zhang4830f582017-03-21 11:13:42 +08005095 errmsg = PyUnicode_FromFormat(
5096 "cannot import name %R from %R (unknown location)",
5097 name, pkgname_or_unknown
5098 );
Stefan Krah027b09c2019-03-25 21:50:58 +01005099 /* NULL checks for errmsg and pkgname done by PyErr_SetImportError. */
Xiang Zhang4830f582017-03-21 11:13:42 +08005100 PyErr_SetImportError(errmsg, pkgname, NULL);
5101 }
5102 else {
Anthony Sottile65366bc2019-09-09 08:17:50 -07005103 _Py_IDENTIFIER(__spec__);
5104 PyObject *spec = _PyObject_GetAttrId(v, &PyId___spec__);
Anthony Sottile65366bc2019-09-09 08:17:50 -07005105 const char *fmt =
5106 _PyModuleSpec_IsInitializing(spec) ?
5107 "cannot import name %R from partially initialized module %R "
5108 "(most likely due to a circular import) (%S)" :
5109 "cannot import name %R from %R (%S)";
5110 Py_XDECREF(spec);
5111
5112 errmsg = PyUnicode_FromFormat(fmt, name, pkgname_or_unknown, pkgpath);
Stefan Krah027b09c2019-03-25 21:50:58 +01005113 /* NULL checks for errmsg and pkgname done by PyErr_SetImportError. */
Xiang Zhang4830f582017-03-21 11:13:42 +08005114 PyErr_SetImportError(errmsg, pkgname, pkgpath);
Matthias Bussonnierbc4bed42017-02-14 16:05:25 -08005115 }
5116
Xiang Zhang4830f582017-03-21 11:13:42 +08005117 Py_XDECREF(errmsg);
Matthias Bussonnier1bc15642017-02-22 07:06:50 -08005118 Py_XDECREF(pkgname_or_unknown);
5119 Py_XDECREF(pkgpath);
Brett Cannon3008bc02015-08-11 18:01:31 -07005120 return NULL;
Thomas Wouters52152252000-08-17 22:55:00 +00005121}
Guido van Rossumac7be682001-01-17 15:42:30 +00005122
Thomas Wouters52152252000-08-17 22:55:00 +00005123static int
Victor Stinner438a12d2019-05-24 17:01:38 +02005124import_all_from(PyThreadState *tstate, PyObject *locals, PyObject *v)
Thomas Wouters52152252000-08-17 22:55:00 +00005125{
Martin v. Löwis1c67dd92011-10-14 15:16:45 +02005126 _Py_IDENTIFIER(__all__);
5127 _Py_IDENTIFIER(__dict__);
Xiang Zhangd8b291a2018-03-24 18:39:36 +08005128 _Py_IDENTIFIER(__name__);
Serhiy Storchakaf320be72018-01-25 10:49:40 +02005129 PyObject *all, *dict, *name, *value;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005130 int skip_leading_underscores = 0;
5131 int pos, err;
Thomas Wouters52152252000-08-17 22:55:00 +00005132
Serhiy Storchakaf320be72018-01-25 10:49:40 +02005133 if (_PyObject_LookupAttrId(v, &PyId___all__, &all) < 0) {
5134 return -1; /* Unexpected error */
5135 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005136 if (all == NULL) {
Serhiy Storchakaf320be72018-01-25 10:49:40 +02005137 if (_PyObject_LookupAttrId(v, &PyId___dict__, &dict) < 0) {
5138 return -1;
5139 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005140 if (dict == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005141 _PyErr_SetString(tstate, PyExc_ImportError,
Serhiy Storchakaf320be72018-01-25 10:49:40 +02005142 "from-import-* object has no __dict__ and no __all__");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005143 return -1;
5144 }
5145 all = PyMapping_Keys(dict);
5146 Py_DECREF(dict);
5147 if (all == NULL)
5148 return -1;
5149 skip_leading_underscores = 1;
5150 }
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00005151
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005152 for (pos = 0, err = 0; ; pos++) {
5153 name = PySequence_GetItem(all, pos);
5154 if (name == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005155 if (!_PyErr_ExceptionMatches(tstate, PyExc_IndexError)) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005156 err = -1;
Victor Stinner438a12d2019-05-24 17:01:38 +02005157 }
5158 else {
5159 _PyErr_Clear(tstate);
5160 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005161 break;
5162 }
Xiang Zhangd8b291a2018-03-24 18:39:36 +08005163 if (!PyUnicode_Check(name)) {
5164 PyObject *modname = _PyObject_GetAttrId(v, &PyId___name__);
5165 if (modname == NULL) {
5166 Py_DECREF(name);
5167 err = -1;
5168 break;
5169 }
5170 if (!PyUnicode_Check(modname)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005171 _PyErr_Format(tstate, PyExc_TypeError,
5172 "module __name__ must be a string, not %.100s",
5173 Py_TYPE(modname)->tp_name);
Xiang Zhangd8b291a2018-03-24 18:39:36 +08005174 }
5175 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02005176 _PyErr_Format(tstate, PyExc_TypeError,
5177 "%s in %U.%s must be str, not %.100s",
5178 skip_leading_underscores ? "Key" : "Item",
5179 modname,
5180 skip_leading_underscores ? "__dict__" : "__all__",
5181 Py_TYPE(name)->tp_name);
Xiang Zhangd8b291a2018-03-24 18:39:36 +08005182 }
5183 Py_DECREF(modname);
5184 Py_DECREF(name);
5185 err = -1;
5186 break;
5187 }
5188 if (skip_leading_underscores) {
Serhiy Storchakae3b2b4b2017-09-08 09:58:51 +03005189 if (PyUnicode_READY(name) == -1) {
5190 Py_DECREF(name);
5191 err = -1;
5192 break;
5193 }
5194 if (PyUnicode_READ_CHAR(name, 0) == '_') {
5195 Py_DECREF(name);
5196 continue;
5197 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005198 }
5199 value = PyObject_GetAttr(v, name);
5200 if (value == NULL)
5201 err = -1;
5202 else if (PyDict_CheckExact(locals))
5203 err = PyDict_SetItem(locals, name, value);
5204 else
5205 err = PyObject_SetItem(locals, name, value);
5206 Py_DECREF(name);
5207 Py_XDECREF(value);
5208 if (err != 0)
5209 break;
5210 }
5211 Py_DECREF(all);
5212 return err;
Guido van Rossume9736fc1990-11-18 17:33:06 +00005213}
5214
Serhiy Storchaka25e4f772017-08-03 11:37:15 +03005215static int
Victor Stinner438a12d2019-05-24 17:01:38 +02005216check_args_iterable(PyThreadState *tstate, PyObject *func, PyObject *args)
Serhiy Storchaka25e4f772017-08-03 11:37:15 +03005217{
5218 if (args->ob_type->tp_iter == NULL && !PySequence_Check(args)) {
Jeroen Demeyerbf17d412019-11-05 16:48:04 +01005219 /* check_args_iterable() may be called with a live exception:
5220 * clear it to prevent calling _PyObject_FunctionStr() with an
5221 * exception set. */
5222 PyErr_Clear();
5223 PyObject *funcstr = _PyObject_FunctionStr(func);
5224 if (funcstr != NULL) {
5225 _PyErr_Format(tstate, PyExc_TypeError,
5226 "%U argument after * must be an iterable, not %.200s",
5227 funcstr, Py_TYPE(args)->tp_name);
5228 Py_DECREF(funcstr);
5229 }
Serhiy Storchaka25e4f772017-08-03 11:37:15 +03005230 return -1;
5231 }
5232 return 0;
5233}
5234
5235static void
Victor Stinner438a12d2019-05-24 17:01:38 +02005236format_kwargs_error(PyThreadState *tstate, PyObject *func, PyObject *kwargs)
Serhiy Storchaka25e4f772017-08-03 11:37:15 +03005237{
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02005238 /* _PyDict_MergeEx raises attribute
5239 * error (percolated from an attempt
5240 * to get 'keys' attribute) instead of
5241 * a type error if its second argument
5242 * is not a mapping.
5243 */
Victor Stinner438a12d2019-05-24 17:01:38 +02005244 if (_PyErr_ExceptionMatches(tstate, PyExc_AttributeError)) {
Jeroen Demeyerbf17d412019-11-05 16:48:04 +01005245 PyErr_Clear();
5246 PyObject *funcstr = _PyObject_FunctionStr(func);
5247 if (funcstr != NULL) {
5248 _PyErr_Format(
5249 tstate, PyExc_TypeError,
5250 "%U argument after ** must be a mapping, not %.200s",
5251 funcstr, Py_TYPE(kwargs)->tp_name);
5252 Py_DECREF(funcstr);
5253 }
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02005254 }
Victor Stinner438a12d2019-05-24 17:01:38 +02005255 else if (_PyErr_ExceptionMatches(tstate, PyExc_KeyError)) {
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02005256 PyObject *exc, *val, *tb;
Victor Stinner438a12d2019-05-24 17:01:38 +02005257 _PyErr_Fetch(tstate, &exc, &val, &tb);
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02005258 if (val && PyTuple_Check(val) && PyTuple_GET_SIZE(val) == 1) {
Jeroen Demeyerbf17d412019-11-05 16:48:04 +01005259 PyErr_Clear();
5260 PyObject *funcstr = _PyObject_FunctionStr(func);
5261 if (funcstr != NULL) {
5262 PyObject *key = PyTuple_GET_ITEM(val, 0);
5263 _PyErr_Format(
5264 tstate, PyExc_TypeError,
5265 "%U got multiple values for keyword argument '%S'",
5266 funcstr, key);
5267 Py_DECREF(funcstr);
5268 }
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02005269 Py_XDECREF(exc);
5270 Py_XDECREF(val);
5271 Py_XDECREF(tb);
5272 }
5273 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02005274 _PyErr_Restore(tstate, exc, val, tb);
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02005275 }
5276 }
Serhiy Storchaka25e4f772017-08-03 11:37:15 +03005277}
5278
Guido van Rossumac7be682001-01-17 15:42:30 +00005279static void
Victor Stinner438a12d2019-05-24 17:01:38 +02005280format_exc_check_arg(PyThreadState *tstate, PyObject *exc,
5281 const char *format_str, PyObject *obj)
Paul Prescode68140d2000-08-30 20:25:01 +00005282{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005283 const char *obj_str;
Paul Prescode68140d2000-08-30 20:25:01 +00005284
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005285 if (!obj)
5286 return;
Paul Prescode68140d2000-08-30 20:25:01 +00005287
Serhiy Storchaka06515832016-11-20 09:13:07 +02005288 obj_str = PyUnicode_AsUTF8(obj);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005289 if (!obj_str)
5290 return;
Paul Prescode68140d2000-08-30 20:25:01 +00005291
Victor Stinner438a12d2019-05-24 17:01:38 +02005292 _PyErr_Format(tstate, exc, format_str, obj_str);
Paul Prescode68140d2000-08-30 20:25:01 +00005293}
Guido van Rossum950361c1997-01-24 13:49:28 +00005294
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00005295static void
Victor Stinner438a12d2019-05-24 17:01:38 +02005296format_exc_unbound(PyThreadState *tstate, PyCodeObject *co, int oparg)
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00005297{
5298 PyObject *name;
5299 /* Don't stomp existing exception */
Victor Stinner438a12d2019-05-24 17:01:38 +02005300 if (_PyErr_Occurred(tstate))
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00005301 return;
5302 if (oparg < PyTuple_GET_SIZE(co->co_cellvars)) {
5303 name = PyTuple_GET_ITEM(co->co_cellvars,
5304 oparg);
Victor Stinner438a12d2019-05-24 17:01:38 +02005305 format_exc_check_arg(tstate,
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00005306 PyExc_UnboundLocalError,
5307 UNBOUNDLOCAL_ERROR_MSG,
5308 name);
5309 } else {
5310 name = PyTuple_GET_ITEM(co->co_freevars, oparg -
5311 PyTuple_GET_SIZE(co->co_cellvars));
Victor Stinner438a12d2019-05-24 17:01:38 +02005312 format_exc_check_arg(tstate, PyExc_NameError,
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00005313 UNBOUNDFREE_ERROR_MSG, name);
5314 }
5315}
5316
Serhiy Storchakaa68f2f02018-04-03 01:41:38 +03005317static void
Mark Shannonfee55262019-11-21 09:11:43 +00005318format_awaitable_error(PyThreadState *tstate, PyTypeObject *type, int prevprevopcode, int prevopcode)
Serhiy Storchakaa68f2f02018-04-03 01:41:38 +03005319{
5320 if (type->tp_as_async == NULL || type->tp_as_async->am_await == NULL) {
5321 if (prevopcode == BEFORE_ASYNC_WITH) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005322 _PyErr_Format(tstate, PyExc_TypeError,
5323 "'async with' received an object from __aenter__ "
5324 "that does not implement __await__: %.100s",
5325 type->tp_name);
Serhiy Storchakaa68f2f02018-04-03 01:41:38 +03005326 }
Mark Shannonfee55262019-11-21 09:11:43 +00005327 else if (prevopcode == WITH_EXCEPT_START || (prevopcode == CALL_FUNCTION && prevprevopcode == DUP_TOP)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005328 _PyErr_Format(tstate, PyExc_TypeError,
5329 "'async with' received an object from __aexit__ "
5330 "that does not implement __await__: %.100s",
5331 type->tp_name);
Serhiy Storchakaa68f2f02018-04-03 01:41:38 +03005332 }
5333 }
5334}
5335
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005336static PyObject *
Victor Stinner438a12d2019-05-24 17:01:38 +02005337unicode_concatenate(PyThreadState *tstate, PyObject *v, PyObject *w,
Serhiy Storchakaab874002016-09-11 13:48:15 +03005338 PyFrameObject *f, const _Py_CODEUNIT *next_instr)
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005339{
5340 PyObject *res;
5341 if (Py_REFCNT(v) == 2) {
5342 /* In the common case, there are 2 references to the value
5343 * stored in 'variable' when the += is performed: one on the
5344 * value stack (in 'v') and one still stored in the
5345 * 'variable'. We try to delete the variable now to reduce
5346 * the refcnt to 1.
5347 */
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +03005348 int opcode, oparg;
5349 NEXTOPARG();
5350 switch (opcode) {
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005351 case STORE_FAST:
5352 {
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005353 PyObject **fastlocals = f->f_localsplus;
5354 if (GETLOCAL(oparg) == v)
5355 SETLOCAL(oparg, NULL);
5356 break;
5357 }
5358 case STORE_DEREF:
5359 {
5360 PyObject **freevars = (f->f_localsplus +
5361 f->f_code->co_nlocals);
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +03005362 PyObject *c = freevars[oparg];
Raymond Hettingerc32f9db2016-11-12 04:10:35 -05005363 if (PyCell_GET(c) == v) {
5364 PyCell_SET(c, NULL);
5365 Py_DECREF(v);
5366 }
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005367 break;
5368 }
5369 case STORE_NAME:
5370 {
5371 PyObject *names = f->f_code->co_names;
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +03005372 PyObject *name = GETITEM(names, oparg);
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005373 PyObject *locals = f->f_locals;
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02005374 if (locals && PyDict_CheckExact(locals)) {
5375 PyObject *w = PyDict_GetItemWithError(locals, name);
5376 if ((w == v && PyDict_DelItem(locals, name) != 0) ||
Victor Stinner438a12d2019-05-24 17:01:38 +02005377 (w == NULL && _PyErr_Occurred(tstate)))
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02005378 {
5379 Py_DECREF(v);
5380 return NULL;
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005381 }
5382 }
5383 break;
5384 }
5385 }
5386 }
5387 res = v;
5388 PyUnicode_Append(&res, w);
5389 return res;
5390}
5391
Guido van Rossum950361c1997-01-24 13:49:28 +00005392#ifdef DYNAMIC_EXECUTION_PROFILE
5393
Skip Montanarof118cb12001-10-15 20:51:38 +00005394static PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00005395getarray(long a[256])
Guido van Rossum950361c1997-01-24 13:49:28 +00005396{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005397 int i;
5398 PyObject *l = PyList_New(256);
5399 if (l == NULL) return NULL;
5400 for (i = 0; i < 256; i++) {
5401 PyObject *x = PyLong_FromLong(a[i]);
5402 if (x == NULL) {
5403 Py_DECREF(l);
5404 return NULL;
5405 }
Zackery Spytz99d56b52018-12-08 07:16:55 -07005406 PyList_SET_ITEM(l, i, x);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005407 }
5408 for (i = 0; i < 256; i++)
5409 a[i] = 0;
5410 return l;
Guido van Rossum950361c1997-01-24 13:49:28 +00005411}
5412
5413PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00005414_Py_GetDXProfile(PyObject *self, PyObject *args)
Guido van Rossum950361c1997-01-24 13:49:28 +00005415{
5416#ifndef DXPAIRS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005417 return getarray(dxp);
Guido van Rossum950361c1997-01-24 13:49:28 +00005418#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005419 int i;
5420 PyObject *l = PyList_New(257);
5421 if (l == NULL) return NULL;
5422 for (i = 0; i < 257; i++) {
5423 PyObject *x = getarray(dxpairs[i]);
5424 if (x == NULL) {
5425 Py_DECREF(l);
5426 return NULL;
5427 }
Zackery Spytz99d56b52018-12-08 07:16:55 -07005428 PyList_SET_ITEM(l, i, x);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005429 }
5430 return l;
Guido van Rossum950361c1997-01-24 13:49:28 +00005431#endif
5432}
5433
5434#endif
Brett Cannon5c4de282016-09-07 11:16:41 -07005435
5436Py_ssize_t
5437_PyEval_RequestCodeExtraIndex(freefunc free)
5438{
Victor Stinnercaba55b2018-08-03 15:33:52 +02005439 PyInterpreterState *interp = _PyInterpreterState_GET_UNSAFE();
Brett Cannon5c4de282016-09-07 11:16:41 -07005440 Py_ssize_t new_index;
5441
Dino Viehlandf3cffd22017-06-21 14:44:36 -07005442 if (interp->co_extra_user_count == MAX_CO_EXTRA_USERS - 1) {
Brett Cannon5c4de282016-09-07 11:16:41 -07005443 return -1;
5444 }
Dino Viehlandf3cffd22017-06-21 14:44:36 -07005445 new_index = interp->co_extra_user_count++;
5446 interp->co_extra_freefuncs[new_index] = free;
Brett Cannon5c4de282016-09-07 11:16:41 -07005447 return new_index;
5448}
Łukasz Langaa785c872016-09-09 17:37:37 -07005449
5450static void
5451dtrace_function_entry(PyFrameObject *f)
5452{
Serhiy Storchaka85b0f5b2016-11-20 10:16:47 +02005453 const char *filename;
5454 const char *funcname;
Łukasz Langaa785c872016-09-09 17:37:37 -07005455 int lineno;
5456
5457 filename = PyUnicode_AsUTF8(f->f_code->co_filename);
5458 funcname = PyUnicode_AsUTF8(f->f_code->co_name);
5459 lineno = PyCode_Addr2Line(f->f_code, f->f_lasti);
5460
5461 PyDTrace_FUNCTION_ENTRY(filename, funcname, lineno);
5462}
5463
5464static void
5465dtrace_function_return(PyFrameObject *f)
5466{
Serhiy Storchaka85b0f5b2016-11-20 10:16:47 +02005467 const char *filename;
5468 const char *funcname;
Łukasz Langaa785c872016-09-09 17:37:37 -07005469 int lineno;
5470
5471 filename = PyUnicode_AsUTF8(f->f_code->co_filename);
5472 funcname = PyUnicode_AsUTF8(f->f_code->co_name);
5473 lineno = PyCode_Addr2Line(f->f_code, f->f_lasti);
5474
5475 PyDTrace_FUNCTION_RETURN(filename, funcname, lineno);
5476}
5477
5478/* DTrace equivalent of maybe_call_line_trace. */
5479static void
5480maybe_dtrace_line(PyFrameObject *frame,
5481 int *instr_lb, int *instr_ub, int *instr_prev)
5482{
5483 int line = frame->f_lineno;
Serhiy Storchaka85b0f5b2016-11-20 10:16:47 +02005484 const char *co_filename, *co_name;
Łukasz Langaa785c872016-09-09 17:37:37 -07005485
5486 /* If the last instruction executed isn't in the current
5487 instruction window, reset the window.
5488 */
5489 if (frame->f_lasti < *instr_lb || frame->f_lasti >= *instr_ub) {
5490 PyAddrPair bounds;
5491 line = _PyCode_CheckLineNumber(frame->f_code, frame->f_lasti,
5492 &bounds);
5493 *instr_lb = bounds.ap_lower;
5494 *instr_ub = bounds.ap_upper;
5495 }
5496 /* If the last instruction falls at the start of a line or if
5497 it represents a jump backwards, update the frame's line
5498 number and call the trace function. */
5499 if (frame->f_lasti == *instr_lb || frame->f_lasti < *instr_prev) {
5500 frame->f_lineno = line;
5501 co_filename = PyUnicode_AsUTF8(frame->f_code->co_filename);
5502 if (!co_filename)
5503 co_filename = "?";
5504 co_name = PyUnicode_AsUTF8(frame->f_code->co_name);
5505 if (!co_name)
5506 co_name = "?";
5507 PyDTrace_LINE(co_filename, co_name, line);
5508 }
5509 *instr_prev = frame->f_lasti;
5510}
Victor Stinnerf4b1e3d2019-11-04 19:48:34 +01005511
5512
5513/* Implement Py_EnterRecursiveCall() and Py_LeaveRecursiveCall() as functions
5514 for the limited API. */
5515
5516#undef Py_EnterRecursiveCall
5517
5518int Py_EnterRecursiveCall(const char *where)
5519{
Victor Stinnerbe434dc2019-11-05 00:51:22 +01005520 return _Py_EnterRecursiveCall_inline(where);
Victor Stinnerf4b1e3d2019-11-04 19:48:34 +01005521}
5522
5523#undef Py_LeaveRecursiveCall
5524
5525void Py_LeaveRecursiveCall(void)
5526{
Victor Stinnerbe434dc2019-11-05 00:51:22 +01005527 _Py_LeaveRecursiveCall_inline();
Victor Stinnerf4b1e3d2019-11-04 19:48:34 +01005528}