blob: 00237c04d81b3662fcc378f11b029a35190d107a [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
Guido van Rossumb209a111997-04-29 18:18:01 +00009#include "Python.h"
Guido van Rossum10dc2e81990-11-18 17:27:39 +000010
Guido van Rossum10dc2e81990-11-18 17:27:39 +000011#include "compile.h"
Guido van Rossum3f5da241990-12-20 15:06:42 +000012#include "frameobject.h"
Guido van Rossumff4949e1992-08-05 19:58:53 +000013#include "eval.h"
Guido van Rossum10dc2e81990-11-18 17:27:39 +000014#include "opcode.h"
Tim Peters6d6c1a32001-08-02 04:15:00 +000015#include "structmember.h"
Guido van Rossum10dc2e81990-11-18 17:27:39 +000016
Jack Jansencbf630f2000-07-11 21:59:16 +000017#ifdef macintosh
18#include "macglue.h"
19#endif
20
Guido van Rossumc6004111993-11-05 10:22:19 +000021#include <ctype.h>
22
Guido van Rossum04691fc1992-08-12 15:35:34 +000023/* Turn this on if your compiler chokes on the big switch: */
Guido van Rossum1ae940a1995-01-02 19:04:15 +000024/* #define CASE_TOO_BIG 1 */
Guido van Rossum04691fc1992-08-12 15:35:34 +000025
Guido van Rossum408027e1996-12-30 16:17:54 +000026#ifdef Py_DEBUG
Guido van Rossum96a42c81992-01-12 02:29:51 +000027/* For debugging the interpreter: */
28#define LLTRACE 1 /* Low-level trace feature */
29#define CHECKEXC 1 /* Double-check exception checking */
Guido van Rossum10dc2e81990-11-18 17:27:39 +000030#endif
31
Jeremy Hylton52820442001-01-03 23:52:36 +000032typedef PyObject *(*callproc)(PyObject *, PyObject *, PyObject *);
Guido van Rossum5b722181993-03-30 17:46:03 +000033
Guido van Rossum374a9221991-04-04 10:40:29 +000034/* Forward declarations */
Tim Peters5ca576e2001-06-18 22:08:13 +000035static PyObject *eval_frame(PyFrameObject *);
Jeremy Hyltone8c04322002-08-16 17:47:26 +000036static PyObject *call_function(PyObject ***, int);
Jeremy Hylton52820442001-01-03 23:52:36 +000037static PyObject *fast_function(PyObject *, PyObject ***, int, int, int);
Jeremy Hylton52820442001-01-03 23:52:36 +000038static PyObject *do_call(PyObject *, PyObject ***, int, int);
39static PyObject *ext_do_call(PyObject *, PyObject ***, int, int, int);
Guido van Rossumac7be682001-01-17 15:42:30 +000040static PyObject *update_keyword_args(PyObject *, int, PyObject ***,PyObject *);
Ka-Ping Yee20579702001-01-15 22:14:16 +000041static PyObject *update_star_args(int, int, PyObject *, PyObject ***);
Jeremy Hylton52820442001-01-03 23:52:36 +000042static PyObject *load_args(PyObject ***, int);
43#define CALL_FLAG_VAR 1
44#define CALL_FLAG_KW 2
45
Guido van Rossum0a066c01992-03-27 17:29:15 +000046#ifdef LLTRACE
Tim Petersdbd9ba62000-07-09 03:09:57 +000047static int prtrace(PyObject *, char *);
Guido van Rossum0a066c01992-03-27 17:29:15 +000048#endif
Fred Drake5755ce62001-06-27 19:19:46 +000049static int call_trace(Py_tracefunc, PyObject *, PyFrameObject *,
50 int, PyObject *);
Fred Drake4ec5d562001-10-04 19:26:43 +000051static void call_trace_protected(Py_tracefunc, PyObject *,
52 PyFrameObject *, int);
Fred Drake5755ce62001-06-27 19:19:46 +000053static void call_exc_trace(Py_tracefunc, PyObject *, PyFrameObject *);
Michael W. Hudsondd32a912002-08-15 14:59:02 +000054static void maybe_call_line_trace(int, Py_tracefunc, PyObject *,
55 PyFrameObject *, int *, int *);
56
Tim Petersdbd9ba62000-07-09 03:09:57 +000057static PyObject *apply_slice(PyObject *, PyObject *, PyObject *);
58static int assign_slice(PyObject *, PyObject *,
59 PyObject *, PyObject *);
60static PyObject *cmp_outcome(int, PyObject *, PyObject *);
Thomas Wouters52152252000-08-17 22:55:00 +000061static PyObject *import_from(PyObject *, PyObject *);
62static int import_all_from(PyObject *, PyObject *);
Tim Petersdbd9ba62000-07-09 03:09:57 +000063static PyObject *build_class(PyObject *, PyObject *, PyObject *);
64static int exec_statement(PyFrameObject *,
65 PyObject *, PyObject *, PyObject *);
Tim Petersdbd9ba62000-07-09 03:09:57 +000066static void set_exc_info(PyThreadState *, PyObject *, PyObject *, PyObject *);
67static void reset_exc_info(PyThreadState *);
Paul Prescode68140d2000-08-30 20:25:01 +000068static void format_exc_check_arg(PyObject *, char *, PyObject *);
Guido van Rossum374a9221991-04-04 10:40:29 +000069
Paul Prescode68140d2000-08-30 20:25:01 +000070#define NAME_ERROR_MSG \
Fred Drake661ea262000-10-24 19:57:45 +000071 "name '%.200s' is not defined"
Jeremy Hylton64949cb2001-01-25 20:06:59 +000072#define GLOBAL_NAME_ERROR_MSG \
73 "global name '%.200s' is not defined"
Paul Prescode68140d2000-08-30 20:25:01 +000074#define UNBOUNDLOCAL_ERROR_MSG \
Fred Drake661ea262000-10-24 19:57:45 +000075 "local variable '%.200s' referenced before assignment"
Jeremy Hyltonc76770c2001-04-13 16:51:46 +000076#define UNBOUNDFREE_ERROR_MSG \
77 "free variable '%.200s' referenced before assignment" \
78 " in enclosing scope"
Guido van Rossum374a9221991-04-04 10:40:29 +000079
Guido van Rossum950361c1997-01-24 13:49:28 +000080/* Dynamic execution profile */
81#ifdef DYNAMIC_EXECUTION_PROFILE
82#ifdef DXPAIRS
83static long dxpairs[257][256];
84#define dxp dxpairs[256]
85#else
86static long dxp[256];
87#endif
88#endif
89
Jeremy Hylton938ace62002-07-17 16:30:39 +000090static PyTypeObject gentype;
Tim Peters5ca576e2001-06-18 22:08:13 +000091
92typedef struct {
93 PyObject_HEAD
Tim Petersd8e1c9e2001-06-26 20:58:58 +000094 /* The gi_ prefix is intended to remind of generator-iterator. */
95
96 PyFrameObject *gi_frame;
97
Tim Peterse77f2e22001-06-26 22:24:51 +000098 /* True if generator is being executed. */
99 int gi_running;
Fred Drake72bc4562002-08-09 18:35:52 +0000100
101 /* List of weak reference. */
102 PyObject *gi_weakreflist;
Tim Peters5ca576e2001-06-18 22:08:13 +0000103} genobject;
104
105static PyObject *
106gen_new(PyFrameObject *f)
107{
Neil Schemenauer08de92a2002-03-18 20:45:09 +0000108 genobject *gen = PyObject_GC_New(genobject, &gentype);
Tim Peters5ca576e2001-06-18 22:08:13 +0000109 if (gen == NULL) {
110 Py_DECREF(f);
111 return NULL;
112 }
Tim Petersd8e1c9e2001-06-26 20:58:58 +0000113 gen->gi_frame = f;
114 gen->gi_running = 0;
Fred Drake72bc4562002-08-09 18:35:52 +0000115 gen->gi_weakreflist = NULL;
Neil Schemenauer08de92a2002-03-18 20:45:09 +0000116 _PyObject_GC_TRACK(gen);
Tim Peters5ca576e2001-06-18 22:08:13 +0000117 return (PyObject *)gen;
118}
119
Neil Schemenauerf8c7c202001-07-12 13:27:49 +0000120static int
121gen_traverse(genobject *gen, visitproc visit, void *arg)
122{
123 return visit((PyObject *)gen->gi_frame, arg);
124}
125
Tim Peters5ca576e2001-06-18 22:08:13 +0000126static void
127gen_dealloc(genobject *gen)
128{
Neil Schemenauer08de92a2002-03-18 20:45:09 +0000129 _PyObject_GC_UNTRACK(gen);
Fred Drake72bc4562002-08-09 18:35:52 +0000130 if (gen->gi_weakreflist != NULL)
131 PyObject_ClearWeakRefs((PyObject *) gen);
Tim Petersd8e1c9e2001-06-26 20:58:58 +0000132 Py_DECREF(gen->gi_frame);
Neil Schemenauer08de92a2002-03-18 20:45:09 +0000133 PyObject_GC_Del(gen);
Tim Peters5ca576e2001-06-18 22:08:13 +0000134}
135
136static PyObject *
137gen_iternext(genobject *gen)
138{
Neil Schemenauer2b13ce82001-06-21 02:41:10 +0000139 PyThreadState *tstate = PyThreadState_GET();
Tim Petersd8e1c9e2001-06-26 20:58:58 +0000140 PyFrameObject *f = gen->gi_frame;
Tim Peters5ca576e2001-06-18 22:08:13 +0000141 PyObject *result;
142
Tim Petersd8e1c9e2001-06-26 20:58:58 +0000143 if (gen->gi_running) {
Tim Peters5ca576e2001-06-18 22:08:13 +0000144 PyErr_SetString(PyExc_ValueError,
145 "generator already executing");
146 return NULL;
147 }
Tim Peters8c963692001-06-23 05:26:56 +0000148 if (f->f_stacktop == NULL)
Tim Peters5ca576e2001-06-18 22:08:13 +0000149 return NULL;
Neil Schemenauer2b13ce82001-06-21 02:41:10 +0000150
151 /* Generators always return to their most recent caller, not
152 * necessarily their creator. */
Tim Peters5eb4b872001-06-23 05:47:56 +0000153 Py_XINCREF(tstate->frame);
Neil Schemenauer2b13ce82001-06-21 02:41:10 +0000154 assert(f->f_back == NULL);
155 f->f_back = tstate->frame;
156
Tim Petersd8e1c9e2001-06-26 20:58:58 +0000157 gen->gi_running = 1;
Tim Peters5ca576e2001-06-18 22:08:13 +0000158 result = eval_frame(f);
Tim Petersd8e1c9e2001-06-26 20:58:58 +0000159 gen->gi_running = 0;
Neil Schemenauer2b13ce82001-06-21 02:41:10 +0000160
161 /* Don't keep the reference to f_back any longer than necessary. It
162 * may keep a chain of frames alive or it could create a reference
163 * cycle. */
Tim Peters5eb4b872001-06-23 05:47:56 +0000164 Py_XDECREF(f->f_back);
Tim Peters6302ec62001-06-20 06:57:32 +0000165 f->f_back = NULL;
Neil Schemenauer2b13ce82001-06-21 02:41:10 +0000166
Tim Petersad1a18b2001-06-23 06:19:16 +0000167 /* If the generator just returned (as opposed to yielding), signal
168 * that the generator is exhausted. */
169 if (result == Py_None && f->f_stacktop == NULL) {
170 Py_DECREF(result);
171 result = NULL;
172 }
173
Neil Schemenauer2b13ce82001-06-21 02:41:10 +0000174 return result;
Tim Peters5ca576e2001-06-18 22:08:13 +0000175}
176
177static PyObject *
Tim Peters5ca576e2001-06-18 22:08:13 +0000178gen_getiter(PyObject *gen)
179{
180 Py_INCREF(gen);
181 return gen;
182}
183
Guido van Rossum6f799372001-09-20 20:46:19 +0000184static PyMemberDef gen_memberlist[] = {
Tim Peters6d6c1a32001-08-02 04:15:00 +0000185 {"gi_frame", T_OBJECT, offsetof(genobject, gi_frame), RO},
186 {"gi_running", T_INT, offsetof(genobject, gi_running), RO},
187 {NULL} /* Sentinel */
188};
Tim Peters5ca576e2001-06-18 22:08:13 +0000189
Tim Peters0c322792002-07-17 16:49:03 +0000190static PyTypeObject gentype = {
Tim Peters5ca576e2001-06-18 22:08:13 +0000191 PyObject_HEAD_INIT(&PyType_Type)
192 0, /* ob_size */
193 "generator", /* tp_name */
Neil Schemenauer08de92a2002-03-18 20:45:09 +0000194 sizeof(genobject), /* tp_basicsize */
Tim Peters5ca576e2001-06-18 22:08:13 +0000195 0, /* tp_itemsize */
196 /* methods */
197 (destructor)gen_dealloc, /* tp_dealloc */
198 0, /* tp_print */
Tim Peters6d6c1a32001-08-02 04:15:00 +0000199 0, /* tp_getattr */
Tim Peters5ca576e2001-06-18 22:08:13 +0000200 0, /* tp_setattr */
201 0, /* tp_compare */
202 0, /* tp_repr */
203 0, /* tp_as_number */
204 0, /* tp_as_sequence */
205 0, /* tp_as_mapping */
206 0, /* tp_hash */
207 0, /* tp_call */
208 0, /* tp_str */
Tim Peters6d6c1a32001-08-02 04:15:00 +0000209 PyObject_GenericGetAttr, /* tp_getattro */
Tim Peters5ca576e2001-06-18 22:08:13 +0000210 0, /* tp_setattro */
211 0, /* tp_as_buffer */
Neil Schemenauer08de92a2002-03-18 20:45:09 +0000212 Py_TPFLAGS_DEFAULT | Py_TPFLAGS_HAVE_GC,/* tp_flags */
Tim Peters5ca576e2001-06-18 22:08:13 +0000213 0, /* tp_doc */
Neil Schemenauerf8c7c202001-07-12 13:27:49 +0000214 (traverseproc)gen_traverse, /* tp_traverse */
Tim Peters5ca576e2001-06-18 22:08:13 +0000215 0, /* tp_clear */
216 0, /* tp_richcompare */
Fred Drake72bc4562002-08-09 18:35:52 +0000217 offsetof(genobject, gi_weakreflist), /* tp_weaklistoffset */
Tim Peters5ca576e2001-06-18 22:08:13 +0000218 (getiterfunc)gen_getiter, /* tp_iter */
219 (iternextfunc)gen_iternext, /* tp_iternext */
Tim Petersa64295b2002-07-17 00:15:22 +0000220 0, /* tp_methods */
Tim Peters6d6c1a32001-08-02 04:15:00 +0000221 gen_memberlist, /* tp_members */
222 0, /* tp_getset */
223 0, /* tp_base */
224 0, /* tp_dict */
Tim Peters5ca576e2001-06-18 22:08:13 +0000225};
226
227
Guido van Rossume59214e1994-08-30 08:01:59 +0000228#ifdef WITH_THREAD
Guido van Rossumff4949e1992-08-05 19:58:53 +0000229
Guido van Rossum2571cc81999-04-07 16:07:23 +0000230#ifndef DONT_HAVE_ERRNO_H
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000231#include <errno.h>
Guido van Rossum2571cc81999-04-07 16:07:23 +0000232#endif
Guido van Rossum49b56061998-10-01 20:42:43 +0000233#include "pythread.h"
Guido van Rossumff4949e1992-08-05 19:58:53 +0000234
Guido van Rossuma027efa1997-05-05 20:56:21 +0000235extern int _PyThread_Started; /* Flag for Py_Exit */
236
Guido van Rossum65d5b571998-12-21 19:32:43 +0000237static PyThread_type_lock interpreter_lock = 0;
Guido van Rossuma9672091994-09-14 13:31:22 +0000238static long main_thread = 0;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000239
240void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000241PyEval_InitThreads(void)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000242{
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000243 if (interpreter_lock)
Sjoerd Mullendered59d201993-01-06 13:36:38 +0000244 return;
Guido van Rossuma027efa1997-05-05 20:56:21 +0000245 _PyThread_Started = 1;
Guido van Rossum65d5b571998-12-21 19:32:43 +0000246 interpreter_lock = PyThread_allocate_lock();
247 PyThread_acquire_lock(interpreter_lock, 1);
248 main_thread = PyThread_get_thread_ident();
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000249}
Guido van Rossumff4949e1992-08-05 19:58:53 +0000250
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000251void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000252PyEval_AcquireLock(void)
Guido van Rossum25ce5661997-08-02 03:10:38 +0000253{
Guido van Rossum65d5b571998-12-21 19:32:43 +0000254 PyThread_acquire_lock(interpreter_lock, 1);
Guido van Rossum25ce5661997-08-02 03:10:38 +0000255}
256
257void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000258PyEval_ReleaseLock(void)
Guido van Rossum25ce5661997-08-02 03:10:38 +0000259{
Guido van Rossum65d5b571998-12-21 19:32:43 +0000260 PyThread_release_lock(interpreter_lock);
Guido van Rossum25ce5661997-08-02 03:10:38 +0000261}
262
263void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000264PyEval_AcquireThread(PyThreadState *tstate)
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000265{
266 if (tstate == NULL)
267 Py_FatalError("PyEval_AcquireThread: NULL new thread state");
Guido van Rossum65d5b571998-12-21 19:32:43 +0000268 PyThread_acquire_lock(interpreter_lock, 1);
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000269 if (PyThreadState_Swap(tstate) != NULL)
270 Py_FatalError(
271 "PyEval_AcquireThread: non-NULL old thread state");
272}
273
274void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000275PyEval_ReleaseThread(PyThreadState *tstate)
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000276{
277 if (tstate == NULL)
278 Py_FatalError("PyEval_ReleaseThread: NULL thread state");
279 if (PyThreadState_Swap(NULL) != tstate)
280 Py_FatalError("PyEval_ReleaseThread: wrong thread state");
Guido van Rossum65d5b571998-12-21 19:32:43 +0000281 PyThread_release_lock(interpreter_lock);
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000282}
Guido van Rossumfee3a2d2000-08-27 17:34:07 +0000283
284/* This function is called from PyOS_AfterFork to ensure that newly
285 created child processes don't hold locks referring to threads which
286 are not running in the child process. (This could also be done using
287 pthread_atfork mechanism, at least for the pthreads implementation.) */
288
289void
290PyEval_ReInitThreads(void)
291{
292 if (!interpreter_lock)
293 return;
294 /*XXX Can't use PyThread_free_lock here because it does too
295 much error-checking. Doing this cleanly would require
296 adding a new function to each thread_*.h. Instead, just
297 create a new lock and waste a little bit of memory */
298 interpreter_lock = PyThread_allocate_lock();
299 PyThread_acquire_lock(interpreter_lock, 1);
300 main_thread = PyThread_get_thread_ident();
301}
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000302#endif
303
Guido van Rossumff4949e1992-08-05 19:58:53 +0000304/* Functions save_thread and restore_thread are always defined so
305 dynamically loaded modules needn't be compiled separately for use
306 with and without threads: */
307
Guido van Rossum2fca21f71997-07-18 23:56:58 +0000308PyThreadState *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000309PyEval_SaveThread(void)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000310{
Guido van Rossumb74eca91997-09-30 22:03:16 +0000311 PyThreadState *tstate = PyThreadState_Swap(NULL);
312 if (tstate == NULL)
313 Py_FatalError("PyEval_SaveThread: NULL tstate");
Guido van Rossume59214e1994-08-30 08:01:59 +0000314#ifdef WITH_THREAD
Guido van Rossumb74eca91997-09-30 22:03:16 +0000315 if (interpreter_lock)
Guido van Rossum65d5b571998-12-21 19:32:43 +0000316 PyThread_release_lock(interpreter_lock);
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000317#endif
Guido van Rossumb74eca91997-09-30 22:03:16 +0000318 return tstate;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000319}
320
321void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000322PyEval_RestoreThread(PyThreadState *tstate)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000323{
Guido van Rossumb74eca91997-09-30 22:03:16 +0000324 if (tstate == NULL)
325 Py_FatalError("PyEval_RestoreThread: NULL tstate");
Guido van Rossume59214e1994-08-30 08:01:59 +0000326#ifdef WITH_THREAD
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000327 if (interpreter_lock) {
Guido van Rossumb74eca91997-09-30 22:03:16 +0000328 int err = errno;
Guido van Rossum65d5b571998-12-21 19:32:43 +0000329 PyThread_acquire_lock(interpreter_lock, 1);
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000330 errno = err;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000331 }
332#endif
Guido van Rossumb74eca91997-09-30 22:03:16 +0000333 PyThreadState_Swap(tstate);
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000334}
335
336
Guido van Rossuma9672091994-09-14 13:31:22 +0000337/* Mechanism whereby asynchronously executing callbacks (e.g. UNIX
338 signal handlers or Mac I/O completion routines) can schedule calls
339 to a function to be called synchronously.
340 The synchronous function is called with one void* argument.
341 It should return 0 for success or -1 for failure -- failure should
342 be accompanied by an exception.
343
344 If registry succeeds, the registry function returns 0; if it fails
345 (e.g. due to too many pending calls) it returns -1 (without setting
346 an exception condition).
347
348 Note that because registry may occur from within signal handlers,
349 or other asynchronous events, calling malloc() is unsafe!
350
351#ifdef WITH_THREAD
352 Any thread can schedule pending calls, but only the main thread
353 will execute them.
354#endif
355
356 XXX WARNING! ASYNCHRONOUSLY EXECUTING CODE!
357 There are two possible race conditions:
358 (1) nested asynchronous registry calls;
359 (2) registry calls made while pending calls are being processed.
360 While (1) is very unlikely, (2) is a real possibility.
361 The current code is safe against (2), but not against (1).
362 The safety against (2) is derived from the fact that only one
363 thread (the main thread) ever takes things out of the queue.
Guido van Rossuma9672091994-09-14 13:31:22 +0000364
Guido van Rossuma027efa1997-05-05 20:56:21 +0000365 XXX Darn! With the advent of thread state, we should have an array
366 of pending calls per thread in the thread state! Later...
367*/
Guido van Rossum8861b741996-07-30 16:49:37 +0000368
Guido van Rossuma9672091994-09-14 13:31:22 +0000369#define NPENDINGCALLS 32
370static struct {
Thomas Wouters334fb892000-07-25 12:56:38 +0000371 int (*func)(void *);
372 void *arg;
Guido van Rossuma9672091994-09-14 13:31:22 +0000373} pendingcalls[NPENDINGCALLS];
374static volatile int pendingfirst = 0;
375static volatile int pendinglast = 0;
Guido van Rossuma027efa1997-05-05 20:56:21 +0000376static volatile int things_to_do = 0;
Guido van Rossuma9672091994-09-14 13:31:22 +0000377
378int
Thomas Wouters334fb892000-07-25 12:56:38 +0000379Py_AddPendingCall(int (*func)(void *), void *arg)
Guido van Rossuma9672091994-09-14 13:31:22 +0000380{
Guido van Rossum180d7b41994-09-29 09:45:57 +0000381 static int busy = 0;
Guido van Rossuma9672091994-09-14 13:31:22 +0000382 int i, j;
383 /* XXX Begin critical section */
384 /* XXX If you want this to be safe against nested
385 XXX asynchronous calls, you'll have to work harder! */
Guido van Rossum180d7b41994-09-29 09:45:57 +0000386 if (busy)
387 return -1;
388 busy = 1;
Guido van Rossuma9672091994-09-14 13:31:22 +0000389 i = pendinglast;
390 j = (i + 1) % NPENDINGCALLS;
Guido van Rossum04e70322002-07-17 16:57:13 +0000391 if (j == pendingfirst) {
392 busy = 0;
Guido van Rossuma9672091994-09-14 13:31:22 +0000393 return -1; /* Queue full */
Guido van Rossum04e70322002-07-17 16:57:13 +0000394 }
Guido van Rossuma9672091994-09-14 13:31:22 +0000395 pendingcalls[i].func = func;
396 pendingcalls[i].arg = arg;
397 pendinglast = j;
Guido van Rossuma027efa1997-05-05 20:56:21 +0000398 things_to_do = 1; /* Signal main loop */
Guido van Rossum180d7b41994-09-29 09:45:57 +0000399 busy = 0;
Guido van Rossuma9672091994-09-14 13:31:22 +0000400 /* XXX End critical section */
401 return 0;
402}
403
Guido van Rossum180d7b41994-09-29 09:45:57 +0000404int
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000405Py_MakePendingCalls(void)
Guido van Rossuma9672091994-09-14 13:31:22 +0000406{
Guido van Rossum180d7b41994-09-29 09:45:57 +0000407 static int busy = 0;
Guido van Rossuma9672091994-09-14 13:31:22 +0000408#ifdef WITH_THREAD
Guido van Rossum65d5b571998-12-21 19:32:43 +0000409 if (main_thread && PyThread_get_thread_ident() != main_thread)
Guido van Rossuma9672091994-09-14 13:31:22 +0000410 return 0;
411#endif
Guido van Rossuma027efa1997-05-05 20:56:21 +0000412 if (busy)
Guido van Rossum180d7b41994-09-29 09:45:57 +0000413 return 0;
414 busy = 1;
Guido van Rossuma027efa1997-05-05 20:56:21 +0000415 things_to_do = 0;
Guido van Rossuma9672091994-09-14 13:31:22 +0000416 for (;;) {
417 int i;
Thomas Wouters334fb892000-07-25 12:56:38 +0000418 int (*func)(void *);
419 void *arg;
Guido van Rossuma9672091994-09-14 13:31:22 +0000420 i = pendingfirst;
421 if (i == pendinglast)
422 break; /* Queue empty */
423 func = pendingcalls[i].func;
424 arg = pendingcalls[i].arg;
425 pendingfirst = (i + 1) % NPENDINGCALLS;
Guido van Rossum180d7b41994-09-29 09:45:57 +0000426 if (func(arg) < 0) {
427 busy = 0;
Guido van Rossuma027efa1997-05-05 20:56:21 +0000428 things_to_do = 1; /* We're not done yet */
Guido van Rossuma9672091994-09-14 13:31:22 +0000429 return -1;
Guido van Rossum180d7b41994-09-29 09:45:57 +0000430 }
Guido van Rossuma9672091994-09-14 13:31:22 +0000431 }
Guido van Rossum180d7b41994-09-29 09:45:57 +0000432 busy = 0;
Guido van Rossuma9672091994-09-14 13:31:22 +0000433 return 0;
434}
435
436
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000437/* The interpreter's recursion limit */
438
Guido van Rossum349ff6f2000-09-01 01:52:08 +0000439static int recursion_limit = 1000;
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000440
Vladimir Marangozov7bd25be2000-09-01 11:07:19 +0000441int
442Py_GetRecursionLimit(void)
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000443{
444 return recursion_limit;
445}
446
Vladimir Marangozov7bd25be2000-09-01 11:07:19 +0000447void
448Py_SetRecursionLimit(int new_limit)
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000449{
450 recursion_limit = new_limit;
451}
452
Guido van Rossum374a9221991-04-04 10:40:29 +0000453/* Status code for main loop (reason for stack unwind) */
454
455enum why_code {
456 WHY_NOT, /* No error */
457 WHY_EXCEPTION, /* Exception occurred */
458 WHY_RERAISE, /* Exception re-raised by 'finally' */
459 WHY_RETURN, /* 'return' statement */
Jeremy Hylton3faa52e2001-02-01 22:48:12 +0000460 WHY_BREAK, /* 'break' statement */
Tim Peters5ca576e2001-06-18 22:08:13 +0000461 WHY_CONTINUE, /* 'continue' statement */
Tim Peters6e6a63f2001-10-18 20:49:35 +0000462 WHY_YIELD /* 'yield' operator */
Guido van Rossum374a9221991-04-04 10:40:29 +0000463};
464
Tim Petersdbd9ba62000-07-09 03:09:57 +0000465static enum why_code do_raise(PyObject *, PyObject *, PyObject *);
Tim Petersd6d010b2001-06-21 02:49:55 +0000466static int unpack_iterable(PyObject *, int, PyObject **);
Guido van Rossum1aa14831997-01-21 05:34:20 +0000467
Guido van Rossum374a9221991-04-04 10:40:29 +0000468
Guido van Rossumb209a111997-04-29 18:18:01 +0000469PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000470PyEval_EvalCode(PyCodeObject *co, PyObject *globals, PyObject *locals)
Guido van Rossum681d79a1995-07-18 14:51:37 +0000471{
Tim Peters6d6c1a32001-08-02 04:15:00 +0000472 return PyEval_EvalCodeEx(co,
Guido van Rossum681d79a1995-07-18 14:51:37 +0000473 globals, locals,
Guido van Rossumb209a111997-04-29 18:18:01 +0000474 (PyObject **)NULL, 0,
475 (PyObject **)NULL, 0,
Jeremy Hylton64949cb2001-01-25 20:06:59 +0000476 (PyObject **)NULL, 0,
477 NULL);
Guido van Rossum681d79a1995-07-18 14:51:37 +0000478}
479
480
481/* Interpreter main loop */
482
Tim Peters6d6c1a32001-08-02 04:15:00 +0000483static PyObject *
Tim Peters5ca576e2001-06-18 22:08:13 +0000484eval_frame(PyFrameObject *f)
Guido van Rossum374a9221991-04-04 10:40:29 +0000485{
Guido van Rossum950361c1997-01-24 13:49:28 +0000486#ifdef DXPAIRS
487 int lastopcode = 0;
488#endif
Tim Petersb6d14da2001-12-19 04:11:07 +0000489 PyObject **stack_pointer; /* Next free slot in value stack */
Guido van Rossum374a9221991-04-04 10:40:29 +0000490 register unsigned char *next_instr;
Moshe Zadkaaa39a7e2000-08-07 06:34:45 +0000491 register int opcode=0; /* Current opcode */
492 register int oparg=0; /* Current opcode argument, if any */
Guido van Rossum374a9221991-04-04 10:40:29 +0000493 register enum why_code why; /* Reason for block stack unwind */
494 register int err; /* Error status -- nonzero if error */
Guido van Rossumb209a111997-04-29 18:18:01 +0000495 register PyObject *x; /* Result object -- NULL if error */
496 register PyObject *v; /* Temporary objects popped off stack */
497 register PyObject *w;
498 register PyObject *u;
499 register PyObject *t;
Barry Warsaw23c9ec82000-08-21 15:44:01 +0000500 register PyObject *stream = NULL; /* for PRINT opcodes */
Jeremy Hylton2b724da2001-01-29 22:51:52 +0000501 register PyObject **fastlocals, **freevars;
Guido van Rossum014518f1998-11-23 21:09:51 +0000502 PyObject *retval = NULL; /* Return value */
Guido van Rossum885553e1998-12-21 18:33:30 +0000503 PyThreadState *tstate = PyThreadState_GET();
Tim Peters5ca576e2001-06-18 22:08:13 +0000504 PyCodeObject *co;
Michael W. Hudsondd32a912002-08-15 14:59:02 +0000505
506 /* when tracing we set things up so that
507
508 not (instr_lb <= current_bytecode_offset < instr_ub)
509
510 is true when the line being executed has changed. The
511 initial values are such as to make this false the first
512 time it is tested. */
513 int instr_ub = -1, instr_lb = 0;
514
Guido van Rossumd076c731998-10-07 19:42:25 +0000515 unsigned char *first_instr;
Skip Montanaro04d80f82002-08-04 21:03:35 +0000516 PyObject *names;
517 PyObject *consts;
Guido van Rossum96a42c81992-01-12 02:29:51 +0000518#ifdef LLTRACE
Guido van Rossumacbe8da1993-04-15 15:33:52 +0000519 int lltrace;
Guido van Rossum374a9221991-04-04 10:40:29 +0000520#endif
Guido van Rossum408027e1996-12-30 16:17:54 +0000521#if defined(Py_DEBUG) || defined(LLTRACE)
Guido van Rossum681d79a1995-07-18 14:51:37 +0000522 /* Make it easier to find out where we are with a debugger */
Tim Peters5ca576e2001-06-18 22:08:13 +0000523 char *filename;
Guido van Rossum99bec951992-09-03 20:29:45 +0000524#endif
Guido van Rossum374a9221991-04-04 10:40:29 +0000525
Neal Norwitza81d2202002-07-14 00:27:26 +0000526/* Tuple access macros */
527
528#ifndef Py_DEBUG
529#define GETITEM(v, i) PyTuple_GET_ITEM((PyTupleObject *)(v), (i))
530#else
531#define GETITEM(v, i) PyTuple_GetItem((v), (i))
532#endif
533
Guido van Rossum374a9221991-04-04 10:40:29 +0000534/* Code access macros */
535
Guido van Rossumd076c731998-10-07 19:42:25 +0000536#define INSTR_OFFSET() (next_instr - first_instr)
Guido van Rossum374a9221991-04-04 10:40:29 +0000537#define NEXTOP() (*next_instr++)
538#define NEXTARG() (next_instr += 2, (next_instr[-1]<<8) + next_instr[-2])
Guido van Rossumd076c731998-10-07 19:42:25 +0000539#define JUMPTO(x) (next_instr = first_instr + (x))
Guido van Rossum374a9221991-04-04 10:40:29 +0000540#define JUMPBY(x) (next_instr += (x))
541
542/* Stack manipulation macros */
543
544#define STACK_LEVEL() (stack_pointer - f->f_valuestack)
545#define EMPTY() (STACK_LEVEL() == 0)
546#define TOP() (stack_pointer[-1])
547#define BASIC_PUSH(v) (*stack_pointer++ = (v))
548#define BASIC_POP() (*--stack_pointer)
549
Guido van Rossum96a42c81992-01-12 02:29:51 +0000550#ifdef LLTRACE
Jeremy Hylton14368152001-10-17 13:29:30 +0000551#define PUSH(v) { (void)(BASIC_PUSH(v), \
552 lltrace && prtrace(TOP(), "push")); \
553 assert(STACK_LEVEL() <= f->f_stacksize); }
Fred Drakede26cfc2001-10-13 06:11:28 +0000554#define POP() ((void)(lltrace && prtrace(TOP(), "pop")), BASIC_POP())
Guido van Rossum374a9221991-04-04 10:40:29 +0000555#else
556#define PUSH(v) BASIC_PUSH(v)
557#define POP() BASIC_POP()
558#endif
559
Guido van Rossum681d79a1995-07-18 14:51:37 +0000560/* Local variable macros */
561
562#define GETLOCAL(i) (fastlocals[i])
Guido van Rossumcfbf1a32002-03-28 20:17:52 +0000563
564/* The SETLOCAL() macro must not DECREF the local variable in-place and
565 then store the new value; it must copy the old value to a temporary
566 value, then store the new value, and then DECREF the temporary value.
567 This is because it is possible that during the DECREF the frame is
568 accessed by other code (e.g. a __del__ method or gc.collect()) and the
569 variable would be pointing to already-freed memory. */
570#define SETLOCAL(i, value) do { PyObject *tmp = GETLOCAL(i); \
571 GETLOCAL(i) = value; \
572 Py_XDECREF(tmp); } while (0)
Guido van Rossum681d79a1995-07-18 14:51:37 +0000573
Guido van Rossuma027efa1997-05-05 20:56:21 +0000574/* Start of code */
575
Tim Peters5ca576e2001-06-18 22:08:13 +0000576 if (f == NULL)
577 return NULL;
578
Guido van Rossum8861b741996-07-30 16:49:37 +0000579#ifdef USE_STACKCHECK
Guido van Rossuma027efa1997-05-05 20:56:21 +0000580 if (tstate->recursion_depth%10 == 0 && PyOS_CheckStack()) {
Guido van Rossumb209a111997-04-29 18:18:01 +0000581 PyErr_SetString(PyExc_MemoryError, "Stack overflow");
Guido van Rossum8861b741996-07-30 16:49:37 +0000582 return NULL;
583 }
584#endif
585
Tim Peters5ca576e2001-06-18 22:08:13 +0000586 /* push frame */
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000587 if (++tstate->recursion_depth > recursion_limit) {
Guido van Rossuma027efa1997-05-05 20:56:21 +0000588 --tstate->recursion_depth;
589 PyErr_SetString(PyExc_RuntimeError,
Fred Drake661ea262000-10-24 19:57:45 +0000590 "maximum recursion depth exceeded");
Guido van Rossuma027efa1997-05-05 20:56:21 +0000591 tstate->frame = f->f_back;
Guido van Rossum8861b741996-07-30 16:49:37 +0000592 return NULL;
593 }
594
Tim Peters5ca576e2001-06-18 22:08:13 +0000595 tstate->frame = f;
Tim Peters5ca576e2001-06-18 22:08:13 +0000596 co = f->f_code;
Skip Montanaro04d80f82002-08-04 21:03:35 +0000597 names = co->co_names;
598 consts = co->co_consts;
Tim Peters5ca576e2001-06-18 22:08:13 +0000599 fastlocals = f->f_localsplus;
600 freevars = f->f_localsplus + f->f_nlocals;
Guido van Rossumd076c731998-10-07 19:42:25 +0000601 _PyCode_GETCODEPTR(co, &first_instr);
Michael W. Hudsondd32a912002-08-15 14:59:02 +0000602 if (f->f_lasti < 0) {
603 next_instr = first_instr;
604 }
605 else {
606 next_instr = first_instr + f->f_lasti;
607 }
Tim Peters8c963692001-06-23 05:26:56 +0000608 stack_pointer = f->f_stacktop;
609 assert(stack_pointer != NULL);
Tim Petersb6d14da2001-12-19 04:11:07 +0000610 f->f_stacktop = NULL; /* remains NULL unless yield suspends frame */
Tim Peters5ca576e2001-06-18 22:08:13 +0000611
Neil Schemenauer6c0f2002001-09-04 19:03:35 +0000612 if (tstate->use_tracing) {
613 if (tstate->c_tracefunc != NULL) {
614 /* tstate->c_tracefunc, if defined, is a
615 function that will be called on *every* entry
616 to a code block. Its return value, if not
617 None, is a function that will be called at
618 the start of each executed line of code.
619 (Actually, the function must return itself
620 in order to continue tracing.) The trace
621 functions are called with three arguments:
622 a pointer to the current frame, a string
623 indicating why the function is called, and
624 an argument which depends on the situation.
625 The global trace function is also called
626 whenever an exception is detected. */
627 if (call_trace(tstate->c_tracefunc, tstate->c_traceobj,
628 f, PyTrace_CALL, Py_None)) {
Neil Schemenauer6c0f2002001-09-04 19:03:35 +0000629 /* Trace function raised an error */
630 return NULL;
631 }
632 }
633 if (tstate->c_profilefunc != NULL) {
634 /* Similar for c_profilefunc, except it needn't
635 return itself and isn't called for "line" events */
636 if (call_trace(tstate->c_profilefunc,
637 tstate->c_profileobj,
638 f, PyTrace_CALL, Py_None)) {
Neil Schemenauer6c0f2002001-09-04 19:03:35 +0000639 /* Profile function raised an error */
640 return NULL;
641 }
642 }
643 }
644
Tim Peters5ca576e2001-06-18 22:08:13 +0000645#ifdef LLTRACE
646 lltrace = PyDict_GetItemString(f->f_globals,"__lltrace__") != NULL;
647#endif
648#if defined(Py_DEBUG) || defined(LLTRACE)
649 filename = PyString_AsString(co->co_filename);
650#endif
Guido van Rossumac7be682001-01-17 15:42:30 +0000651
Guido van Rossum374a9221991-04-04 10:40:29 +0000652 why = WHY_NOT;
653 err = 0;
Guido van Rossumb209a111997-04-29 18:18:01 +0000654 x = Py_None; /* Not a reference, just anything non-NULL */
Fred Drake48fba732000-10-11 13:54:07 +0000655 w = NULL;
Guido van Rossumac7be682001-01-17 15:42:30 +0000656
Guido van Rossum374a9221991-04-04 10:40:29 +0000657 for (;;) {
Michael W. Hudsondd32a912002-08-15 14:59:02 +0000658 assert(stack_pointer >= f->f_valuestack); /* else underflow */
659 assert(STACK_LEVEL() <= f->f_stacksize); /* else overflow */
660
Guido van Rossuma027efa1997-05-05 20:56:21 +0000661 /* Do periodic things. Doing this every time through
662 the loop would add too much overhead, so we do it
663 only every Nth instruction. We also do it if
664 ``things_to_do'' is set, i.e. when an asynchronous
665 event needs attention (e.g. a signal handler or
666 async I/O handler); see Py_AddPendingCall() and
667 Py_MakePendingCalls() above. */
Guido van Rossumac7be682001-01-17 15:42:30 +0000668
Guido van Rossuma027efa1997-05-05 20:56:21 +0000669 if (things_to_do || --tstate->ticker < 0) {
Guido van Rossum25ce5661997-08-02 03:10:38 +0000670 tstate->ticker = tstate->interp->checkinterval;
Guido van Rossuma027efa1997-05-05 20:56:21 +0000671 if (things_to_do) {
Guido van Rossum8861b741996-07-30 16:49:37 +0000672 if (Py_MakePendingCalls() < 0) {
673 why = WHY_EXCEPTION;
674 goto on_error;
675 }
676 }
Guido van Rossumdf0d00e1997-05-20 15:57:49 +0000677#if !defined(HAVE_SIGNAL_H) || defined(macintosh)
Guido van Rossuma027efa1997-05-05 20:56:21 +0000678 /* If we have true signals, the signal handler
679 will call Py_AddPendingCall() so we don't
Michael W. Hudsondd32a912002-08-15 14:59:02 +0000680 have to call PyErr_CheckSignals(). On the
681 Mac and DOS, alas, we have to call it. */
Guido van Rossumb209a111997-04-29 18:18:01 +0000682 if (PyErr_CheckSignals()) {
Guido van Rossum374a9221991-04-04 10:40:29 +0000683 why = WHY_EXCEPTION;
Guido van Rossum374a9221991-04-04 10:40:29 +0000684 goto on_error;
685 }
Guido van Rossum70d44781997-01-21 06:15:24 +0000686#endif
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000687
Guido van Rossume59214e1994-08-30 08:01:59 +0000688#ifdef WITH_THREAD
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000689 if (interpreter_lock) {
690 /* Give another thread a chance */
691
Guido van Rossum25ce5661997-08-02 03:10:38 +0000692 if (PyThreadState_Swap(NULL) != tstate)
693 Py_FatalError("ceval: tstate mix-up");
Guido van Rossum65d5b571998-12-21 19:32:43 +0000694 PyThread_release_lock(interpreter_lock);
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000695
696 /* Other threads may run now */
697
Guido van Rossum65d5b571998-12-21 19:32:43 +0000698 PyThread_acquire_lock(interpreter_lock, 1);
Guido van Rossum25ce5661997-08-02 03:10:38 +0000699 if (PyThreadState_Swap(tstate) != NULL)
700 Py_FatalError("ceval: orphan tstate");
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000701 }
702#endif
Guido van Rossum374a9221991-04-04 10:40:29 +0000703 }
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000704
Neil Schemenauer63543862002-02-17 19:10:14 +0000705 fast_next_opcode:
Guido van Rossum374a9221991-04-04 10:40:29 +0000706 /* Extract opcode and argument */
Guido van Rossum99bec951992-09-03 20:29:45 +0000707
Guido van Rossum99bec951992-09-03 20:29:45 +0000708 f->f_lasti = INSTR_OFFSET();
Guido van Rossumac7be682001-01-17 15:42:30 +0000709
Guido van Rossum374a9221991-04-04 10:40:29 +0000710 opcode = NEXTOP();
711 if (HAS_ARG(opcode))
712 oparg = NEXTARG();
Fred Drakeef8ace32000-08-24 00:32:09 +0000713 dispatch_opcode:
Guido van Rossum950361c1997-01-24 13:49:28 +0000714#ifdef DYNAMIC_EXECUTION_PROFILE
715#ifdef DXPAIRS
716 dxpairs[lastopcode][opcode]++;
717 lastopcode = opcode;
718#endif
719 dxp[opcode]++;
720#endif
Guido van Rossum374a9221991-04-04 10:40:29 +0000721
Guido van Rossum96a42c81992-01-12 02:29:51 +0000722#ifdef LLTRACE
Guido van Rossum374a9221991-04-04 10:40:29 +0000723 /* Instruction tracing */
Guido van Rossumac7be682001-01-17 15:42:30 +0000724
Guido van Rossum96a42c81992-01-12 02:29:51 +0000725 if (lltrace) {
Guido van Rossum374a9221991-04-04 10:40:29 +0000726 if (HAS_ARG(opcode)) {
727 printf("%d: %d, %d\n",
Michael W. Hudsondd32a912002-08-15 14:59:02 +0000728 f->f_lasti, opcode, oparg);
Guido van Rossum374a9221991-04-04 10:40:29 +0000729 }
730 else {
731 printf("%d: %d\n",
Michael W. Hudsondd32a912002-08-15 14:59:02 +0000732 f->f_lasti, opcode);
Guido van Rossum374a9221991-04-04 10:40:29 +0000733 }
734 }
735#endif
Michael W. Hudsondd32a912002-08-15 14:59:02 +0000736
737 /* line-by-line tracing support */
738
739 if (tstate->c_tracefunc != NULL && !tstate->tracing) {
740 /* see maybe_call_line_trace
741 for expository comments */
742 maybe_call_line_trace(opcode,
743 tstate->c_tracefunc,
744 tstate->c_traceobj,
745 f, &instr_lb, &instr_ub);
746 }
747
Guido van Rossum374a9221991-04-04 10:40:29 +0000748 /* Main switch on opcode */
Jeremy Hylton52820442001-01-03 23:52:36 +0000749
Guido van Rossum374a9221991-04-04 10:40:29 +0000750 switch (opcode) {
Guido van Rossumac7be682001-01-17 15:42:30 +0000751
Guido van Rossum374a9221991-04-04 10:40:29 +0000752 /* BEWARE!
753 It is essential that any operation that fails sets either
754 x to NULL, err to nonzero, or why to anything but WHY_NOT,
755 and that no operation that succeeds does this! */
Guido van Rossumac7be682001-01-17 15:42:30 +0000756
Guido van Rossum374a9221991-04-04 10:40:29 +0000757 /* case STOP_CODE: this is an error! */
Guido van Rossumac7be682001-01-17 15:42:30 +0000758
Neil Schemenauer63543862002-02-17 19:10:14 +0000759 case LOAD_FAST:
760 x = GETLOCAL(oparg);
761 if (x != NULL) {
762 Py_INCREF(x);
763 PUSH(x);
764 goto fast_next_opcode;
765 }
766 format_exc_check_arg(PyExc_UnboundLocalError,
767 UNBOUNDLOCAL_ERROR_MSG,
768 PyTuple_GetItem(co->co_varnames, oparg));
769 break;
770
771 case LOAD_CONST:
Skip Montanaro04d80f82002-08-04 21:03:35 +0000772 x = GETITEM(consts, oparg);
Neil Schemenauer63543862002-02-17 19:10:14 +0000773 Py_INCREF(x);
774 PUSH(x);
775 goto fast_next_opcode;
776
777 case STORE_FAST:
778 v = POP();
779 SETLOCAL(oparg, v);
780 goto fast_next_opcode;
781
Guido van Rossum374a9221991-04-04 10:40:29 +0000782 case POP_TOP:
783 v = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +0000784 Py_DECREF(v);
Neil Schemenauer63543862002-02-17 19:10:14 +0000785 goto fast_next_opcode;
Guido van Rossumac7be682001-01-17 15:42:30 +0000786
Guido van Rossum374a9221991-04-04 10:40:29 +0000787 case ROT_TWO:
788 v = POP();
789 w = POP();
790 PUSH(v);
791 PUSH(w);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000792 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +0000793
Guido van Rossum374a9221991-04-04 10:40:29 +0000794 case ROT_THREE:
795 v = POP();
796 w = POP();
797 x = POP();
798 PUSH(v);
799 PUSH(x);
800 PUSH(w);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000801 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +0000802
Thomas Wouters434d0822000-08-24 20:11:32 +0000803 case ROT_FOUR:
804 u = POP();
805 v = POP();
806 w = POP();
807 x = POP();
808 PUSH(u);
809 PUSH(x);
810 PUSH(w);
811 PUSH(v);
812 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +0000813
Guido van Rossum374a9221991-04-04 10:40:29 +0000814 case DUP_TOP:
815 v = TOP();
Guido van Rossumb209a111997-04-29 18:18:01 +0000816 Py_INCREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +0000817 PUSH(v);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000818 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +0000819
Thomas Wouters434d0822000-08-24 20:11:32 +0000820 case DUP_TOPX:
821 switch (oparg) {
Thomas Wouters434d0822000-08-24 20:11:32 +0000822 case 1:
Tim Peters35ba6892000-10-11 07:04:49 +0000823 x = TOP();
824 Py_INCREF(x);
825 PUSH(x);
826 continue;
827 case 2:
Thomas Wouters434d0822000-08-24 20:11:32 +0000828 x = POP();
Tim Peters35ba6892000-10-11 07:04:49 +0000829 Py_INCREF(x);
830 w = TOP();
831 Py_INCREF(w);
832 PUSH(x);
833 PUSH(w);
834 PUSH(x);
835 continue;
836 case 3:
837 x = POP();
838 Py_INCREF(x);
Thomas Wouters434d0822000-08-24 20:11:32 +0000839 w = POP();
Tim Peters35ba6892000-10-11 07:04:49 +0000840 Py_INCREF(w);
841 v = TOP();
842 Py_INCREF(v);
843 PUSH(w);
844 PUSH(x);
845 PUSH(v);
846 PUSH(w);
847 PUSH(x);
848 continue;
849 case 4:
850 x = POP();
851 Py_INCREF(x);
852 w = POP();
853 Py_INCREF(w);
Thomas Wouters434d0822000-08-24 20:11:32 +0000854 v = POP();
Tim Peters35ba6892000-10-11 07:04:49 +0000855 Py_INCREF(v);
856 u = TOP();
857 Py_INCREF(u);
858 PUSH(v);
859 PUSH(w);
860 PUSH(x);
861 PUSH(u);
862 PUSH(v);
863 PUSH(w);
864 PUSH(x);
865 continue;
866 case 5:
867 x = POP();
868 Py_INCREF(x);
869 w = POP();
870 Py_INCREF(w);
871 v = POP();
872 Py_INCREF(v);
Thomas Wouters434d0822000-08-24 20:11:32 +0000873 u = POP();
Tim Peters35ba6892000-10-11 07:04:49 +0000874 Py_INCREF(u);
875 t = TOP();
876 Py_INCREF(t);
877 PUSH(u);
878 PUSH(v);
879 PUSH(w);
880 PUSH(x);
881 PUSH(t);
882 PUSH(u);
883 PUSH(v);
884 PUSH(w);
885 PUSH(x);
886 continue;
Thomas Wouters434d0822000-08-24 20:11:32 +0000887 default:
Thomas Wouters0be483f2000-10-11 23:26:11 +0000888 Py_FatalError("invalid argument to DUP_TOPX"
889 " (bytecode corruption?)");
Thomas Wouters434d0822000-08-24 20:11:32 +0000890 }
Tim Peters35ba6892000-10-11 07:04:49 +0000891 break;
Thomas Wouters434d0822000-08-24 20:11:32 +0000892
Guido van Rossum374a9221991-04-04 10:40:29 +0000893 case UNARY_POSITIVE:
894 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +0000895 x = PyNumber_Positive(v);
Guido van Rossumb209a111997-04-29 18:18:01 +0000896 Py_DECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +0000897 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000898 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +0000899 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000900
Guido van Rossum374a9221991-04-04 10:40:29 +0000901 case UNARY_NEGATIVE:
902 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +0000903 x = PyNumber_Negative(v);
Guido van Rossumb209a111997-04-29 18:18:01 +0000904 Py_DECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +0000905 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000906 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +0000907 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000908
Guido van Rossum374a9221991-04-04 10:40:29 +0000909 case UNARY_NOT:
910 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +0000911 err = PyObject_IsTrue(v);
Guido van Rossumb209a111997-04-29 18:18:01 +0000912 Py_DECREF(v);
Guido van Rossumfc490731997-05-06 15:06:49 +0000913 if (err == 0) {
914 Py_INCREF(Py_True);
915 PUSH(Py_True);
916 continue;
917 }
918 else if (err > 0) {
919 Py_INCREF(Py_False);
920 PUSH(Py_False);
921 err = 0;
922 continue;
923 }
Guido van Rossum374a9221991-04-04 10:40:29 +0000924 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000925
Guido van Rossum374a9221991-04-04 10:40:29 +0000926 case UNARY_CONVERT:
927 v = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +0000928 x = PyObject_Repr(v);
929 Py_DECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +0000930 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000931 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +0000932 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000933
Guido van Rossum7928cd71991-10-24 14:59:31 +0000934 case UNARY_INVERT:
935 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +0000936 x = PyNumber_Invert(v);
Guido van Rossumb209a111997-04-29 18:18:01 +0000937 Py_DECREF(v);
Guido van Rossum7928cd71991-10-24 14:59:31 +0000938 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000939 if (x != NULL) continue;
Guido van Rossum7928cd71991-10-24 14:59:31 +0000940 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000941
Guido van Rossum50564e81996-01-12 01:13:16 +0000942 case BINARY_POWER:
943 w = POP();
944 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +0000945 x = PyNumber_Power(v, w, Py_None);
Guido van Rossumb209a111997-04-29 18:18:01 +0000946 Py_DECREF(v);
947 Py_DECREF(w);
Guido van Rossum50564e81996-01-12 01:13:16 +0000948 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000949 if (x != NULL) continue;
Guido van Rossum50564e81996-01-12 01:13:16 +0000950 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000951
Guido van Rossum374a9221991-04-04 10:40:29 +0000952 case BINARY_MULTIPLY:
953 w = POP();
954 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +0000955 x = PyNumber_Multiply(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +0000956 Py_DECREF(v);
957 Py_DECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +0000958 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000959 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +0000960 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000961
Guido van Rossum374a9221991-04-04 10:40:29 +0000962 case BINARY_DIVIDE:
Tim Peters3caca232001-12-06 06:23:26 +0000963 if (!_Py_QnewFlag) {
964 w = POP();
965 v = POP();
966 x = PyNumber_Divide(v, w);
967 Py_DECREF(v);
968 Py_DECREF(w);
969 PUSH(x);
970 if (x != NULL) continue;
971 break;
972 }
973 /* -Qnew is in effect: fall through to
974 BINARY_TRUE_DIVIDE */
975 case BINARY_TRUE_DIVIDE:
Guido van Rossum374a9221991-04-04 10:40:29 +0000976 w = POP();
977 v = POP();
Tim Peters3caca232001-12-06 06:23:26 +0000978 x = PyNumber_TrueDivide(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +0000979 Py_DECREF(v);
980 Py_DECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +0000981 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000982 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +0000983 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000984
Guido van Rossum4668b002001-08-08 05:00:18 +0000985 case BINARY_FLOOR_DIVIDE:
986 w = POP();
987 v = POP();
988 x = PyNumber_FloorDivide(v, w);
989 Py_DECREF(v);
990 Py_DECREF(w);
991 PUSH(x);
992 if (x != NULL) continue;
993 break;
994
Guido van Rossum374a9221991-04-04 10:40:29 +0000995 case BINARY_MODULO:
996 w = POP();
997 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +0000998 x = PyNumber_Remainder(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +0000999 Py_DECREF(v);
1000 Py_DECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001001 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001002 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001003 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001004
Guido van Rossum374a9221991-04-04 10:40:29 +00001005 case BINARY_ADD:
1006 w = POP();
1007 v = POP();
Tim Petersc1e6d962001-10-05 20:21:03 +00001008 if (PyInt_CheckExact(v) && PyInt_CheckExact(w)) {
Guido van Rossumc12da691997-07-17 23:12:42 +00001009 /* INLINE: int + int */
1010 register long a, b, i;
Guido van Rossumcf183ac1998-12-04 18:51:36 +00001011 a = PyInt_AS_LONG(v);
1012 b = PyInt_AS_LONG(w);
Guido van Rossumc12da691997-07-17 23:12:42 +00001013 i = a + b;
Guido van Rossum87780df2001-08-23 02:58:07 +00001014 if ((i^a) < 0 && (i^b) < 0)
1015 goto slow_add;
1016 x = PyInt_FromLong(i);
Guido van Rossumc12da691997-07-17 23:12:42 +00001017 }
Guido van Rossum87780df2001-08-23 02:58:07 +00001018 else {
1019 slow_add:
Guido van Rossumc12da691997-07-17 23:12:42 +00001020 x = PyNumber_Add(v, w);
Guido van Rossum87780df2001-08-23 02:58:07 +00001021 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001022 Py_DECREF(v);
1023 Py_DECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001024 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001025 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001026 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001027
Guido van Rossum374a9221991-04-04 10:40:29 +00001028 case BINARY_SUBTRACT:
1029 w = POP();
1030 v = POP();
Tim Petersc1e6d962001-10-05 20:21:03 +00001031 if (PyInt_CheckExact(v) && PyInt_CheckExact(w)) {
Guido van Rossumc12da691997-07-17 23:12:42 +00001032 /* INLINE: int - int */
1033 register long a, b, i;
Guido van Rossumcf183ac1998-12-04 18:51:36 +00001034 a = PyInt_AS_LONG(v);
1035 b = PyInt_AS_LONG(w);
Guido van Rossumc12da691997-07-17 23:12:42 +00001036 i = a - b;
Guido van Rossum87780df2001-08-23 02:58:07 +00001037 if ((i^a) < 0 && (i^~b) < 0)
1038 goto slow_sub;
1039 x = PyInt_FromLong(i);
Guido van Rossumc12da691997-07-17 23:12:42 +00001040 }
Guido van Rossum87780df2001-08-23 02:58:07 +00001041 else {
1042 slow_sub:
Guido van Rossumc12da691997-07-17 23:12:42 +00001043 x = PyNumber_Subtract(v, w);
Guido van Rossum87780df2001-08-23 02:58:07 +00001044 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001045 Py_DECREF(v);
1046 Py_DECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001047 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001048 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001049 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001050
Guido van Rossum374a9221991-04-04 10:40:29 +00001051 case BINARY_SUBSCR:
1052 w = POP();
1053 v = POP();
Tim Petersb1c46982001-10-05 20:41:38 +00001054 if (PyList_CheckExact(v) && PyInt_CheckExact(w)) {
Guido van Rossumc12da691997-07-17 23:12:42 +00001055 /* INLINE: list[int] */
1056 long i = PyInt_AsLong(w);
1057 if (i < 0)
Guido van Rossumfa00e951998-07-08 15:02:37 +00001058 i += PyList_GET_SIZE(v);
Guido van Rossumc12da691997-07-17 23:12:42 +00001059 if (i < 0 ||
Guido van Rossumfa00e951998-07-08 15:02:37 +00001060 i >= PyList_GET_SIZE(v)) {
Guido van Rossumc12da691997-07-17 23:12:42 +00001061 PyErr_SetString(PyExc_IndexError,
1062 "list index out of range");
1063 x = NULL;
1064 }
1065 else {
Guido van Rossumfa00e951998-07-08 15:02:37 +00001066 x = PyList_GET_ITEM(v, i);
Guido van Rossumc12da691997-07-17 23:12:42 +00001067 Py_INCREF(x);
1068 }
1069 }
1070 else
1071 x = PyObject_GetItem(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00001072 Py_DECREF(v);
1073 Py_DECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001074 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001075 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001076 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001077
Guido van Rossum7928cd71991-10-24 14:59:31 +00001078 case BINARY_LSHIFT:
1079 w = POP();
1080 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +00001081 x = PyNumber_Lshift(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00001082 Py_DECREF(v);
1083 Py_DECREF(w);
Guido van Rossum7928cd71991-10-24 14:59:31 +00001084 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001085 if (x != NULL) continue;
Guido van Rossum7928cd71991-10-24 14:59:31 +00001086 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001087
Guido van Rossum7928cd71991-10-24 14:59:31 +00001088 case BINARY_RSHIFT:
1089 w = POP();
1090 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +00001091 x = PyNumber_Rshift(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00001092 Py_DECREF(v);
1093 Py_DECREF(w);
Guido van Rossum7928cd71991-10-24 14:59:31 +00001094 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001095 if (x != NULL) continue;
Guido van Rossum7928cd71991-10-24 14:59:31 +00001096 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001097
Guido van Rossum7928cd71991-10-24 14:59:31 +00001098 case BINARY_AND:
1099 w = POP();
1100 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +00001101 x = PyNumber_And(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00001102 Py_DECREF(v);
1103 Py_DECREF(w);
Guido van Rossum7928cd71991-10-24 14:59:31 +00001104 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001105 if (x != NULL) continue;
Guido van Rossum7928cd71991-10-24 14:59:31 +00001106 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001107
Guido van Rossum7928cd71991-10-24 14:59:31 +00001108 case BINARY_XOR:
1109 w = POP();
1110 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +00001111 x = PyNumber_Xor(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00001112 Py_DECREF(v);
1113 Py_DECREF(w);
Guido van Rossum7928cd71991-10-24 14:59:31 +00001114 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001115 if (x != NULL) continue;
Guido van Rossum7928cd71991-10-24 14:59:31 +00001116 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001117
Guido van Rossum7928cd71991-10-24 14:59:31 +00001118 case BINARY_OR:
1119 w = POP();
1120 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +00001121 x = PyNumber_Or(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00001122 Py_DECREF(v);
1123 Py_DECREF(w);
Guido van Rossum7928cd71991-10-24 14:59:31 +00001124 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001125 if (x != NULL) continue;
Guido van Rossum7928cd71991-10-24 14:59:31 +00001126 break;
Thomas Wouters434d0822000-08-24 20:11:32 +00001127
1128 case INPLACE_POWER:
1129 w = POP();
1130 v = POP();
1131 x = PyNumber_InPlacePower(v, w, Py_None);
1132 Py_DECREF(v);
1133 Py_DECREF(w);
1134 PUSH(x);
1135 if (x != NULL) continue;
1136 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001137
Thomas Wouters434d0822000-08-24 20:11:32 +00001138 case INPLACE_MULTIPLY:
1139 w = POP();
1140 v = POP();
1141 x = PyNumber_InPlaceMultiply(v, w);
1142 Py_DECREF(v);
1143 Py_DECREF(w);
1144 PUSH(x);
1145 if (x != NULL) continue;
1146 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001147
Thomas Wouters434d0822000-08-24 20:11:32 +00001148 case INPLACE_DIVIDE:
Tim Peters54b11912001-12-25 18:49:11 +00001149 if (!_Py_QnewFlag) {
1150 w = POP();
1151 v = POP();
1152 x = PyNumber_InPlaceDivide(v, w);
1153 Py_DECREF(v);
1154 Py_DECREF(w);
1155 PUSH(x);
1156 if (x != NULL) continue;
1157 break;
1158 }
1159 /* -Qnew is in effect: fall through to
1160 INPLACE_TRUE_DIVIDE */
1161 case INPLACE_TRUE_DIVIDE:
Thomas Wouters434d0822000-08-24 20:11:32 +00001162 w = POP();
1163 v = POP();
Tim Peters54b11912001-12-25 18:49:11 +00001164 x = PyNumber_InPlaceTrueDivide(v, w);
Thomas Wouters434d0822000-08-24 20:11:32 +00001165 Py_DECREF(v);
1166 Py_DECREF(w);
1167 PUSH(x);
1168 if (x != NULL) continue;
1169 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001170
Guido van Rossum4668b002001-08-08 05:00:18 +00001171 case INPLACE_FLOOR_DIVIDE:
1172 w = POP();
1173 v = POP();
1174 x = PyNumber_InPlaceFloorDivide(v, w);
1175 Py_DECREF(v);
1176 Py_DECREF(w);
1177 PUSH(x);
1178 if (x != NULL) continue;
1179 break;
1180
Thomas Wouters434d0822000-08-24 20:11:32 +00001181 case INPLACE_MODULO:
1182 w = POP();
1183 v = POP();
1184 x = PyNumber_InPlaceRemainder(v, w);
1185 Py_DECREF(v);
1186 Py_DECREF(w);
1187 PUSH(x);
1188 if (x != NULL) continue;
1189 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001190
Thomas Wouters434d0822000-08-24 20:11:32 +00001191 case INPLACE_ADD:
1192 w = POP();
1193 v = POP();
Tim Petersc1e6d962001-10-05 20:21:03 +00001194 if (PyInt_CheckExact(v) && PyInt_CheckExact(w)) {
Thomas Wouters434d0822000-08-24 20:11:32 +00001195 /* INLINE: int + int */
1196 register long a, b, i;
1197 a = PyInt_AS_LONG(v);
1198 b = PyInt_AS_LONG(w);
1199 i = a + b;
Guido van Rossum87780df2001-08-23 02:58:07 +00001200 if ((i^a) < 0 && (i^b) < 0)
1201 goto slow_iadd;
1202 x = PyInt_FromLong(i);
Thomas Wouters434d0822000-08-24 20:11:32 +00001203 }
Guido van Rossum87780df2001-08-23 02:58:07 +00001204 else {
1205 slow_iadd:
Thomas Wouters434d0822000-08-24 20:11:32 +00001206 x = PyNumber_InPlaceAdd(v, w);
Guido van Rossum87780df2001-08-23 02:58:07 +00001207 }
Thomas Wouters434d0822000-08-24 20:11:32 +00001208 Py_DECREF(v);
1209 Py_DECREF(w);
1210 PUSH(x);
1211 if (x != NULL) continue;
1212 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001213
Thomas Wouters434d0822000-08-24 20:11:32 +00001214 case INPLACE_SUBTRACT:
1215 w = POP();
1216 v = POP();
Tim Petersc1e6d962001-10-05 20:21:03 +00001217 if (PyInt_CheckExact(v) && PyInt_CheckExact(w)) {
Thomas Wouters434d0822000-08-24 20:11:32 +00001218 /* INLINE: int - int */
1219 register long a, b, i;
1220 a = PyInt_AS_LONG(v);
1221 b = PyInt_AS_LONG(w);
1222 i = a - b;
Guido van Rossum87780df2001-08-23 02:58:07 +00001223 if ((i^a) < 0 && (i^~b) < 0)
1224 goto slow_isub;
1225 x = PyInt_FromLong(i);
Thomas Wouters434d0822000-08-24 20:11:32 +00001226 }
Guido van Rossum87780df2001-08-23 02:58:07 +00001227 else {
1228 slow_isub:
Thomas Wouters434d0822000-08-24 20:11:32 +00001229 x = PyNumber_InPlaceSubtract(v, w);
Guido van Rossum87780df2001-08-23 02:58:07 +00001230 }
Thomas Wouters434d0822000-08-24 20:11:32 +00001231 Py_DECREF(v);
1232 Py_DECREF(w);
1233 PUSH(x);
1234 if (x != NULL) continue;
1235 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001236
Thomas Wouters434d0822000-08-24 20:11:32 +00001237 case INPLACE_LSHIFT:
1238 w = POP();
1239 v = POP();
1240 x = PyNumber_InPlaceLshift(v, w);
1241 Py_DECREF(v);
1242 Py_DECREF(w);
1243 PUSH(x);
1244 if (x != NULL) continue;
1245 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001246
Thomas Wouters434d0822000-08-24 20:11:32 +00001247 case INPLACE_RSHIFT:
1248 w = POP();
1249 v = POP();
1250 x = PyNumber_InPlaceRshift(v, w);
1251 Py_DECREF(v);
1252 Py_DECREF(w);
1253 PUSH(x);
1254 if (x != NULL) continue;
1255 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001256
Thomas Wouters434d0822000-08-24 20:11:32 +00001257 case INPLACE_AND:
1258 w = POP();
1259 v = POP();
1260 x = PyNumber_InPlaceAnd(v, w);
1261 Py_DECREF(v);
1262 Py_DECREF(w);
1263 PUSH(x);
1264 if (x != NULL) continue;
1265 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001266
Thomas Wouters434d0822000-08-24 20:11:32 +00001267 case INPLACE_XOR:
1268 w = POP();
1269 v = POP();
1270 x = PyNumber_InPlaceXor(v, w);
1271 Py_DECREF(v);
1272 Py_DECREF(w);
1273 PUSH(x);
1274 if (x != NULL) continue;
1275 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001276
Thomas Wouters434d0822000-08-24 20:11:32 +00001277 case INPLACE_OR:
1278 w = POP();
1279 v = POP();
1280 x = PyNumber_InPlaceOr(v, w);
1281 Py_DECREF(v);
1282 Py_DECREF(w);
1283 PUSH(x);
1284 if (x != NULL) continue;
1285 break;
1286
Guido van Rossum374a9221991-04-04 10:40:29 +00001287 case SLICE+0:
1288 case SLICE+1:
1289 case SLICE+2:
1290 case SLICE+3:
1291 if ((opcode-SLICE) & 2)
1292 w = POP();
1293 else
1294 w = NULL;
1295 if ((opcode-SLICE) & 1)
1296 v = POP();
1297 else
1298 v = NULL;
1299 u = POP();
1300 x = apply_slice(u, v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00001301 Py_DECREF(u);
1302 Py_XDECREF(v);
1303 Py_XDECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001304 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001305 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001306 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001307
Guido van Rossum374a9221991-04-04 10:40:29 +00001308 case STORE_SLICE+0:
1309 case STORE_SLICE+1:
1310 case STORE_SLICE+2:
1311 case STORE_SLICE+3:
1312 if ((opcode-STORE_SLICE) & 2)
1313 w = POP();
1314 else
1315 w = NULL;
1316 if ((opcode-STORE_SLICE) & 1)
1317 v = POP();
1318 else
1319 v = NULL;
1320 u = POP();
1321 t = POP();
1322 err = assign_slice(u, v, w, t); /* u[v:w] = t */
Guido van Rossumb209a111997-04-29 18:18:01 +00001323 Py_DECREF(t);
1324 Py_DECREF(u);
1325 Py_XDECREF(v);
1326 Py_XDECREF(w);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001327 if (err == 0) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001328 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001329
Guido van Rossum374a9221991-04-04 10:40:29 +00001330 case DELETE_SLICE+0:
1331 case DELETE_SLICE+1:
1332 case DELETE_SLICE+2:
1333 case DELETE_SLICE+3:
1334 if ((opcode-DELETE_SLICE) & 2)
1335 w = POP();
1336 else
1337 w = NULL;
1338 if ((opcode-DELETE_SLICE) & 1)
1339 v = POP();
1340 else
1341 v = NULL;
1342 u = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001343 err = assign_slice(u, v, w, (PyObject *)NULL);
Guido van Rossum374a9221991-04-04 10:40:29 +00001344 /* del u[v:w] */
Guido van Rossumb209a111997-04-29 18:18:01 +00001345 Py_DECREF(u);
1346 Py_XDECREF(v);
1347 Py_XDECREF(w);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001348 if (err == 0) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001349 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001350
Guido van Rossum374a9221991-04-04 10:40:29 +00001351 case STORE_SUBSCR:
1352 w = POP();
1353 v = POP();
1354 u = POP();
1355 /* v[w] = u */
Guido van Rossumfc490731997-05-06 15:06:49 +00001356 err = PyObject_SetItem(v, w, u);
Guido van Rossumb209a111997-04-29 18:18:01 +00001357 Py_DECREF(u);
1358 Py_DECREF(v);
1359 Py_DECREF(w);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001360 if (err == 0) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001361 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001362
Guido van Rossum374a9221991-04-04 10:40:29 +00001363 case DELETE_SUBSCR:
1364 w = POP();
1365 v = POP();
1366 /* del v[w] */
Guido van Rossumfc490731997-05-06 15:06:49 +00001367 err = PyObject_DelItem(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00001368 Py_DECREF(v);
1369 Py_DECREF(w);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001370 if (err == 0) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001371 break;
Barry Warsaw23c9ec82000-08-21 15:44:01 +00001372
Guido van Rossum374a9221991-04-04 10:40:29 +00001373 case PRINT_EXPR:
1374 v = POP();
Moshe Zadkaf68f2fe2001-01-11 05:41:27 +00001375 w = PySys_GetObject("displayhook");
1376 if (w == NULL) {
1377 PyErr_SetString(PyExc_RuntimeError,
1378 "lost sys.displayhook");
1379 err = -1;
Moshe Zadkaf5df3832001-01-11 11:55:37 +00001380 x = NULL;
Moshe Zadkaf68f2fe2001-01-11 05:41:27 +00001381 }
1382 if (err == 0) {
1383 x = Py_BuildValue("(O)", v);
1384 if (x == NULL)
1385 err = -1;
1386 }
1387 if (err == 0) {
1388 w = PyEval_CallObject(w, x);
Moshe Zadkaf5df3832001-01-11 11:55:37 +00001389 Py_XDECREF(w);
Moshe Zadkaf68f2fe2001-01-11 05:41:27 +00001390 if (w == NULL)
1391 err = -1;
Guido van Rossum374a9221991-04-04 10:40:29 +00001392 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001393 Py_DECREF(v);
Moshe Zadkaf68f2fe2001-01-11 05:41:27 +00001394 Py_XDECREF(x);
Guido van Rossum374a9221991-04-04 10:40:29 +00001395 break;
Moshe Zadkaf68f2fe2001-01-11 05:41:27 +00001396
Barry Warsaw23c9ec82000-08-21 15:44:01 +00001397 case PRINT_ITEM_TO:
1398 w = stream = POP();
1399 /* fall through to PRINT_ITEM */
1400
Guido van Rossum374a9221991-04-04 10:40:29 +00001401 case PRINT_ITEM:
1402 v = POP();
Barry Warsaw093abe02000-08-29 04:56:13 +00001403 if (stream == NULL || stream == Py_None) {
Barry Warsaw23c9ec82000-08-21 15:44:01 +00001404 w = PySys_GetObject("stdout");
1405 if (w == NULL) {
1406 PyErr_SetString(PyExc_RuntimeError,
1407 "lost sys.stdout");
1408 err = -1;
1409 }
Guido van Rossum8f183201997-12-31 05:53:15 +00001410 }
Tim Peters8e5fd532002-03-24 19:25:00 +00001411 if (w != NULL && PyFile_SoftSpace(w, 0))
Guido van Rossumbe270261997-05-22 22:26:18 +00001412 err = PyFile_WriteString(" ", w);
1413 if (err == 0)
1414 err = PyFile_WriteObject(v, w, Py_PRINT_RAW);
Marc-André Lemburg0c4d8d02001-11-20 15:17:25 +00001415 if (err == 0) {
Tim Peters8e5fd532002-03-24 19:25:00 +00001416 /* XXX move into writeobject() ? */
Marc-André Lemburg0c4d8d02001-11-20 15:17:25 +00001417 if (PyString_Check(v)) {
1418 char *s = PyString_AS_STRING(v);
1419 int len = PyString_GET_SIZE(v);
Tim Peters8e5fd532002-03-24 19:25:00 +00001420 if (len == 0 ||
1421 !isspace(Py_CHARMASK(s[len-1])) ||
1422 s[len-1] == ' ')
1423 PyFile_SoftSpace(w, 1);
Marc-André Lemburg0c4d8d02001-11-20 15:17:25 +00001424 }
Martin v. Löwis8d3ce5a2001-12-18 22:36:40 +00001425#ifdef Py_USING_UNICODE
Marc-André Lemburg0c4d8d02001-11-20 15:17:25 +00001426 else if (PyUnicode_Check(v)) {
1427 Py_UNICODE *s = PyUnicode_AS_UNICODE(v);
1428 int len = PyUnicode_GET_SIZE(v);
Tim Peters8e5fd532002-03-24 19:25:00 +00001429 if (len == 0 ||
1430 !Py_UNICODE_ISSPACE(s[len-1]) ||
1431 s[len-1] == ' ')
1432 PyFile_SoftSpace(w, 1);
Marc-André Lemburg0c4d8d02001-11-20 15:17:25 +00001433 }
Michael W. Hudsond95c8282002-05-20 13:56:11 +00001434#endif
Tim Peters8e5fd532002-03-24 19:25:00 +00001435 else
1436 PyFile_SoftSpace(w, 1);
Guido van Rossum374a9221991-04-04 10:40:29 +00001437 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001438 Py_DECREF(v);
Barry Warsaw23c9ec82000-08-21 15:44:01 +00001439 Py_XDECREF(stream);
1440 stream = NULL;
1441 if (err == 0)
1442 continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001443 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001444
Barry Warsaw23c9ec82000-08-21 15:44:01 +00001445 case PRINT_NEWLINE_TO:
1446 w = stream = POP();
1447 /* fall through to PRINT_NEWLINE */
1448
Guido van Rossum374a9221991-04-04 10:40:29 +00001449 case PRINT_NEWLINE:
Barry Warsaw093abe02000-08-29 04:56:13 +00001450 if (stream == NULL || stream == Py_None) {
Barry Warsaw23c9ec82000-08-21 15:44:01 +00001451 w = PySys_GetObject("stdout");
1452 if (w == NULL)
1453 PyErr_SetString(PyExc_RuntimeError,
1454 "lost sys.stdout");
Guido van Rossum3165fe61992-09-25 21:59:05 +00001455 }
Barry Warsaw23c9ec82000-08-21 15:44:01 +00001456 if (w != NULL) {
1457 err = PyFile_WriteString("\n", w);
1458 if (err == 0)
1459 PyFile_SoftSpace(w, 0);
1460 }
1461 Py_XDECREF(stream);
1462 stream = NULL;
Guido van Rossum374a9221991-04-04 10:40:29 +00001463 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001464
Thomas Wouters434d0822000-08-24 20:11:32 +00001465
1466#ifdef CASE_TOO_BIG
1467 default: switch (opcode) {
1468#endif
Guido van Rossum374a9221991-04-04 10:40:29 +00001469 case BREAK_LOOP:
1470 why = WHY_BREAK;
1471 break;
Guido van Rossum66b0e9c2001-03-21 19:17:22 +00001472
Jeremy Hylton3faa52e2001-02-01 22:48:12 +00001473 case CONTINUE_LOOP:
1474 retval = PyInt_FromLong(oparg);
1475 why = WHY_CONTINUE;
1476 break;
Guido van Rossumf10570b1995-07-07 22:53:21 +00001477
Guido van Rossumf10570b1995-07-07 22:53:21 +00001478 case RAISE_VARARGS:
1479 u = v = w = NULL;
1480 switch (oparg) {
1481 case 3:
1482 u = POP(); /* traceback */
Guido van Rossumf10570b1995-07-07 22:53:21 +00001483 /* Fallthrough */
1484 case 2:
1485 v = POP(); /* value */
1486 /* Fallthrough */
1487 case 1:
1488 w = POP(); /* exc */
Guido van Rossumd295f121998-04-09 21:39:57 +00001489 case 0: /* Fallthrough */
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00001490 why = do_raise(w, v, u);
Guido van Rossumf10570b1995-07-07 22:53:21 +00001491 break;
1492 default:
Guido van Rossumb209a111997-04-29 18:18:01 +00001493 PyErr_SetString(PyExc_SystemError,
Guido van Rossumf10570b1995-07-07 22:53:21 +00001494 "bad RAISE_VARARGS oparg");
Guido van Rossumf10570b1995-07-07 22:53:21 +00001495 why = WHY_EXCEPTION;
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00001496 break;
1497 }
Guido van Rossum374a9221991-04-04 10:40:29 +00001498 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001499
Guido van Rossum374a9221991-04-04 10:40:29 +00001500 case LOAD_LOCALS:
Guido van Rossum681d79a1995-07-18 14:51:37 +00001501 if ((x = f->f_locals) == NULL) {
Guido van Rossuma027efa1997-05-05 20:56:21 +00001502 PyErr_SetString(PyExc_SystemError,
1503 "no locals");
Guido van Rossum681d79a1995-07-18 14:51:37 +00001504 break;
1505 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001506 Py_INCREF(x);
Guido van Rossum681d79a1995-07-18 14:51:37 +00001507 PUSH(x);
Guido van Rossum374a9221991-04-04 10:40:29 +00001508 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001509
Guido van Rossum374a9221991-04-04 10:40:29 +00001510 case RETURN_VALUE:
1511 retval = POP();
1512 why = WHY_RETURN;
1513 break;
Guido van Rossumdb3165e1993-10-18 17:06:59 +00001514
Michael W. Hudsondd32a912002-08-15 14:59:02 +00001515 case RETURN_NONE:
1516 retval = Py_None;
1517 Py_INCREF(retval);
1518 why = WHY_RETURN;
1519 break;
1520
Tim Peters5ca576e2001-06-18 22:08:13 +00001521 case YIELD_VALUE:
1522 retval = POP();
Tim Peters8c963692001-06-23 05:26:56 +00001523 f->f_stacktop = stack_pointer;
Michael W. Hudsondd32a912002-08-15 14:59:02 +00001524 /* abuse the lasti field: here it points to
1525 the *next* instruction */
Tim Peters5ca576e2001-06-18 22:08:13 +00001526 f->f_lasti = INSTR_OFFSET();
1527 why = WHY_YIELD;
1528 break;
1529
1530
Guido van Rossumdb3165e1993-10-18 17:06:59 +00001531 case EXEC_STMT:
1532 w = POP();
1533 v = POP();
1534 u = POP();
Guido van Rossuma027efa1997-05-05 20:56:21 +00001535 err = exec_statement(f, u, v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00001536 Py_DECREF(u);
1537 Py_DECREF(v);
1538 Py_DECREF(w);
Guido van Rossumdb3165e1993-10-18 17:06:59 +00001539 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001540
Guido van Rossum374a9221991-04-04 10:40:29 +00001541 case POP_BLOCK:
1542 {
Guido van Rossumb209a111997-04-29 18:18:01 +00001543 PyTryBlock *b = PyFrame_BlockPop(f);
Guido van Rossum374a9221991-04-04 10:40:29 +00001544 while (STACK_LEVEL() > b->b_level) {
1545 v = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001546 Py_DECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +00001547 }
1548 }
1549 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001550
Guido van Rossum374a9221991-04-04 10:40:29 +00001551 case END_FINALLY:
1552 v = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001553 if (PyInt_Check(v)) {
1554 why = (enum why_code) PyInt_AsLong(v);
Jeremy Hylton3faa52e2001-02-01 22:48:12 +00001555 if (why == WHY_RETURN ||
Tim Peters5ca576e2001-06-18 22:08:13 +00001556 why == WHY_YIELD ||
Guido van Rossumc5fe5eb2002-06-12 03:45:21 +00001557 why == WHY_CONTINUE)
Guido van Rossum374a9221991-04-04 10:40:29 +00001558 retval = POP();
1559 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001560 else if (PyString_Check(v) || PyClass_Check(v)) {
Guido van Rossum374a9221991-04-04 10:40:29 +00001561 w = POP();
Guido van Rossumf10570b1995-07-07 22:53:21 +00001562 u = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001563 PyErr_Restore(v, w, u);
Guido van Rossum374a9221991-04-04 10:40:29 +00001564 why = WHY_RERAISE;
Guido van Rossum0db1ef91995-07-28 23:06:00 +00001565 break;
Guido van Rossum374a9221991-04-04 10:40:29 +00001566 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001567 else if (v != Py_None) {
1568 PyErr_SetString(PyExc_SystemError,
Guido van Rossum374a9221991-04-04 10:40:29 +00001569 "'finally' pops bad exception");
1570 why = WHY_EXCEPTION;
1571 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001572 Py_DECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +00001573 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001574
Guido van Rossum374a9221991-04-04 10:40:29 +00001575 case BUILD_CLASS:
Guido van Rossum25831651993-05-19 14:50:45 +00001576 u = POP();
Guido van Rossum374a9221991-04-04 10:40:29 +00001577 v = POP();
Guido van Rossum25831651993-05-19 14:50:45 +00001578 w = POP();
1579 x = build_class(u, v, w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001580 PUSH(x);
Guido van Rossumb209a111997-04-29 18:18:01 +00001581 Py_DECREF(u);
1582 Py_DECREF(v);
1583 Py_DECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001584 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001585
Guido van Rossum374a9221991-04-04 10:40:29 +00001586 case STORE_NAME:
Skip Montanaro496e6582002-08-06 17:47:40 +00001587 w = GETITEM(names, oparg);
Guido van Rossum374a9221991-04-04 10:40:29 +00001588 v = POP();
Guido van Rossum681d79a1995-07-18 14:51:37 +00001589 if ((x = f->f_locals) == NULL) {
Jeremy Hyltonc862cf42001-01-19 03:25:05 +00001590 PyErr_Format(PyExc_SystemError,
1591 "no locals found when storing %s",
Jeremy Hylton483638c2001-02-01 20:20:45 +00001592 PyObject_REPR(w));
Guido van Rossum681d79a1995-07-18 14:51:37 +00001593 break;
1594 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001595 err = PyDict_SetItem(x, w, v);
1596 Py_DECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +00001597 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001598
Guido van Rossum374a9221991-04-04 10:40:29 +00001599 case DELETE_NAME:
Skip Montanaro496e6582002-08-06 17:47:40 +00001600 w = GETITEM(names, oparg);
Guido van Rossum681d79a1995-07-18 14:51:37 +00001601 if ((x = f->f_locals) == NULL) {
Jeremy Hyltonc862cf42001-01-19 03:25:05 +00001602 PyErr_Format(PyExc_SystemError,
1603 "no locals when deleting %s",
Jeremy Hylton483638c2001-02-01 20:20:45 +00001604 PyObject_REPR(w));
Guido van Rossum681d79a1995-07-18 14:51:37 +00001605 break;
1606 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001607 if ((err = PyDict_DelItem(x, w)) != 0)
Guido van Rossumac7be682001-01-17 15:42:30 +00001608 format_exc_check_arg(PyExc_NameError,
Paul Prescode68140d2000-08-30 20:25:01 +00001609 NAME_ERROR_MSG ,w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001610 break;
Guido van Rossum04691fc1992-08-12 15:35:34 +00001611
Thomas Wouters0be5aab2000-08-11 22:15:52 +00001612 case UNPACK_SEQUENCE:
Guido van Rossum374a9221991-04-04 10:40:29 +00001613 v = POP();
Barry Warsawe42b18f1997-08-25 22:13:04 +00001614 if (PyTuple_Check(v)) {
1615 if (PyTuple_Size(v) != oparg) {
1616 PyErr_SetString(PyExc_ValueError,
1617 "unpack tuple of wrong size");
1618 why = WHY_EXCEPTION;
1619 }
1620 else {
1621 for (; --oparg >= 0; ) {
1622 w = PyTuple_GET_ITEM(v, oparg);
1623 Py_INCREF(w);
1624 PUSH(w);
1625 }
1626 }
Guido van Rossum374a9221991-04-04 10:40:29 +00001627 }
Barry Warsawe42b18f1997-08-25 22:13:04 +00001628 else if (PyList_Check(v)) {
1629 if (PyList_Size(v) != oparg) {
1630 PyErr_SetString(PyExc_ValueError,
1631 "unpack list of wrong size");
1632 why = WHY_EXCEPTION;
1633 }
1634 else {
1635 for (; --oparg >= 0; ) {
1636 w = PyList_GET_ITEM(v, oparg);
1637 Py_INCREF(w);
1638 PUSH(w);
1639 }
1640 }
1641 }
Tim Petersd6d010b2001-06-21 02:49:55 +00001642 else if (unpack_iterable(v, oparg,
1643 stack_pointer + oparg))
1644 stack_pointer += oparg;
Tim Peters8b13b3e2001-09-30 05:58:42 +00001645 else {
1646 if (PyErr_ExceptionMatches(PyExc_TypeError))
1647 PyErr_SetString(PyExc_TypeError,
1648 "unpack non-sequence");
Barry Warsawe42b18f1997-08-25 22:13:04 +00001649 why = WHY_EXCEPTION;
Tim Peters8b13b3e2001-09-30 05:58:42 +00001650 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001651 Py_DECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +00001652 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001653
Guido van Rossum374a9221991-04-04 10:40:29 +00001654 case STORE_ATTR:
Skip Montanaro496e6582002-08-06 17:47:40 +00001655 w = GETITEM(names, oparg);
Guido van Rossum374a9221991-04-04 10:40:29 +00001656 v = POP();
1657 u = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001658 err = PyObject_SetAttr(v, w, u); /* v.w = u */
1659 Py_DECREF(v);
1660 Py_DECREF(u);
Guido van Rossum374a9221991-04-04 10:40:29 +00001661 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001662
Guido van Rossum374a9221991-04-04 10:40:29 +00001663 case DELETE_ATTR:
Skip Montanaro496e6582002-08-06 17:47:40 +00001664 w = GETITEM(names, oparg);
Guido van Rossum374a9221991-04-04 10:40:29 +00001665 v = POP();
Guido van Rossuma027efa1997-05-05 20:56:21 +00001666 err = PyObject_SetAttr(v, w, (PyObject *)NULL);
1667 /* del v.w */
Guido van Rossumb209a111997-04-29 18:18:01 +00001668 Py_DECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +00001669 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001670
Guido van Rossum32c6cdf1991-12-10 13:52:46 +00001671 case STORE_GLOBAL:
Skip Montanaro496e6582002-08-06 17:47:40 +00001672 w = GETITEM(names, oparg);
Guido van Rossum32c6cdf1991-12-10 13:52:46 +00001673 v = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001674 err = PyDict_SetItem(f->f_globals, w, v);
1675 Py_DECREF(v);
Guido van Rossum32c6cdf1991-12-10 13:52:46 +00001676 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001677
Guido van Rossum32c6cdf1991-12-10 13:52:46 +00001678 case DELETE_GLOBAL:
Skip Montanaro496e6582002-08-06 17:47:40 +00001679 w = GETITEM(names, oparg);
Guido van Rossumb209a111997-04-29 18:18:01 +00001680 if ((err = PyDict_DelItem(f->f_globals, w)) != 0)
Paul Prescode68140d2000-08-30 20:25:01 +00001681 format_exc_check_arg(
Jeremy Hylton64949cb2001-01-25 20:06:59 +00001682 PyExc_NameError, GLOBAL_NAME_ERROR_MSG, w);
Guido van Rossum32c6cdf1991-12-10 13:52:46 +00001683 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001684
Guido van Rossum374a9221991-04-04 10:40:29 +00001685 case LOAD_NAME:
Skip Montanaro496e6582002-08-06 17:47:40 +00001686 w = GETITEM(names, oparg);
Guido van Rossum681d79a1995-07-18 14:51:37 +00001687 if ((x = f->f_locals) == NULL) {
Jeremy Hyltonc862cf42001-01-19 03:25:05 +00001688 PyErr_Format(PyExc_SystemError,
1689 "no locals when loading %s",
Jeremy Hylton483638c2001-02-01 20:20:45 +00001690 PyObject_REPR(w));
Guido van Rossum681d79a1995-07-18 14:51:37 +00001691 break;
1692 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001693 x = PyDict_GetItem(x, w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001694 if (x == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00001695 x = PyDict_GetItem(f->f_globals, w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001696 if (x == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00001697 x = PyDict_GetItem(f->f_builtins, w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001698 if (x == NULL) {
Paul Prescode68140d2000-08-30 20:25:01 +00001699 format_exc_check_arg(
Guido van Rossumac7be682001-01-17 15:42:30 +00001700 PyExc_NameError,
Paul Prescode68140d2000-08-30 20:25:01 +00001701 NAME_ERROR_MSG ,w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001702 break;
1703 }
1704 }
1705 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001706 Py_INCREF(x);
Guido van Rossum374a9221991-04-04 10:40:29 +00001707 PUSH(x);
1708 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001709
Guido van Rossum374a9221991-04-04 10:40:29 +00001710 case LOAD_GLOBAL:
Skip Montanaro496e6582002-08-06 17:47:40 +00001711 w = GETITEM(names, oparg);
Guido van Rossum3a4dfc82002-08-19 20:24:07 +00001712 if (PyString_CheckExact(w)) {
Guido van Rossumd8dbf842002-08-19 21:17:53 +00001713 /* Inline the PyDict_GetItem() calls.
1714 WARNING: this is an extreme speed hack.
1715 Do not try this at home. */
Guido van Rossum3a4dfc82002-08-19 20:24:07 +00001716 long hash = ((PyStringObject *)w)->ob_shash;
1717 if (hash != -1) {
Guido van Rossum3a4dfc82002-08-19 20:24:07 +00001718 PyDictObject *d;
1719 d = (PyDictObject *)(f->f_globals);
1720 x = d->ma_lookup(d, w, hash)->me_value;
1721 if (x != NULL) {
1722 Py_INCREF(x);
1723 PUSH(x);
1724 continue;
1725 }
1726 d = (PyDictObject *)(f->f_builtins);
1727 x = d->ma_lookup(d, w, hash)->me_value;
1728 if (x != NULL) {
1729 Py_INCREF(x);
1730 PUSH(x);
1731 continue;
1732 }
1733 goto load_global_error;
1734 }
1735 }
1736 /* This is the un-inlined version of the code above */
Guido van Rossumb209a111997-04-29 18:18:01 +00001737 x = PyDict_GetItem(f->f_globals, w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001738 if (x == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00001739 x = PyDict_GetItem(f->f_builtins, w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001740 if (x == NULL) {
Guido van Rossum3a4dfc82002-08-19 20:24:07 +00001741 load_global_error:
Paul Prescode68140d2000-08-30 20:25:01 +00001742 format_exc_check_arg(
Guido van Rossumac7be682001-01-17 15:42:30 +00001743 PyExc_NameError,
Guido van Rossum3a4dfc82002-08-19 20:24:07 +00001744 GLOBAL_NAME_ERROR_MSG, w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001745 break;
1746 }
1747 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001748 Py_INCREF(x);
Guido van Rossum374a9221991-04-04 10:40:29 +00001749 PUSH(x);
1750 break;
Guido van Rossum681d79a1995-07-18 14:51:37 +00001751
Guido van Rossum8b17d6b1993-03-30 13:18:41 +00001752 case DELETE_FAST:
Guido van Rossum2e4c8991998-05-12 20:27:36 +00001753 x = GETLOCAL(oparg);
1754 if (x == NULL) {
Paul Prescode68140d2000-08-30 20:25:01 +00001755 format_exc_check_arg(
1756 PyExc_UnboundLocalError,
1757 UNBOUNDLOCAL_ERROR_MSG,
1758 PyTuple_GetItem(co->co_varnames, oparg)
1759 );
Guido van Rossum2e4c8991998-05-12 20:27:36 +00001760 break;
1761 }
Guido van Rossum681d79a1995-07-18 14:51:37 +00001762 SETLOCAL(oparg, NULL);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001763 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +00001764
Jeremy Hylton64949cb2001-01-25 20:06:59 +00001765 case LOAD_CLOSURE:
Jeremy Hylton2b724da2001-01-29 22:51:52 +00001766 x = freevars[oparg];
Jeremy Hylton64949cb2001-01-25 20:06:59 +00001767 Py_INCREF(x);
1768 PUSH(x);
1769 break;
1770
1771 case LOAD_DEREF:
Jeremy Hylton2b724da2001-01-29 22:51:52 +00001772 x = freevars[oparg];
Jeremy Hylton64949cb2001-01-25 20:06:59 +00001773 w = PyCell_Get(x);
Jeremy Hylton2524d692001-02-05 17:23:16 +00001774 if (w == NULL) {
Jeremy Hylton76c81ee2002-07-11 16:56:38 +00001775 err = -1;
1776 /* Don't stomp existing exception */
1777 if (PyErr_Occurred())
1778 break;
Jeremy Hyltonc76770c2001-04-13 16:51:46 +00001779 if (oparg < f->f_ncells) {
Jeremy Hylton2524d692001-02-05 17:23:16 +00001780 v = PyTuple_GetItem(co->co_cellvars,
1781 oparg);
Jeremy Hyltonc76770c2001-04-13 16:51:46 +00001782 format_exc_check_arg(
1783 PyExc_UnboundLocalError,
1784 UNBOUNDLOCAL_ERROR_MSG,
1785 v);
1786 } else {
Jeremy Hylton2524d692001-02-05 17:23:16 +00001787 v = PyTuple_GetItem(
1788 co->co_freevars,
1789 oparg - f->f_ncells);
Jeremy Hyltonc76770c2001-04-13 16:51:46 +00001790 format_exc_check_arg(
1791 PyExc_NameError,
1792 UNBOUNDFREE_ERROR_MSG,
1793 v);
1794 }
Jeremy Hylton2524d692001-02-05 17:23:16 +00001795 break;
1796 }
Jeremy Hylton64949cb2001-01-25 20:06:59 +00001797 PUSH(w);
1798 break;
1799
1800 case STORE_DEREF:
1801 w = POP();
Jeremy Hylton2b724da2001-01-29 22:51:52 +00001802 x = freevars[oparg];
Jeremy Hylton64949cb2001-01-25 20:06:59 +00001803 PyCell_Set(x, w);
Jeremy Hylton30c9f392001-03-13 01:58:22 +00001804 Py_DECREF(w);
Jeremy Hylton64949cb2001-01-25 20:06:59 +00001805 continue;
1806
Guido van Rossum374a9221991-04-04 10:40:29 +00001807 case BUILD_TUPLE:
Guido van Rossumb209a111997-04-29 18:18:01 +00001808 x = PyTuple_New(oparg);
Guido van Rossum374a9221991-04-04 10:40:29 +00001809 if (x != NULL) {
1810 for (; --oparg >= 0;) {
1811 w = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001812 PyTuple_SET_ITEM(x, oparg, w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001813 }
1814 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001815 continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001816 }
1817 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001818
Guido van Rossum374a9221991-04-04 10:40:29 +00001819 case BUILD_LIST:
Guido van Rossumb209a111997-04-29 18:18:01 +00001820 x = PyList_New(oparg);
Guido van Rossum374a9221991-04-04 10:40:29 +00001821 if (x != NULL) {
1822 for (; --oparg >= 0;) {
1823 w = POP();
Guido van Rossum5053efc1998-08-04 15:27:50 +00001824 PyList_SET_ITEM(x, oparg, w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001825 }
1826 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001827 continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001828 }
1829 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001830
Guido van Rossum374a9221991-04-04 10:40:29 +00001831 case BUILD_MAP:
Guido van Rossumb209a111997-04-29 18:18:01 +00001832 x = PyDict_New();
Guido van Rossum374a9221991-04-04 10:40:29 +00001833 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001834 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001835 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001836
Guido van Rossum374a9221991-04-04 10:40:29 +00001837 case LOAD_ATTR:
Skip Montanaro496e6582002-08-06 17:47:40 +00001838 w = GETITEM(names, oparg);
Guido van Rossum374a9221991-04-04 10:40:29 +00001839 v = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001840 x = PyObject_GetAttr(v, w);
1841 Py_DECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +00001842 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001843 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001844 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001845
Guido van Rossum374a9221991-04-04 10:40:29 +00001846 case COMPARE_OP:
1847 w = POP();
1848 v = POP();
Tim Petersc1e6d962001-10-05 20:21:03 +00001849 if (PyInt_CheckExact(v) && PyInt_CheckExact(w)) {
Guido van Rossumc12da691997-07-17 23:12:42 +00001850 /* INLINE: cmp(int, int) */
1851 register long a, b;
1852 register int res;
Guido van Rossumcf183ac1998-12-04 18:51:36 +00001853 a = PyInt_AS_LONG(v);
1854 b = PyInt_AS_LONG(w);
Guido van Rossumc12da691997-07-17 23:12:42 +00001855 switch (oparg) {
Martin v. Löwis7198a522002-01-01 19:59:11 +00001856 case PyCmp_LT: res = a < b; break;
1857 case PyCmp_LE: res = a <= b; break;
1858 case PyCmp_EQ: res = a == b; break;
1859 case PyCmp_NE: res = a != b; break;
1860 case PyCmp_GT: res = a > b; break;
1861 case PyCmp_GE: res = a >= b; break;
1862 case PyCmp_IS: res = v == w; break;
1863 case PyCmp_IS_NOT: res = v != w; break;
Guido van Rossumc12da691997-07-17 23:12:42 +00001864 default: goto slow_compare;
1865 }
1866 x = res ? Py_True : Py_False;
1867 Py_INCREF(x);
1868 }
1869 else {
1870 slow_compare:
1871 x = cmp_outcome(oparg, v, w);
1872 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001873 Py_DECREF(v);
1874 Py_DECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001875 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001876 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001877 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001878
Guido van Rossum374a9221991-04-04 10:40:29 +00001879 case IMPORT_NAME:
Skip Montanaro496e6582002-08-06 17:47:40 +00001880 w = GETITEM(names, oparg);
Guido van Rossumb209a111997-04-29 18:18:01 +00001881 x = PyDict_GetItemString(f->f_builtins, "__import__");
Guido van Rossum1ae940a1995-01-02 19:04:15 +00001882 if (x == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00001883 PyErr_SetString(PyExc_ImportError,
Guido van Rossumfc490731997-05-06 15:06:49 +00001884 "__import__ not found");
Guido van Rossum1ae940a1995-01-02 19:04:15 +00001885 break;
1886 }
Thomas Woutersdd13e4f2000-08-27 20:31:27 +00001887 u = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001888 w = Py_BuildValue("(OOOO)",
Guido van Rossum681d79a1995-07-18 14:51:37 +00001889 w,
1890 f->f_globals,
Guido van Rossuma027efa1997-05-05 20:56:21 +00001891 f->f_locals == NULL ?
1892 Py_None : f->f_locals,
Guido van Rossum681d79a1995-07-18 14:51:37 +00001893 u);
Guido van Rossumb209a111997-04-29 18:18:01 +00001894 Py_DECREF(u);
Guido van Rossum1ae940a1995-01-02 19:04:15 +00001895 if (w == NULL) {
1896 x = NULL;
1897 break;
1898 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001899 x = PyEval_CallObject(x, w);
1900 Py_DECREF(w);
Guido van Rossumf10570b1995-07-07 22:53:21 +00001901 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001902 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001903 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001904
Thomas Wouters52152252000-08-17 22:55:00 +00001905 case IMPORT_STAR:
1906 v = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001907 PyFrame_FastToLocals(f);
Guido van Rossum681d79a1995-07-18 14:51:37 +00001908 if ((x = f->f_locals) == NULL) {
Guido van Rossuma027efa1997-05-05 20:56:21 +00001909 PyErr_SetString(PyExc_SystemError,
Jeremy Hyltonc862cf42001-01-19 03:25:05 +00001910 "no locals found during 'import *'");
Guido van Rossum681d79a1995-07-18 14:51:37 +00001911 break;
1912 }
Thomas Wouters52152252000-08-17 22:55:00 +00001913 err = import_all_from(x, v);
Guido van Rossumb209a111997-04-29 18:18:01 +00001914 PyFrame_LocalsToFast(f, 0);
Thomas Wouters52152252000-08-17 22:55:00 +00001915 Py_DECREF(v);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001916 if (err == 0) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001917 break;
Guido van Rossum25831651993-05-19 14:50:45 +00001918
Thomas Wouters52152252000-08-17 22:55:00 +00001919 case IMPORT_FROM:
Skip Montanaro496e6582002-08-06 17:47:40 +00001920 w = GETITEM(names, oparg);
Thomas Wouters52152252000-08-17 22:55:00 +00001921 v = TOP();
1922 x = import_from(v, w);
1923 PUSH(x);
1924 if (x != NULL) continue;
1925 break;
1926
Guido van Rossum374a9221991-04-04 10:40:29 +00001927 case JUMP_FORWARD:
1928 JUMPBY(oparg);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001929 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +00001930
Guido van Rossum374a9221991-04-04 10:40:29 +00001931 case JUMP_IF_FALSE:
Guido van Rossumb209a111997-04-29 18:18:01 +00001932 err = PyObject_IsTrue(TOP());
Guido van Rossum04691fc1992-08-12 15:35:34 +00001933 if (err > 0)
1934 err = 0;
1935 else if (err == 0)
Guido van Rossum374a9221991-04-04 10:40:29 +00001936 JUMPBY(oparg);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001937 else
1938 break;
1939 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +00001940
Guido van Rossum374a9221991-04-04 10:40:29 +00001941 case JUMP_IF_TRUE:
Guido van Rossumb209a111997-04-29 18:18:01 +00001942 err = PyObject_IsTrue(TOP());
Guido van Rossum04691fc1992-08-12 15:35:34 +00001943 if (err > 0) {
1944 err = 0;
Guido van Rossum374a9221991-04-04 10:40:29 +00001945 JUMPBY(oparg);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001946 }
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001947 else if (err == 0)
1948 ;
1949 else
1950 break;
1951 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +00001952
Guido van Rossum374a9221991-04-04 10:40:29 +00001953 case JUMP_ABSOLUTE:
1954 JUMPTO(oparg);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001955 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +00001956
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00001957 case GET_ITER:
1958 /* before: [obj]; after [getiter(obj)] */
1959 v = POP();
1960 x = PyObject_GetIter(v);
1961 Py_DECREF(v);
1962 if (x != NULL) {
Guido van Rossum213c7a62001-04-23 14:08:49 +00001963 PUSH(x);
1964 continue;
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00001965 }
1966 break;
1967
1968 case FOR_ITER:
1969 /* before: [iter]; after: [iter, iter()] *or* [] */
1970 v = TOP();
Guido van Rossum213c7a62001-04-23 14:08:49 +00001971 x = PyIter_Next(v);
1972 if (x != NULL) {
1973 PUSH(x);
1974 continue;
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00001975 }
Tim Petersf4848da2001-05-05 00:14:56 +00001976 if (!PyErr_Occurred()) {
1977 /* iterator ended normally */
1978 x = v = POP();
Guido van Rossum213c7a62001-04-23 14:08:49 +00001979 Py_DECREF(v);
1980 JUMPBY(oparg);
1981 continue;
1982 }
1983 break;
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00001984
Guido van Rossum374a9221991-04-04 10:40:29 +00001985 case SETUP_LOOP:
1986 case SETUP_EXCEPT:
1987 case SETUP_FINALLY:
Guido van Rossumb209a111997-04-29 18:18:01 +00001988 PyFrame_BlockSetup(f, opcode, INSTR_OFFSET() + oparg,
Jeremy Hylton3faa52e2001-02-01 22:48:12 +00001989 STACK_LEVEL());
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001990 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +00001991
Guido van Rossumf10570b1995-07-07 22:53:21 +00001992 case CALL_FUNCTION:
Jeremy Hyltone8c04322002-08-16 17:47:26 +00001993 x = call_function(&stack_pointer, oparg);
1994 PUSH(x);
1995 if (x != NULL)
1996 continue;
1997 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001998
Jeremy Hylton76901512000-03-28 23:49:17 +00001999 case CALL_FUNCTION_VAR:
2000 case CALL_FUNCTION_KW:
2001 case CALL_FUNCTION_VAR_KW:
Guido van Rossumf10570b1995-07-07 22:53:21 +00002002 {
Jeremy Hylton76901512000-03-28 23:49:17 +00002003 int na = oparg & 0xff;
2004 int nk = (oparg>>8) & 0xff;
2005 int flags = (opcode - CALL_FUNCTION) & 3;
Jeremy Hylton52820442001-01-03 23:52:36 +00002006 int n = na + 2 * nk;
2007 PyObject **pfunc, *func;
2008 if (flags & CALL_FLAG_VAR)
2009 n++;
2010 if (flags & CALL_FLAG_KW)
2011 n++;
2012 pfunc = stack_pointer - n - 1;
2013 func = *pfunc;
Jeremy Hylton52820442001-01-03 23:52:36 +00002014
Guido van Rossumac7be682001-01-17 15:42:30 +00002015 if (PyMethod_Check(func)
Jeremy Hylton52820442001-01-03 23:52:36 +00002016 && PyMethod_GET_SELF(func) != NULL) {
2017 PyObject *self = PyMethod_GET_SELF(func);
Jeremy Hylton76901512000-03-28 23:49:17 +00002018 Py_INCREF(self);
Jeremy Hylton52820442001-01-03 23:52:36 +00002019 func = PyMethod_GET_FUNCTION(func);
2020 Py_INCREF(func);
Jeremy Hylton76901512000-03-28 23:49:17 +00002021 Py_DECREF(*pfunc);
2022 *pfunc = self;
2023 na++;
2024 n++;
Guido van Rossumac7be682001-01-17 15:42:30 +00002025 } else
Jeremy Hylton52820442001-01-03 23:52:36 +00002026 Py_INCREF(func);
2027 x = ext_do_call(func, &stack_pointer, flags, na, nk);
Jeremy Hylton76901512000-03-28 23:49:17 +00002028 Py_DECREF(func);
Jeremy Hylton52820442001-01-03 23:52:36 +00002029
Jeremy Hylton76901512000-03-28 23:49:17 +00002030 while (stack_pointer > pfunc) {
Jeremy Hylton52820442001-01-03 23:52:36 +00002031 w = POP();
2032 Py_DECREF(w);
Jeremy Hylton76901512000-03-28 23:49:17 +00002033 }
2034 PUSH(x);
Guido van Rossumac7be682001-01-17 15:42:30 +00002035 if (x != NULL)
Jeremy Hylton52820442001-01-03 23:52:36 +00002036 continue;
Jeremy Hylton76901512000-03-28 23:49:17 +00002037 break;
Guido van Rossumf10570b1995-07-07 22:53:21 +00002038 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002039
Guido van Rossum681d79a1995-07-18 14:51:37 +00002040 case MAKE_FUNCTION:
2041 v = POP(); /* code object */
Guido van Rossumb209a111997-04-29 18:18:01 +00002042 x = PyFunction_New(v, f->f_globals);
2043 Py_DECREF(v);
Guido van Rossum681d79a1995-07-18 14:51:37 +00002044 /* XXX Maybe this should be a separate opcode? */
2045 if (x != NULL && oparg > 0) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002046 v = PyTuple_New(oparg);
Guido van Rossum681d79a1995-07-18 14:51:37 +00002047 if (v == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002048 Py_DECREF(x);
Guido van Rossum681d79a1995-07-18 14:51:37 +00002049 x = NULL;
2050 break;
2051 }
2052 while (--oparg >= 0) {
2053 w = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00002054 PyTuple_SET_ITEM(v, oparg, w);
Guido van Rossum681d79a1995-07-18 14:51:37 +00002055 }
2056 err = PyFunction_SetDefaults(x, v);
Guido van Rossumb209a111997-04-29 18:18:01 +00002057 Py_DECREF(v);
Guido van Rossum681d79a1995-07-18 14:51:37 +00002058 }
2059 PUSH(x);
2060 break;
Guido van Rossum8861b741996-07-30 16:49:37 +00002061
Jeremy Hylton64949cb2001-01-25 20:06:59 +00002062 case MAKE_CLOSURE:
2063 {
2064 int nfree;
2065 v = POP(); /* code object */
2066 x = PyFunction_New(v, f->f_globals);
Jeremy Hylton733c8932001-12-13 19:51:56 +00002067 nfree = PyCode_GetNumFree((PyCodeObject *)v);
Jeremy Hylton64949cb2001-01-25 20:06:59 +00002068 Py_DECREF(v);
2069 /* XXX Maybe this should be a separate opcode? */
2070 if (x != NULL && nfree > 0) {
2071 v = PyTuple_New(nfree);
2072 if (v == NULL) {
2073 Py_DECREF(x);
2074 x = NULL;
2075 break;
2076 }
2077 while (--nfree >= 0) {
2078 w = POP();
2079 PyTuple_SET_ITEM(v, nfree, w);
2080 }
2081 err = PyFunction_SetClosure(x, v);
2082 Py_DECREF(v);
2083 }
2084 if (x != NULL && oparg > 0) {
2085 v = PyTuple_New(oparg);
2086 if (v == NULL) {
2087 Py_DECREF(x);
2088 x = NULL;
2089 break;
2090 }
2091 while (--oparg >= 0) {
2092 w = POP();
2093 PyTuple_SET_ITEM(v, oparg, w);
2094 }
2095 err = PyFunction_SetDefaults(x, v);
2096 Py_DECREF(v);
2097 }
2098 PUSH(x);
2099 break;
2100 }
2101
Guido van Rossum8861b741996-07-30 16:49:37 +00002102 case BUILD_SLICE:
2103 if (oparg == 3)
2104 w = POP();
2105 else
2106 w = NULL;
2107 v = POP();
2108 u = POP();
Guido van Rossum1aa14831997-01-21 05:34:20 +00002109 x = PySlice_New(u, v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00002110 Py_DECREF(u);
2111 Py_DECREF(v);
2112 Py_XDECREF(w);
Guido van Rossum8861b741996-07-30 16:49:37 +00002113 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00002114 if (x != NULL) continue;
Guido van Rossum8861b741996-07-30 16:49:37 +00002115 break;
2116
Fred Drakeef8ace32000-08-24 00:32:09 +00002117 case EXTENDED_ARG:
2118 opcode = NEXTOP();
2119 oparg = oparg<<16 | NEXTARG();
2120 goto dispatch_opcode;
Guido van Rossum8861b741996-07-30 16:49:37 +00002121
Guido van Rossum374a9221991-04-04 10:40:29 +00002122 default:
2123 fprintf(stderr,
2124 "XXX lineno: %d, opcode: %d\n",
Michael W. Hudsondd32a912002-08-15 14:59:02 +00002125 PyCode_Addr2Line(f->f_code, f->f_lasti),
2126 opcode);
Guido van Rossumb209a111997-04-29 18:18:01 +00002127 PyErr_SetString(PyExc_SystemError, "unknown opcode");
Guido van Rossum374a9221991-04-04 10:40:29 +00002128 why = WHY_EXCEPTION;
2129 break;
Guido van Rossum04691fc1992-08-12 15:35:34 +00002130
2131#ifdef CASE_TOO_BIG
2132 }
2133#endif
2134
Guido van Rossum374a9221991-04-04 10:40:29 +00002135 } /* switch */
2136
2137 on_error:
Guido van Rossumac7be682001-01-17 15:42:30 +00002138
Guido van Rossum374a9221991-04-04 10:40:29 +00002139 /* Quickly continue if no error occurred */
Guido van Rossumac7be682001-01-17 15:42:30 +00002140
Guido van Rossum374a9221991-04-04 10:40:29 +00002141 if (why == WHY_NOT) {
Guido van Rossum681d79a1995-07-18 14:51:37 +00002142 if (err == 0 && x != NULL) {
2143#ifdef CHECKEXC
Guido van Rossumeb894eb1999-03-09 16:16:45 +00002144 /* This check is expensive! */
Guido van Rossumb209a111997-04-29 18:18:01 +00002145 if (PyErr_Occurred())
Guido van Rossum681d79a1995-07-18 14:51:37 +00002146 fprintf(stderr,
2147 "XXX undetected error\n");
2148 else
2149#endif
2150 continue; /* Normal, fast path */
2151 }
Guido van Rossum374a9221991-04-04 10:40:29 +00002152 why = WHY_EXCEPTION;
Guido van Rossumb209a111997-04-29 18:18:01 +00002153 x = Py_None;
Guido van Rossum374a9221991-04-04 10:40:29 +00002154 err = 0;
2155 }
2156
Guido van Rossum374a9221991-04-04 10:40:29 +00002157 /* Double-check exception status */
Guido van Rossumac7be682001-01-17 15:42:30 +00002158
Guido van Rossum374a9221991-04-04 10:40:29 +00002159 if (why == WHY_EXCEPTION || why == WHY_RERAISE) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002160 if (!PyErr_Occurred()) {
Guido van Rossuma027efa1997-05-05 20:56:21 +00002161 PyErr_SetString(PyExc_SystemError,
Guido van Rossumeb894eb1999-03-09 16:16:45 +00002162 "error return without exception set");
Guido van Rossum374a9221991-04-04 10:40:29 +00002163 why = WHY_EXCEPTION;
2164 }
2165 }
Guido van Rossumeb894eb1999-03-09 16:16:45 +00002166#ifdef CHECKEXC
Guido van Rossum374a9221991-04-04 10:40:29 +00002167 else {
Guido van Rossumeb894eb1999-03-09 16:16:45 +00002168 /* This check is expensive! */
Guido van Rossumb209a111997-04-29 18:18:01 +00002169 if (PyErr_Occurred()) {
Guido van Rossum681d79a1995-07-18 14:51:37 +00002170 fprintf(stderr,
2171 "XXX undetected error (why=%d)\n",
2172 why);
2173 why = WHY_EXCEPTION;
2174 }
Guido van Rossum374a9221991-04-04 10:40:29 +00002175 }
2176#endif
2177
2178 /* Log traceback info if this is a real exception */
Guido van Rossumac7be682001-01-17 15:42:30 +00002179
Guido van Rossum374a9221991-04-04 10:40:29 +00002180 if (why == WHY_EXCEPTION) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002181 PyTraceBack_Here(f);
Guido van Rossum96a42c81992-01-12 02:29:51 +00002182
Fred Drake8f51f542001-10-04 14:48:42 +00002183 if (tstate->c_tracefunc != NULL)
2184 call_exc_trace(tstate->c_tracefunc,
2185 tstate->c_traceobj, f);
Guido van Rossum014518f1998-11-23 21:09:51 +00002186 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002187
Guido van Rossum374a9221991-04-04 10:40:29 +00002188 /* For the rest, treat WHY_RERAISE as WHY_EXCEPTION */
Guido van Rossumac7be682001-01-17 15:42:30 +00002189
Guido van Rossum374a9221991-04-04 10:40:29 +00002190 if (why == WHY_RERAISE)
2191 why = WHY_EXCEPTION;
2192
2193 /* Unwind stacks if a (pseudo) exception occurred */
Guido van Rossumac7be682001-01-17 15:42:30 +00002194
Tim Peters5ca576e2001-06-18 22:08:13 +00002195 while (why != WHY_NOT && why != WHY_YIELD && f->f_iblock > 0) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002196 PyTryBlock *b = PyFrame_BlockPop(f);
Jeremy Hylton3faa52e2001-02-01 22:48:12 +00002197
2198 if (b->b_type == SETUP_LOOP && why == WHY_CONTINUE) {
2199 /* For a continue inside a try block,
2200 don't pop the block for the loop. */
Thomas Wouters1ee64222001-09-24 19:32:01 +00002201 PyFrame_BlockSetup(f, b->b_type, b->b_handler,
2202 b->b_level);
Jeremy Hylton3faa52e2001-02-01 22:48:12 +00002203 why = WHY_NOT;
2204 JUMPTO(PyInt_AS_LONG(retval));
2205 Py_DECREF(retval);
2206 break;
2207 }
2208
Guido van Rossum374a9221991-04-04 10:40:29 +00002209 while (STACK_LEVEL() > b->b_level) {
2210 v = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00002211 Py_XDECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +00002212 }
2213 if (b->b_type == SETUP_LOOP && why == WHY_BREAK) {
2214 why = WHY_NOT;
2215 JUMPTO(b->b_handler);
2216 break;
2217 }
2218 if (b->b_type == SETUP_FINALLY ||
Guido van Rossum150b2df1996-12-05 23:17:11 +00002219 (b->b_type == SETUP_EXCEPT &&
2220 why == WHY_EXCEPTION)) {
Guido van Rossum374a9221991-04-04 10:40:29 +00002221 if (why == WHY_EXCEPTION) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002222 PyObject *exc, *val, *tb;
2223 PyErr_Fetch(&exc, &val, &tb);
Guido van Rossum374a9221991-04-04 10:40:29 +00002224 if (val == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002225 val = Py_None;
2226 Py_INCREF(val);
Guido van Rossum374a9221991-04-04 10:40:29 +00002227 }
Guido van Rossum374a9221991-04-04 10:40:29 +00002228 /* Make the raw exception data
2229 available to the handler,
2230 so a program can emulate the
2231 Python main loop. Don't do
2232 this for 'finally'. */
2233 if (b->b_type == SETUP_EXCEPT) {
Barry Warsaweaedc7c1997-08-28 22:36:40 +00002234 PyErr_NormalizeException(
2235 &exc, &val, &tb);
Guido van Rossuma027efa1997-05-05 20:56:21 +00002236 set_exc_info(tstate,
2237 exc, val, tb);
Guido van Rossum374a9221991-04-04 10:40:29 +00002238 }
Jeremy Hyltonc6314892001-09-26 19:24:45 +00002239 if (tb == NULL) {
2240 Py_INCREF(Py_None);
2241 PUSH(Py_None);
2242 } else
2243 PUSH(tb);
Guido van Rossum374a9221991-04-04 10:40:29 +00002244 PUSH(val);
2245 PUSH(exc);
2246 }
2247 else {
Jeremy Hylton3faa52e2001-02-01 22:48:12 +00002248 if (why == WHY_RETURN ||
Guido van Rossumc5fe5eb2002-06-12 03:45:21 +00002249 why == WHY_CONTINUE)
Guido van Rossum374a9221991-04-04 10:40:29 +00002250 PUSH(retval);
Guido van Rossumb209a111997-04-29 18:18:01 +00002251 v = PyInt_FromLong((long)why);
Guido van Rossum374a9221991-04-04 10:40:29 +00002252 PUSH(v);
2253 }
2254 why = WHY_NOT;
2255 JUMPTO(b->b_handler);
2256 break;
2257 }
2258 } /* unwind stack */
2259
2260 /* End the loop if we still have an error (or return) */
Guido van Rossumac7be682001-01-17 15:42:30 +00002261
Guido van Rossum374a9221991-04-04 10:40:29 +00002262 if (why != WHY_NOT)
2263 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00002264
Guido van Rossum374a9221991-04-04 10:40:29 +00002265 } /* main loop */
Guido van Rossumac7be682001-01-17 15:42:30 +00002266
Guido van Rossum35974fb2001-12-06 21:28:18 +00002267 if (why != WHY_YIELD) {
2268 /* Pop remaining stack entries -- but when yielding */
2269 while (!EMPTY()) {
2270 v = POP();
2271 Py_XDECREF(v);
2272 }
2273 }
2274
Tim Peters5ca576e2001-06-18 22:08:13 +00002275 if (why != WHY_RETURN && why != WHY_YIELD)
Guido van Rossum96a42c81992-01-12 02:29:51 +00002276 retval = NULL;
Guido van Rossumac7be682001-01-17 15:42:30 +00002277
Fred Drake9e3ad782001-07-03 23:39:52 +00002278 if (tstate->use_tracing) {
2279 if (tstate->c_tracefunc
2280 && (why == WHY_RETURN || why == WHY_YIELD)) {
2281 if (call_trace(tstate->c_tracefunc,
2282 tstate->c_traceobj, f,
2283 PyTrace_RETURN, retval)) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002284 Py_XDECREF(retval);
Guido van Rossum96a42c81992-01-12 02:29:51 +00002285 retval = NULL;
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002286 why = WHY_EXCEPTION;
Guido van Rossum96a42c81992-01-12 02:29:51 +00002287 }
Guido van Rossum96a42c81992-01-12 02:29:51 +00002288 }
Fred Drake8f51f542001-10-04 14:48:42 +00002289 if (tstate->c_profilefunc) {
Fred Drake4ec5d562001-10-04 19:26:43 +00002290 if (why == WHY_EXCEPTION)
2291 call_trace_protected(tstate->c_profilefunc,
2292 tstate->c_profileobj, f,
2293 PyTrace_RETURN);
2294 else if (call_trace(tstate->c_profilefunc,
2295 tstate->c_profileobj, f,
2296 PyTrace_RETURN, retval)) {
Fred Drake9e3ad782001-07-03 23:39:52 +00002297 Py_XDECREF(retval);
2298 retval = NULL;
2299 why = WHY_EXCEPTION;
2300 }
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002301 }
Guido van Rossum96a42c81992-01-12 02:29:51 +00002302 }
Guido van Rossuma4240131997-01-21 21:18:36 +00002303
Guido van Rossuma027efa1997-05-05 20:56:21 +00002304 reset_exc_info(tstate);
2305
Tim Peters5ca576e2001-06-18 22:08:13 +00002306 /* pop frame */
Guido van Rossuma027efa1997-05-05 20:56:21 +00002307 --tstate->recursion_depth;
Guido van Rossuma027efa1997-05-05 20:56:21 +00002308 tstate->frame = f->f_back;
Guido van Rossumac7be682001-01-17 15:42:30 +00002309
Guido van Rossum96a42c81992-01-12 02:29:51 +00002310 return retval;
Guido van Rossum374a9221991-04-04 10:40:29 +00002311}
2312
Tim Peters6d6c1a32001-08-02 04:15:00 +00002313PyObject *
2314PyEval_EvalCodeEx(PyCodeObject *co, PyObject *globals, PyObject *locals,
Tim Peters5ca576e2001-06-18 22:08:13 +00002315 PyObject **args, int argcount, PyObject **kws, int kwcount,
2316 PyObject **defs, int defcount, PyObject *closure)
2317{
2318 register PyFrameObject *f;
2319 register PyObject *retval = NULL;
2320 register PyObject **fastlocals, **freevars;
2321 PyThreadState *tstate = PyThreadState_GET();
2322 PyObject *x, *u;
2323
2324 if (globals == NULL) {
Jeremy Hylton910d7d42001-08-12 21:52:24 +00002325 PyErr_SetString(PyExc_SystemError,
2326 "PyEval_EvalCodeEx: NULL globals");
Tim Peters5ca576e2001-06-18 22:08:13 +00002327 return NULL;
2328 }
2329
2330 f = PyFrame_New(tstate, /*back*/
2331 co, /*code*/
2332 globals, locals);
2333 if (f == NULL)
2334 return NULL;
2335
2336 fastlocals = f->f_localsplus;
2337 freevars = f->f_localsplus + f->f_nlocals;
2338
2339 if (co->co_argcount > 0 ||
2340 co->co_flags & (CO_VARARGS | CO_VARKEYWORDS)) {
2341 int i;
2342 int n = argcount;
2343 PyObject *kwdict = NULL;
2344 if (co->co_flags & CO_VARKEYWORDS) {
2345 kwdict = PyDict_New();
2346 if (kwdict == NULL)
2347 goto fail;
2348 i = co->co_argcount;
2349 if (co->co_flags & CO_VARARGS)
2350 i++;
2351 SETLOCAL(i, kwdict);
2352 }
2353 if (argcount > co->co_argcount) {
2354 if (!(co->co_flags & CO_VARARGS)) {
2355 PyErr_Format(PyExc_TypeError,
2356 "%.200s() takes %s %d "
2357 "%sargument%s (%d given)",
2358 PyString_AsString(co->co_name),
2359 defcount ? "at most" : "exactly",
2360 co->co_argcount,
2361 kwcount ? "non-keyword " : "",
2362 co->co_argcount == 1 ? "" : "s",
2363 argcount);
2364 goto fail;
2365 }
2366 n = co->co_argcount;
2367 }
2368 for (i = 0; i < n; i++) {
2369 x = args[i];
2370 Py_INCREF(x);
2371 SETLOCAL(i, x);
2372 }
2373 if (co->co_flags & CO_VARARGS) {
2374 u = PyTuple_New(argcount - n);
2375 if (u == NULL)
2376 goto fail;
2377 SETLOCAL(co->co_argcount, u);
2378 for (i = n; i < argcount; i++) {
2379 x = args[i];
2380 Py_INCREF(x);
2381 PyTuple_SET_ITEM(u, i-n, x);
2382 }
2383 }
2384 for (i = 0; i < kwcount; i++) {
2385 PyObject *keyword = kws[2*i];
2386 PyObject *value = kws[2*i + 1];
2387 int j;
2388 if (keyword == NULL || !PyString_Check(keyword)) {
2389 PyErr_Format(PyExc_TypeError,
2390 "%.200s() keywords must be strings",
2391 PyString_AsString(co->co_name));
2392 goto fail;
2393 }
2394 /* XXX slow -- speed up using dictionary? */
2395 for (j = 0; j < co->co_argcount; j++) {
2396 PyObject *nm = PyTuple_GET_ITEM(
2397 co->co_varnames, j);
2398 int cmp = PyObject_RichCompareBool(
2399 keyword, nm, Py_EQ);
2400 if (cmp > 0)
2401 break;
2402 else if (cmp < 0)
2403 goto fail;
2404 }
2405 /* Check errors from Compare */
2406 if (PyErr_Occurred())
2407 goto fail;
2408 if (j >= co->co_argcount) {
2409 if (kwdict == NULL) {
2410 PyErr_Format(PyExc_TypeError,
2411 "%.200s() got an unexpected "
2412 "keyword argument '%.400s'",
2413 PyString_AsString(co->co_name),
2414 PyString_AsString(keyword));
2415 goto fail;
2416 }
2417 PyDict_SetItem(kwdict, keyword, value);
2418 }
2419 else {
2420 if (GETLOCAL(j) != NULL) {
2421 PyErr_Format(PyExc_TypeError,
2422 "%.200s() got multiple "
2423 "values for keyword "
2424 "argument '%.400s'",
2425 PyString_AsString(co->co_name),
2426 PyString_AsString(keyword));
2427 goto fail;
2428 }
2429 Py_INCREF(value);
2430 SETLOCAL(j, value);
2431 }
2432 }
2433 if (argcount < co->co_argcount) {
2434 int m = co->co_argcount - defcount;
2435 for (i = argcount; i < m; i++) {
2436 if (GETLOCAL(i) == NULL) {
2437 PyErr_Format(PyExc_TypeError,
2438 "%.200s() takes %s %d "
2439 "%sargument%s (%d given)",
2440 PyString_AsString(co->co_name),
2441 ((co->co_flags & CO_VARARGS) ||
2442 defcount) ? "at least"
2443 : "exactly",
2444 m, kwcount ? "non-keyword " : "",
2445 m == 1 ? "" : "s", i);
2446 goto fail;
2447 }
2448 }
2449 if (n > m)
2450 i = n - m;
2451 else
2452 i = 0;
2453 for (; i < defcount; i++) {
2454 if (GETLOCAL(m+i) == NULL) {
2455 PyObject *def = defs[i];
2456 Py_INCREF(def);
2457 SETLOCAL(m+i, def);
2458 }
2459 }
2460 }
2461 }
2462 else {
2463 if (argcount > 0 || kwcount > 0) {
2464 PyErr_Format(PyExc_TypeError,
2465 "%.200s() takes no arguments (%d given)",
2466 PyString_AsString(co->co_name),
2467 argcount + kwcount);
2468 goto fail;
2469 }
2470 }
2471 /* Allocate and initialize storage for cell vars, and copy free
2472 vars into frame. This isn't too efficient right now. */
2473 if (f->f_ncells) {
2474 int i = 0, j = 0, nargs, found;
2475 char *cellname, *argname;
2476 PyObject *c;
2477
2478 nargs = co->co_argcount;
2479 if (co->co_flags & CO_VARARGS)
2480 nargs++;
2481 if (co->co_flags & CO_VARKEYWORDS)
2482 nargs++;
2483
2484 /* Check for cells that shadow args */
2485 for (i = 0; i < f->f_ncells && j < nargs; ++i) {
2486 cellname = PyString_AS_STRING(
2487 PyTuple_GET_ITEM(co->co_cellvars, i));
2488 found = 0;
2489 while (j < nargs) {
2490 argname = PyString_AS_STRING(
2491 PyTuple_GET_ITEM(co->co_varnames, j));
2492 if (strcmp(cellname, argname) == 0) {
2493 c = PyCell_New(GETLOCAL(j));
2494 if (c == NULL)
2495 goto fail;
2496 GETLOCAL(f->f_nlocals + i) = c;
2497 found = 1;
2498 break;
2499 }
2500 j++;
2501 }
2502 if (found == 0) {
2503 c = PyCell_New(NULL);
2504 if (c == NULL)
2505 goto fail;
2506 SETLOCAL(f->f_nlocals + i, c);
2507 }
2508 }
2509 /* Initialize any that are left */
2510 while (i < f->f_ncells) {
2511 c = PyCell_New(NULL);
2512 if (c == NULL)
2513 goto fail;
2514 SETLOCAL(f->f_nlocals + i, c);
2515 i++;
2516 }
2517 }
2518 if (f->f_nfreevars) {
2519 int i;
2520 for (i = 0; i < f->f_nfreevars; ++i) {
2521 PyObject *o = PyTuple_GET_ITEM(closure, i);
2522 Py_INCREF(o);
2523 freevars[f->f_ncells + i] = o;
2524 }
2525 }
2526
Tim Peters5ca576e2001-06-18 22:08:13 +00002527 if (co->co_flags & CO_GENERATOR) {
Neil Schemenauer2b13ce82001-06-21 02:41:10 +00002528 /* Don't need to keep the reference to f_back, it will be set
2529 * when the generator is resumed. */
Tim Peters5ba58662001-07-16 02:29:45 +00002530 Py_XDECREF(f->f_back);
Neil Schemenauer2b13ce82001-06-21 02:41:10 +00002531 f->f_back = NULL;
2532
2533 /* Create a new generator that owns the ready to run frame
2534 * and return that as the value. */
Tim Peters5ca576e2001-06-18 22:08:13 +00002535 return gen_new(f);
2536 }
2537
2538 retval = eval_frame(f);
2539
2540 fail: /* Jump here from prelude on failure */
2541
Tim Petersb13680b2001-11-27 23:29:29 +00002542 /* decref'ing the frame can cause __del__ methods to get invoked,
2543 which can call back into Python. While we're done with the
2544 current Python frame (f), the associated C stack is still in use,
2545 so recursion_depth must be boosted for the duration.
2546 */
2547 assert(tstate != NULL);
2548 ++tstate->recursion_depth;
Tim Peters5ca576e2001-06-18 22:08:13 +00002549 Py_DECREF(f);
Tim Petersb13680b2001-11-27 23:29:29 +00002550 --tstate->recursion_depth;
Tim Peters5ca576e2001-06-18 22:08:13 +00002551 return retval;
2552}
2553
2554
Guido van Rossuma027efa1997-05-05 20:56:21 +00002555static void
Guido van Rossumac7be682001-01-17 15:42:30 +00002556set_exc_info(PyThreadState *tstate,
2557 PyObject *type, PyObject *value, PyObject *tb)
Guido van Rossuma027efa1997-05-05 20:56:21 +00002558{
2559 PyFrameObject *frame;
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002560 PyObject *tmp_type, *tmp_value, *tmp_tb;
Barry Warsaw4249f541997-08-22 21:26:19 +00002561
Guido van Rossuma027efa1997-05-05 20:56:21 +00002562 frame = tstate->frame;
2563 if (frame->f_exc_type == NULL) {
2564 /* This frame didn't catch an exception before */
2565 /* Save previous exception of this thread in this frame */
Guido van Rossuma027efa1997-05-05 20:56:21 +00002566 if (tstate->exc_type == NULL) {
2567 Py_INCREF(Py_None);
2568 tstate->exc_type = Py_None;
2569 }
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002570 tmp_type = frame->f_exc_type;
2571 tmp_value = frame->f_exc_value;
2572 tmp_tb = frame->f_exc_traceback;
Guido van Rossuma027efa1997-05-05 20:56:21 +00002573 Py_XINCREF(tstate->exc_type);
2574 Py_XINCREF(tstate->exc_value);
2575 Py_XINCREF(tstate->exc_traceback);
2576 frame->f_exc_type = tstate->exc_type;
2577 frame->f_exc_value = tstate->exc_value;
2578 frame->f_exc_traceback = tstate->exc_traceback;
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002579 Py_XDECREF(tmp_type);
2580 Py_XDECREF(tmp_value);
2581 Py_XDECREF(tmp_tb);
Guido van Rossuma027efa1997-05-05 20:56:21 +00002582 }
2583 /* Set new exception for this thread */
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002584 tmp_type = tstate->exc_type;
2585 tmp_value = tstate->exc_value;
2586 tmp_tb = tstate->exc_traceback;
Guido van Rossuma027efa1997-05-05 20:56:21 +00002587 Py_XINCREF(type);
2588 Py_XINCREF(value);
2589 Py_XINCREF(tb);
2590 tstate->exc_type = type;
2591 tstate->exc_value = value;
2592 tstate->exc_traceback = tb;
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002593 Py_XDECREF(tmp_type);
2594 Py_XDECREF(tmp_value);
2595 Py_XDECREF(tmp_tb);
Guido van Rossuma027efa1997-05-05 20:56:21 +00002596 /* For b/w compatibility */
2597 PySys_SetObject("exc_type", type);
2598 PySys_SetObject("exc_value", value);
2599 PySys_SetObject("exc_traceback", tb);
2600}
2601
2602static void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002603reset_exc_info(PyThreadState *tstate)
Guido van Rossuma027efa1997-05-05 20:56:21 +00002604{
2605 PyFrameObject *frame;
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002606 PyObject *tmp_type, *tmp_value, *tmp_tb;
Guido van Rossuma027efa1997-05-05 20:56:21 +00002607 frame = tstate->frame;
2608 if (frame->f_exc_type != NULL) {
2609 /* This frame caught an exception */
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002610 tmp_type = tstate->exc_type;
2611 tmp_value = tstate->exc_value;
2612 tmp_tb = tstate->exc_traceback;
Guido van Rossuma027efa1997-05-05 20:56:21 +00002613 Py_XINCREF(frame->f_exc_type);
2614 Py_XINCREF(frame->f_exc_value);
2615 Py_XINCREF(frame->f_exc_traceback);
2616 tstate->exc_type = frame->f_exc_type;
2617 tstate->exc_value = frame->f_exc_value;
2618 tstate->exc_traceback = frame->f_exc_traceback;
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002619 Py_XDECREF(tmp_type);
2620 Py_XDECREF(tmp_value);
2621 Py_XDECREF(tmp_tb);
Guido van Rossuma027efa1997-05-05 20:56:21 +00002622 /* For b/w compatibility */
2623 PySys_SetObject("exc_type", frame->f_exc_type);
2624 PySys_SetObject("exc_value", frame->f_exc_value);
2625 PySys_SetObject("exc_traceback", frame->f_exc_traceback);
2626 }
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002627 tmp_type = frame->f_exc_type;
2628 tmp_value = frame->f_exc_value;
2629 tmp_tb = frame->f_exc_traceback;
Guido van Rossuma027efa1997-05-05 20:56:21 +00002630 frame->f_exc_type = NULL;
2631 frame->f_exc_value = NULL;
2632 frame->f_exc_traceback = NULL;
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002633 Py_XDECREF(tmp_type);
2634 Py_XDECREF(tmp_value);
2635 Py_XDECREF(tmp_tb);
Guido van Rossuma027efa1997-05-05 20:56:21 +00002636}
2637
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002638/* Logic for the raise statement (too complicated for inlining).
2639 This *consumes* a reference count to each of its arguments. */
Guido van Rossum1aa14831997-01-21 05:34:20 +00002640static enum why_code
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002641do_raise(PyObject *type, PyObject *value, PyObject *tb)
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002642{
Guido van Rossumd295f121998-04-09 21:39:57 +00002643 if (type == NULL) {
2644 /* Reraise */
2645 PyThreadState *tstate = PyThreadState_Get();
2646 type = tstate->exc_type == NULL ? Py_None : tstate->exc_type;
2647 value = tstate->exc_value;
2648 tb = tstate->exc_traceback;
2649 Py_XINCREF(type);
2650 Py_XINCREF(value);
2651 Py_XINCREF(tb);
2652 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002653
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002654 /* We support the following forms of raise:
2655 raise <class>, <classinstance>
2656 raise <class>, <argument tuple>
2657 raise <class>, None
2658 raise <class>, <argument>
2659 raise <classinstance>, None
2660 raise <string>, <object>
2661 raise <string>, None
2662
2663 An omitted second argument is the same as None.
2664
2665 In addition, raise <tuple>, <anything> is the same as
2666 raising the tuple's first item (and it better have one!);
2667 this rule is applied recursively.
2668
2669 Finally, an optional third argument can be supplied, which
2670 gives the traceback to be substituted (useful when
2671 re-raising an exception after examining it). */
2672
2673 /* First, check the traceback argument, replacing None with
2674 NULL. */
Guido van Rossumb209a111997-04-29 18:18:01 +00002675 if (tb == Py_None) {
2676 Py_DECREF(tb);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002677 tb = NULL;
2678 }
2679 else if (tb != NULL && !PyTraceBack_Check(tb)) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002680 PyErr_SetString(PyExc_TypeError,
Fred Drake661ea262000-10-24 19:57:45 +00002681 "raise: arg 3 must be a traceback or None");
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002682 goto raise_error;
2683 }
2684
2685 /* Next, replace a missing value with None */
2686 if (value == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002687 value = Py_None;
2688 Py_INCREF(value);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002689 }
2690
2691 /* Next, repeatedly, replace a tuple exception with its first item */
Guido van Rossumb209a111997-04-29 18:18:01 +00002692 while (PyTuple_Check(type) && PyTuple_Size(type) > 0) {
2693 PyObject *tmp = type;
2694 type = PyTuple_GET_ITEM(type, 0);
2695 Py_INCREF(type);
2696 Py_DECREF(tmp);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002697 }
2698
Tim Petersafb2c802002-04-18 18:06:20 +00002699 if (PyString_CheckExact(type))
2700 /* Raising builtin string is deprecated but still allowed --
2701 * do nothing. Raising an instance of a new-style str
2702 * subclass is right out. */
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002703 ;
Barry Warsaw4249f541997-08-22 21:26:19 +00002704
2705 else if (PyClass_Check(type))
2706 PyErr_NormalizeException(&type, &value, &tb);
2707
Guido van Rossumb209a111997-04-29 18:18:01 +00002708 else if (PyInstance_Check(type)) {
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002709 /* Raising an instance. The value should be a dummy. */
Guido van Rossumb209a111997-04-29 18:18:01 +00002710 if (value != Py_None) {
2711 PyErr_SetString(PyExc_TypeError,
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002712 "instance exception may not have a separate value");
2713 goto raise_error;
2714 }
2715 else {
2716 /* Normalize to raise <class>, <instance> */
Guido van Rossumb209a111997-04-29 18:18:01 +00002717 Py_DECREF(value);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002718 value = type;
Guido van Rossumb209a111997-04-29 18:18:01 +00002719 type = (PyObject*) ((PyInstanceObject*)type)->in_class;
2720 Py_INCREF(type);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002721 }
2722 }
2723 else {
2724 /* Not something you can raise. You get an exception
2725 anyway, just not what you specified :-) */
Jeremy Hylton960d9482001-04-27 02:25:33 +00002726 PyErr_Format(PyExc_TypeError,
2727 "exceptions must be strings, classes, or "
2728 "instances, not %s", type->ob_type->tp_name);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002729 goto raise_error;
2730 }
Guido van Rossumb209a111997-04-29 18:18:01 +00002731 PyErr_Restore(type, value, tb);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002732 if (tb == NULL)
2733 return WHY_EXCEPTION;
2734 else
2735 return WHY_RERAISE;
2736 raise_error:
Guido van Rossumb209a111997-04-29 18:18:01 +00002737 Py_XDECREF(value);
2738 Py_XDECREF(type);
2739 Py_XDECREF(tb);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002740 return WHY_EXCEPTION;
2741}
2742
Tim Petersd6d010b2001-06-21 02:49:55 +00002743/* Iterate v argcnt times and store the results on the stack (via decreasing
2744 sp). Return 1 for success, 0 if error. */
2745
Barry Warsawe42b18f1997-08-25 22:13:04 +00002746static int
Tim Petersd6d010b2001-06-21 02:49:55 +00002747unpack_iterable(PyObject *v, int argcnt, PyObject **sp)
Barry Warsawe42b18f1997-08-25 22:13:04 +00002748{
Tim Petersd6d010b2001-06-21 02:49:55 +00002749 int i = 0;
2750 PyObject *it; /* iter(v) */
Barry Warsawe42b18f1997-08-25 22:13:04 +00002751 PyObject *w;
Guido van Rossumac7be682001-01-17 15:42:30 +00002752
Tim Petersd6d010b2001-06-21 02:49:55 +00002753 assert(v != NULL);
2754
2755 it = PyObject_GetIter(v);
2756 if (it == NULL)
2757 goto Error;
2758
2759 for (; i < argcnt; i++) {
2760 w = PyIter_Next(it);
2761 if (w == NULL) {
2762 /* Iterator done, via error or exhaustion. */
2763 if (!PyErr_Occurred()) {
2764 PyErr_Format(PyExc_ValueError,
2765 "need more than %d value%s to unpack",
2766 i, i == 1 ? "" : "s");
2767 }
2768 goto Error;
Barry Warsawe42b18f1997-08-25 22:13:04 +00002769 }
2770 *--sp = w;
2771 }
Tim Petersd6d010b2001-06-21 02:49:55 +00002772
2773 /* We better have exhausted the iterator now. */
2774 w = PyIter_Next(it);
2775 if (w == NULL) {
2776 if (PyErr_Occurred())
2777 goto Error;
2778 Py_DECREF(it);
2779 return 1;
Barry Warsawe42b18f1997-08-25 22:13:04 +00002780 }
Guido van Rossumbb8f59a2001-12-03 19:33:25 +00002781 Py_DECREF(w);
Tim Petersd6d010b2001-06-21 02:49:55 +00002782 PyErr_SetString(PyExc_ValueError, "too many values to unpack");
Barry Warsawe42b18f1997-08-25 22:13:04 +00002783 /* fall through */
Tim Petersd6d010b2001-06-21 02:49:55 +00002784Error:
Barry Warsaw91010551997-08-25 22:30:51 +00002785 for (; i > 0; i--, sp++)
2786 Py_DECREF(*sp);
Tim Petersd6d010b2001-06-21 02:49:55 +00002787 Py_XDECREF(it);
Barry Warsawe42b18f1997-08-25 22:13:04 +00002788 return 0;
2789}
2790
2791
Guido van Rossum96a42c81992-01-12 02:29:51 +00002792#ifdef LLTRACE
Guido van Rossum3f5da241990-12-20 15:06:42 +00002793static int
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002794prtrace(PyObject *v, char *str)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00002795{
Guido van Rossum3f5da241990-12-20 15:06:42 +00002796 printf("%s ", str);
Guido van Rossumb209a111997-04-29 18:18:01 +00002797 if (PyObject_Print(v, stdout, 0) != 0)
2798 PyErr_Clear(); /* Don't know what else to do */
Guido van Rossum3f5da241990-12-20 15:06:42 +00002799 printf("\n");
Guido van Rossumcc229ea2000-05-04 00:55:17 +00002800 return 1;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00002801}
Guido van Rossum3f5da241990-12-20 15:06:42 +00002802#endif
Guido van Rossum10dc2e81990-11-18 17:27:39 +00002803
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002804static void
Fred Drake5755ce62001-06-27 19:19:46 +00002805call_exc_trace(Py_tracefunc func, PyObject *self, PyFrameObject *f)
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002806{
Guido van Rossumb209a111997-04-29 18:18:01 +00002807 PyObject *type, *value, *traceback, *arg;
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002808 int err;
Guido van Rossumb209a111997-04-29 18:18:01 +00002809 PyErr_Fetch(&type, &value, &traceback);
Guido van Rossumbd9ccca1992-04-09 14:58:08 +00002810 if (value == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002811 value = Py_None;
2812 Py_INCREF(value);
Guido van Rossumbd9ccca1992-04-09 14:58:08 +00002813 }
Guido van Rossumb209a111997-04-29 18:18:01 +00002814 arg = Py_BuildValue("(OOO)", type, value, traceback);
Guido van Rossum1ae940a1995-01-02 19:04:15 +00002815 if (arg == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002816 PyErr_Restore(type, value, traceback);
Guido van Rossum1ae940a1995-01-02 19:04:15 +00002817 return;
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002818 }
Fred Drake5755ce62001-06-27 19:19:46 +00002819 err = call_trace(func, self, f, PyTrace_EXCEPTION, arg);
Guido van Rossumb209a111997-04-29 18:18:01 +00002820 Py_DECREF(arg);
Guido van Rossum1ae940a1995-01-02 19:04:15 +00002821 if (err == 0)
Guido van Rossumb209a111997-04-29 18:18:01 +00002822 PyErr_Restore(type, value, traceback);
Guido van Rossum1ae940a1995-01-02 19:04:15 +00002823 else {
Guido van Rossumb209a111997-04-29 18:18:01 +00002824 Py_XDECREF(type);
2825 Py_XDECREF(value);
2826 Py_XDECREF(traceback);
Guido van Rossum1ae940a1995-01-02 19:04:15 +00002827 }
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002828}
2829
Fred Drake4ec5d562001-10-04 19:26:43 +00002830static void
2831call_trace_protected(Py_tracefunc func, PyObject *obj, PyFrameObject *frame,
2832 int what)
2833{
2834 PyObject *type, *value, *traceback;
2835 int err;
2836 PyErr_Fetch(&type, &value, &traceback);
2837 err = call_trace(func, obj, frame, what, NULL);
2838 if (err == 0)
2839 PyErr_Restore(type, value, traceback);
2840 else {
2841 Py_XDECREF(type);
2842 Py_XDECREF(value);
2843 Py_XDECREF(traceback);
2844 }
2845}
2846
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002847static int
Fred Drake5755ce62001-06-27 19:19:46 +00002848call_trace(Py_tracefunc func, PyObject *obj, PyFrameObject *frame,
2849 int what, PyObject *arg)
Guido van Rossum96a42c81992-01-12 02:29:51 +00002850{
Fred Drake5755ce62001-06-27 19:19:46 +00002851 register PyThreadState *tstate = frame->f_tstate;
2852 int result;
2853 if (tstate->tracing)
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002854 return 0;
Guido van Rossuma027efa1997-05-05 20:56:21 +00002855 tstate->tracing++;
Fred Drake9e3ad782001-07-03 23:39:52 +00002856 tstate->use_tracing = 0;
Fred Drake5755ce62001-06-27 19:19:46 +00002857 result = func(obj, frame, what, arg);
Fred Drake9e3ad782001-07-03 23:39:52 +00002858 tstate->use_tracing = ((tstate->c_tracefunc != NULL)
2859 || (tstate->c_profilefunc != NULL));
Guido van Rossuma027efa1997-05-05 20:56:21 +00002860 tstate->tracing--;
Fred Drake5755ce62001-06-27 19:19:46 +00002861 return result;
Guido van Rossum96a42c81992-01-12 02:29:51 +00002862}
2863
Michael W. Hudsondd32a912002-08-15 14:59:02 +00002864static void
2865maybe_call_line_trace(int opcode, Py_tracefunc func, PyObject *obj,
2866 PyFrameObject *frame, int *instr_lb, int *instr_ub)
2867{
2868 /* The theory of SET_LINENO-less tracing.
2869
2870 In a nutshell, we use the co_lnotab field of the code object
2871 to tell when execution has moved onto a different line.
2872
2873 As mentioned above, the basic idea is so set things up so
2874 that
2875
2876 *instr_lb <= frame->f_lasti < *instr_ub
2877
2878 is true so long as execution does not change lines.
2879
2880 This is all fairly simple. Digging the information out of
2881 co_lnotab takes some work, but is conceptually clear.
2882
2883 Somewhat harder to explain is why we don't call the line
2884 trace function when executing a POP_TOP or RETURN_NONE
2885 opcodes. An example probably serves best.
2886
2887 Consider this code:
2888
2889 1: def f(a):
2890 2: if a:
2891 3: print 1
2892 4: else:
2893 5: print 2
2894
2895 which compiles to this:
2896
2897 2 0 LOAD_FAST 0 (a)
2898 3 JUMP_IF_FALSE 9 (to 15)
2899 6 POP_TOP
2900
2901 3 7 LOAD_CONST 1 (1)
2902 10 PRINT_ITEM
2903 11 PRINT_NEWLINE
2904 12 JUMP_FORWARD 6 (to 21)
2905 >> 15 POP_TOP
2906
2907 5 16 LOAD_CONST 2 (2)
2908 19 PRINT_ITEM
2909 20 PRINT_NEWLINE
2910 >> 21 RETURN_NONE
2911
2912 If a is false, execution will jump to instruction at offset
2913 15 and the co_lnotab will claim that execution has moved to
2914 line 3. This is at best misleading. In this case we could
2915 associate the POP_TOP with line 4, but that doesn't make
2916 sense in all cases (I think).
2917
2918 On the other hand, if a is true, execution will jump from
2919 instruction offset 12 to offset 21. Then the co_lnotab would
2920 imply that execution has moved to line 5, which is again
2921 misleading.
2922
2923 This is why it is important that RETURN_NONE is *only* used
2924 for the "falling off the end of the function" form of
2925 returning None -- using it for code like
2926
2927 1: def f():
2928 2: return
2929
2930 would, once again, lead to misleading tracing behaviour.
2931
2932 It is also worth mentioning that getting tracing behaviour
2933 right is the *entire* motivation for adding the RETURN_NONE
2934 opcode.
2935 */
2936
2937 if (opcode != POP_TOP && opcode != RETURN_NONE &&
2938 (frame->f_lasti < *instr_lb || frame->f_lasti > *instr_ub)) {
2939 PyCodeObject* co = frame->f_code;
2940 int size, addr;
2941 unsigned char* p;
2942
2943 call_trace(func, obj, frame, PyTrace_LINE, Py_None);
2944
2945 size = PyString_Size(co->co_lnotab) / 2;
2946 p = (unsigned char*)PyString_AsString(co->co_lnotab);
2947
2948 /* possible optimization: if f->f_lasti == instr_ub
2949 (likely to be a common case) then we already know
2950 instr_lb -- if we stored the matching value of p
2951 somwhere we could skip the first while loop. */
2952
2953 addr = 0;
2954
2955 /* see comments in compile.c for the description of
2956 co_lnotab. A point to remember: increments to p
2957 should come in pairs -- although we don't care about
2958 the line increments here, treating them as byte
2959 increments gets confusing, to say the least. */
2960
2961 while (size >= 0) {
2962 if (addr + *p > frame->f_lasti)
2963 break;
2964 addr += *p++;
2965 p++;
2966 --size;
2967 }
2968 *instr_lb = addr;
2969 if (size > 0) {
2970 while (--size >= 0) {
2971 addr += *p++;
2972 if (*p++)
2973 break;
2974 }
2975 *instr_ub = addr;
2976 }
2977 else {
2978 *instr_ub = INT_MAX;
2979 }
2980 }
2981}
2982
Fred Drake5755ce62001-06-27 19:19:46 +00002983void
2984PyEval_SetProfile(Py_tracefunc func, PyObject *arg)
Fred Draked0838392001-06-16 21:02:31 +00002985{
Fred Drake5755ce62001-06-27 19:19:46 +00002986 PyThreadState *tstate = PyThreadState_Get();
2987 PyObject *temp = tstate->c_profileobj;
2988 Py_XINCREF(arg);
2989 tstate->c_profilefunc = NULL;
2990 tstate->c_profileobj = NULL;
Fred Drake9e3ad782001-07-03 23:39:52 +00002991 tstate->use_tracing = tstate->c_tracefunc != NULL;
Fred Drake5755ce62001-06-27 19:19:46 +00002992 Py_XDECREF(temp);
2993 tstate->c_profilefunc = func;
2994 tstate->c_profileobj = arg;
Fred Drake9e3ad782001-07-03 23:39:52 +00002995 tstate->use_tracing = (func != NULL) || (tstate->c_tracefunc != NULL);
Fred Drake5755ce62001-06-27 19:19:46 +00002996}
2997
2998void
2999PyEval_SetTrace(Py_tracefunc func, PyObject *arg)
3000{
3001 PyThreadState *tstate = PyThreadState_Get();
3002 PyObject *temp = tstate->c_traceobj;
3003 Py_XINCREF(arg);
3004 tstate->c_tracefunc = NULL;
3005 tstate->c_traceobj = NULL;
Fred Drake9e3ad782001-07-03 23:39:52 +00003006 tstate->use_tracing = tstate->c_profilefunc != NULL;
Fred Drake5755ce62001-06-27 19:19:46 +00003007 Py_XDECREF(temp);
3008 tstate->c_tracefunc = func;
3009 tstate->c_traceobj = arg;
Fred Drake9e3ad782001-07-03 23:39:52 +00003010 tstate->use_tracing = ((func != NULL)
3011 || (tstate->c_profilefunc != NULL));
Fred Draked0838392001-06-16 21:02:31 +00003012}
3013
Guido van Rossumb209a111997-04-29 18:18:01 +00003014PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003015PyEval_GetBuiltins(void)
Guido van Rossum6135a871995-01-09 17:53:26 +00003016{
Guido van Rossum25ce5661997-08-02 03:10:38 +00003017 PyThreadState *tstate = PyThreadState_Get();
3018 PyFrameObject *current_frame = tstate->frame;
Guido van Rossum6135a871995-01-09 17:53:26 +00003019 if (current_frame == NULL)
Guido van Rossum25ce5661997-08-02 03:10:38 +00003020 return tstate->interp->builtins;
Guido van Rossum6135a871995-01-09 17:53:26 +00003021 else
3022 return current_frame->f_builtins;
3023}
3024
Guido van Rossumb209a111997-04-29 18:18:01 +00003025PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003026PyEval_GetLocals(void)
Guido van Rossum5b722181993-03-30 17:46:03 +00003027{
Guido van Rossuma027efa1997-05-05 20:56:21 +00003028 PyFrameObject *current_frame = PyThreadState_Get()->frame;
Guido van Rossum5b722181993-03-30 17:46:03 +00003029 if (current_frame == NULL)
3030 return NULL;
Guido van Rossumb209a111997-04-29 18:18:01 +00003031 PyFrame_FastToLocals(current_frame);
Guido van Rossum5b722181993-03-30 17:46:03 +00003032 return current_frame->f_locals;
3033}
3034
Guido van Rossumb209a111997-04-29 18:18:01 +00003035PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003036PyEval_GetGlobals(void)
Guido van Rossum3f5da241990-12-20 15:06:42 +00003037{
Guido van Rossuma027efa1997-05-05 20:56:21 +00003038 PyFrameObject *current_frame = PyThreadState_Get()->frame;
Guido van Rossum3f5da241990-12-20 15:06:42 +00003039 if (current_frame == NULL)
3040 return NULL;
3041 else
3042 return current_frame->f_globals;
3043}
3044
Guido van Rossumb209a111997-04-29 18:18:01 +00003045PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003046PyEval_GetFrame(void)
Guido van Rossume59214e1994-08-30 08:01:59 +00003047{
Guido van Rossuma027efa1997-05-05 20:56:21 +00003048 PyFrameObject *current_frame = PyThreadState_Get()->frame;
Guido van Rossumb209a111997-04-29 18:18:01 +00003049 return (PyObject *)current_frame;
Guido van Rossume59214e1994-08-30 08:01:59 +00003050}
3051
Guido van Rossum6135a871995-01-09 17:53:26 +00003052int
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003053PyEval_GetRestricted(void)
Guido van Rossum6135a871995-01-09 17:53:26 +00003054{
Guido van Rossuma027efa1997-05-05 20:56:21 +00003055 PyFrameObject *current_frame = PyThreadState_Get()->frame;
Guido van Rossum6135a871995-01-09 17:53:26 +00003056 return current_frame == NULL ? 0 : current_frame->f_restricted;
3057}
3058
Guido van Rossumbe270261997-05-22 22:26:18 +00003059int
Tim Peters5ba58662001-07-16 02:29:45 +00003060PyEval_MergeCompilerFlags(PyCompilerFlags *cf)
Jeremy Hylton061d1062001-03-22 02:32:48 +00003061{
3062 PyFrameObject *current_frame = PyThreadState_Get()->frame;
Tim Peters5ba58662001-07-16 02:29:45 +00003063 int result = 0;
3064
3065 if (current_frame != NULL) {
3066 const int codeflags = current_frame->f_code->co_flags;
Tim Peterse2c18e92001-08-17 20:47:47 +00003067 const int compilerflags = codeflags & PyCF_MASK;
3068 if (compilerflags) {
Tim Peters5ba58662001-07-16 02:29:45 +00003069 result = 1;
Tim Peterse2c18e92001-08-17 20:47:47 +00003070 cf->cf_flags |= compilerflags;
Tim Peters5ba58662001-07-16 02:29:45 +00003071 }
Neil Schemenauerc24ea082002-03-22 23:53:36 +00003072#if 0 /* future keyword */
Martin v. Löwis7198a522002-01-01 19:59:11 +00003073 if (codeflags & CO_GENERATOR_ALLOWED) {
3074 result = 1;
3075 cf->cf_flags |= CO_GENERATOR_ALLOWED;
3076 }
Neil Schemenauerc24ea082002-03-22 23:53:36 +00003077#endif
Tim Peters5ba58662001-07-16 02:29:45 +00003078 }
3079 return result;
Jeremy Hylton061d1062001-03-22 02:32:48 +00003080}
3081
3082int
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003083Py_FlushLine(void)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003084{
Guido van Rossumb209a111997-04-29 18:18:01 +00003085 PyObject *f = PySys_GetObject("stdout");
Guido van Rossumbe270261997-05-22 22:26:18 +00003086 if (f == NULL)
3087 return 0;
3088 if (!PyFile_SoftSpace(f, 0))
3089 return 0;
3090 return PyFile_WriteString("\n", f);
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003091}
3092
Guido van Rossum3f5da241990-12-20 15:06:42 +00003093
Guido van Rossum681d79a1995-07-18 14:51:37 +00003094/* External interface to call any callable object.
3095 The arg must be a tuple or NULL. */
Guido van Rossum83bf35c1991-07-27 21:32:34 +00003096
Guido van Rossumd7ed6831997-08-30 15:02:50 +00003097#undef PyEval_CallObject
3098/* for backward compatibility: export this interface */
3099
Guido van Rossumb209a111997-04-29 18:18:01 +00003100PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003101PyEval_CallObject(PyObject *func, PyObject *arg)
Guido van Rossum83bf35c1991-07-27 21:32:34 +00003102{
Guido van Rossumb209a111997-04-29 18:18:01 +00003103 return PyEval_CallObjectWithKeywords(func, arg, (PyObject *)NULL);
Guido van Rossum681d79a1995-07-18 14:51:37 +00003104}
Guido van Rossumd7ed6831997-08-30 15:02:50 +00003105#define PyEval_CallObject(func,arg) \
3106 PyEval_CallObjectWithKeywords(func, arg, (PyObject *)NULL)
Guido van Rossume59214e1994-08-30 08:01:59 +00003107
Guido van Rossumb209a111997-04-29 18:18:01 +00003108PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003109PyEval_CallObjectWithKeywords(PyObject *func, PyObject *arg, PyObject *kw)
Guido van Rossum681d79a1995-07-18 14:51:37 +00003110{
Jeremy Hylton52820442001-01-03 23:52:36 +00003111 PyObject *result;
Guido van Rossum681d79a1995-07-18 14:51:37 +00003112
3113 if (arg == NULL)
Guido van Rossumb209a111997-04-29 18:18:01 +00003114 arg = PyTuple_New(0);
3115 else if (!PyTuple_Check(arg)) {
Guido van Rossuma027efa1997-05-05 20:56:21 +00003116 PyErr_SetString(PyExc_TypeError,
3117 "argument list must be a tuple");
Guido van Rossum681d79a1995-07-18 14:51:37 +00003118 return NULL;
3119 }
3120 else
Guido van Rossumb209a111997-04-29 18:18:01 +00003121 Py_INCREF(arg);
Guido van Rossum681d79a1995-07-18 14:51:37 +00003122
Guido van Rossumb209a111997-04-29 18:18:01 +00003123 if (kw != NULL && !PyDict_Check(kw)) {
Guido van Rossuma027efa1997-05-05 20:56:21 +00003124 PyErr_SetString(PyExc_TypeError,
3125 "keyword list must be a dictionary");
Guido van Rossum25826c92000-04-21 21:17:39 +00003126 Py_DECREF(arg);
Guido van Rossume3e61c11995-08-04 04:14:47 +00003127 return NULL;
3128 }
3129
Tim Peters6d6c1a32001-08-02 04:15:00 +00003130 result = PyObject_Call(func, arg, kw);
Guido van Rossumb209a111997-04-29 18:18:01 +00003131 Py_DECREF(arg);
Jeremy Hylton52820442001-01-03 23:52:36 +00003132 return result;
3133}
3134
Tim Peters6d6c1a32001-08-02 04:15:00 +00003135char *
3136PyEval_GetFuncName(PyObject *func)
Jeremy Hylton512a2372001-04-11 13:52:29 +00003137{
3138 if (PyMethod_Check(func))
Tim Peters6d6c1a32001-08-02 04:15:00 +00003139 return PyEval_GetFuncName(PyMethod_GET_FUNCTION(func));
Jeremy Hylton512a2372001-04-11 13:52:29 +00003140 else if (PyFunction_Check(func))
3141 return PyString_AsString(((PyFunctionObject*)func)->func_name);
3142 else if (PyCFunction_Check(func))
3143 return ((PyCFunctionObject*)func)->m_ml->ml_name;
3144 else if (PyClass_Check(func))
3145 return PyString_AsString(((PyClassObject*)func)->cl_name);
3146 else if (PyInstance_Check(func)) {
3147 return PyString_AsString(
3148 ((PyInstanceObject*)func)->in_class->cl_name);
3149 } else {
3150 return func->ob_type->tp_name;
3151 }
3152}
3153
Tim Peters6d6c1a32001-08-02 04:15:00 +00003154char *
3155PyEval_GetFuncDesc(PyObject *func)
Jeremy Hylton512a2372001-04-11 13:52:29 +00003156{
3157 if (PyMethod_Check(func))
3158 return "()";
3159 else if (PyFunction_Check(func))
3160 return "()";
3161 else if (PyCFunction_Check(func))
3162 return "()";
3163 else if (PyClass_Check(func))
3164 return " constructor";
3165 else if (PyInstance_Check(func)) {
3166 return " instance";
3167 } else {
3168 return " object";
3169 }
3170}
3171
Jeremy Hylton52820442001-01-03 23:52:36 +00003172#define EXT_POP(STACK_POINTER) (*--(STACK_POINTER))
3173
Jeremy Hylton192690e2002-08-16 18:36:11 +00003174void
3175err_args(PyObject *func, int flags, int nargs)
3176{
3177 if (flags & METH_NOARGS)
3178 PyErr_Format(PyExc_TypeError,
3179 "%.200s() takes 1 argument (%d given)",
3180 ((PyCFunctionObject *)func)->m_ml->ml_name,
3181 nargs);
3182 else
3183 PyErr_Format(PyExc_TypeError,
3184 "%.200s() takes no arguments (%d given)",
3185 ((PyCFunctionObject *)func)->m_ml->ml_name,
3186 nargs);
3187}
3188
Jeremy Hyltone8c04322002-08-16 17:47:26 +00003189static PyObject *
3190call_function(PyObject ***pp_stack, int oparg)
3191{
3192 int na = oparg & 0xff;
3193 int nk = (oparg>>8) & 0xff;
3194 int n = na + 2 * nk;
3195 PyObject **pfunc = (*pp_stack) - n - 1;
3196 PyObject *func = *pfunc;
3197 PyObject *x, *w;
3198
3199 /* Always dispatch PyCFunction first, because
3200 these are presumed to be the most frequent
3201 callable object.
3202 */
3203 if (PyCFunction_Check(func) && nk == 0) {
3204 int flags = PyCFunction_GET_FLAGS(func);
Jeremy Hylton192690e2002-08-16 18:36:11 +00003205 if (flags & (METH_NOARGS | METH_O)) {
3206 PyCFunction meth = PyCFunction_GET_FUNCTION(func);
3207 PyObject *self = PyCFunction_GET_SELF(func);
3208 if (flags & METH_NOARGS && na == 0)
3209 x = (*meth)(self, NULL);
3210 else if (flags & METH_O && na == 1) {
3211 PyObject *arg = EXT_POP(*pp_stack);
3212 x = (*meth)(self, arg);
3213 Py_DECREF(arg);
3214 }
3215 else {
3216 err_args(func, flags, na);
3217 x = NULL;
3218 }
3219 }
3220 else {
Jeremy Hyltone8c04322002-08-16 17:47:26 +00003221 PyObject *callargs;
3222 callargs = load_args(pp_stack, na);
3223 x = PyCFunction_Call(func, callargs, NULL);
3224 Py_XDECREF(callargs);
Jeremy Hylton192690e2002-08-16 18:36:11 +00003225 }
Jeremy Hyltone8c04322002-08-16 17:47:26 +00003226 } else {
3227 if (PyMethod_Check(func) && PyMethod_GET_SELF(func) != NULL) {
3228 /* optimize access to bound methods */
3229 PyObject *self = PyMethod_GET_SELF(func);
3230 Py_INCREF(self);
3231 func = PyMethod_GET_FUNCTION(func);
3232 Py_INCREF(func);
3233 Py_DECREF(*pfunc);
3234 *pfunc = self;
3235 na++;
3236 n++;
3237 } else
3238 Py_INCREF(func);
3239 if (PyFunction_Check(func))
3240 x = fast_function(func, pp_stack, n, na, nk);
3241 else
3242 x = do_call(func, pp_stack, na, nk);
3243 Py_DECREF(func);
3244 }
3245
3246 while ((*pp_stack) > pfunc) {
3247 w = EXT_POP(*pp_stack);
3248 Py_DECREF(w);
3249 }
3250 return x;
3251}
3252
Jeremy Hylton192690e2002-08-16 18:36:11 +00003253/* The fast_function() function optimize calls for which no argument
Jeremy Hylton52820442001-01-03 23:52:36 +00003254 tuple is necessary; the objects are passed directly from the stack.
Jeremy Hylton52820442001-01-03 23:52:36 +00003255*/
3256
3257static PyObject *
Guido van Rossumac7be682001-01-17 15:42:30 +00003258fast_function(PyObject *func, PyObject ***pp_stack, int n, int na, int nk)
Jeremy Hylton52820442001-01-03 23:52:36 +00003259{
3260 PyObject *co = PyFunction_GET_CODE(func);
3261 PyObject *globals = PyFunction_GET_GLOBALS(func);
3262 PyObject *argdefs = PyFunction_GET_DEFAULTS(func);
Jeremy Hylton64949cb2001-01-25 20:06:59 +00003263 PyObject *closure = PyFunction_GET_CLOSURE(func);
Jeremy Hylton52820442001-01-03 23:52:36 +00003264 PyObject **d = NULL;
3265 int nd = 0;
3266
3267 if (argdefs != NULL) {
3268 d = &PyTuple_GET_ITEM(argdefs, 0);
3269 nd = ((PyTupleObject *)argdefs)->ob_size;
3270 }
Tim Peters6d6c1a32001-08-02 04:15:00 +00003271 return PyEval_EvalCodeEx((PyCodeObject *)co, globals,
Jeremy Hylton52820442001-01-03 23:52:36 +00003272 (PyObject *)NULL, (*pp_stack)-n, na,
Jeremy Hylton64949cb2001-01-25 20:06:59 +00003273 (*pp_stack)-2*nk, nk, d, nd,
3274 closure);
Jeremy Hylton52820442001-01-03 23:52:36 +00003275}
3276
3277static PyObject *
Ka-Ping Yee20579702001-01-15 22:14:16 +00003278update_keyword_args(PyObject *orig_kwdict, int nk, PyObject ***pp_stack,
3279 PyObject *func)
Jeremy Hylton52820442001-01-03 23:52:36 +00003280{
3281 PyObject *kwdict = NULL;
3282 if (orig_kwdict == NULL)
3283 kwdict = PyDict_New();
3284 else {
3285 kwdict = PyDict_Copy(orig_kwdict);
3286 Py_DECREF(orig_kwdict);
3287 }
3288 if (kwdict == NULL)
3289 return NULL;
3290 while (--nk >= 0) {
3291 int err;
3292 PyObject *value = EXT_POP(*pp_stack);
3293 PyObject *key = EXT_POP(*pp_stack);
3294 if (PyDict_GetItem(kwdict, key) != NULL) {
Guido van Rossumac7be682001-01-17 15:42:30 +00003295 PyErr_Format(PyExc_TypeError,
Ka-Ping Yee20579702001-01-15 22:14:16 +00003296 "%.200s%s got multiple values "
Jeremy Hylton512a2372001-04-11 13:52:29 +00003297 "for keyword argument '%.200s'",
Tim Peters6d6c1a32001-08-02 04:15:00 +00003298 PyEval_GetFuncName(func),
3299 PyEval_GetFuncDesc(func),
Jeremy Hylton512a2372001-04-11 13:52:29 +00003300 PyString_AsString(key));
Jeremy Hylton52820442001-01-03 23:52:36 +00003301 Py_DECREF(key);
3302 Py_DECREF(value);
3303 Py_DECREF(kwdict);
3304 return NULL;
3305 }
3306 err = PyDict_SetItem(kwdict, key, value);
3307 Py_DECREF(key);
3308 Py_DECREF(value);
3309 if (err) {
3310 Py_DECREF(kwdict);
3311 return NULL;
3312 }
3313 }
3314 return kwdict;
3315}
3316
3317static PyObject *
3318update_star_args(int nstack, int nstar, PyObject *stararg,
3319 PyObject ***pp_stack)
3320{
3321 PyObject *callargs, *w;
3322
3323 callargs = PyTuple_New(nstack + nstar);
3324 if (callargs == NULL) {
3325 return NULL;
3326 }
3327 if (nstar) {
3328 int i;
3329 for (i = 0; i < nstar; i++) {
3330 PyObject *a = PyTuple_GET_ITEM(stararg, i);
3331 Py_INCREF(a);
3332 PyTuple_SET_ITEM(callargs, nstack + i, a);
3333 }
3334 }
3335 while (--nstack >= 0) {
3336 w = EXT_POP(*pp_stack);
3337 PyTuple_SET_ITEM(callargs, nstack, w);
3338 }
3339 return callargs;
3340}
3341
3342static PyObject *
3343load_args(PyObject ***pp_stack, int na)
3344{
3345 PyObject *args = PyTuple_New(na);
3346 PyObject *w;
3347
3348 if (args == NULL)
3349 return NULL;
3350 while (--na >= 0) {
3351 w = EXT_POP(*pp_stack);
3352 PyTuple_SET_ITEM(args, na, w);
3353 }
3354 return args;
3355}
3356
3357static PyObject *
3358do_call(PyObject *func, PyObject ***pp_stack, int na, int nk)
3359{
3360 PyObject *callargs = NULL;
3361 PyObject *kwdict = NULL;
3362 PyObject *result = NULL;
3363
3364 if (nk > 0) {
Ka-Ping Yee20579702001-01-15 22:14:16 +00003365 kwdict = update_keyword_args(NULL, nk, pp_stack, func);
Jeremy Hylton52820442001-01-03 23:52:36 +00003366 if (kwdict == NULL)
3367 goto call_fail;
3368 }
3369 callargs = load_args(pp_stack, na);
3370 if (callargs == NULL)
3371 goto call_fail;
Tim Peters6d6c1a32001-08-02 04:15:00 +00003372 result = PyObject_Call(func, callargs, kwdict);
Jeremy Hylton52820442001-01-03 23:52:36 +00003373 call_fail:
3374 Py_XDECREF(callargs);
3375 Py_XDECREF(kwdict);
3376 return result;
3377}
3378
3379static PyObject *
3380ext_do_call(PyObject *func, PyObject ***pp_stack, int flags, int na, int nk)
3381{
3382 int nstar = 0;
3383 PyObject *callargs = NULL;
3384 PyObject *stararg = NULL;
3385 PyObject *kwdict = NULL;
3386 PyObject *result = NULL;
3387
3388 if (flags & CALL_FLAG_KW) {
3389 kwdict = EXT_POP(*pp_stack);
3390 if (!(kwdict && PyDict_Check(kwdict))) {
Ka-Ping Yee20579702001-01-15 22:14:16 +00003391 PyErr_Format(PyExc_TypeError,
Jeremy Hylton512a2372001-04-11 13:52:29 +00003392 "%s%s argument after ** "
3393 "must be a dictionary",
Tim Peters6d6c1a32001-08-02 04:15:00 +00003394 PyEval_GetFuncName(func),
3395 PyEval_GetFuncDesc(func));
Jeremy Hylton52820442001-01-03 23:52:36 +00003396 goto ext_call_fail;
3397 }
3398 }
3399 if (flags & CALL_FLAG_VAR) {
3400 stararg = EXT_POP(*pp_stack);
3401 if (!PyTuple_Check(stararg)) {
3402 PyObject *t = NULL;
3403 t = PySequence_Tuple(stararg);
3404 if (t == NULL) {
Jeremy Hylton512a2372001-04-11 13:52:29 +00003405 if (PyErr_ExceptionMatches(PyExc_TypeError)) {
3406 PyErr_Format(PyExc_TypeError,
3407 "%s%s argument after * "
3408 "must be a sequence",
Tim Peters6d6c1a32001-08-02 04:15:00 +00003409 PyEval_GetFuncName(func),
3410 PyEval_GetFuncDesc(func));
Jeremy Hylton512a2372001-04-11 13:52:29 +00003411 }
Jeremy Hylton52820442001-01-03 23:52:36 +00003412 goto ext_call_fail;
3413 }
3414 Py_DECREF(stararg);
3415 stararg = t;
3416 }
3417 nstar = PyTuple_GET_SIZE(stararg);
3418 }
3419 if (nk > 0) {
Ka-Ping Yee20579702001-01-15 22:14:16 +00003420 kwdict = update_keyword_args(kwdict, nk, pp_stack, func);
Jeremy Hylton52820442001-01-03 23:52:36 +00003421 if (kwdict == NULL)
3422 goto ext_call_fail;
3423 }
3424 callargs = update_star_args(na, nstar, stararg, pp_stack);
3425 if (callargs == NULL)
3426 goto ext_call_fail;
Tim Peters6d6c1a32001-08-02 04:15:00 +00003427 result = PyObject_Call(func, callargs, kwdict);
Jeremy Hylton52820442001-01-03 23:52:36 +00003428 ext_call_fail:
3429 Py_XDECREF(callargs);
3430 Py_XDECREF(kwdict);
3431 Py_XDECREF(stararg);
3432 return result;
3433}
3434
Guido van Rossum3b9c6671996-07-30 18:40:29 +00003435#define SLICE_ERROR_MSG \
3436 "standard sequence type does not support step size other than one"
3437
Tim Peterscb479e72001-12-16 19:11:44 +00003438/* Extract a slice index from a PyInt or PyLong, and store in *pi.
3439 Silently reduce values larger than INT_MAX to INT_MAX, and silently
3440 boost values less than -INT_MAX to 0. Return 0 on error, 1 on success.
3441*/
Tim Petersb5196382001-12-16 19:44:20 +00003442/* Note: If v is NULL, return success without storing into *pi. This
3443 is because_PyEval_SliceIndex() is called by apply_slice(), which can be
3444 called by the SLICE opcode with v and/or w equal to NULL.
Tim Peterscb479e72001-12-16 19:11:44 +00003445*/
Guido van Rossum20c6add2000-05-08 14:06:50 +00003446int
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003447_PyEval_SliceIndex(PyObject *v, int *pi)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003448{
Tim Petersb5196382001-12-16 19:44:20 +00003449 if (v != NULL) {
Guido van Rossuma027efa1997-05-05 20:56:21 +00003450 long x;
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003451 if (PyInt_Check(v)) {
3452 x = PyInt_AsLong(v);
3453 } else if (PyLong_Check(v)) {
3454 x = PyLong_AsLong(v);
3455 if (x==-1 && PyErr_Occurred()) {
3456 PyObject *long_zero;
Guido van Rossumac7be682001-01-17 15:42:30 +00003457 int cmp;
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003458
Guido van Rossumac7be682001-01-17 15:42:30 +00003459 if (!PyErr_ExceptionMatches(
3460 PyExc_OverflowError)) {
3461 /* It's not an overflow error, so just
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003462 signal an error */
Guido van Rossum20c6add2000-05-08 14:06:50 +00003463 return 0;
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003464 }
3465
Guido van Rossumac7be682001-01-17 15:42:30 +00003466 /* Clear the OverflowError */
3467 PyErr_Clear();
3468
3469 /* It's an overflow error, so we need to
3470 check the sign of the long integer,
3471 set the value to INT_MAX or 0, and clear
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003472 the error. */
3473
3474 /* Create a long integer with a value of 0 */
Guido van Rossumac7be682001-01-17 15:42:30 +00003475 long_zero = PyLong_FromLong(0L);
Tim Peterscb479e72001-12-16 19:11:44 +00003476 if (long_zero == NULL)
3477 return 0;
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003478
3479 /* Check sign */
Guido van Rossumac7be682001-01-17 15:42:30 +00003480 cmp = PyObject_RichCompareBool(v, long_zero,
3481 Py_GT);
3482 Py_DECREF(long_zero);
3483 if (cmp < 0)
3484 return 0;
3485 else if (cmp > 0)
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003486 x = INT_MAX;
3487 else
3488 x = 0;
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003489 }
3490 } else {
Guido van Rossuma027efa1997-05-05 20:56:21 +00003491 PyErr_SetString(PyExc_TypeError,
Fred Drake661ea262000-10-24 19:57:45 +00003492 "slice indices must be integers");
Guido van Rossum20c6add2000-05-08 14:06:50 +00003493 return 0;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003494 }
Guido van Rossuma027efa1997-05-05 20:56:21 +00003495 /* Truncate -- very long indices are truncated anyway */
3496 if (x > INT_MAX)
3497 x = INT_MAX;
3498 else if (x < -INT_MAX)
3499 x = 0;
3500 *pi = x;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003501 }
Guido van Rossum20c6add2000-05-08 14:06:50 +00003502 return 1;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003503}
3504
Guido van Rossum50d756e2001-08-18 17:43:36 +00003505#undef ISINT
3506#define ISINT(x) ((x) == NULL || PyInt_Check(x) || PyLong_Check(x))
3507
Guido van Rossumb209a111997-04-29 18:18:01 +00003508static PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003509apply_slice(PyObject *u, PyObject *v, PyObject *w) /* return u[v:w] */
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003510{
Guido van Rossum50d756e2001-08-18 17:43:36 +00003511 PyTypeObject *tp = u->ob_type;
3512 PySequenceMethods *sq = tp->tp_as_sequence;
3513
3514 if (sq && sq->sq_slice && ISINT(v) && ISINT(w)) {
3515 int ilow = 0, ihigh = INT_MAX;
3516 if (!_PyEval_SliceIndex(v, &ilow))
3517 return NULL;
3518 if (!_PyEval_SliceIndex(w, &ihigh))
3519 return NULL;
3520 return PySequence_GetSlice(u, ilow, ihigh);
3521 }
3522 else {
3523 PyObject *slice = PySlice_New(v, w, NULL);
Guido van Rossum354797c2001-12-03 19:45:06 +00003524 if (slice != NULL) {
3525 PyObject *res = PyObject_GetItem(u, slice);
3526 Py_DECREF(slice);
3527 return res;
3528 }
Guido van Rossum50d756e2001-08-18 17:43:36 +00003529 else
3530 return NULL;
3531 }
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003532}
Guido van Rossum3f5da241990-12-20 15:06:42 +00003533
3534static int
Guido van Rossumac7be682001-01-17 15:42:30 +00003535assign_slice(PyObject *u, PyObject *v, PyObject *w, PyObject *x)
3536 /* u[v:w] = x */
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003537{
Guido van Rossum50d756e2001-08-18 17:43:36 +00003538 PyTypeObject *tp = u->ob_type;
3539 PySequenceMethods *sq = tp->tp_as_sequence;
3540
3541 if (sq && sq->sq_slice && ISINT(v) && ISINT(w)) {
3542 int ilow = 0, ihigh = INT_MAX;
3543 if (!_PyEval_SliceIndex(v, &ilow))
3544 return -1;
3545 if (!_PyEval_SliceIndex(w, &ihigh))
3546 return -1;
3547 if (x == NULL)
3548 return PySequence_DelSlice(u, ilow, ihigh);
3549 else
3550 return PySequence_SetSlice(u, ilow, ihigh, x);
3551 }
3552 else {
3553 PyObject *slice = PySlice_New(v, w, NULL);
3554 if (slice != NULL) {
Guido van Rossum354797c2001-12-03 19:45:06 +00003555 int res;
Guido van Rossum50d756e2001-08-18 17:43:36 +00003556 if (x != NULL)
Guido van Rossum354797c2001-12-03 19:45:06 +00003557 res = PyObject_SetItem(u, slice, x);
Guido van Rossum50d756e2001-08-18 17:43:36 +00003558 else
Guido van Rossum354797c2001-12-03 19:45:06 +00003559 res = PyObject_DelItem(u, slice);
3560 Py_DECREF(slice);
3561 return res;
Guido van Rossum50d756e2001-08-18 17:43:36 +00003562 }
3563 else
3564 return -1;
3565 }
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003566}
3567
Guido van Rossumb209a111997-04-29 18:18:01 +00003568static PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003569cmp_outcome(int op, register PyObject *v, register PyObject *w)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003570{
Guido van Rossumac7be682001-01-17 15:42:30 +00003571 int res = 0;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003572 switch (op) {
Martin v. Löwis7198a522002-01-01 19:59:11 +00003573 case PyCmp_IS:
3574 case PyCmp_IS_NOT:
Guido van Rossum3f5da241990-12-20 15:06:42 +00003575 res = (v == w);
Martin v. Löwis7198a522002-01-01 19:59:11 +00003576 if (op == (int) PyCmp_IS_NOT)
Guido van Rossum3f5da241990-12-20 15:06:42 +00003577 res = !res;
3578 break;
Martin v. Löwis7198a522002-01-01 19:59:11 +00003579 case PyCmp_IN:
3580 case PyCmp_NOT_IN:
Guido van Rossum7e33c6e1998-05-22 00:52:29 +00003581 res = PySequence_Contains(w, v);
Guido van Rossum3f5da241990-12-20 15:06:42 +00003582 if (res < 0)
3583 return NULL;
Martin v. Löwis7198a522002-01-01 19:59:11 +00003584 if (op == (int) PyCmp_NOT_IN)
Guido van Rossum3f5da241990-12-20 15:06:42 +00003585 res = !res;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003586 break;
Martin v. Löwis7198a522002-01-01 19:59:11 +00003587 case PyCmp_EXC_MATCH:
Barry Warsaw4249f541997-08-22 21:26:19 +00003588 res = PyErr_GivenExceptionMatches(v, w);
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003589 break;
3590 default:
Guido van Rossumac7be682001-01-17 15:42:30 +00003591 return PyObject_RichCompare(v, w, op);
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003592 }
Guido van Rossumb209a111997-04-29 18:18:01 +00003593 v = res ? Py_True : Py_False;
3594 Py_INCREF(v);
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003595 return v;
3596}
3597
Thomas Wouters52152252000-08-17 22:55:00 +00003598static PyObject *
3599import_from(PyObject *v, PyObject *name)
Guido van Rossume9736fc1990-11-18 17:33:06 +00003600{
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00003601 PyObject *x;
3602
3603 x = PyObject_GetAttr(v, name);
3604 if (x == NULL && PyErr_ExceptionMatches(PyExc_AttributeError)) {
Thomas Wouters52152252000-08-17 22:55:00 +00003605 PyErr_Format(PyExc_ImportError,
3606 "cannot import name %.230s",
3607 PyString_AsString(name));
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00003608 }
Thomas Wouters52152252000-08-17 22:55:00 +00003609 return x;
3610}
Guido van Rossumac7be682001-01-17 15:42:30 +00003611
Thomas Wouters52152252000-08-17 22:55:00 +00003612static int
3613import_all_from(PyObject *locals, PyObject *v)
3614{
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00003615 PyObject *all = PyObject_GetAttrString(v, "__all__");
3616 PyObject *dict, *name, *value;
3617 int skip_leading_underscores = 0;
3618 int pos, err;
Thomas Wouters52152252000-08-17 22:55:00 +00003619
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00003620 if (all == NULL) {
3621 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
3622 return -1; /* Unexpected error */
3623 PyErr_Clear();
3624 dict = PyObject_GetAttrString(v, "__dict__");
3625 if (dict == NULL) {
3626 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
3627 return -1;
3628 PyErr_SetString(PyExc_ImportError,
3629 "from-import-* object has no __dict__ and no __all__");
Guido van Rossum3f5da241990-12-20 15:06:42 +00003630 return -1;
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00003631 }
3632 all = PyMapping_Keys(dict);
3633 Py_DECREF(dict);
3634 if (all == NULL)
3635 return -1;
3636 skip_leading_underscores = 1;
Guido van Rossume9736fc1990-11-18 17:33:06 +00003637 }
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00003638
3639 for (pos = 0, err = 0; ; pos++) {
3640 name = PySequence_GetItem(all, pos);
3641 if (name == NULL) {
3642 if (!PyErr_ExceptionMatches(PyExc_IndexError))
3643 err = -1;
3644 else
3645 PyErr_Clear();
3646 break;
3647 }
3648 if (skip_leading_underscores &&
3649 PyString_Check(name) &&
3650 PyString_AS_STRING(name)[0] == '_')
3651 {
3652 Py_DECREF(name);
3653 continue;
3654 }
3655 value = PyObject_GetAttr(v, name);
3656 if (value == NULL)
3657 err = -1;
3658 else
3659 err = PyDict_SetItem(locals, name, value);
3660 Py_DECREF(name);
3661 Py_XDECREF(value);
3662 if (err != 0)
3663 break;
3664 }
3665 Py_DECREF(all);
3666 return err;
Guido van Rossume9736fc1990-11-18 17:33:06 +00003667}
3668
Guido van Rossumb209a111997-04-29 18:18:01 +00003669static PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003670build_class(PyObject *methods, PyObject *bases, PyObject *name)
Guido van Rossume9736fc1990-11-18 17:33:06 +00003671{
Guido van Rossum7851eea2001-09-12 19:19:18 +00003672 PyObject *metaclass = NULL, *result, *base;
Tim Peters6d6c1a32001-08-02 04:15:00 +00003673
3674 if (PyDict_Check(methods))
3675 metaclass = PyDict_GetItemString(methods, "__metaclass__");
Guido van Rossum7851eea2001-09-12 19:19:18 +00003676 if (metaclass != NULL)
Guido van Rossum2556f2e2001-12-06 14:09:56 +00003677 Py_INCREF(metaclass);
Guido van Rossum7851eea2001-09-12 19:19:18 +00003678 else if (PyTuple_Check(bases) && PyTuple_GET_SIZE(bases) > 0) {
3679 base = PyTuple_GET_ITEM(bases, 0);
3680 metaclass = PyObject_GetAttrString(base, "__class__");
3681 if (metaclass == NULL) {
3682 PyErr_Clear();
3683 metaclass = (PyObject *)base->ob_type;
3684 Py_INCREF(metaclass);
Guido van Rossum25831651993-05-19 14:50:45 +00003685 }
3686 }
Guido van Rossum7851eea2001-09-12 19:19:18 +00003687 else {
3688 PyObject *g = PyEval_GetGlobals();
3689 if (g != NULL && PyDict_Check(g))
3690 metaclass = PyDict_GetItemString(g, "__metaclass__");
3691 if (metaclass == NULL)
3692 metaclass = (PyObject *) &PyClass_Type;
3693 Py_INCREF(metaclass);
3694 }
3695 result = PyObject_CallFunction(metaclass, "OOO", name, bases, methods);
3696 Py_DECREF(metaclass);
3697 return result;
Guido van Rossum25831651993-05-19 14:50:45 +00003698}
3699
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003700static int
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003701exec_statement(PyFrameObject *f, PyObject *prog, PyObject *globals,
3702 PyObject *locals)
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003703{
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003704 int n;
Guido van Rossumb209a111997-04-29 18:18:01 +00003705 PyObject *v;
Guido van Rossum681d79a1995-07-18 14:51:37 +00003706 int plain = 0;
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003707
Guido van Rossumb209a111997-04-29 18:18:01 +00003708 if (PyTuple_Check(prog) && globals == Py_None && locals == Py_None &&
3709 ((n = PyTuple_Size(prog)) == 2 || n == 3)) {
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003710 /* Backward compatibility hack */
Guido van Rossumb209a111997-04-29 18:18:01 +00003711 globals = PyTuple_GetItem(prog, 1);
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003712 if (n == 3)
Guido van Rossumb209a111997-04-29 18:18:01 +00003713 locals = PyTuple_GetItem(prog, 2);
3714 prog = PyTuple_GetItem(prog, 0);
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003715 }
Guido van Rossumb209a111997-04-29 18:18:01 +00003716 if (globals == Py_None) {
3717 globals = PyEval_GetGlobals();
3718 if (locals == Py_None) {
3719 locals = PyEval_GetLocals();
Guido van Rossum681d79a1995-07-18 14:51:37 +00003720 plain = 1;
3721 }
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003722 }
Guido van Rossumb209a111997-04-29 18:18:01 +00003723 else if (locals == Py_None)
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003724 locals = globals;
Guido van Rossumb209a111997-04-29 18:18:01 +00003725 if (!PyString_Check(prog) &&
Marc-André Lemburgd1ba4432000-09-19 21:04:18 +00003726 !PyUnicode_Check(prog) &&
Guido van Rossumb209a111997-04-29 18:18:01 +00003727 !PyCode_Check(prog) &&
3728 !PyFile_Check(prog)) {
3729 PyErr_SetString(PyExc_TypeError,
Guido van Rossumac7be682001-01-17 15:42:30 +00003730 "exec: arg 1 must be a string, file, or code object");
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003731 return -1;
3732 }
Fred Drake661ea262000-10-24 19:57:45 +00003733 if (!PyDict_Check(globals)) {
Guido van Rossumb209a111997-04-29 18:18:01 +00003734 PyErr_SetString(PyExc_TypeError,
Fred Drake661ea262000-10-24 19:57:45 +00003735 "exec: arg 2 must be a dictionary or None");
3736 return -1;
3737 }
3738 if (!PyDict_Check(locals)) {
3739 PyErr_SetString(PyExc_TypeError,
3740 "exec: arg 3 must be a dictionary or None");
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003741 return -1;
3742 }
Guido van Rossumb209a111997-04-29 18:18:01 +00003743 if (PyDict_GetItemString(globals, "__builtins__") == NULL)
Guido van Rossuma027efa1997-05-05 20:56:21 +00003744 PyDict_SetItemString(globals, "__builtins__", f->f_builtins);
Guido van Rossumb209a111997-04-29 18:18:01 +00003745 if (PyCode_Check(prog)) {
Jeremy Hylton733c8932001-12-13 19:51:56 +00003746 if (PyCode_GetNumFree((PyCodeObject *)prog) > 0) {
3747 PyErr_SetString(PyExc_TypeError,
3748 "code object passed to exec may not contain free variables");
3749 return -1;
3750 }
Guido van Rossuma400d8a2000-01-12 22:45:54 +00003751 v = PyEval_EvalCode((PyCodeObject *) prog, globals, locals);
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003752 }
Guido van Rossuma400d8a2000-01-12 22:45:54 +00003753 else if (PyFile_Check(prog)) {
Guido van Rossumb209a111997-04-29 18:18:01 +00003754 FILE *fp = PyFile_AsFile(prog);
3755 char *name = PyString_AsString(PyFile_Name(prog));
Tim Peters5ba58662001-07-16 02:29:45 +00003756 PyCompilerFlags cf;
3757 cf.cf_flags = 0;
3758 if (PyEval_MergeCompilerFlags(&cf))
Jeremy Hyltonbc320242001-03-22 02:47:58 +00003759 v = PyRun_FileFlags(fp, name, Py_file_input, globals,
3760 locals, &cf);
Tim Peters5ba58662001-07-16 02:29:45 +00003761 else
Jeremy Hyltonbc320242001-03-22 02:47:58 +00003762 v = PyRun_File(fp, name, Py_file_input, globals,
3763 locals);
Guido van Rossuma400d8a2000-01-12 22:45:54 +00003764 }
3765 else {
Marc-André Lemburgd1ba4432000-09-19 21:04:18 +00003766 char *str;
Tim Peters5ba58662001-07-16 02:29:45 +00003767 PyCompilerFlags cf;
Marc-André Lemburgd1ba4432000-09-19 21:04:18 +00003768 if (PyString_AsStringAndSize(prog, &str, NULL))
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003769 return -1;
Tim Peters5ba58662001-07-16 02:29:45 +00003770 cf.cf_flags = 0;
3771 if (PyEval_MergeCompilerFlags(&cf))
Jeremy Hyltonbc320242001-03-22 02:47:58 +00003772 v = PyRun_StringFlags(str, Py_file_input, globals,
3773 locals, &cf);
Tim Peters5ba58662001-07-16 02:29:45 +00003774 else
Jeremy Hyltonbc320242001-03-22 02:47:58 +00003775 v = PyRun_String(str, Py_file_input, globals, locals);
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003776 }
Guido van Rossuma400d8a2000-01-12 22:45:54 +00003777 if (plain)
3778 PyFrame_LocalsToFast(f, 0);
Guido van Rossum681d79a1995-07-18 14:51:37 +00003779 if (v == NULL)
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003780 return -1;
Guido van Rossumb209a111997-04-29 18:18:01 +00003781 Py_DECREF(v);
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003782 return 0;
3783}
Guido van Rossum24c13741995-02-14 09:42:43 +00003784
Guido van Rossumac7be682001-01-17 15:42:30 +00003785static void
Paul Prescode68140d2000-08-30 20:25:01 +00003786format_exc_check_arg(PyObject *exc, char *format_str, PyObject *obj)
3787{
3788 char *obj_str;
3789
3790 if (!obj)
3791 return;
3792
3793 obj_str = PyString_AsString(obj);
3794 if (!obj_str)
3795 return;
3796
3797 PyErr_Format(exc, format_str, obj_str);
3798}
Guido van Rossum950361c1997-01-24 13:49:28 +00003799
3800#ifdef DYNAMIC_EXECUTION_PROFILE
3801
Skip Montanarof118cb12001-10-15 20:51:38 +00003802static PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003803getarray(long a[256])
Guido van Rossum950361c1997-01-24 13:49:28 +00003804{
3805 int i;
3806 PyObject *l = PyList_New(256);
3807 if (l == NULL) return NULL;
3808 for (i = 0; i < 256; i++) {
3809 PyObject *x = PyInt_FromLong(a[i]);
3810 if (x == NULL) {
3811 Py_DECREF(l);
3812 return NULL;
3813 }
3814 PyList_SetItem(l, i, x);
3815 }
3816 for (i = 0; i < 256; i++)
3817 a[i] = 0;
3818 return l;
3819}
3820
3821PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003822_Py_GetDXProfile(PyObject *self, PyObject *args)
Guido van Rossum950361c1997-01-24 13:49:28 +00003823{
3824#ifndef DXPAIRS
3825 return getarray(dxp);
3826#else
3827 int i;
3828 PyObject *l = PyList_New(257);
3829 if (l == NULL) return NULL;
3830 for (i = 0; i < 257; i++) {
3831 PyObject *x = getarray(dxpairs[i]);
3832 if (x == NULL) {
3833 Py_DECREF(l);
3834 return NULL;
3835 }
3836 PyList_SetItem(l, i, x);
3837 }
3838 return l;
3839#endif
3840}
3841
3842#endif