blob: 731e93fa834ccc1759f128f765e81609661470d5 [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 Hylton52820442001-01-03 23:52:36 +000036static PyObject *fast_function(PyObject *, PyObject ***, int, int, int);
37static PyObject *fast_cfunction(PyObject *, PyObject ***, int);
38static 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 *);
51static void call_exc_trace(Py_tracefunc, PyObject *, PyFrameObject *);
Tim Petersdbd9ba62000-07-09 03:09:57 +000052static PyObject *loop_subscript(PyObject *, PyObject *);
53static PyObject *apply_slice(PyObject *, PyObject *, PyObject *);
54static int assign_slice(PyObject *, PyObject *,
55 PyObject *, PyObject *);
56static PyObject *cmp_outcome(int, PyObject *, PyObject *);
Thomas Wouters52152252000-08-17 22:55:00 +000057static PyObject *import_from(PyObject *, PyObject *);
58static int import_all_from(PyObject *, PyObject *);
Tim Petersdbd9ba62000-07-09 03:09:57 +000059static PyObject *build_class(PyObject *, PyObject *, PyObject *);
60static int exec_statement(PyFrameObject *,
61 PyObject *, PyObject *, PyObject *);
Tim Petersdbd9ba62000-07-09 03:09:57 +000062static void set_exc_info(PyThreadState *, PyObject *, PyObject *, PyObject *);
63static void reset_exc_info(PyThreadState *);
Paul Prescode68140d2000-08-30 20:25:01 +000064static void format_exc_check_arg(PyObject *, char *, PyObject *);
Guido van Rossum374a9221991-04-04 10:40:29 +000065
Paul Prescode68140d2000-08-30 20:25:01 +000066#define NAME_ERROR_MSG \
Fred Drake661ea262000-10-24 19:57:45 +000067 "name '%.200s' is not defined"
Jeremy Hylton64949cb2001-01-25 20:06:59 +000068#define GLOBAL_NAME_ERROR_MSG \
69 "global name '%.200s' is not defined"
Paul Prescode68140d2000-08-30 20:25:01 +000070#define UNBOUNDLOCAL_ERROR_MSG \
Fred Drake661ea262000-10-24 19:57:45 +000071 "local variable '%.200s' referenced before assignment"
Jeremy Hyltonc76770c2001-04-13 16:51:46 +000072#define UNBOUNDFREE_ERROR_MSG \
73 "free variable '%.200s' referenced before assignment" \
74 " in enclosing scope"
Guido van Rossum374a9221991-04-04 10:40:29 +000075
Guido van Rossum950361c1997-01-24 13:49:28 +000076/* Dynamic execution profile */
77#ifdef DYNAMIC_EXECUTION_PROFILE
78#ifdef DXPAIRS
79static long dxpairs[257][256];
80#define dxp dxpairs[256]
81#else
82static long dxp[256];
83#endif
84#endif
85
Tim Peters5ca576e2001-06-18 22:08:13 +000086staticforward PyTypeObject gentype;
87
88typedef struct {
89 PyObject_HEAD
Tim Petersd8e1c9e2001-06-26 20:58:58 +000090 /* The gi_ prefix is intended to remind of generator-iterator. */
91
92 PyFrameObject *gi_frame;
93
Tim Peterse77f2e22001-06-26 22:24:51 +000094 /* True if generator is being executed. */
95 int gi_running;
Tim Peters5ca576e2001-06-18 22:08:13 +000096} genobject;
97
98static PyObject *
99gen_new(PyFrameObject *f)
100{
101 genobject *gen = PyObject_New(genobject, &gentype);
102 if (gen == NULL) {
103 Py_DECREF(f);
104 return NULL;
105 }
Tim Petersd8e1c9e2001-06-26 20:58:58 +0000106 gen->gi_frame = f;
107 gen->gi_running = 0;
Neil Schemenauerf8c7c202001-07-12 13:27:49 +0000108 PyObject_GC_Init(gen);
Tim Peters5ca576e2001-06-18 22:08:13 +0000109 return (PyObject *)gen;
110}
111
Neil Schemenauerf8c7c202001-07-12 13:27:49 +0000112static int
113gen_traverse(genobject *gen, visitproc visit, void *arg)
114{
115 return visit((PyObject *)gen->gi_frame, arg);
116}
117
Tim Peters5ca576e2001-06-18 22:08:13 +0000118static void
119gen_dealloc(genobject *gen)
120{
Neil Schemenauerf8c7c202001-07-12 13:27:49 +0000121 PyObject_GC_Fini(gen);
Tim Petersd8e1c9e2001-06-26 20:58:58 +0000122 Py_DECREF(gen->gi_frame);
Neil Schemenauerf8c7c202001-07-12 13:27:49 +0000123 PyObject_Del(gen);
Tim Peters5ca576e2001-06-18 22:08:13 +0000124}
125
126static PyObject *
127gen_iternext(genobject *gen)
128{
Neil Schemenauer2b13ce82001-06-21 02:41:10 +0000129 PyThreadState *tstate = PyThreadState_GET();
Tim Petersd8e1c9e2001-06-26 20:58:58 +0000130 PyFrameObject *f = gen->gi_frame;
Tim Peters5ca576e2001-06-18 22:08:13 +0000131 PyObject *result;
132
Tim Petersd8e1c9e2001-06-26 20:58:58 +0000133 if (gen->gi_running) {
Tim Peters5ca576e2001-06-18 22:08:13 +0000134 PyErr_SetString(PyExc_ValueError,
135 "generator already executing");
136 return NULL;
137 }
Tim Peters8c963692001-06-23 05:26:56 +0000138 if (f->f_stacktop == NULL)
Tim Peters5ca576e2001-06-18 22:08:13 +0000139 return NULL;
Neil Schemenauer2b13ce82001-06-21 02:41:10 +0000140
141 /* Generators always return to their most recent caller, not
142 * necessarily their creator. */
Tim Peters5eb4b872001-06-23 05:47:56 +0000143 Py_XINCREF(tstate->frame);
Neil Schemenauer2b13ce82001-06-21 02:41:10 +0000144 assert(f->f_back == NULL);
145 f->f_back = tstate->frame;
146
Tim Petersd8e1c9e2001-06-26 20:58:58 +0000147 gen->gi_running = 1;
Tim Peters5ca576e2001-06-18 22:08:13 +0000148 result = eval_frame(f);
Tim Petersd8e1c9e2001-06-26 20:58:58 +0000149 gen->gi_running = 0;
Neil Schemenauer2b13ce82001-06-21 02:41:10 +0000150
151 /* Don't keep the reference to f_back any longer than necessary. It
152 * may keep a chain of frames alive or it could create a reference
153 * cycle. */
Tim Peters5eb4b872001-06-23 05:47:56 +0000154 Py_XDECREF(f->f_back);
Tim Peters6302ec62001-06-20 06:57:32 +0000155 f->f_back = NULL;
Neil Schemenauer2b13ce82001-06-21 02:41:10 +0000156
Tim Petersad1a18b2001-06-23 06:19:16 +0000157 /* If the generator just returned (as opposed to yielding), signal
158 * that the generator is exhausted. */
159 if (result == Py_None && f->f_stacktop == NULL) {
160 Py_DECREF(result);
161 result = NULL;
162 }
163
Neil Schemenauer2b13ce82001-06-21 02:41:10 +0000164 return result;
Tim Peters5ca576e2001-06-18 22:08:13 +0000165}
166
167static PyObject *
Martin v. Löwise3eb1f22001-08-16 13:15:00 +0000168gen_next(genobject *gen)
Tim Peters5ca576e2001-06-18 22:08:13 +0000169{
170 PyObject *result;
171
Neil Schemenauer2b13ce82001-06-21 02:41:10 +0000172 result = gen_iternext(gen);
Tim Peters5ca576e2001-06-18 22:08:13 +0000173
Neil Schemenauer2b13ce82001-06-21 02:41:10 +0000174 if (result == NULL && !PyErr_Occurred()) {
Tim Peters5ca576e2001-06-18 22:08:13 +0000175 PyErr_SetObject(PyExc_StopIteration, Py_None);
176 return NULL;
Neil Schemenauer2b13ce82001-06-21 02:41:10 +0000177 }
Tim Peters5ca576e2001-06-18 22:08:13 +0000178
179 return result;
180}
181
182static PyObject *
183gen_getiter(PyObject *gen)
184{
185 Py_INCREF(gen);
186 return gen;
187}
188
189static struct PyMethodDef gen_methods[] = {
Martin v. Löwise3eb1f22001-08-16 13:15:00 +0000190 {"next", (PyCFunction)gen_next, METH_NOARGS,
Tim Peterse77f2e22001-06-26 22:24:51 +0000191 "next() -- get the next value, or raise StopIteration"},
Tim Peters5ca576e2001-06-18 22:08:13 +0000192 {NULL, NULL} /* Sentinel */
193};
194
Guido van Rossum6f799372001-09-20 20:46:19 +0000195static PyMemberDef gen_memberlist[] = {
Tim Peters6d6c1a32001-08-02 04:15:00 +0000196 {"gi_frame", T_OBJECT, offsetof(genobject, gi_frame), RO},
197 {"gi_running", T_INT, offsetof(genobject, gi_running), RO},
198 {NULL} /* Sentinel */
199};
Tim Peters5ca576e2001-06-18 22:08:13 +0000200
201statichere PyTypeObject gentype = {
202 PyObject_HEAD_INIT(&PyType_Type)
203 0, /* ob_size */
204 "generator", /* tp_name */
Neil Schemenauerf8c7c202001-07-12 13:27:49 +0000205 sizeof(genobject) + PyGC_HEAD_SIZE, /* tp_basicsize */
Tim Peters5ca576e2001-06-18 22:08:13 +0000206 0, /* tp_itemsize */
207 /* methods */
208 (destructor)gen_dealloc, /* tp_dealloc */
209 0, /* tp_print */
Tim Peters6d6c1a32001-08-02 04:15:00 +0000210 0, /* tp_getattr */
Tim Peters5ca576e2001-06-18 22:08:13 +0000211 0, /* tp_setattr */
212 0, /* tp_compare */
213 0, /* tp_repr */
214 0, /* tp_as_number */
215 0, /* tp_as_sequence */
216 0, /* tp_as_mapping */
217 0, /* tp_hash */
218 0, /* tp_call */
219 0, /* tp_str */
Tim Peters6d6c1a32001-08-02 04:15:00 +0000220 PyObject_GenericGetAttr, /* tp_getattro */
Tim Peters5ca576e2001-06-18 22:08:13 +0000221 0, /* tp_setattro */
222 0, /* tp_as_buffer */
Neil Schemenauerf8c7c202001-07-12 13:27:49 +0000223 Py_TPFLAGS_DEFAULT | Py_TPFLAGS_GC, /* tp_flags */
Tim Peters5ca576e2001-06-18 22:08:13 +0000224 0, /* tp_doc */
Neil Schemenauerf8c7c202001-07-12 13:27:49 +0000225 (traverseproc)gen_traverse, /* tp_traverse */
Tim Peters5ca576e2001-06-18 22:08:13 +0000226 0, /* tp_clear */
227 0, /* tp_richcompare */
228 0, /* tp_weaklistoffset */
229 (getiterfunc)gen_getiter, /* tp_iter */
230 (iternextfunc)gen_iternext, /* tp_iternext */
Tim Peters6d6c1a32001-08-02 04:15:00 +0000231 gen_methods, /* tp_methods */
232 gen_memberlist, /* tp_members */
233 0, /* tp_getset */
234 0, /* tp_base */
235 0, /* tp_dict */
Tim Peters5ca576e2001-06-18 22:08:13 +0000236};
237
238
Guido van Rossume59214e1994-08-30 08:01:59 +0000239#ifdef WITH_THREAD
Guido van Rossumff4949e1992-08-05 19:58:53 +0000240
Guido van Rossum2571cc81999-04-07 16:07:23 +0000241#ifndef DONT_HAVE_ERRNO_H
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000242#include <errno.h>
Guido van Rossum2571cc81999-04-07 16:07:23 +0000243#endif
Guido van Rossum49b56061998-10-01 20:42:43 +0000244#include "pythread.h"
Guido van Rossumff4949e1992-08-05 19:58:53 +0000245
Guido van Rossuma027efa1997-05-05 20:56:21 +0000246extern int _PyThread_Started; /* Flag for Py_Exit */
247
Guido van Rossum65d5b571998-12-21 19:32:43 +0000248static PyThread_type_lock interpreter_lock = 0;
Guido van Rossuma9672091994-09-14 13:31:22 +0000249static long main_thread = 0;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000250
251void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000252PyEval_InitThreads(void)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000253{
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000254 if (interpreter_lock)
Sjoerd Mullendered59d201993-01-06 13:36:38 +0000255 return;
Guido van Rossuma027efa1997-05-05 20:56:21 +0000256 _PyThread_Started = 1;
Guido van Rossum65d5b571998-12-21 19:32:43 +0000257 interpreter_lock = PyThread_allocate_lock();
258 PyThread_acquire_lock(interpreter_lock, 1);
259 main_thread = PyThread_get_thread_ident();
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000260}
Guido van Rossumff4949e1992-08-05 19:58:53 +0000261
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000262void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000263PyEval_AcquireLock(void)
Guido van Rossum25ce5661997-08-02 03:10:38 +0000264{
Guido van Rossum65d5b571998-12-21 19:32:43 +0000265 PyThread_acquire_lock(interpreter_lock, 1);
Guido van Rossum25ce5661997-08-02 03:10:38 +0000266}
267
268void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000269PyEval_ReleaseLock(void)
Guido van Rossum25ce5661997-08-02 03:10:38 +0000270{
Guido van Rossum65d5b571998-12-21 19:32:43 +0000271 PyThread_release_lock(interpreter_lock);
Guido van Rossum25ce5661997-08-02 03:10:38 +0000272}
273
274void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000275PyEval_AcquireThread(PyThreadState *tstate)
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000276{
277 if (tstate == NULL)
278 Py_FatalError("PyEval_AcquireThread: NULL new thread state");
Guido van Rossum65d5b571998-12-21 19:32:43 +0000279 PyThread_acquire_lock(interpreter_lock, 1);
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000280 if (PyThreadState_Swap(tstate) != NULL)
281 Py_FatalError(
282 "PyEval_AcquireThread: non-NULL old thread state");
283}
284
285void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000286PyEval_ReleaseThread(PyThreadState *tstate)
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000287{
288 if (tstate == NULL)
289 Py_FatalError("PyEval_ReleaseThread: NULL thread state");
290 if (PyThreadState_Swap(NULL) != tstate)
291 Py_FatalError("PyEval_ReleaseThread: wrong thread state");
Guido van Rossum65d5b571998-12-21 19:32:43 +0000292 PyThread_release_lock(interpreter_lock);
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000293}
Guido van Rossumfee3a2d2000-08-27 17:34:07 +0000294
295/* This function is called from PyOS_AfterFork to ensure that newly
296 created child processes don't hold locks referring to threads which
297 are not running in the child process. (This could also be done using
298 pthread_atfork mechanism, at least for the pthreads implementation.) */
299
300void
301PyEval_ReInitThreads(void)
302{
303 if (!interpreter_lock)
304 return;
305 /*XXX Can't use PyThread_free_lock here because it does too
306 much error-checking. Doing this cleanly would require
307 adding a new function to each thread_*.h. Instead, just
308 create a new lock and waste a little bit of memory */
309 interpreter_lock = PyThread_allocate_lock();
310 PyThread_acquire_lock(interpreter_lock, 1);
311 main_thread = PyThread_get_thread_ident();
312}
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000313#endif
314
Guido van Rossumff4949e1992-08-05 19:58:53 +0000315/* Functions save_thread and restore_thread are always defined so
316 dynamically loaded modules needn't be compiled separately for use
317 with and without threads: */
318
Guido van Rossum2fca21f71997-07-18 23:56:58 +0000319PyThreadState *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000320PyEval_SaveThread(void)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000321{
Guido van Rossumb74eca91997-09-30 22:03:16 +0000322 PyThreadState *tstate = PyThreadState_Swap(NULL);
323 if (tstate == NULL)
324 Py_FatalError("PyEval_SaveThread: NULL tstate");
Guido van Rossume59214e1994-08-30 08:01:59 +0000325#ifdef WITH_THREAD
Guido van Rossumb74eca91997-09-30 22:03:16 +0000326 if (interpreter_lock)
Guido van Rossum65d5b571998-12-21 19:32:43 +0000327 PyThread_release_lock(interpreter_lock);
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000328#endif
Guido van Rossumb74eca91997-09-30 22:03:16 +0000329 return tstate;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000330}
331
332void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000333PyEval_RestoreThread(PyThreadState *tstate)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000334{
Guido van Rossumb74eca91997-09-30 22:03:16 +0000335 if (tstate == NULL)
336 Py_FatalError("PyEval_RestoreThread: NULL tstate");
Guido van Rossume59214e1994-08-30 08:01:59 +0000337#ifdef WITH_THREAD
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000338 if (interpreter_lock) {
Guido van Rossumb74eca91997-09-30 22:03:16 +0000339 int err = errno;
Guido van Rossum65d5b571998-12-21 19:32:43 +0000340 PyThread_acquire_lock(interpreter_lock, 1);
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000341 errno = err;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000342 }
343#endif
Guido van Rossumb74eca91997-09-30 22:03:16 +0000344 PyThreadState_Swap(tstate);
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000345}
346
347
Guido van Rossuma9672091994-09-14 13:31:22 +0000348/* Mechanism whereby asynchronously executing callbacks (e.g. UNIX
349 signal handlers or Mac I/O completion routines) can schedule calls
350 to a function to be called synchronously.
351 The synchronous function is called with one void* argument.
352 It should return 0 for success or -1 for failure -- failure should
353 be accompanied by an exception.
354
355 If registry succeeds, the registry function returns 0; if it fails
356 (e.g. due to too many pending calls) it returns -1 (without setting
357 an exception condition).
358
359 Note that because registry may occur from within signal handlers,
360 or other asynchronous events, calling malloc() is unsafe!
361
362#ifdef WITH_THREAD
363 Any thread can schedule pending calls, but only the main thread
364 will execute them.
365#endif
366
367 XXX WARNING! ASYNCHRONOUSLY EXECUTING CODE!
368 There are two possible race conditions:
369 (1) nested asynchronous registry calls;
370 (2) registry calls made while pending calls are being processed.
371 While (1) is very unlikely, (2) is a real possibility.
372 The current code is safe against (2), but not against (1).
373 The safety against (2) is derived from the fact that only one
374 thread (the main thread) ever takes things out of the queue.
Guido van Rossuma9672091994-09-14 13:31:22 +0000375
Guido van Rossuma027efa1997-05-05 20:56:21 +0000376 XXX Darn! With the advent of thread state, we should have an array
377 of pending calls per thread in the thread state! Later...
378*/
Guido van Rossum8861b741996-07-30 16:49:37 +0000379
Guido van Rossuma9672091994-09-14 13:31:22 +0000380#define NPENDINGCALLS 32
381static struct {
Thomas Wouters334fb892000-07-25 12:56:38 +0000382 int (*func)(void *);
383 void *arg;
Guido van Rossuma9672091994-09-14 13:31:22 +0000384} pendingcalls[NPENDINGCALLS];
385static volatile int pendingfirst = 0;
386static volatile int pendinglast = 0;
Guido van Rossuma027efa1997-05-05 20:56:21 +0000387static volatile int things_to_do = 0;
Guido van Rossuma9672091994-09-14 13:31:22 +0000388
389int
Thomas Wouters334fb892000-07-25 12:56:38 +0000390Py_AddPendingCall(int (*func)(void *), void *arg)
Guido van Rossuma9672091994-09-14 13:31:22 +0000391{
Guido van Rossum180d7b41994-09-29 09:45:57 +0000392 static int busy = 0;
Guido van Rossuma9672091994-09-14 13:31:22 +0000393 int i, j;
394 /* XXX Begin critical section */
395 /* XXX If you want this to be safe against nested
396 XXX asynchronous calls, you'll have to work harder! */
Guido van Rossum180d7b41994-09-29 09:45:57 +0000397 if (busy)
398 return -1;
399 busy = 1;
Guido van Rossuma9672091994-09-14 13:31:22 +0000400 i = pendinglast;
401 j = (i + 1) % NPENDINGCALLS;
402 if (j == pendingfirst)
403 return -1; /* Queue full */
404 pendingcalls[i].func = func;
405 pendingcalls[i].arg = arg;
406 pendinglast = j;
Guido van Rossuma027efa1997-05-05 20:56:21 +0000407 things_to_do = 1; /* Signal main loop */
Guido van Rossum180d7b41994-09-29 09:45:57 +0000408 busy = 0;
Guido van Rossuma9672091994-09-14 13:31:22 +0000409 /* XXX End critical section */
410 return 0;
411}
412
Guido van Rossum180d7b41994-09-29 09:45:57 +0000413int
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000414Py_MakePendingCalls(void)
Guido van Rossuma9672091994-09-14 13:31:22 +0000415{
Guido van Rossum180d7b41994-09-29 09:45:57 +0000416 static int busy = 0;
Guido van Rossuma9672091994-09-14 13:31:22 +0000417#ifdef WITH_THREAD
Guido van Rossum65d5b571998-12-21 19:32:43 +0000418 if (main_thread && PyThread_get_thread_ident() != main_thread)
Guido van Rossuma9672091994-09-14 13:31:22 +0000419 return 0;
420#endif
Guido van Rossuma027efa1997-05-05 20:56:21 +0000421 if (busy)
Guido van Rossum180d7b41994-09-29 09:45:57 +0000422 return 0;
423 busy = 1;
Guido van Rossuma027efa1997-05-05 20:56:21 +0000424 things_to_do = 0;
Guido van Rossuma9672091994-09-14 13:31:22 +0000425 for (;;) {
426 int i;
Thomas Wouters334fb892000-07-25 12:56:38 +0000427 int (*func)(void *);
428 void *arg;
Guido van Rossuma9672091994-09-14 13:31:22 +0000429 i = pendingfirst;
430 if (i == pendinglast)
431 break; /* Queue empty */
432 func = pendingcalls[i].func;
433 arg = pendingcalls[i].arg;
434 pendingfirst = (i + 1) % NPENDINGCALLS;
Guido van Rossum180d7b41994-09-29 09:45:57 +0000435 if (func(arg) < 0) {
436 busy = 0;
Guido van Rossuma027efa1997-05-05 20:56:21 +0000437 things_to_do = 1; /* We're not done yet */
Guido van Rossuma9672091994-09-14 13:31:22 +0000438 return -1;
Guido van Rossum180d7b41994-09-29 09:45:57 +0000439 }
Guido van Rossuma9672091994-09-14 13:31:22 +0000440 }
Guido van Rossum180d7b41994-09-29 09:45:57 +0000441 busy = 0;
Guido van Rossuma9672091994-09-14 13:31:22 +0000442 return 0;
443}
444
445
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000446/* The interpreter's recursion limit */
447
Guido van Rossum349ff6f2000-09-01 01:52:08 +0000448static int recursion_limit = 1000;
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000449
Vladimir Marangozov7bd25be2000-09-01 11:07:19 +0000450int
451Py_GetRecursionLimit(void)
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000452{
453 return recursion_limit;
454}
455
Vladimir Marangozov7bd25be2000-09-01 11:07:19 +0000456void
457Py_SetRecursionLimit(int new_limit)
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000458{
459 recursion_limit = new_limit;
460}
461
Guido van Rossum374a9221991-04-04 10:40:29 +0000462/* Status code for main loop (reason for stack unwind) */
463
464enum why_code {
465 WHY_NOT, /* No error */
466 WHY_EXCEPTION, /* Exception occurred */
467 WHY_RERAISE, /* Exception re-raised by 'finally' */
468 WHY_RETURN, /* 'return' statement */
Jeremy Hylton3faa52e2001-02-01 22:48:12 +0000469 WHY_BREAK, /* 'break' statement */
Tim Peters5ca576e2001-06-18 22:08:13 +0000470 WHY_CONTINUE, /* 'continue' statement */
471 WHY_YIELD, /* 'yield' operator */
Guido van Rossum374a9221991-04-04 10:40:29 +0000472};
473
Tim Petersdbd9ba62000-07-09 03:09:57 +0000474static enum why_code do_raise(PyObject *, PyObject *, PyObject *);
Tim Petersd6d010b2001-06-21 02:49:55 +0000475static int unpack_iterable(PyObject *, int, PyObject **);
Guido van Rossum1aa14831997-01-21 05:34:20 +0000476
Guido van Rossum374a9221991-04-04 10:40:29 +0000477
Guido van Rossumb209a111997-04-29 18:18:01 +0000478PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000479PyEval_EvalCode(PyCodeObject *co, PyObject *globals, PyObject *locals)
Guido van Rossum681d79a1995-07-18 14:51:37 +0000480{
Tim Peters6d6c1a32001-08-02 04:15:00 +0000481 return PyEval_EvalCodeEx(co,
Guido van Rossum681d79a1995-07-18 14:51:37 +0000482 globals, locals,
Guido van Rossumb209a111997-04-29 18:18:01 +0000483 (PyObject **)NULL, 0,
484 (PyObject **)NULL, 0,
Jeremy Hylton64949cb2001-01-25 20:06:59 +0000485 (PyObject **)NULL, 0,
486 NULL);
Guido van Rossum681d79a1995-07-18 14:51:37 +0000487}
488
489
490/* Interpreter main loop */
491
Tim Peters6d6c1a32001-08-02 04:15:00 +0000492static PyObject *
Tim Peters5ca576e2001-06-18 22:08:13 +0000493eval_frame(PyFrameObject *f)
Guido van Rossum374a9221991-04-04 10:40:29 +0000494{
Guido van Rossum950361c1997-01-24 13:49:28 +0000495#ifdef DXPAIRS
496 int lastopcode = 0;
497#endif
Jeremy Hylton52820442001-01-03 23:52:36 +0000498 PyObject **stack_pointer;
Guido van Rossum374a9221991-04-04 10:40:29 +0000499 register unsigned char *next_instr;
Moshe Zadkaaa39a7e2000-08-07 06:34:45 +0000500 register int opcode=0; /* Current opcode */
501 register int oparg=0; /* Current opcode argument, if any */
Guido van Rossum374a9221991-04-04 10:40:29 +0000502 register enum why_code why; /* Reason for block stack unwind */
503 register int err; /* Error status -- nonzero if error */
Guido van Rossumb209a111997-04-29 18:18:01 +0000504 register PyObject *x; /* Result object -- NULL if error */
505 register PyObject *v; /* Temporary objects popped off stack */
506 register PyObject *w;
507 register PyObject *u;
508 register PyObject *t;
Barry Warsaw23c9ec82000-08-21 15:44:01 +0000509 register PyObject *stream = NULL; /* for PRINT opcodes */
Jeremy Hylton2b724da2001-01-29 22:51:52 +0000510 register PyObject **fastlocals, **freevars;
Guido van Rossum014518f1998-11-23 21:09:51 +0000511 PyObject *retval = NULL; /* Return value */
Guido van Rossum885553e1998-12-21 18:33:30 +0000512 PyThreadState *tstate = PyThreadState_GET();
Tim Peters5ca576e2001-06-18 22:08:13 +0000513 PyCodeObject *co;
Guido van Rossumd076c731998-10-07 19:42:25 +0000514 unsigned char *first_instr;
Guido van Rossum96a42c81992-01-12 02:29:51 +0000515#ifdef LLTRACE
Guido van Rossumacbe8da1993-04-15 15:33:52 +0000516 int lltrace;
Guido van Rossum374a9221991-04-04 10:40:29 +0000517#endif
Guido van Rossum408027e1996-12-30 16:17:54 +0000518#if defined(Py_DEBUG) || defined(LLTRACE)
Guido van Rossum681d79a1995-07-18 14:51:37 +0000519 /* Make it easier to find out where we are with a debugger */
Tim Peters5ca576e2001-06-18 22:08:13 +0000520 char *filename;
Guido van Rossum99bec951992-09-03 20:29:45 +0000521#endif
Guido van Rossum374a9221991-04-04 10:40:29 +0000522
523/* Code access macros */
524
525#define GETCONST(i) Getconst(f, i)
526#define GETNAME(i) Getname(f, i)
527#define GETNAMEV(i) Getnamev(f, i)
Guido van Rossumd076c731998-10-07 19:42:25 +0000528#define INSTR_OFFSET() (next_instr - first_instr)
Guido van Rossum374a9221991-04-04 10:40:29 +0000529#define NEXTOP() (*next_instr++)
530#define NEXTARG() (next_instr += 2, (next_instr[-1]<<8) + next_instr[-2])
Guido van Rossumd076c731998-10-07 19:42:25 +0000531#define JUMPTO(x) (next_instr = first_instr + (x))
Guido van Rossum374a9221991-04-04 10:40:29 +0000532#define JUMPBY(x) (next_instr += (x))
533
534/* Stack manipulation macros */
535
536#define STACK_LEVEL() (stack_pointer - f->f_valuestack)
537#define EMPTY() (STACK_LEVEL() == 0)
538#define TOP() (stack_pointer[-1])
539#define BASIC_PUSH(v) (*stack_pointer++ = (v))
540#define BASIC_POP() (*--stack_pointer)
541
Guido van Rossum96a42c81992-01-12 02:29:51 +0000542#ifdef LLTRACE
543#define PUSH(v) (BASIC_PUSH(v), lltrace && prtrace(TOP(), "push"))
544#define POP() (lltrace && prtrace(TOP(), "pop"), BASIC_POP())
Guido van Rossum374a9221991-04-04 10:40:29 +0000545#else
546#define PUSH(v) BASIC_PUSH(v)
547#define POP() BASIC_POP()
548#endif
549
Guido van Rossum46add982001-08-30 16:06:23 +0000550/* Strict int check macros */
551#define ISSTRICTINT(v) ((v)->ob_type == &PyInt_Type)
552
Guido van Rossum681d79a1995-07-18 14:51:37 +0000553/* Local variable macros */
554
555#define GETLOCAL(i) (fastlocals[i])
Guido van Rossumb209a111997-04-29 18:18:01 +0000556#define SETLOCAL(i, value) do { Py_XDECREF(GETLOCAL(i)); \
Guido van Rossum681d79a1995-07-18 14:51:37 +0000557 GETLOCAL(i) = value; } while (0)
558
Guido van Rossuma027efa1997-05-05 20:56:21 +0000559/* Start of code */
560
Tim Peters5ca576e2001-06-18 22:08:13 +0000561 if (f == NULL)
562 return NULL;
563
Guido van Rossum8861b741996-07-30 16:49:37 +0000564#ifdef USE_STACKCHECK
Guido van Rossuma027efa1997-05-05 20:56:21 +0000565 if (tstate->recursion_depth%10 == 0 && PyOS_CheckStack()) {
Guido van Rossumb209a111997-04-29 18:18:01 +0000566 PyErr_SetString(PyExc_MemoryError, "Stack overflow");
Guido van Rossum8861b741996-07-30 16:49:37 +0000567 return NULL;
568 }
569#endif
570
Tim Peters5ca576e2001-06-18 22:08:13 +0000571 /* push frame */
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000572 if (++tstate->recursion_depth > recursion_limit) {
Guido van Rossuma027efa1997-05-05 20:56:21 +0000573 --tstate->recursion_depth;
574 PyErr_SetString(PyExc_RuntimeError,
Fred Drake661ea262000-10-24 19:57:45 +0000575 "maximum recursion depth exceeded");
Guido van Rossuma027efa1997-05-05 20:56:21 +0000576 tstate->frame = f->f_back;
Guido van Rossum8861b741996-07-30 16:49:37 +0000577 return NULL;
578 }
579
Tim Peters5ca576e2001-06-18 22:08:13 +0000580 tstate->frame = f;
Tim Peters5ca576e2001-06-18 22:08:13 +0000581 co = f->f_code;
582 fastlocals = f->f_localsplus;
583 freevars = f->f_localsplus + f->f_nlocals;
Guido van Rossumd076c731998-10-07 19:42:25 +0000584 _PyCode_GETCODEPTR(co, &first_instr);
Tim Peters5ca576e2001-06-18 22:08:13 +0000585 next_instr = first_instr + f->f_lasti;
Tim Peters8c963692001-06-23 05:26:56 +0000586 stack_pointer = f->f_stacktop;
587 assert(stack_pointer != NULL);
588 f->f_stacktop = NULL;
Tim Peters5ca576e2001-06-18 22:08:13 +0000589
Neil Schemenauer6c0f2002001-09-04 19:03:35 +0000590 if (tstate->use_tracing) {
591 if (tstate->c_tracefunc != NULL) {
592 /* tstate->c_tracefunc, if defined, is a
593 function that will be called on *every* entry
594 to a code block. Its return value, if not
595 None, is a function that will be called at
596 the start of each executed line of code.
597 (Actually, the function must return itself
598 in order to continue tracing.) The trace
599 functions are called with three arguments:
600 a pointer to the current frame, a string
601 indicating why the function is called, and
602 an argument which depends on the situation.
603 The global trace function is also called
604 whenever an exception is detected. */
605 if (call_trace(tstate->c_tracefunc, tstate->c_traceobj,
606 f, PyTrace_CALL, Py_None)) {
Neil Schemenauer6c0f2002001-09-04 19:03:35 +0000607 /* Trace function raised an error */
608 return NULL;
609 }
610 }
611 if (tstate->c_profilefunc != NULL) {
612 /* Similar for c_profilefunc, except it needn't
613 return itself and isn't called for "line" events */
614 if (call_trace(tstate->c_profilefunc,
615 tstate->c_profileobj,
616 f, PyTrace_CALL, Py_None)) {
Neil Schemenauer6c0f2002001-09-04 19:03:35 +0000617 /* Profile function raised an error */
618 return NULL;
619 }
620 }
621 }
622
Tim Peters5ca576e2001-06-18 22:08:13 +0000623#ifdef LLTRACE
624 lltrace = PyDict_GetItemString(f->f_globals,"__lltrace__") != NULL;
625#endif
626#if defined(Py_DEBUG) || defined(LLTRACE)
627 filename = PyString_AsString(co->co_filename);
628#endif
Guido van Rossumac7be682001-01-17 15:42:30 +0000629
Guido van Rossum374a9221991-04-04 10:40:29 +0000630 why = WHY_NOT;
631 err = 0;
Guido van Rossumb209a111997-04-29 18:18:01 +0000632 x = Py_None; /* Not a reference, just anything non-NULL */
Fred Drake48fba732000-10-11 13:54:07 +0000633 w = NULL;
Guido van Rossumac7be682001-01-17 15:42:30 +0000634
Guido van Rossum374a9221991-04-04 10:40:29 +0000635 for (;;) {
Guido van Rossuma027efa1997-05-05 20:56:21 +0000636 /* Do periodic things. Doing this every time through
637 the loop would add too much overhead, so we do it
638 only every Nth instruction. We also do it if
639 ``things_to_do'' is set, i.e. when an asynchronous
640 event needs attention (e.g. a signal handler or
641 async I/O handler); see Py_AddPendingCall() and
642 Py_MakePendingCalls() above. */
Guido van Rossumac7be682001-01-17 15:42:30 +0000643
Guido van Rossuma027efa1997-05-05 20:56:21 +0000644 if (things_to_do || --tstate->ticker < 0) {
Guido van Rossum25ce5661997-08-02 03:10:38 +0000645 tstate->ticker = tstate->interp->checkinterval;
Guido van Rossuma027efa1997-05-05 20:56:21 +0000646 if (things_to_do) {
Guido van Rossum8861b741996-07-30 16:49:37 +0000647 if (Py_MakePendingCalls() < 0) {
648 why = WHY_EXCEPTION;
649 goto on_error;
650 }
651 }
Guido van Rossumdf0d00e1997-05-20 15:57:49 +0000652#if !defined(HAVE_SIGNAL_H) || defined(macintosh)
Guido van Rossuma027efa1997-05-05 20:56:21 +0000653 /* If we have true signals, the signal handler
654 will call Py_AddPendingCall() so we don't
655 have to call sigcheck(). On the Mac and
656 DOS, alas, we have to call it. */
Guido van Rossumb209a111997-04-29 18:18:01 +0000657 if (PyErr_CheckSignals()) {
Guido van Rossum374a9221991-04-04 10:40:29 +0000658 why = WHY_EXCEPTION;
Guido van Rossum374a9221991-04-04 10:40:29 +0000659 goto on_error;
660 }
Guido van Rossum70d44781997-01-21 06:15:24 +0000661#endif
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000662
Guido van Rossume59214e1994-08-30 08:01:59 +0000663#ifdef WITH_THREAD
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000664 if (interpreter_lock) {
665 /* Give another thread a chance */
666
Guido van Rossum25ce5661997-08-02 03:10:38 +0000667 if (PyThreadState_Swap(NULL) != tstate)
668 Py_FatalError("ceval: tstate mix-up");
Guido van Rossum65d5b571998-12-21 19:32:43 +0000669 PyThread_release_lock(interpreter_lock);
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000670
671 /* Other threads may run now */
672
Guido van Rossum65d5b571998-12-21 19:32:43 +0000673 PyThread_acquire_lock(interpreter_lock, 1);
Guido van Rossum25ce5661997-08-02 03:10:38 +0000674 if (PyThreadState_Swap(tstate) != NULL)
675 Py_FatalError("ceval: orphan tstate");
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000676 }
677#endif
Guido van Rossum374a9221991-04-04 10:40:29 +0000678 }
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000679
Guido van Rossum374a9221991-04-04 10:40:29 +0000680 /* Extract opcode and argument */
Guido van Rossum99bec951992-09-03 20:29:45 +0000681
Guido van Rossum408027e1996-12-30 16:17:54 +0000682#if defined(Py_DEBUG) || defined(LLTRACE)
Guido van Rossum99bec951992-09-03 20:29:45 +0000683 f->f_lasti = INSTR_OFFSET();
684#endif
Guido van Rossumac7be682001-01-17 15:42:30 +0000685
Guido van Rossum374a9221991-04-04 10:40:29 +0000686 opcode = NEXTOP();
687 if (HAS_ARG(opcode))
688 oparg = NEXTARG();
Fred Drakeef8ace32000-08-24 00:32:09 +0000689 dispatch_opcode:
Guido van Rossum950361c1997-01-24 13:49:28 +0000690#ifdef DYNAMIC_EXECUTION_PROFILE
691#ifdef DXPAIRS
692 dxpairs[lastopcode][opcode]++;
693 lastopcode = opcode;
694#endif
695 dxp[opcode]++;
696#endif
Guido van Rossum374a9221991-04-04 10:40:29 +0000697
Guido van Rossum96a42c81992-01-12 02:29:51 +0000698#ifdef LLTRACE
Guido van Rossum374a9221991-04-04 10:40:29 +0000699 /* Instruction tracing */
Guido van Rossumac7be682001-01-17 15:42:30 +0000700
Guido van Rossum96a42c81992-01-12 02:29:51 +0000701 if (lltrace) {
Guido van Rossum374a9221991-04-04 10:40:29 +0000702 if (HAS_ARG(opcode)) {
703 printf("%d: %d, %d\n",
704 (int) (INSTR_OFFSET() - 3),
705 opcode, oparg);
706 }
707 else {
708 printf("%d: %d\n",
709 (int) (INSTR_OFFSET() - 1), opcode);
710 }
711 }
712#endif
Guido van Rossum374a9221991-04-04 10:40:29 +0000713 /* Main switch on opcode */
Jeremy Hylton52820442001-01-03 23:52:36 +0000714
Guido van Rossum374a9221991-04-04 10:40:29 +0000715 switch (opcode) {
Guido van Rossumac7be682001-01-17 15:42:30 +0000716
Guido van Rossum374a9221991-04-04 10:40:29 +0000717 /* BEWARE!
718 It is essential that any operation that fails sets either
719 x to NULL, err to nonzero, or why to anything but WHY_NOT,
720 and that no operation that succeeds does this! */
Guido van Rossumac7be682001-01-17 15:42:30 +0000721
Guido van Rossum374a9221991-04-04 10:40:29 +0000722 /* case STOP_CODE: this is an error! */
Guido van Rossumac7be682001-01-17 15:42:30 +0000723
Guido van Rossum374a9221991-04-04 10:40:29 +0000724 case POP_TOP:
725 v = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +0000726 Py_DECREF(v);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000727 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +0000728
Guido van Rossum374a9221991-04-04 10:40:29 +0000729 case ROT_TWO:
730 v = POP();
731 w = POP();
732 PUSH(v);
733 PUSH(w);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000734 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +0000735
Guido van Rossum374a9221991-04-04 10:40:29 +0000736 case ROT_THREE:
737 v = POP();
738 w = POP();
739 x = POP();
740 PUSH(v);
741 PUSH(x);
742 PUSH(w);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000743 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +0000744
Thomas Wouters434d0822000-08-24 20:11:32 +0000745 case ROT_FOUR:
746 u = POP();
747 v = POP();
748 w = POP();
749 x = POP();
750 PUSH(u);
751 PUSH(x);
752 PUSH(w);
753 PUSH(v);
754 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +0000755
Guido van Rossum374a9221991-04-04 10:40:29 +0000756 case DUP_TOP:
757 v = TOP();
Guido van Rossumb209a111997-04-29 18:18:01 +0000758 Py_INCREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +0000759 PUSH(v);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000760 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +0000761
Thomas Wouters434d0822000-08-24 20:11:32 +0000762 case DUP_TOPX:
763 switch (oparg) {
Thomas Wouters434d0822000-08-24 20:11:32 +0000764 case 1:
Tim Peters35ba6892000-10-11 07:04:49 +0000765 x = TOP();
766 Py_INCREF(x);
767 PUSH(x);
768 continue;
769 case 2:
Thomas Wouters434d0822000-08-24 20:11:32 +0000770 x = POP();
Tim Peters35ba6892000-10-11 07:04:49 +0000771 Py_INCREF(x);
772 w = TOP();
773 Py_INCREF(w);
774 PUSH(x);
775 PUSH(w);
776 PUSH(x);
777 continue;
778 case 3:
779 x = POP();
780 Py_INCREF(x);
Thomas Wouters434d0822000-08-24 20:11:32 +0000781 w = POP();
Tim Peters35ba6892000-10-11 07:04:49 +0000782 Py_INCREF(w);
783 v = TOP();
784 Py_INCREF(v);
785 PUSH(w);
786 PUSH(x);
787 PUSH(v);
788 PUSH(w);
789 PUSH(x);
790 continue;
791 case 4:
792 x = POP();
793 Py_INCREF(x);
794 w = POP();
795 Py_INCREF(w);
Thomas Wouters434d0822000-08-24 20:11:32 +0000796 v = POP();
Tim Peters35ba6892000-10-11 07:04:49 +0000797 Py_INCREF(v);
798 u = TOP();
799 Py_INCREF(u);
800 PUSH(v);
801 PUSH(w);
802 PUSH(x);
803 PUSH(u);
804 PUSH(v);
805 PUSH(w);
806 PUSH(x);
807 continue;
808 case 5:
809 x = POP();
810 Py_INCREF(x);
811 w = POP();
812 Py_INCREF(w);
813 v = POP();
814 Py_INCREF(v);
Thomas Wouters434d0822000-08-24 20:11:32 +0000815 u = POP();
Tim Peters35ba6892000-10-11 07:04:49 +0000816 Py_INCREF(u);
817 t = TOP();
818 Py_INCREF(t);
819 PUSH(u);
820 PUSH(v);
821 PUSH(w);
822 PUSH(x);
823 PUSH(t);
824 PUSH(u);
825 PUSH(v);
826 PUSH(w);
827 PUSH(x);
828 continue;
Thomas Wouters434d0822000-08-24 20:11:32 +0000829 default:
Thomas Wouters0be483f2000-10-11 23:26:11 +0000830 Py_FatalError("invalid argument to DUP_TOPX"
831 " (bytecode corruption?)");
Thomas Wouters434d0822000-08-24 20:11:32 +0000832 }
Tim Peters35ba6892000-10-11 07:04:49 +0000833 break;
Thomas Wouters434d0822000-08-24 20:11:32 +0000834
Guido van Rossum374a9221991-04-04 10:40:29 +0000835 case UNARY_POSITIVE:
836 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +0000837 x = PyNumber_Positive(v);
Guido van Rossumb209a111997-04-29 18:18:01 +0000838 Py_DECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +0000839 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000840 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +0000841 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000842
Guido van Rossum374a9221991-04-04 10:40:29 +0000843 case UNARY_NEGATIVE:
844 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +0000845 x = PyNumber_Negative(v);
Guido van Rossumb209a111997-04-29 18:18:01 +0000846 Py_DECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +0000847 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000848 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +0000849 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000850
Guido van Rossum374a9221991-04-04 10:40:29 +0000851 case UNARY_NOT:
852 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +0000853 err = PyObject_IsTrue(v);
Guido van Rossumb209a111997-04-29 18:18:01 +0000854 Py_DECREF(v);
Guido van Rossumfc490731997-05-06 15:06:49 +0000855 if (err == 0) {
856 Py_INCREF(Py_True);
857 PUSH(Py_True);
858 continue;
859 }
860 else if (err > 0) {
861 Py_INCREF(Py_False);
862 PUSH(Py_False);
863 err = 0;
864 continue;
865 }
Guido van Rossum374a9221991-04-04 10:40:29 +0000866 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000867
Guido van Rossum374a9221991-04-04 10:40:29 +0000868 case UNARY_CONVERT:
869 v = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +0000870 x = PyObject_Repr(v);
871 Py_DECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +0000872 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000873 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +0000874 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000875
Guido van Rossum7928cd71991-10-24 14:59:31 +0000876 case UNARY_INVERT:
877 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +0000878 x = PyNumber_Invert(v);
Guido van Rossumb209a111997-04-29 18:18:01 +0000879 Py_DECREF(v);
Guido van Rossum7928cd71991-10-24 14:59:31 +0000880 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000881 if (x != NULL) continue;
Guido van Rossum7928cd71991-10-24 14:59:31 +0000882 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000883
Guido van Rossum50564e81996-01-12 01:13:16 +0000884 case BINARY_POWER:
885 w = POP();
886 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +0000887 x = PyNumber_Power(v, w, Py_None);
Guido van Rossumb209a111997-04-29 18:18:01 +0000888 Py_DECREF(v);
889 Py_DECREF(w);
Guido van Rossum50564e81996-01-12 01:13:16 +0000890 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000891 if (x != NULL) continue;
Guido van Rossum50564e81996-01-12 01:13:16 +0000892 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000893
Guido van Rossum374a9221991-04-04 10:40:29 +0000894 case BINARY_MULTIPLY:
895 w = POP();
896 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +0000897 x = PyNumber_Multiply(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +0000898 Py_DECREF(v);
899 Py_DECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +0000900 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000901 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +0000902 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000903
Guido van Rossum374a9221991-04-04 10:40:29 +0000904 case BINARY_DIVIDE:
905 w = POP();
906 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +0000907 x = PyNumber_Divide(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +0000908 Py_DECREF(v);
909 Py_DECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +0000910 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000911 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +0000912 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000913
Guido van Rossum4668b002001-08-08 05:00:18 +0000914 case BINARY_FLOOR_DIVIDE:
915 w = POP();
916 v = POP();
917 x = PyNumber_FloorDivide(v, w);
918 Py_DECREF(v);
919 Py_DECREF(w);
920 PUSH(x);
921 if (x != NULL) continue;
922 break;
923
924 case BINARY_TRUE_DIVIDE:
925 w = POP();
926 v = POP();
927 x = PyNumber_TrueDivide(v, w);
928 Py_DECREF(v);
929 Py_DECREF(w);
930 PUSH(x);
931 if (x != NULL) continue;
932 break;
933
Guido van Rossum374a9221991-04-04 10:40:29 +0000934 case BINARY_MODULO:
935 w = POP();
936 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +0000937 x = PyNumber_Remainder(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +0000938 Py_DECREF(v);
939 Py_DECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +0000940 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000941 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +0000942 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000943
Guido van Rossum374a9221991-04-04 10:40:29 +0000944 case BINARY_ADD:
945 w = POP();
946 v = POP();
Guido van Rossum46add982001-08-30 16:06:23 +0000947 if (ISSTRICTINT(v) && ISSTRICTINT(w)) {
Guido van Rossumc12da691997-07-17 23:12:42 +0000948 /* INLINE: int + int */
949 register long a, b, i;
Guido van Rossumcf183ac1998-12-04 18:51:36 +0000950 a = PyInt_AS_LONG(v);
951 b = PyInt_AS_LONG(w);
Guido van Rossumc12da691997-07-17 23:12:42 +0000952 i = a + b;
Guido van Rossum87780df2001-08-23 02:58:07 +0000953 if ((i^a) < 0 && (i^b) < 0)
954 goto slow_add;
955 x = PyInt_FromLong(i);
Guido van Rossumc12da691997-07-17 23:12:42 +0000956 }
Guido van Rossum87780df2001-08-23 02:58:07 +0000957 else {
958 slow_add:
Guido van Rossumc12da691997-07-17 23:12:42 +0000959 x = PyNumber_Add(v, w);
Guido van Rossum87780df2001-08-23 02:58:07 +0000960 }
Guido van Rossumb209a111997-04-29 18:18:01 +0000961 Py_DECREF(v);
962 Py_DECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +0000963 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000964 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +0000965 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000966
Guido van Rossum374a9221991-04-04 10:40:29 +0000967 case BINARY_SUBTRACT:
968 w = POP();
969 v = POP();
Guido van Rossum46add982001-08-30 16:06:23 +0000970 if (ISSTRICTINT(v) && ISSTRICTINT(w)) {
Guido van Rossumc12da691997-07-17 23:12:42 +0000971 /* INLINE: int - int */
972 register long a, b, i;
Guido van Rossumcf183ac1998-12-04 18:51:36 +0000973 a = PyInt_AS_LONG(v);
974 b = PyInt_AS_LONG(w);
Guido van Rossumc12da691997-07-17 23:12:42 +0000975 i = a - b;
Guido van Rossum87780df2001-08-23 02:58:07 +0000976 if ((i^a) < 0 && (i^~b) < 0)
977 goto slow_sub;
978 x = PyInt_FromLong(i);
Guido van Rossumc12da691997-07-17 23:12:42 +0000979 }
Guido van Rossum87780df2001-08-23 02:58:07 +0000980 else {
981 slow_sub:
Guido van Rossumc12da691997-07-17 23:12:42 +0000982 x = PyNumber_Subtract(v, w);
Guido van Rossum87780df2001-08-23 02:58:07 +0000983 }
Guido van Rossumb209a111997-04-29 18:18:01 +0000984 Py_DECREF(v);
985 Py_DECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +0000986 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +0000987 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +0000988 break;
Guido van Rossumac7be682001-01-17 15:42:30 +0000989
Guido van Rossum374a9221991-04-04 10:40:29 +0000990 case BINARY_SUBSCR:
991 w = POP();
992 v = POP();
Guido van Rossum46add982001-08-30 16:06:23 +0000993 if (v->ob_type == &PyList_Type && ISSTRICTINT(w)) {
Guido van Rossumc12da691997-07-17 23:12:42 +0000994 /* INLINE: list[int] */
995 long i = PyInt_AsLong(w);
996 if (i < 0)
Guido van Rossumfa00e951998-07-08 15:02:37 +0000997 i += PyList_GET_SIZE(v);
Guido van Rossumc12da691997-07-17 23:12:42 +0000998 if (i < 0 ||
Guido van Rossumfa00e951998-07-08 15:02:37 +0000999 i >= PyList_GET_SIZE(v)) {
Guido van Rossumc12da691997-07-17 23:12:42 +00001000 PyErr_SetString(PyExc_IndexError,
1001 "list index out of range");
1002 x = NULL;
1003 }
1004 else {
Guido van Rossumfa00e951998-07-08 15:02:37 +00001005 x = PyList_GET_ITEM(v, i);
Guido van Rossumc12da691997-07-17 23:12:42 +00001006 Py_INCREF(x);
1007 }
1008 }
1009 else
1010 x = PyObject_GetItem(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00001011 Py_DECREF(v);
1012 Py_DECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001013 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001014 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001015 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001016
Guido van Rossum7928cd71991-10-24 14:59:31 +00001017 case BINARY_LSHIFT:
1018 w = POP();
1019 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +00001020 x = PyNumber_Lshift(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00001021 Py_DECREF(v);
1022 Py_DECREF(w);
Guido van Rossum7928cd71991-10-24 14:59:31 +00001023 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001024 if (x != NULL) continue;
Guido van Rossum7928cd71991-10-24 14:59:31 +00001025 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001026
Guido van Rossum7928cd71991-10-24 14:59:31 +00001027 case BINARY_RSHIFT:
1028 w = POP();
1029 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +00001030 x = PyNumber_Rshift(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00001031 Py_DECREF(v);
1032 Py_DECREF(w);
Guido van Rossum7928cd71991-10-24 14:59:31 +00001033 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001034 if (x != NULL) continue;
Guido van Rossum7928cd71991-10-24 14:59:31 +00001035 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001036
Guido van Rossum7928cd71991-10-24 14:59:31 +00001037 case BINARY_AND:
1038 w = POP();
1039 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +00001040 x = PyNumber_And(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00001041 Py_DECREF(v);
1042 Py_DECREF(w);
Guido van Rossum7928cd71991-10-24 14:59:31 +00001043 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001044 if (x != NULL) continue;
Guido van Rossum7928cd71991-10-24 14:59:31 +00001045 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001046
Guido van Rossum7928cd71991-10-24 14:59:31 +00001047 case BINARY_XOR:
1048 w = POP();
1049 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +00001050 x = PyNumber_Xor(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00001051 Py_DECREF(v);
1052 Py_DECREF(w);
Guido van Rossum7928cd71991-10-24 14:59:31 +00001053 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001054 if (x != NULL) continue;
Guido van Rossum7928cd71991-10-24 14:59:31 +00001055 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001056
Guido van Rossum7928cd71991-10-24 14:59:31 +00001057 case BINARY_OR:
1058 w = POP();
1059 v = POP();
Guido van Rossumfc490731997-05-06 15:06:49 +00001060 x = PyNumber_Or(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00001061 Py_DECREF(v);
1062 Py_DECREF(w);
Guido van Rossum7928cd71991-10-24 14:59:31 +00001063 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001064 if (x != NULL) continue;
Guido van Rossum7928cd71991-10-24 14:59:31 +00001065 break;
Thomas Wouters434d0822000-08-24 20:11:32 +00001066
1067 case INPLACE_POWER:
1068 w = POP();
1069 v = POP();
1070 x = PyNumber_InPlacePower(v, w, Py_None);
1071 Py_DECREF(v);
1072 Py_DECREF(w);
1073 PUSH(x);
1074 if (x != NULL) continue;
1075 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001076
Thomas Wouters434d0822000-08-24 20:11:32 +00001077 case INPLACE_MULTIPLY:
1078 w = POP();
1079 v = POP();
1080 x = PyNumber_InPlaceMultiply(v, w);
1081 Py_DECREF(v);
1082 Py_DECREF(w);
1083 PUSH(x);
1084 if (x != NULL) continue;
1085 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001086
Thomas Wouters434d0822000-08-24 20:11:32 +00001087 case INPLACE_DIVIDE:
1088 w = POP();
1089 v = POP();
1090 x = PyNumber_InPlaceDivide(v, w);
1091 Py_DECREF(v);
1092 Py_DECREF(w);
1093 PUSH(x);
1094 if (x != NULL) continue;
1095 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001096
Guido van Rossum4668b002001-08-08 05:00:18 +00001097 case INPLACE_FLOOR_DIVIDE:
1098 w = POP();
1099 v = POP();
1100 x = PyNumber_InPlaceFloorDivide(v, w);
1101 Py_DECREF(v);
1102 Py_DECREF(w);
1103 PUSH(x);
1104 if (x != NULL) continue;
1105 break;
1106
1107 case INPLACE_TRUE_DIVIDE:
1108 w = POP();
1109 v = POP();
1110 x = PyNumber_InPlaceTrueDivide(v, w);
1111 Py_DECREF(v);
1112 Py_DECREF(w);
1113 PUSH(x);
1114 if (x != NULL) continue;
1115 break;
1116
Thomas Wouters434d0822000-08-24 20:11:32 +00001117 case INPLACE_MODULO:
1118 w = POP();
1119 v = POP();
1120 x = PyNumber_InPlaceRemainder(v, w);
1121 Py_DECREF(v);
1122 Py_DECREF(w);
1123 PUSH(x);
1124 if (x != NULL) continue;
1125 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001126
Thomas Wouters434d0822000-08-24 20:11:32 +00001127 case INPLACE_ADD:
1128 w = POP();
1129 v = POP();
Guido van Rossum46add982001-08-30 16:06:23 +00001130 if (ISSTRICTINT(v) && ISSTRICTINT(w)) {
Thomas Wouters434d0822000-08-24 20:11:32 +00001131 /* INLINE: int + int */
1132 register long a, b, i;
1133 a = PyInt_AS_LONG(v);
1134 b = PyInt_AS_LONG(w);
1135 i = a + b;
Guido van Rossum87780df2001-08-23 02:58:07 +00001136 if ((i^a) < 0 && (i^b) < 0)
1137 goto slow_iadd;
1138 x = PyInt_FromLong(i);
Thomas Wouters434d0822000-08-24 20:11:32 +00001139 }
Guido van Rossum87780df2001-08-23 02:58:07 +00001140 else {
1141 slow_iadd:
Thomas Wouters434d0822000-08-24 20:11:32 +00001142 x = PyNumber_InPlaceAdd(v, w);
Guido van Rossum87780df2001-08-23 02:58:07 +00001143 }
Thomas Wouters434d0822000-08-24 20:11:32 +00001144 Py_DECREF(v);
1145 Py_DECREF(w);
1146 PUSH(x);
1147 if (x != NULL) continue;
1148 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001149
Thomas Wouters434d0822000-08-24 20:11:32 +00001150 case INPLACE_SUBTRACT:
1151 w = POP();
1152 v = POP();
Guido van Rossum46add982001-08-30 16:06:23 +00001153 if (ISSTRICTINT(v) && ISSTRICTINT(w)) {
Thomas Wouters434d0822000-08-24 20:11:32 +00001154 /* INLINE: int - int */
1155 register long a, b, i;
1156 a = PyInt_AS_LONG(v);
1157 b = PyInt_AS_LONG(w);
1158 i = a - b;
Guido van Rossum87780df2001-08-23 02:58:07 +00001159 if ((i^a) < 0 && (i^~b) < 0)
1160 goto slow_isub;
1161 x = PyInt_FromLong(i);
Thomas Wouters434d0822000-08-24 20:11:32 +00001162 }
Guido van Rossum87780df2001-08-23 02:58:07 +00001163 else {
1164 slow_isub:
Thomas Wouters434d0822000-08-24 20:11:32 +00001165 x = PyNumber_InPlaceSubtract(v, w);
Guido van Rossum87780df2001-08-23 02:58:07 +00001166 }
Thomas Wouters434d0822000-08-24 20:11:32 +00001167 Py_DECREF(v);
1168 Py_DECREF(w);
1169 PUSH(x);
1170 if (x != NULL) continue;
1171 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001172
Thomas Wouters434d0822000-08-24 20:11:32 +00001173 case INPLACE_LSHIFT:
1174 w = POP();
1175 v = POP();
1176 x = PyNumber_InPlaceLshift(v, w);
1177 Py_DECREF(v);
1178 Py_DECREF(w);
1179 PUSH(x);
1180 if (x != NULL) continue;
1181 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001182
Thomas Wouters434d0822000-08-24 20:11:32 +00001183 case INPLACE_RSHIFT:
1184 w = POP();
1185 v = POP();
1186 x = PyNumber_InPlaceRshift(v, w);
1187 Py_DECREF(v);
1188 Py_DECREF(w);
1189 PUSH(x);
1190 if (x != NULL) continue;
1191 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001192
Thomas Wouters434d0822000-08-24 20:11:32 +00001193 case INPLACE_AND:
1194 w = POP();
1195 v = POP();
1196 x = PyNumber_InPlaceAnd(v, w);
1197 Py_DECREF(v);
1198 Py_DECREF(w);
1199 PUSH(x);
1200 if (x != NULL) continue;
1201 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001202
Thomas Wouters434d0822000-08-24 20:11:32 +00001203 case INPLACE_XOR:
1204 w = POP();
1205 v = POP();
1206 x = PyNumber_InPlaceXor(v, w);
1207 Py_DECREF(v);
1208 Py_DECREF(w);
1209 PUSH(x);
1210 if (x != NULL) continue;
1211 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001212
Thomas Wouters434d0822000-08-24 20:11:32 +00001213 case INPLACE_OR:
1214 w = POP();
1215 v = POP();
1216 x = PyNumber_InPlaceOr(v, w);
1217 Py_DECREF(v);
1218 Py_DECREF(w);
1219 PUSH(x);
1220 if (x != NULL) continue;
1221 break;
1222
Guido van Rossum374a9221991-04-04 10:40:29 +00001223 case SLICE+0:
1224 case SLICE+1:
1225 case SLICE+2:
1226 case SLICE+3:
1227 if ((opcode-SLICE) & 2)
1228 w = POP();
1229 else
1230 w = NULL;
1231 if ((opcode-SLICE) & 1)
1232 v = POP();
1233 else
1234 v = NULL;
1235 u = POP();
1236 x = apply_slice(u, v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00001237 Py_DECREF(u);
1238 Py_XDECREF(v);
1239 Py_XDECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001240 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001241 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001242 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001243
Guido van Rossum374a9221991-04-04 10:40:29 +00001244 case STORE_SLICE+0:
1245 case STORE_SLICE+1:
1246 case STORE_SLICE+2:
1247 case STORE_SLICE+3:
1248 if ((opcode-STORE_SLICE) & 2)
1249 w = POP();
1250 else
1251 w = NULL;
1252 if ((opcode-STORE_SLICE) & 1)
1253 v = POP();
1254 else
1255 v = NULL;
1256 u = POP();
1257 t = POP();
1258 err = assign_slice(u, v, w, t); /* u[v:w] = t */
Guido van Rossumb209a111997-04-29 18:18:01 +00001259 Py_DECREF(t);
1260 Py_DECREF(u);
1261 Py_XDECREF(v);
1262 Py_XDECREF(w);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001263 if (err == 0) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001264 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001265
Guido van Rossum374a9221991-04-04 10:40:29 +00001266 case DELETE_SLICE+0:
1267 case DELETE_SLICE+1:
1268 case DELETE_SLICE+2:
1269 case DELETE_SLICE+3:
1270 if ((opcode-DELETE_SLICE) & 2)
1271 w = POP();
1272 else
1273 w = NULL;
1274 if ((opcode-DELETE_SLICE) & 1)
1275 v = POP();
1276 else
1277 v = NULL;
1278 u = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001279 err = assign_slice(u, v, w, (PyObject *)NULL);
Guido van Rossum374a9221991-04-04 10:40:29 +00001280 /* del u[v:w] */
Guido van Rossumb209a111997-04-29 18:18:01 +00001281 Py_DECREF(u);
1282 Py_XDECREF(v);
1283 Py_XDECREF(w);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001284 if (err == 0) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001285 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001286
Guido van Rossum374a9221991-04-04 10:40:29 +00001287 case STORE_SUBSCR:
1288 w = POP();
1289 v = POP();
1290 u = POP();
1291 /* v[w] = u */
Guido van Rossumfc490731997-05-06 15:06:49 +00001292 err = PyObject_SetItem(v, w, u);
Guido van Rossumb209a111997-04-29 18:18:01 +00001293 Py_DECREF(u);
1294 Py_DECREF(v);
1295 Py_DECREF(w);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001296 if (err == 0) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001297 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001298
Guido van Rossum374a9221991-04-04 10:40:29 +00001299 case DELETE_SUBSCR:
1300 w = POP();
1301 v = POP();
1302 /* del v[w] */
Guido van Rossumfc490731997-05-06 15:06:49 +00001303 err = PyObject_DelItem(v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00001304 Py_DECREF(v);
1305 Py_DECREF(w);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001306 if (err == 0) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001307 break;
Barry Warsaw23c9ec82000-08-21 15:44:01 +00001308
Guido van Rossum374a9221991-04-04 10:40:29 +00001309 case PRINT_EXPR:
1310 v = POP();
Moshe Zadkaf68f2fe2001-01-11 05:41:27 +00001311 w = PySys_GetObject("displayhook");
1312 if (w == NULL) {
1313 PyErr_SetString(PyExc_RuntimeError,
1314 "lost sys.displayhook");
1315 err = -1;
Moshe Zadkaf5df3832001-01-11 11:55:37 +00001316 x = NULL;
Moshe Zadkaf68f2fe2001-01-11 05:41:27 +00001317 }
1318 if (err == 0) {
1319 x = Py_BuildValue("(O)", v);
1320 if (x == NULL)
1321 err = -1;
1322 }
1323 if (err == 0) {
1324 w = PyEval_CallObject(w, x);
Moshe Zadkaf5df3832001-01-11 11:55:37 +00001325 Py_XDECREF(w);
Moshe Zadkaf68f2fe2001-01-11 05:41:27 +00001326 if (w == NULL)
1327 err = -1;
Guido van Rossum374a9221991-04-04 10:40:29 +00001328 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001329 Py_DECREF(v);
Moshe Zadkaf68f2fe2001-01-11 05:41:27 +00001330 Py_XDECREF(x);
Guido van Rossum374a9221991-04-04 10:40:29 +00001331 break;
Moshe Zadkaf68f2fe2001-01-11 05:41:27 +00001332
Barry Warsaw23c9ec82000-08-21 15:44:01 +00001333 case PRINT_ITEM_TO:
1334 w = stream = POP();
1335 /* fall through to PRINT_ITEM */
1336
Guido van Rossum374a9221991-04-04 10:40:29 +00001337 case PRINT_ITEM:
1338 v = POP();
Barry Warsaw093abe02000-08-29 04:56:13 +00001339 if (stream == NULL || stream == Py_None) {
Barry Warsaw23c9ec82000-08-21 15:44:01 +00001340 w = PySys_GetObject("stdout");
1341 if (w == NULL) {
1342 PyErr_SetString(PyExc_RuntimeError,
1343 "lost sys.stdout");
1344 err = -1;
1345 }
Guido van Rossum8f183201997-12-31 05:53:15 +00001346 }
Barry Warsaw23c9ec82000-08-21 15:44:01 +00001347 if (w != NULL && PyFile_SoftSpace(w, 1))
Guido van Rossumbe270261997-05-22 22:26:18 +00001348 err = PyFile_WriteString(" ", w);
1349 if (err == 0)
1350 err = PyFile_WriteObject(v, w, Py_PRINT_RAW);
Guido van Rossumb209a111997-04-29 18:18:01 +00001351 if (err == 0 && PyString_Check(v)) {
Guido van Rossumc6004111993-11-05 10:22:19 +00001352 /* XXX move into writeobject() ? */
Guido van Rossumb209a111997-04-29 18:18:01 +00001353 char *s = PyString_AsString(v);
1354 int len = PyString_Size(v);
Guido van Rossum7f7f2741995-02-10 17:01:56 +00001355 if (len > 0 &&
1356 isspace(Py_CHARMASK(s[len-1])) &&
Guido van Rossumc6004111993-11-05 10:22:19 +00001357 s[len-1] != ' ')
Guido van Rossumb209a111997-04-29 18:18:01 +00001358 PyFile_SoftSpace(w, 0);
Guido van Rossum374a9221991-04-04 10:40:29 +00001359 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001360 Py_DECREF(v);
Barry Warsaw23c9ec82000-08-21 15:44:01 +00001361 Py_XDECREF(stream);
1362 stream = NULL;
1363 if (err == 0)
1364 continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001365 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001366
Barry Warsaw23c9ec82000-08-21 15:44:01 +00001367 case PRINT_NEWLINE_TO:
1368 w = stream = POP();
1369 /* fall through to PRINT_NEWLINE */
1370
Guido van Rossum374a9221991-04-04 10:40:29 +00001371 case PRINT_NEWLINE:
Barry Warsaw093abe02000-08-29 04:56:13 +00001372 if (stream == NULL || stream == Py_None) {
Barry Warsaw23c9ec82000-08-21 15:44:01 +00001373 w = PySys_GetObject("stdout");
1374 if (w == NULL)
1375 PyErr_SetString(PyExc_RuntimeError,
1376 "lost sys.stdout");
Guido van Rossum3165fe61992-09-25 21:59:05 +00001377 }
Barry Warsaw23c9ec82000-08-21 15:44:01 +00001378 if (w != NULL) {
1379 err = PyFile_WriteString("\n", w);
1380 if (err == 0)
1381 PyFile_SoftSpace(w, 0);
1382 }
1383 Py_XDECREF(stream);
1384 stream = NULL;
Guido van Rossum374a9221991-04-04 10:40:29 +00001385 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001386
Thomas Wouters434d0822000-08-24 20:11:32 +00001387
1388#ifdef CASE_TOO_BIG
1389 default: switch (opcode) {
1390#endif
Guido van Rossum374a9221991-04-04 10:40:29 +00001391 case BREAK_LOOP:
1392 why = WHY_BREAK;
1393 break;
Guido van Rossum66b0e9c2001-03-21 19:17:22 +00001394
Jeremy Hylton3faa52e2001-02-01 22:48:12 +00001395 case CONTINUE_LOOP:
1396 retval = PyInt_FromLong(oparg);
1397 why = WHY_CONTINUE;
1398 break;
Guido van Rossumf10570b1995-07-07 22:53:21 +00001399
Guido van Rossumf10570b1995-07-07 22:53:21 +00001400 case RAISE_VARARGS:
1401 u = v = w = NULL;
1402 switch (oparg) {
1403 case 3:
1404 u = POP(); /* traceback */
Guido van Rossumf10570b1995-07-07 22:53:21 +00001405 /* Fallthrough */
1406 case 2:
1407 v = POP(); /* value */
1408 /* Fallthrough */
1409 case 1:
1410 w = POP(); /* exc */
Guido van Rossumd295f121998-04-09 21:39:57 +00001411 case 0: /* Fallthrough */
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00001412 why = do_raise(w, v, u);
Guido van Rossumf10570b1995-07-07 22:53:21 +00001413 break;
1414 default:
Guido van Rossumb209a111997-04-29 18:18:01 +00001415 PyErr_SetString(PyExc_SystemError,
Guido van Rossumf10570b1995-07-07 22:53:21 +00001416 "bad RAISE_VARARGS oparg");
Guido van Rossumf10570b1995-07-07 22:53:21 +00001417 why = WHY_EXCEPTION;
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00001418 break;
1419 }
Guido van Rossum374a9221991-04-04 10:40:29 +00001420 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001421
Guido van Rossum374a9221991-04-04 10:40:29 +00001422 case LOAD_LOCALS:
Guido van Rossum681d79a1995-07-18 14:51:37 +00001423 if ((x = f->f_locals) == NULL) {
Guido van Rossuma027efa1997-05-05 20:56:21 +00001424 PyErr_SetString(PyExc_SystemError,
1425 "no locals");
Guido van Rossum681d79a1995-07-18 14:51:37 +00001426 break;
1427 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001428 Py_INCREF(x);
Guido van Rossum681d79a1995-07-18 14:51:37 +00001429 PUSH(x);
Guido van Rossum374a9221991-04-04 10:40:29 +00001430 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001431
Guido van Rossum374a9221991-04-04 10:40:29 +00001432 case RETURN_VALUE:
1433 retval = POP();
1434 why = WHY_RETURN;
1435 break;
Guido van Rossumdb3165e1993-10-18 17:06:59 +00001436
Tim Peters5ca576e2001-06-18 22:08:13 +00001437 case YIELD_VALUE:
1438 retval = POP();
Tim Peters8c963692001-06-23 05:26:56 +00001439 f->f_stacktop = stack_pointer;
Tim Peters5ca576e2001-06-18 22:08:13 +00001440 f->f_lasti = INSTR_OFFSET();
1441 why = WHY_YIELD;
1442 break;
1443
1444
Guido van Rossumdb3165e1993-10-18 17:06:59 +00001445 case EXEC_STMT:
1446 w = POP();
1447 v = POP();
1448 u = POP();
Guido van Rossuma027efa1997-05-05 20:56:21 +00001449 err = exec_statement(f, u, v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00001450 Py_DECREF(u);
1451 Py_DECREF(v);
1452 Py_DECREF(w);
Guido van Rossumdb3165e1993-10-18 17:06:59 +00001453 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001454
Guido van Rossum374a9221991-04-04 10:40:29 +00001455 case POP_BLOCK:
1456 {
Guido van Rossumb209a111997-04-29 18:18:01 +00001457 PyTryBlock *b = PyFrame_BlockPop(f);
Guido van Rossum374a9221991-04-04 10:40:29 +00001458 while (STACK_LEVEL() > b->b_level) {
1459 v = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001460 Py_DECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +00001461 }
1462 }
1463 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001464
Guido van Rossum374a9221991-04-04 10:40:29 +00001465 case END_FINALLY:
1466 v = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001467 if (PyInt_Check(v)) {
1468 why = (enum why_code) PyInt_AsLong(v);
Jeremy Hylton3faa52e2001-02-01 22:48:12 +00001469 if (why == WHY_RETURN ||
Tim Peters5ca576e2001-06-18 22:08:13 +00001470 why == WHY_YIELD ||
Jeremy Hylton3faa52e2001-02-01 22:48:12 +00001471 why == CONTINUE_LOOP)
Guido van Rossum374a9221991-04-04 10:40:29 +00001472 retval = POP();
1473 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001474 else if (PyString_Check(v) || PyClass_Check(v)) {
Guido van Rossum374a9221991-04-04 10:40:29 +00001475 w = POP();
Guido van Rossumf10570b1995-07-07 22:53:21 +00001476 u = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001477 PyErr_Restore(v, w, u);
Guido van Rossum374a9221991-04-04 10:40:29 +00001478 why = WHY_RERAISE;
Guido van Rossum0db1ef91995-07-28 23:06:00 +00001479 break;
Guido van Rossum374a9221991-04-04 10:40:29 +00001480 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001481 else if (v != Py_None) {
1482 PyErr_SetString(PyExc_SystemError,
Guido van Rossum374a9221991-04-04 10:40:29 +00001483 "'finally' pops bad exception");
1484 why = WHY_EXCEPTION;
1485 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001486 Py_DECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +00001487 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001488
Guido van Rossum374a9221991-04-04 10:40:29 +00001489 case BUILD_CLASS:
Guido van Rossum25831651993-05-19 14:50:45 +00001490 u = POP();
Guido van Rossum374a9221991-04-04 10:40:29 +00001491 v = POP();
Guido van Rossum25831651993-05-19 14:50:45 +00001492 w = POP();
1493 x = build_class(u, v, w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001494 PUSH(x);
Guido van Rossumb209a111997-04-29 18:18:01 +00001495 Py_DECREF(u);
1496 Py_DECREF(v);
1497 Py_DECREF(w);
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 STORE_NAME:
1501 w = GETNAMEV(oparg);
1502 v = POP();
Guido van Rossum681d79a1995-07-18 14:51:37 +00001503 if ((x = f->f_locals) == NULL) {
Jeremy Hyltonc862cf42001-01-19 03:25:05 +00001504 PyErr_Format(PyExc_SystemError,
1505 "no locals found when storing %s",
Jeremy Hylton483638c2001-02-01 20:20:45 +00001506 PyObject_REPR(w));
Guido van Rossum681d79a1995-07-18 14:51:37 +00001507 break;
1508 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001509 err = PyDict_SetItem(x, w, v);
1510 Py_DECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +00001511 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001512
Guido van Rossum374a9221991-04-04 10:40:29 +00001513 case DELETE_NAME:
Guido van Rossumdf62e441991-08-16 08:56:04 +00001514 w = GETNAMEV(oparg);
Guido van Rossum681d79a1995-07-18 14:51:37 +00001515 if ((x = f->f_locals) == NULL) {
Jeremy Hyltonc862cf42001-01-19 03:25:05 +00001516 PyErr_Format(PyExc_SystemError,
1517 "no locals when deleting %s",
Jeremy Hylton483638c2001-02-01 20:20:45 +00001518 PyObject_REPR(w));
Guido van Rossum681d79a1995-07-18 14:51:37 +00001519 break;
1520 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001521 if ((err = PyDict_DelItem(x, w)) != 0)
Guido van Rossumac7be682001-01-17 15:42:30 +00001522 format_exc_check_arg(PyExc_NameError,
Paul Prescode68140d2000-08-30 20:25:01 +00001523 NAME_ERROR_MSG ,w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001524 break;
Guido van Rossum04691fc1992-08-12 15:35:34 +00001525
Thomas Wouters0be5aab2000-08-11 22:15:52 +00001526 case UNPACK_SEQUENCE:
Guido van Rossum374a9221991-04-04 10:40:29 +00001527 v = POP();
Barry Warsawe42b18f1997-08-25 22:13:04 +00001528 if (PyTuple_Check(v)) {
1529 if (PyTuple_Size(v) != oparg) {
1530 PyErr_SetString(PyExc_ValueError,
1531 "unpack tuple of wrong size");
1532 why = WHY_EXCEPTION;
1533 }
1534 else {
1535 for (; --oparg >= 0; ) {
1536 w = PyTuple_GET_ITEM(v, oparg);
1537 Py_INCREF(w);
1538 PUSH(w);
1539 }
1540 }
Guido van Rossum374a9221991-04-04 10:40:29 +00001541 }
Barry Warsawe42b18f1997-08-25 22:13:04 +00001542 else if (PyList_Check(v)) {
1543 if (PyList_Size(v) != oparg) {
1544 PyErr_SetString(PyExc_ValueError,
1545 "unpack list of wrong size");
1546 why = WHY_EXCEPTION;
1547 }
1548 else {
1549 for (; --oparg >= 0; ) {
1550 w = PyList_GET_ITEM(v, oparg);
1551 Py_INCREF(w);
1552 PUSH(w);
1553 }
1554 }
1555 }
Tim Petersd6d010b2001-06-21 02:49:55 +00001556 else if (unpack_iterable(v, oparg,
1557 stack_pointer + oparg))
1558 stack_pointer += oparg;
1559 else
Barry Warsawe42b18f1997-08-25 22:13:04 +00001560 why = WHY_EXCEPTION;
Guido van Rossumb209a111997-04-29 18:18:01 +00001561 Py_DECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +00001562 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001563
Guido van Rossum374a9221991-04-04 10:40:29 +00001564 case STORE_ATTR:
Guido van Rossum9bfef441993-03-29 10:43:31 +00001565 w = GETNAMEV(oparg);
Guido van Rossum374a9221991-04-04 10:40:29 +00001566 v = POP();
1567 u = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001568 err = PyObject_SetAttr(v, w, u); /* v.w = u */
1569 Py_DECREF(v);
1570 Py_DECREF(u);
Guido van Rossum374a9221991-04-04 10:40:29 +00001571 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001572
Guido van Rossum374a9221991-04-04 10:40:29 +00001573 case DELETE_ATTR:
Guido van Rossum9bfef441993-03-29 10:43:31 +00001574 w = GETNAMEV(oparg);
Guido van Rossum374a9221991-04-04 10:40:29 +00001575 v = POP();
Guido van Rossuma027efa1997-05-05 20:56:21 +00001576 err = PyObject_SetAttr(v, w, (PyObject *)NULL);
1577 /* del v.w */
Guido van Rossumb209a111997-04-29 18:18:01 +00001578 Py_DECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +00001579 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001580
Guido van Rossum32c6cdf1991-12-10 13:52:46 +00001581 case STORE_GLOBAL:
1582 w = GETNAMEV(oparg);
1583 v = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001584 err = PyDict_SetItem(f->f_globals, w, v);
1585 Py_DECREF(v);
Guido van Rossum32c6cdf1991-12-10 13:52:46 +00001586 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001587
Guido van Rossum32c6cdf1991-12-10 13:52:46 +00001588 case DELETE_GLOBAL:
1589 w = GETNAMEV(oparg);
Guido van Rossumb209a111997-04-29 18:18:01 +00001590 if ((err = PyDict_DelItem(f->f_globals, w)) != 0)
Paul Prescode68140d2000-08-30 20:25:01 +00001591 format_exc_check_arg(
Jeremy Hylton64949cb2001-01-25 20:06:59 +00001592 PyExc_NameError, GLOBAL_NAME_ERROR_MSG, w);
Guido van Rossum32c6cdf1991-12-10 13:52:46 +00001593 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001594
Guido van Rossum374a9221991-04-04 10:40:29 +00001595 case LOAD_CONST:
1596 x = GETCONST(oparg);
Guido van Rossumb209a111997-04-29 18:18:01 +00001597 Py_INCREF(x);
Guido van Rossum374a9221991-04-04 10:40:29 +00001598 PUSH(x);
1599 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001600
Guido van Rossum374a9221991-04-04 10:40:29 +00001601 case LOAD_NAME:
Guido van Rossumdf62e441991-08-16 08:56:04 +00001602 w = GETNAMEV(oparg);
Guido van Rossum681d79a1995-07-18 14:51:37 +00001603 if ((x = f->f_locals) == NULL) {
Jeremy Hyltonc862cf42001-01-19 03:25:05 +00001604 PyErr_Format(PyExc_SystemError,
1605 "no locals when loading %s",
Jeremy Hylton483638c2001-02-01 20:20:45 +00001606 PyObject_REPR(w));
Guido van Rossum681d79a1995-07-18 14:51:37 +00001607 break;
1608 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001609 x = PyDict_GetItem(x, w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001610 if (x == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00001611 x = PyDict_GetItem(f->f_globals, w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001612 if (x == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00001613 x = PyDict_GetItem(f->f_builtins, w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001614 if (x == NULL) {
Paul Prescode68140d2000-08-30 20:25:01 +00001615 format_exc_check_arg(
Guido van Rossumac7be682001-01-17 15:42:30 +00001616 PyExc_NameError,
Paul Prescode68140d2000-08-30 20:25:01 +00001617 NAME_ERROR_MSG ,w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001618 break;
1619 }
1620 }
1621 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001622 Py_INCREF(x);
Guido van Rossum374a9221991-04-04 10:40:29 +00001623 PUSH(x);
1624 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001625
Guido van Rossum374a9221991-04-04 10:40:29 +00001626 case LOAD_GLOBAL:
Guido van Rossumdf62e441991-08-16 08:56:04 +00001627 w = GETNAMEV(oparg);
Guido van Rossumb209a111997-04-29 18:18:01 +00001628 x = PyDict_GetItem(f->f_globals, w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001629 if (x == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00001630 x = PyDict_GetItem(f->f_builtins, w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001631 if (x == NULL) {
Paul Prescode68140d2000-08-30 20:25:01 +00001632 format_exc_check_arg(
Guido van Rossumac7be682001-01-17 15:42:30 +00001633 PyExc_NameError,
Jeremy Hylton64949cb2001-01-25 20:06:59 +00001634 GLOBAL_NAME_ERROR_MSG ,w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001635 break;
1636 }
1637 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001638 Py_INCREF(x);
Guido van Rossum374a9221991-04-04 10:40:29 +00001639 PUSH(x);
1640 break;
Guido van Rossum681d79a1995-07-18 14:51:37 +00001641
Guido van Rossum9bfef441993-03-29 10:43:31 +00001642 case LOAD_FAST:
Guido van Rossum681d79a1995-07-18 14:51:37 +00001643 x = GETLOCAL(oparg);
Guido van Rossum8b17d6b1993-03-30 13:18:41 +00001644 if (x == NULL) {
Paul Prescode68140d2000-08-30 20:25:01 +00001645 format_exc_check_arg(
1646 PyExc_UnboundLocalError,
1647 UNBOUNDLOCAL_ERROR_MSG,
1648 PyTuple_GetItem(co->co_varnames, oparg)
1649 );
Guido van Rossum8b17d6b1993-03-30 13:18:41 +00001650 break;
1651 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001652 Py_INCREF(x);
Guido van Rossum8b17d6b1993-03-30 13:18:41 +00001653 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001654 if (x != NULL) continue;
Guido van Rossum9bfef441993-03-29 10:43:31 +00001655 break;
1656
1657 case STORE_FAST:
Guido van Rossum25831651993-05-19 14:50:45 +00001658 v = POP();
Guido van Rossum681d79a1995-07-18 14:51:37 +00001659 SETLOCAL(oparg, v);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001660 continue;
Guido van Rossum8b17d6b1993-03-30 13:18:41 +00001661
1662 case DELETE_FAST:
Guido van Rossum2e4c8991998-05-12 20:27:36 +00001663 x = GETLOCAL(oparg);
1664 if (x == NULL) {
Paul Prescode68140d2000-08-30 20:25:01 +00001665 format_exc_check_arg(
1666 PyExc_UnboundLocalError,
1667 UNBOUNDLOCAL_ERROR_MSG,
1668 PyTuple_GetItem(co->co_varnames, oparg)
1669 );
Guido van Rossum2e4c8991998-05-12 20:27:36 +00001670 break;
1671 }
Guido van Rossum681d79a1995-07-18 14:51:37 +00001672 SETLOCAL(oparg, NULL);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001673 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +00001674
Jeremy Hylton64949cb2001-01-25 20:06:59 +00001675 case LOAD_CLOSURE:
Jeremy Hylton2b724da2001-01-29 22:51:52 +00001676 x = freevars[oparg];
Jeremy Hylton64949cb2001-01-25 20:06:59 +00001677 Py_INCREF(x);
1678 PUSH(x);
1679 break;
1680
1681 case LOAD_DEREF:
Jeremy Hylton2b724da2001-01-29 22:51:52 +00001682 x = freevars[oparg];
Jeremy Hylton64949cb2001-01-25 20:06:59 +00001683 w = PyCell_Get(x);
Jeremy Hylton2524d692001-02-05 17:23:16 +00001684 if (w == NULL) {
Jeremy Hyltonc76770c2001-04-13 16:51:46 +00001685 if (oparg < f->f_ncells) {
Jeremy Hylton2524d692001-02-05 17:23:16 +00001686 v = PyTuple_GetItem(co->co_cellvars,
1687 oparg);
Jeremy Hyltonc76770c2001-04-13 16:51:46 +00001688 format_exc_check_arg(
1689 PyExc_UnboundLocalError,
1690 UNBOUNDLOCAL_ERROR_MSG,
1691 v);
1692 } else {
Jeremy Hylton2524d692001-02-05 17:23:16 +00001693 v = PyTuple_GetItem(
1694 co->co_freevars,
1695 oparg - f->f_ncells);
Jeremy Hyltonc76770c2001-04-13 16:51:46 +00001696 format_exc_check_arg(
1697 PyExc_NameError,
1698 UNBOUNDFREE_ERROR_MSG,
1699 v);
1700 }
Jeremy Hylton2524d692001-02-05 17:23:16 +00001701 err = -1;
1702 break;
1703 }
Jeremy Hylton64949cb2001-01-25 20:06:59 +00001704 PUSH(w);
1705 break;
1706
1707 case STORE_DEREF:
1708 w = POP();
Jeremy Hylton2b724da2001-01-29 22:51:52 +00001709 x = freevars[oparg];
Jeremy Hylton64949cb2001-01-25 20:06:59 +00001710 PyCell_Set(x, w);
Jeremy Hylton30c9f392001-03-13 01:58:22 +00001711 Py_DECREF(w);
Jeremy Hylton64949cb2001-01-25 20:06:59 +00001712 continue;
1713
Guido van Rossum374a9221991-04-04 10:40:29 +00001714 case BUILD_TUPLE:
Guido van Rossumb209a111997-04-29 18:18:01 +00001715 x = PyTuple_New(oparg);
Guido van Rossum374a9221991-04-04 10:40:29 +00001716 if (x != NULL) {
1717 for (; --oparg >= 0;) {
1718 w = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001719 PyTuple_SET_ITEM(x, oparg, w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001720 }
1721 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001722 continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001723 }
1724 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001725
Guido van Rossum374a9221991-04-04 10:40:29 +00001726 case BUILD_LIST:
Guido van Rossumb209a111997-04-29 18:18:01 +00001727 x = PyList_New(oparg);
Guido van Rossum374a9221991-04-04 10:40:29 +00001728 if (x != NULL) {
1729 for (; --oparg >= 0;) {
1730 w = POP();
Guido van Rossum5053efc1998-08-04 15:27:50 +00001731 PyList_SET_ITEM(x, oparg, w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001732 }
1733 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001734 continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001735 }
1736 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001737
Guido van Rossum374a9221991-04-04 10:40:29 +00001738 case BUILD_MAP:
Guido van Rossumb209a111997-04-29 18:18:01 +00001739 x = PyDict_New();
Guido van Rossum374a9221991-04-04 10:40:29 +00001740 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001741 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001742 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001743
Guido van Rossum374a9221991-04-04 10:40:29 +00001744 case LOAD_ATTR:
Guido van Rossum9bfef441993-03-29 10:43:31 +00001745 w = GETNAMEV(oparg);
Guido van Rossum374a9221991-04-04 10:40:29 +00001746 v = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001747 x = PyObject_GetAttr(v, w);
1748 Py_DECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +00001749 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001750 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001751 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001752
Guido van Rossum374a9221991-04-04 10:40:29 +00001753 case COMPARE_OP:
1754 w = POP();
1755 v = POP();
Guido van Rossum46add982001-08-30 16:06:23 +00001756 if (ISSTRICTINT(v) && ISSTRICTINT(w)) {
Guido van Rossumc12da691997-07-17 23:12:42 +00001757 /* INLINE: cmp(int, int) */
1758 register long a, b;
1759 register int res;
Guido van Rossumcf183ac1998-12-04 18:51:36 +00001760 a = PyInt_AS_LONG(v);
1761 b = PyInt_AS_LONG(w);
Guido van Rossumc12da691997-07-17 23:12:42 +00001762 switch (oparg) {
1763 case LT: res = a < b; break;
1764 case LE: res = a <= b; break;
1765 case EQ: res = a == b; break;
1766 case NE: res = a != b; break;
1767 case GT: res = a > b; break;
1768 case GE: res = a >= b; break;
1769 case IS: res = v == w; break;
1770 case IS_NOT: res = v != w; break;
1771 default: goto slow_compare;
1772 }
1773 x = res ? Py_True : Py_False;
1774 Py_INCREF(x);
1775 }
1776 else {
1777 slow_compare:
1778 x = cmp_outcome(oparg, v, w);
1779 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001780 Py_DECREF(v);
1781 Py_DECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001782 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001783 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001784 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001785
Guido van Rossum374a9221991-04-04 10:40:29 +00001786 case IMPORT_NAME:
Guido van Rossum1ae940a1995-01-02 19:04:15 +00001787 w = GETNAMEV(oparg);
Guido van Rossumb209a111997-04-29 18:18:01 +00001788 x = PyDict_GetItemString(f->f_builtins, "__import__");
Guido van Rossum1ae940a1995-01-02 19:04:15 +00001789 if (x == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00001790 PyErr_SetString(PyExc_ImportError,
Guido van Rossumfc490731997-05-06 15:06:49 +00001791 "__import__ not found");
Guido van Rossum1ae940a1995-01-02 19:04:15 +00001792 break;
1793 }
Thomas Woutersdd13e4f2000-08-27 20:31:27 +00001794 u = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001795 w = Py_BuildValue("(OOOO)",
Guido van Rossum681d79a1995-07-18 14:51:37 +00001796 w,
1797 f->f_globals,
Guido van Rossuma027efa1997-05-05 20:56:21 +00001798 f->f_locals == NULL ?
1799 Py_None : f->f_locals,
Guido van Rossum681d79a1995-07-18 14:51:37 +00001800 u);
Guido van Rossumb209a111997-04-29 18:18:01 +00001801 Py_DECREF(u);
Guido van Rossum1ae940a1995-01-02 19:04:15 +00001802 if (w == NULL) {
1803 x = NULL;
1804 break;
1805 }
Guido van Rossumb209a111997-04-29 18:18:01 +00001806 x = PyEval_CallObject(x, w);
1807 Py_DECREF(w);
Guido van Rossumf10570b1995-07-07 22:53:21 +00001808 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001809 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001810 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001811
Thomas Wouters52152252000-08-17 22:55:00 +00001812 case IMPORT_STAR:
1813 v = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00001814 PyFrame_FastToLocals(f);
Guido van Rossum681d79a1995-07-18 14:51:37 +00001815 if ((x = f->f_locals) == NULL) {
Guido van Rossuma027efa1997-05-05 20:56:21 +00001816 PyErr_SetString(PyExc_SystemError,
Jeremy Hyltonc862cf42001-01-19 03:25:05 +00001817 "no locals found during 'import *'");
Guido van Rossum681d79a1995-07-18 14:51:37 +00001818 break;
1819 }
Thomas Wouters52152252000-08-17 22:55:00 +00001820 err = import_all_from(x, v);
Guido van Rossumb209a111997-04-29 18:18:01 +00001821 PyFrame_LocalsToFast(f, 0);
Thomas Wouters52152252000-08-17 22:55:00 +00001822 Py_DECREF(v);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001823 if (err == 0) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001824 break;
Guido van Rossum25831651993-05-19 14:50:45 +00001825
Thomas Wouters52152252000-08-17 22:55:00 +00001826 case IMPORT_FROM:
1827 w = GETNAMEV(oparg);
1828 v = TOP();
1829 x = import_from(v, w);
1830 PUSH(x);
1831 if (x != NULL) continue;
1832 break;
1833
Guido van Rossum374a9221991-04-04 10:40:29 +00001834 case JUMP_FORWARD:
1835 JUMPBY(oparg);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001836 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +00001837
Guido van Rossum374a9221991-04-04 10:40:29 +00001838 case JUMP_IF_FALSE:
Guido van Rossumb209a111997-04-29 18:18:01 +00001839 err = PyObject_IsTrue(TOP());
Guido van Rossum04691fc1992-08-12 15:35:34 +00001840 if (err > 0)
1841 err = 0;
1842 else if (err == 0)
Guido van Rossum374a9221991-04-04 10:40:29 +00001843 JUMPBY(oparg);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001844 else
1845 break;
1846 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +00001847
Guido van Rossum374a9221991-04-04 10:40:29 +00001848 case JUMP_IF_TRUE:
Guido van Rossumb209a111997-04-29 18:18:01 +00001849 err = PyObject_IsTrue(TOP());
Guido van Rossum04691fc1992-08-12 15:35:34 +00001850 if (err > 0) {
1851 err = 0;
Guido van Rossum374a9221991-04-04 10:40:29 +00001852 JUMPBY(oparg);
Guido van Rossum04691fc1992-08-12 15:35:34 +00001853 }
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001854 else if (err == 0)
1855 ;
1856 else
1857 break;
1858 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +00001859
Guido van Rossum374a9221991-04-04 10:40:29 +00001860 case JUMP_ABSOLUTE:
1861 JUMPTO(oparg);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001862 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +00001863
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00001864 case GET_ITER:
1865 /* before: [obj]; after [getiter(obj)] */
1866 v = POP();
1867 x = PyObject_GetIter(v);
1868 Py_DECREF(v);
1869 if (x != NULL) {
Guido van Rossum213c7a62001-04-23 14:08:49 +00001870 PUSH(x);
1871 continue;
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00001872 }
1873 break;
1874
1875 case FOR_ITER:
1876 /* before: [iter]; after: [iter, iter()] *or* [] */
1877 v = TOP();
Guido van Rossum213c7a62001-04-23 14:08:49 +00001878 x = PyIter_Next(v);
1879 if (x != NULL) {
1880 PUSH(x);
1881 continue;
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00001882 }
Tim Petersf4848da2001-05-05 00:14:56 +00001883 if (!PyErr_Occurred()) {
1884 /* iterator ended normally */
1885 x = v = POP();
Guido van Rossum213c7a62001-04-23 14:08:49 +00001886 Py_DECREF(v);
1887 JUMPBY(oparg);
1888 continue;
1889 }
1890 break;
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00001891
Guido van Rossum374a9221991-04-04 10:40:29 +00001892 case FOR_LOOP:
1893 /* for v in s: ...
1894 On entry: stack contains s, i.
1895 On exit: stack contains s, i+1, s[i];
1896 but if loop exhausted:
1897 s, i are popped, and we jump */
1898 w = POP(); /* Loop index */
1899 v = POP(); /* Sequence object */
1900 u = loop_subscript(v, w);
1901 if (u != NULL) {
1902 PUSH(v);
Guido van Rossumb209a111997-04-29 18:18:01 +00001903 x = PyInt_FromLong(PyInt_AsLong(w)+1);
Guido van Rossum374a9221991-04-04 10:40:29 +00001904 PUSH(x);
Guido van Rossumb209a111997-04-29 18:18:01 +00001905 Py_DECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001906 PUSH(u);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001907 if (x != NULL) continue;
Guido van Rossum374a9221991-04-04 10:40:29 +00001908 }
1909 else {
Guido van Rossumb209a111997-04-29 18:18:01 +00001910 Py_DECREF(v);
1911 Py_DECREF(w);
Guido van Rossum374a9221991-04-04 10:40:29 +00001912 /* A NULL can mean "s exhausted"
1913 but also an error: */
Guido van Rossumb209a111997-04-29 18:18:01 +00001914 if (PyErr_Occurred())
Guido van Rossum374a9221991-04-04 10:40:29 +00001915 why = WHY_EXCEPTION;
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001916 else {
Guido van Rossum374a9221991-04-04 10:40:29 +00001917 JUMPBY(oparg);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001918 continue;
1919 }
Guido van Rossum374a9221991-04-04 10:40:29 +00001920 }
1921 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00001922
Guido van Rossum374a9221991-04-04 10:40:29 +00001923 case SETUP_LOOP:
1924 case SETUP_EXCEPT:
1925 case SETUP_FINALLY:
Guido van Rossumb209a111997-04-29 18:18:01 +00001926 PyFrame_BlockSetup(f, opcode, INSTR_OFFSET() + oparg,
Jeremy Hylton3faa52e2001-02-01 22:48:12 +00001927 STACK_LEVEL());
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001928 continue;
Guido van Rossumac7be682001-01-17 15:42:30 +00001929
Guido van Rossum374a9221991-04-04 10:40:29 +00001930 case SET_LINENO:
Guido van Rossum96a42c81992-01-12 02:29:51 +00001931#ifdef LLTRACE
1932 if (lltrace)
Guido van Rossum1ae940a1995-01-02 19:04:15 +00001933 printf("--- %s:%d \n", filename, oparg);
Guido van Rossum374a9221991-04-04 10:40:29 +00001934#endif
Guido van Rossum96a42c81992-01-12 02:29:51 +00001935 f->f_lineno = oparg;
Fred Drake5755ce62001-06-27 19:19:46 +00001936 if (tstate->c_tracefunc == NULL || tstate->tracing)
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00001937 continue;
1938 /* Trace each line of code reached */
1939 f->f_lasti = INSTR_OFFSET();
Fred Drake5755ce62001-06-27 19:19:46 +00001940 /* Inline call_trace() for performance: */
1941 tstate->tracing++;
Fred Drake9e3ad782001-07-03 23:39:52 +00001942 tstate->use_tracing = 0;
Fred Drake5755ce62001-06-27 19:19:46 +00001943 err = (tstate->c_tracefunc)(tstate->c_traceobj, f,
1944 PyTrace_LINE, Py_None);
Fred Drake9e3ad782001-07-03 23:39:52 +00001945 tstate->use_tracing = (tstate->c_tracefunc
1946 || tstate->c_profilefunc);
Fred Drake5755ce62001-06-27 19:19:46 +00001947 tstate->tracing--;
Guido van Rossum374a9221991-04-04 10:40:29 +00001948 break;
Guido van Rossumf10570b1995-07-07 22:53:21 +00001949
1950 case CALL_FUNCTION:
Jeremy Hylton52820442001-01-03 23:52:36 +00001951 {
1952 int na = oparg & 0xff;
1953 int nk = (oparg>>8) & 0xff;
1954 int n = na + 2 * nk;
1955 PyObject **pfunc = stack_pointer - n - 1;
1956 PyObject *func = *pfunc;
1957 f->f_lasti = INSTR_OFFSET() - 3; /* For tracing */
1958
1959 /* Always dispatch PyCFunction first, because
1960 these are presumed to be the most frequent
1961 callable object.
1962 */
1963 if (PyCFunction_Check(func)) {
Jeremy Hyltonda20fce2001-05-18 20:53:14 +00001964 int flags = PyCFunction_GET_FLAGS(func);
Martin v. Löwise3eb1f22001-08-16 13:15:00 +00001965 if (nk != 0 || (flags & METH_KEYWORDS))
Jeremy Hylton4c9dace2001-05-29 16:23:26 +00001966 x = do_call(func, &stack_pointer,
1967 na, nk);
1968 else if (flags == METH_VARARGS) {
Jeremy Hyltonda20fce2001-05-18 20:53:14 +00001969 PyObject *callargs;
1970 callargs = load_args(&stack_pointer, na);
Jeremy Hylton910d7d42001-08-12 21:52:24 +00001971 x = PyCFunction_Call(func, callargs, NULL);
Jeremy Hyltonda20fce2001-05-18 20:53:14 +00001972 Py_XDECREF(callargs);
Martin v. Löwise3eb1f22001-08-16 13:15:00 +00001973 } else
1974 x = fast_cfunction(func,
1975 &stack_pointer, na);
Jeremy Hylton52820442001-01-03 23:52:36 +00001976 } else {
Guido van Rossumac7be682001-01-17 15:42:30 +00001977 if (PyMethod_Check(func)
Jeremy Hylton52820442001-01-03 23:52:36 +00001978 && PyMethod_GET_SELF(func) != NULL) {
1979 /* optimize access to bound methods */
1980 PyObject *self = PyMethod_GET_SELF(func);
1981 Py_INCREF(self);
1982 func = PyMethod_GET_FUNCTION(func);
1983 Py_INCREF(func);
1984 Py_DECREF(*pfunc);
1985 *pfunc = self;
1986 na++;
1987 n++;
Guido van Rossumac7be682001-01-17 15:42:30 +00001988 } else
Jeremy Hylton52820442001-01-03 23:52:36 +00001989 Py_INCREF(func);
1990 if (PyFunction_Check(func)) {
1991 x = fast_function(func, &stack_pointer,
Guido van Rossumac7be682001-01-17 15:42:30 +00001992 n, na, nk);
Jeremy Hylton52820442001-01-03 23:52:36 +00001993 } else {
1994 x = do_call(func, &stack_pointer,
1995 na, nk);
1996 }
1997 Py_DECREF(func);
1998 }
1999
2000 while (stack_pointer > pfunc) {
2001 w = POP();
2002 Py_DECREF(w);
2003 }
2004 PUSH(x);
Guido van Rossumac7be682001-01-17 15:42:30 +00002005 if (x != NULL)
Jeremy Hylton52820442001-01-03 23:52:36 +00002006 continue;
2007 break;
2008 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002009
Jeremy Hylton76901512000-03-28 23:49:17 +00002010 case CALL_FUNCTION_VAR:
2011 case CALL_FUNCTION_KW:
2012 case CALL_FUNCTION_VAR_KW:
Guido van Rossumf10570b1995-07-07 22:53:21 +00002013 {
Jeremy Hylton76901512000-03-28 23:49:17 +00002014 int na = oparg & 0xff;
2015 int nk = (oparg>>8) & 0xff;
2016 int flags = (opcode - CALL_FUNCTION) & 3;
Jeremy Hylton52820442001-01-03 23:52:36 +00002017 int n = na + 2 * nk;
2018 PyObject **pfunc, *func;
2019 if (flags & CALL_FLAG_VAR)
2020 n++;
2021 if (flags & CALL_FLAG_KW)
2022 n++;
2023 pfunc = stack_pointer - n - 1;
2024 func = *pfunc;
Jeremy Hylton76901512000-03-28 23:49:17 +00002025 f->f_lasti = INSTR_OFFSET() - 3; /* For tracing */
Jeremy Hylton52820442001-01-03 23:52:36 +00002026
Guido van Rossumac7be682001-01-17 15:42:30 +00002027 if (PyMethod_Check(func)
Jeremy Hylton52820442001-01-03 23:52:36 +00002028 && PyMethod_GET_SELF(func) != NULL) {
2029 PyObject *self = PyMethod_GET_SELF(func);
Jeremy Hylton76901512000-03-28 23:49:17 +00002030 Py_INCREF(self);
Jeremy Hylton52820442001-01-03 23:52:36 +00002031 func = PyMethod_GET_FUNCTION(func);
2032 Py_INCREF(func);
Jeremy Hylton76901512000-03-28 23:49:17 +00002033 Py_DECREF(*pfunc);
2034 *pfunc = self;
2035 na++;
2036 n++;
Guido van Rossumac7be682001-01-17 15:42:30 +00002037 } else
Jeremy Hylton52820442001-01-03 23:52:36 +00002038 Py_INCREF(func);
2039 x = ext_do_call(func, &stack_pointer, flags, na, nk);
Jeremy Hylton76901512000-03-28 23:49:17 +00002040 Py_DECREF(func);
Jeremy Hylton52820442001-01-03 23:52:36 +00002041
Jeremy Hylton76901512000-03-28 23:49:17 +00002042 while (stack_pointer > pfunc) {
Jeremy Hylton52820442001-01-03 23:52:36 +00002043 w = POP();
2044 Py_DECREF(w);
Jeremy Hylton76901512000-03-28 23:49:17 +00002045 }
2046 PUSH(x);
Guido van Rossumac7be682001-01-17 15:42:30 +00002047 if (x != NULL)
Jeremy Hylton52820442001-01-03 23:52:36 +00002048 continue;
Jeremy Hylton76901512000-03-28 23:49:17 +00002049 break;
Guido van Rossumf10570b1995-07-07 22:53:21 +00002050 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002051
Guido van Rossum681d79a1995-07-18 14:51:37 +00002052 case MAKE_FUNCTION:
2053 v = POP(); /* code object */
Guido van Rossumb209a111997-04-29 18:18:01 +00002054 x = PyFunction_New(v, f->f_globals);
2055 Py_DECREF(v);
Guido van Rossum681d79a1995-07-18 14:51:37 +00002056 /* XXX Maybe this should be a separate opcode? */
2057 if (x != NULL && oparg > 0) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002058 v = PyTuple_New(oparg);
Guido van Rossum681d79a1995-07-18 14:51:37 +00002059 if (v == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002060 Py_DECREF(x);
Guido van Rossum681d79a1995-07-18 14:51:37 +00002061 x = NULL;
2062 break;
2063 }
2064 while (--oparg >= 0) {
2065 w = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00002066 PyTuple_SET_ITEM(v, oparg, w);
Guido van Rossum681d79a1995-07-18 14:51:37 +00002067 }
2068 err = PyFunction_SetDefaults(x, v);
Guido van Rossumb209a111997-04-29 18:18:01 +00002069 Py_DECREF(v);
Guido van Rossum681d79a1995-07-18 14:51:37 +00002070 }
2071 PUSH(x);
2072 break;
Guido van Rossum8861b741996-07-30 16:49:37 +00002073
Jeremy Hylton64949cb2001-01-25 20:06:59 +00002074 case MAKE_CLOSURE:
2075 {
2076 int nfree;
2077 v = POP(); /* code object */
2078 x = PyFunction_New(v, f->f_globals);
2079 nfree = PyTuple_GET_SIZE(((PyCodeObject *)v)->co_freevars);
2080 Py_DECREF(v);
2081 /* XXX Maybe this should be a separate opcode? */
2082 if (x != NULL && nfree > 0) {
2083 v = PyTuple_New(nfree);
2084 if (v == NULL) {
2085 Py_DECREF(x);
2086 x = NULL;
2087 break;
2088 }
2089 while (--nfree >= 0) {
2090 w = POP();
2091 PyTuple_SET_ITEM(v, nfree, w);
2092 }
2093 err = PyFunction_SetClosure(x, v);
2094 Py_DECREF(v);
2095 }
2096 if (x != NULL && oparg > 0) {
2097 v = PyTuple_New(oparg);
2098 if (v == NULL) {
2099 Py_DECREF(x);
2100 x = NULL;
2101 break;
2102 }
2103 while (--oparg >= 0) {
2104 w = POP();
2105 PyTuple_SET_ITEM(v, oparg, w);
2106 }
2107 err = PyFunction_SetDefaults(x, v);
2108 Py_DECREF(v);
2109 }
2110 PUSH(x);
2111 break;
2112 }
2113
Guido van Rossum8861b741996-07-30 16:49:37 +00002114 case BUILD_SLICE:
2115 if (oparg == 3)
2116 w = POP();
2117 else
2118 w = NULL;
2119 v = POP();
2120 u = POP();
Guido van Rossum1aa14831997-01-21 05:34:20 +00002121 x = PySlice_New(u, v, w);
Guido van Rossumb209a111997-04-29 18:18:01 +00002122 Py_DECREF(u);
2123 Py_DECREF(v);
2124 Py_XDECREF(w);
Guido van Rossum8861b741996-07-30 16:49:37 +00002125 PUSH(x);
Guido van Rossum3dfd53b1997-01-18 02:46:13 +00002126 if (x != NULL) continue;
Guido van Rossum8861b741996-07-30 16:49:37 +00002127 break;
2128
Fred Drakeef8ace32000-08-24 00:32:09 +00002129 case EXTENDED_ARG:
2130 opcode = NEXTOP();
2131 oparg = oparg<<16 | NEXTARG();
2132 goto dispatch_opcode;
Guido van Rossum8861b741996-07-30 16:49:37 +00002133
Guido van Rossum374a9221991-04-04 10:40:29 +00002134 default:
2135 fprintf(stderr,
2136 "XXX lineno: %d, opcode: %d\n",
Guido van Rossum96a42c81992-01-12 02:29:51 +00002137 f->f_lineno, opcode);
Guido van Rossumb209a111997-04-29 18:18:01 +00002138 PyErr_SetString(PyExc_SystemError, "unknown opcode");
Guido van Rossum374a9221991-04-04 10:40:29 +00002139 why = WHY_EXCEPTION;
2140 break;
Guido van Rossum04691fc1992-08-12 15:35:34 +00002141
2142#ifdef CASE_TOO_BIG
2143 }
2144#endif
2145
Guido van Rossum374a9221991-04-04 10:40:29 +00002146 } /* switch */
2147
2148 on_error:
Guido van Rossumac7be682001-01-17 15:42:30 +00002149
Guido van Rossum374a9221991-04-04 10:40:29 +00002150 /* Quickly continue if no error occurred */
Guido van Rossumac7be682001-01-17 15:42:30 +00002151
Guido van Rossum374a9221991-04-04 10:40:29 +00002152 if (why == WHY_NOT) {
Guido van Rossum681d79a1995-07-18 14:51:37 +00002153 if (err == 0 && x != NULL) {
2154#ifdef CHECKEXC
Guido van Rossumeb894eb1999-03-09 16:16:45 +00002155 /* This check is expensive! */
Guido van Rossumb209a111997-04-29 18:18:01 +00002156 if (PyErr_Occurred())
Guido van Rossum681d79a1995-07-18 14:51:37 +00002157 fprintf(stderr,
2158 "XXX undetected error\n");
2159 else
2160#endif
2161 continue; /* Normal, fast path */
2162 }
Guido van Rossum374a9221991-04-04 10:40:29 +00002163 why = WHY_EXCEPTION;
Guido van Rossumb209a111997-04-29 18:18:01 +00002164 x = Py_None;
Guido van Rossum374a9221991-04-04 10:40:29 +00002165 err = 0;
2166 }
2167
Guido van Rossum374a9221991-04-04 10:40:29 +00002168 /* Double-check exception status */
Guido van Rossumac7be682001-01-17 15:42:30 +00002169
Guido van Rossum374a9221991-04-04 10:40:29 +00002170 if (why == WHY_EXCEPTION || why == WHY_RERAISE) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002171 if (!PyErr_Occurred()) {
Guido van Rossuma027efa1997-05-05 20:56:21 +00002172 PyErr_SetString(PyExc_SystemError,
Guido van Rossumeb894eb1999-03-09 16:16:45 +00002173 "error return without exception set");
Guido van Rossum374a9221991-04-04 10:40:29 +00002174 why = WHY_EXCEPTION;
2175 }
2176 }
Guido van Rossumeb894eb1999-03-09 16:16:45 +00002177#ifdef CHECKEXC
Guido van Rossum374a9221991-04-04 10:40:29 +00002178 else {
Guido van Rossumeb894eb1999-03-09 16:16:45 +00002179 /* This check is expensive! */
Guido van Rossumb209a111997-04-29 18:18:01 +00002180 if (PyErr_Occurred()) {
Guido van Rossum681d79a1995-07-18 14:51:37 +00002181 fprintf(stderr,
2182 "XXX undetected error (why=%d)\n",
2183 why);
2184 why = WHY_EXCEPTION;
2185 }
Guido van Rossum374a9221991-04-04 10:40:29 +00002186 }
2187#endif
2188
2189 /* Log traceback info if this is a real exception */
Guido van Rossumac7be682001-01-17 15:42:30 +00002190
Guido van Rossum374a9221991-04-04 10:40:29 +00002191 if (why == WHY_EXCEPTION) {
Guido van Rossum96a42c81992-01-12 02:29:51 +00002192 f->f_lasti = INSTR_OFFSET() - 1;
Guido van Rossum374a9221991-04-04 10:40:29 +00002193 if (HAS_ARG(opcode))
Guido van Rossum96a42c81992-01-12 02:29:51 +00002194 f->f_lasti -= 2;
Guido van Rossumb209a111997-04-29 18:18:01 +00002195 PyTraceBack_Here(f);
Guido van Rossum96a42c81992-01-12 02:29:51 +00002196
Fred Drake9e3ad782001-07-03 23:39:52 +00002197 if (tstate->use_tracing) {
2198 if (tstate->c_tracefunc)
2199 call_exc_trace(tstate->c_tracefunc,
2200 tstate->c_traceobj, f);
2201 if (tstate->c_profilefunc)
2202 call_exc_trace(tstate->c_profilefunc,
2203 tstate->c_profileobj,f);
2204 }
Guido van Rossum014518f1998-11-23 21:09:51 +00002205 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002206
Guido van Rossum374a9221991-04-04 10:40:29 +00002207 /* For the rest, treat WHY_RERAISE as WHY_EXCEPTION */
Guido van Rossumac7be682001-01-17 15:42:30 +00002208
Guido van Rossum374a9221991-04-04 10:40:29 +00002209 if (why == WHY_RERAISE)
2210 why = WHY_EXCEPTION;
2211
2212 /* Unwind stacks if a (pseudo) exception occurred */
Guido van Rossumac7be682001-01-17 15:42:30 +00002213
Tim Peters5ca576e2001-06-18 22:08:13 +00002214 while (why != WHY_NOT && why != WHY_YIELD && f->f_iblock > 0) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002215 PyTryBlock *b = PyFrame_BlockPop(f);
Jeremy Hylton3faa52e2001-02-01 22:48:12 +00002216
2217 if (b->b_type == SETUP_LOOP && why == WHY_CONTINUE) {
2218 /* For a continue inside a try block,
2219 don't pop the block for the loop. */
Thomas Wouters1ee64222001-09-24 19:32:01 +00002220 PyFrame_BlockSetup(f, b->b_type, b->b_handler,
2221 b->b_level);
Jeremy Hylton3faa52e2001-02-01 22:48:12 +00002222 why = WHY_NOT;
2223 JUMPTO(PyInt_AS_LONG(retval));
2224 Py_DECREF(retval);
2225 break;
2226 }
2227
Guido van Rossum374a9221991-04-04 10:40:29 +00002228 while (STACK_LEVEL() > b->b_level) {
2229 v = POP();
Guido van Rossumb209a111997-04-29 18:18:01 +00002230 Py_XDECREF(v);
Guido van Rossum374a9221991-04-04 10:40:29 +00002231 }
2232 if (b->b_type == SETUP_LOOP && why == WHY_BREAK) {
2233 why = WHY_NOT;
2234 JUMPTO(b->b_handler);
2235 break;
2236 }
2237 if (b->b_type == SETUP_FINALLY ||
Guido van Rossum150b2df1996-12-05 23:17:11 +00002238 (b->b_type == SETUP_EXCEPT &&
2239 why == WHY_EXCEPTION)) {
Guido van Rossum374a9221991-04-04 10:40:29 +00002240 if (why == WHY_EXCEPTION) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002241 PyObject *exc, *val, *tb;
2242 PyErr_Fetch(&exc, &val, &tb);
Guido van Rossum374a9221991-04-04 10:40:29 +00002243 if (val == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002244 val = Py_None;
2245 Py_INCREF(val);
Guido van Rossum374a9221991-04-04 10:40:29 +00002246 }
Guido van Rossum374a9221991-04-04 10:40:29 +00002247 /* Make the raw exception data
2248 available to the handler,
2249 so a program can emulate the
2250 Python main loop. Don't do
2251 this for 'finally'. */
2252 if (b->b_type == SETUP_EXCEPT) {
Barry Warsaweaedc7c1997-08-28 22:36:40 +00002253 PyErr_NormalizeException(
2254 &exc, &val, &tb);
Guido van Rossuma027efa1997-05-05 20:56:21 +00002255 set_exc_info(tstate,
2256 exc, val, tb);
Guido van Rossum374a9221991-04-04 10:40:29 +00002257 }
Jeremy Hyltonc6314892001-09-26 19:24:45 +00002258 if (tb == NULL) {
2259 Py_INCREF(Py_None);
2260 PUSH(Py_None);
2261 } else
2262 PUSH(tb);
Guido van Rossum374a9221991-04-04 10:40:29 +00002263 PUSH(val);
2264 PUSH(exc);
2265 }
2266 else {
Jeremy Hylton3faa52e2001-02-01 22:48:12 +00002267 if (why == WHY_RETURN ||
2268 why == CONTINUE_LOOP)
Guido van Rossum374a9221991-04-04 10:40:29 +00002269 PUSH(retval);
Guido van Rossumb209a111997-04-29 18:18:01 +00002270 v = PyInt_FromLong((long)why);
Guido van Rossum374a9221991-04-04 10:40:29 +00002271 PUSH(v);
2272 }
2273 why = WHY_NOT;
2274 JUMPTO(b->b_handler);
2275 break;
2276 }
2277 } /* unwind stack */
2278
2279 /* End the loop if we still have an error (or return) */
Guido van Rossumac7be682001-01-17 15:42:30 +00002280
Guido van Rossum374a9221991-04-04 10:40:29 +00002281 if (why != WHY_NOT)
2282 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00002283
Guido van Rossum374a9221991-04-04 10:40:29 +00002284 } /* main loop */
Guido van Rossumac7be682001-01-17 15:42:30 +00002285
Tim Peters5ca576e2001-06-18 22:08:13 +00002286 if (why != WHY_RETURN && why != WHY_YIELD)
Guido van Rossum96a42c81992-01-12 02:29:51 +00002287 retval = NULL;
Guido van Rossumac7be682001-01-17 15:42:30 +00002288
Fred Drake9e3ad782001-07-03 23:39:52 +00002289 if (tstate->use_tracing) {
2290 if (tstate->c_tracefunc
2291 && (why == WHY_RETURN || why == WHY_YIELD)) {
2292 if (call_trace(tstate->c_tracefunc,
2293 tstate->c_traceobj, f,
2294 PyTrace_RETURN, retval)) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002295 Py_XDECREF(retval);
Guido van Rossum96a42c81992-01-12 02:29:51 +00002296 retval = NULL;
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002297 why = WHY_EXCEPTION;
Guido van Rossum96a42c81992-01-12 02:29:51 +00002298 }
Guido van Rossum96a42c81992-01-12 02:29:51 +00002299 }
Fred Drake9e3ad782001-07-03 23:39:52 +00002300 if (tstate->c_profilefunc
2301 && (why == WHY_RETURN || why == WHY_YIELD)) {
2302 if (call_trace(tstate->c_profilefunc,
2303 tstate->c_profileobj, f,
2304 PyTrace_RETURN, retval)) {
2305 Py_XDECREF(retval);
2306 retval = NULL;
2307 why = WHY_EXCEPTION;
2308 }
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002309 }
Guido van Rossum96a42c81992-01-12 02:29:51 +00002310 }
Guido van Rossuma4240131997-01-21 21:18:36 +00002311
Guido van Rossuma027efa1997-05-05 20:56:21 +00002312 reset_exc_info(tstate);
2313
Tim Peters5ca576e2001-06-18 22:08:13 +00002314 /* pop frame */
Guido van Rossuma027efa1997-05-05 20:56:21 +00002315 --tstate->recursion_depth;
Guido van Rossuma027efa1997-05-05 20:56:21 +00002316 tstate->frame = f->f_back;
Guido van Rossumac7be682001-01-17 15:42:30 +00002317
Guido van Rossum96a42c81992-01-12 02:29:51 +00002318 return retval;
Guido van Rossum374a9221991-04-04 10:40:29 +00002319}
2320
Tim Peters6d6c1a32001-08-02 04:15:00 +00002321PyObject *
2322PyEval_EvalCodeEx(PyCodeObject *co, PyObject *globals, PyObject *locals,
Tim Peters5ca576e2001-06-18 22:08:13 +00002323 PyObject **args, int argcount, PyObject **kws, int kwcount,
2324 PyObject **defs, int defcount, PyObject *closure)
2325{
2326 register PyFrameObject *f;
2327 register PyObject *retval = NULL;
2328 register PyObject **fastlocals, **freevars;
2329 PyThreadState *tstate = PyThreadState_GET();
2330 PyObject *x, *u;
2331
2332 if (globals == NULL) {
Jeremy Hylton910d7d42001-08-12 21:52:24 +00002333 PyErr_SetString(PyExc_SystemError,
2334 "PyEval_EvalCodeEx: NULL globals");
Tim Peters5ca576e2001-06-18 22:08:13 +00002335 return NULL;
2336 }
2337
2338 f = PyFrame_New(tstate, /*back*/
2339 co, /*code*/
2340 globals, locals);
2341 if (f == NULL)
2342 return NULL;
2343
2344 fastlocals = f->f_localsplus;
2345 freevars = f->f_localsplus + f->f_nlocals;
2346
2347 if (co->co_argcount > 0 ||
2348 co->co_flags & (CO_VARARGS | CO_VARKEYWORDS)) {
2349 int i;
2350 int n = argcount;
2351 PyObject *kwdict = NULL;
2352 if (co->co_flags & CO_VARKEYWORDS) {
2353 kwdict = PyDict_New();
2354 if (kwdict == NULL)
2355 goto fail;
2356 i = co->co_argcount;
2357 if (co->co_flags & CO_VARARGS)
2358 i++;
2359 SETLOCAL(i, kwdict);
2360 }
2361 if (argcount > co->co_argcount) {
2362 if (!(co->co_flags & CO_VARARGS)) {
2363 PyErr_Format(PyExc_TypeError,
2364 "%.200s() takes %s %d "
2365 "%sargument%s (%d given)",
2366 PyString_AsString(co->co_name),
2367 defcount ? "at most" : "exactly",
2368 co->co_argcount,
2369 kwcount ? "non-keyword " : "",
2370 co->co_argcount == 1 ? "" : "s",
2371 argcount);
2372 goto fail;
2373 }
2374 n = co->co_argcount;
2375 }
2376 for (i = 0; i < n; i++) {
2377 x = args[i];
2378 Py_INCREF(x);
2379 SETLOCAL(i, x);
2380 }
2381 if (co->co_flags & CO_VARARGS) {
2382 u = PyTuple_New(argcount - n);
2383 if (u == NULL)
2384 goto fail;
2385 SETLOCAL(co->co_argcount, u);
2386 for (i = n; i < argcount; i++) {
2387 x = args[i];
2388 Py_INCREF(x);
2389 PyTuple_SET_ITEM(u, i-n, x);
2390 }
2391 }
2392 for (i = 0; i < kwcount; i++) {
2393 PyObject *keyword = kws[2*i];
2394 PyObject *value = kws[2*i + 1];
2395 int j;
2396 if (keyword == NULL || !PyString_Check(keyword)) {
2397 PyErr_Format(PyExc_TypeError,
2398 "%.200s() keywords must be strings",
2399 PyString_AsString(co->co_name));
2400 goto fail;
2401 }
2402 /* XXX slow -- speed up using dictionary? */
2403 for (j = 0; j < co->co_argcount; j++) {
2404 PyObject *nm = PyTuple_GET_ITEM(
2405 co->co_varnames, j);
2406 int cmp = PyObject_RichCompareBool(
2407 keyword, nm, Py_EQ);
2408 if (cmp > 0)
2409 break;
2410 else if (cmp < 0)
2411 goto fail;
2412 }
2413 /* Check errors from Compare */
2414 if (PyErr_Occurred())
2415 goto fail;
2416 if (j >= co->co_argcount) {
2417 if (kwdict == NULL) {
2418 PyErr_Format(PyExc_TypeError,
2419 "%.200s() got an unexpected "
2420 "keyword argument '%.400s'",
2421 PyString_AsString(co->co_name),
2422 PyString_AsString(keyword));
2423 goto fail;
2424 }
2425 PyDict_SetItem(kwdict, keyword, value);
2426 }
2427 else {
2428 if (GETLOCAL(j) != NULL) {
2429 PyErr_Format(PyExc_TypeError,
2430 "%.200s() got multiple "
2431 "values for keyword "
2432 "argument '%.400s'",
2433 PyString_AsString(co->co_name),
2434 PyString_AsString(keyword));
2435 goto fail;
2436 }
2437 Py_INCREF(value);
2438 SETLOCAL(j, value);
2439 }
2440 }
2441 if (argcount < co->co_argcount) {
2442 int m = co->co_argcount - defcount;
2443 for (i = argcount; i < m; i++) {
2444 if (GETLOCAL(i) == NULL) {
2445 PyErr_Format(PyExc_TypeError,
2446 "%.200s() takes %s %d "
2447 "%sargument%s (%d given)",
2448 PyString_AsString(co->co_name),
2449 ((co->co_flags & CO_VARARGS) ||
2450 defcount) ? "at least"
2451 : "exactly",
2452 m, kwcount ? "non-keyword " : "",
2453 m == 1 ? "" : "s", i);
2454 goto fail;
2455 }
2456 }
2457 if (n > m)
2458 i = n - m;
2459 else
2460 i = 0;
2461 for (; i < defcount; i++) {
2462 if (GETLOCAL(m+i) == NULL) {
2463 PyObject *def = defs[i];
2464 Py_INCREF(def);
2465 SETLOCAL(m+i, def);
2466 }
2467 }
2468 }
2469 }
2470 else {
2471 if (argcount > 0 || kwcount > 0) {
2472 PyErr_Format(PyExc_TypeError,
2473 "%.200s() takes no arguments (%d given)",
2474 PyString_AsString(co->co_name),
2475 argcount + kwcount);
2476 goto fail;
2477 }
2478 }
2479 /* Allocate and initialize storage for cell vars, and copy free
2480 vars into frame. This isn't too efficient right now. */
2481 if (f->f_ncells) {
2482 int i = 0, j = 0, nargs, found;
2483 char *cellname, *argname;
2484 PyObject *c;
2485
2486 nargs = co->co_argcount;
2487 if (co->co_flags & CO_VARARGS)
2488 nargs++;
2489 if (co->co_flags & CO_VARKEYWORDS)
2490 nargs++;
2491
2492 /* Check for cells that shadow args */
2493 for (i = 0; i < f->f_ncells && j < nargs; ++i) {
2494 cellname = PyString_AS_STRING(
2495 PyTuple_GET_ITEM(co->co_cellvars, i));
2496 found = 0;
2497 while (j < nargs) {
2498 argname = PyString_AS_STRING(
2499 PyTuple_GET_ITEM(co->co_varnames, j));
2500 if (strcmp(cellname, argname) == 0) {
2501 c = PyCell_New(GETLOCAL(j));
2502 if (c == NULL)
2503 goto fail;
2504 GETLOCAL(f->f_nlocals + i) = c;
2505 found = 1;
2506 break;
2507 }
2508 j++;
2509 }
2510 if (found == 0) {
2511 c = PyCell_New(NULL);
2512 if (c == NULL)
2513 goto fail;
2514 SETLOCAL(f->f_nlocals + i, c);
2515 }
2516 }
2517 /* Initialize any that are left */
2518 while (i < f->f_ncells) {
2519 c = PyCell_New(NULL);
2520 if (c == NULL)
2521 goto fail;
2522 SETLOCAL(f->f_nlocals + i, c);
2523 i++;
2524 }
2525 }
2526 if (f->f_nfreevars) {
2527 int i;
2528 for (i = 0; i < f->f_nfreevars; ++i) {
2529 PyObject *o = PyTuple_GET_ITEM(closure, i);
2530 Py_INCREF(o);
2531 freevars[f->f_ncells + i] = o;
2532 }
2533 }
2534
Tim Peters5ca576e2001-06-18 22:08:13 +00002535 if (co->co_flags & CO_GENERATOR) {
Neil Schemenauer2b13ce82001-06-21 02:41:10 +00002536 /* Don't need to keep the reference to f_back, it will be set
2537 * when the generator is resumed. */
Tim Peters5ba58662001-07-16 02:29:45 +00002538 Py_XDECREF(f->f_back);
Neil Schemenauer2b13ce82001-06-21 02:41:10 +00002539 f->f_back = NULL;
2540
2541 /* Create a new generator that owns the ready to run frame
2542 * and return that as the value. */
Tim Peters5ca576e2001-06-18 22:08:13 +00002543 return gen_new(f);
2544 }
2545
2546 retval = eval_frame(f);
2547
2548 fail: /* Jump here from prelude on failure */
2549
2550 Py_DECREF(f);
2551 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
Barry Warsaw4249f541997-08-22 21:26:19 +00002699 if (PyString_Check(type))
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002700 ;
Barry Warsaw4249f541997-08-22 21:26:19 +00002701
2702 else if (PyClass_Check(type))
2703 PyErr_NormalizeException(&type, &value, &tb);
2704
Guido van Rossumb209a111997-04-29 18:18:01 +00002705 else if (PyInstance_Check(type)) {
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002706 /* Raising an instance. The value should be a dummy. */
Guido van Rossumb209a111997-04-29 18:18:01 +00002707 if (value != Py_None) {
2708 PyErr_SetString(PyExc_TypeError,
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002709 "instance exception may not have a separate value");
2710 goto raise_error;
2711 }
2712 else {
2713 /* Normalize to raise <class>, <instance> */
Guido van Rossumb209a111997-04-29 18:18:01 +00002714 Py_DECREF(value);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002715 value = type;
Guido van Rossumb209a111997-04-29 18:18:01 +00002716 type = (PyObject*) ((PyInstanceObject*)type)->in_class;
2717 Py_INCREF(type);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002718 }
2719 }
2720 else {
2721 /* Not something you can raise. You get an exception
2722 anyway, just not what you specified :-) */
Jeremy Hylton960d9482001-04-27 02:25:33 +00002723 PyErr_Format(PyExc_TypeError,
2724 "exceptions must be strings, classes, or "
2725 "instances, not %s", type->ob_type->tp_name);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002726 goto raise_error;
2727 }
Guido van Rossumb209a111997-04-29 18:18:01 +00002728 PyErr_Restore(type, value, tb);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002729 if (tb == NULL)
2730 return WHY_EXCEPTION;
2731 else
2732 return WHY_RERAISE;
2733 raise_error:
Guido van Rossumb209a111997-04-29 18:18:01 +00002734 Py_XDECREF(value);
2735 Py_XDECREF(type);
2736 Py_XDECREF(tb);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002737 return WHY_EXCEPTION;
2738}
2739
Tim Petersd6d010b2001-06-21 02:49:55 +00002740/* Iterate v argcnt times and store the results on the stack (via decreasing
2741 sp). Return 1 for success, 0 if error. */
2742
Barry Warsawe42b18f1997-08-25 22:13:04 +00002743static int
Tim Petersd6d010b2001-06-21 02:49:55 +00002744unpack_iterable(PyObject *v, int argcnt, PyObject **sp)
Barry Warsawe42b18f1997-08-25 22:13:04 +00002745{
Tim Petersd6d010b2001-06-21 02:49:55 +00002746 int i = 0;
2747 PyObject *it; /* iter(v) */
Barry Warsawe42b18f1997-08-25 22:13:04 +00002748 PyObject *w;
Guido van Rossumac7be682001-01-17 15:42:30 +00002749
Tim Petersd6d010b2001-06-21 02:49:55 +00002750 assert(v != NULL);
2751
2752 it = PyObject_GetIter(v);
2753 if (it == NULL)
2754 goto Error;
2755
2756 for (; i < argcnt; i++) {
2757 w = PyIter_Next(it);
2758 if (w == NULL) {
2759 /* Iterator done, via error or exhaustion. */
2760 if (!PyErr_Occurred()) {
2761 PyErr_Format(PyExc_ValueError,
2762 "need more than %d value%s to unpack",
2763 i, i == 1 ? "" : "s");
2764 }
2765 goto Error;
Barry Warsawe42b18f1997-08-25 22:13:04 +00002766 }
2767 *--sp = w;
2768 }
Tim Petersd6d010b2001-06-21 02:49:55 +00002769
2770 /* We better have exhausted the iterator now. */
2771 w = PyIter_Next(it);
2772 if (w == NULL) {
2773 if (PyErr_Occurred())
2774 goto Error;
2775 Py_DECREF(it);
2776 return 1;
Barry Warsawe42b18f1997-08-25 22:13:04 +00002777 }
Tim Petersd6d010b2001-06-21 02:49:55 +00002778 PyErr_SetString(PyExc_ValueError, "too many values to unpack");
Barry Warsawe42b18f1997-08-25 22:13:04 +00002779 /* fall through */
Tim Petersd6d010b2001-06-21 02:49:55 +00002780Error:
Barry Warsaw91010551997-08-25 22:30:51 +00002781 for (; i > 0; i--, sp++)
2782 Py_DECREF(*sp);
Tim Petersd6d010b2001-06-21 02:49:55 +00002783 Py_XDECREF(it);
Barry Warsawe42b18f1997-08-25 22:13:04 +00002784 return 0;
2785}
2786
2787
Guido van Rossum96a42c81992-01-12 02:29:51 +00002788#ifdef LLTRACE
Guido van Rossum3f5da241990-12-20 15:06:42 +00002789static int
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002790prtrace(PyObject *v, char *str)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00002791{
Guido van Rossum3f5da241990-12-20 15:06:42 +00002792 printf("%s ", str);
Guido van Rossumb209a111997-04-29 18:18:01 +00002793 if (PyObject_Print(v, stdout, 0) != 0)
2794 PyErr_Clear(); /* Don't know what else to do */
Guido van Rossum3f5da241990-12-20 15:06:42 +00002795 printf("\n");
Guido van Rossumcc229ea2000-05-04 00:55:17 +00002796 return 1;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00002797}
Guido van Rossum3f5da241990-12-20 15:06:42 +00002798#endif
Guido van Rossum10dc2e81990-11-18 17:27:39 +00002799
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002800static void
Fred Drake5755ce62001-06-27 19:19:46 +00002801call_exc_trace(Py_tracefunc func, PyObject *self, PyFrameObject *f)
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002802{
Guido van Rossumb209a111997-04-29 18:18:01 +00002803 PyObject *type, *value, *traceback, *arg;
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002804 int err;
Guido van Rossumb209a111997-04-29 18:18:01 +00002805 PyErr_Fetch(&type, &value, &traceback);
Guido van Rossumbd9ccca1992-04-09 14:58:08 +00002806 if (value == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002807 value = Py_None;
2808 Py_INCREF(value);
Guido van Rossumbd9ccca1992-04-09 14:58:08 +00002809 }
Guido van Rossumb209a111997-04-29 18:18:01 +00002810 arg = Py_BuildValue("(OOO)", type, value, traceback);
Guido van Rossum1ae940a1995-01-02 19:04:15 +00002811 if (arg == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002812 PyErr_Restore(type, value, traceback);
Guido van Rossum1ae940a1995-01-02 19:04:15 +00002813 return;
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002814 }
Fred Drake5755ce62001-06-27 19:19:46 +00002815 err = call_trace(func, self, f, PyTrace_EXCEPTION, arg);
Guido van Rossumb209a111997-04-29 18:18:01 +00002816 Py_DECREF(arg);
Guido van Rossum1ae940a1995-01-02 19:04:15 +00002817 if (err == 0)
Guido van Rossumb209a111997-04-29 18:18:01 +00002818 PyErr_Restore(type, value, traceback);
Guido van Rossum1ae940a1995-01-02 19:04:15 +00002819 else {
Guido van Rossumb209a111997-04-29 18:18:01 +00002820 Py_XDECREF(type);
2821 Py_XDECREF(value);
2822 Py_XDECREF(traceback);
Guido van Rossum1ae940a1995-01-02 19:04:15 +00002823 }
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002824}
2825
2826static int
Fred Drake5755ce62001-06-27 19:19:46 +00002827call_trace(Py_tracefunc func, PyObject *obj, PyFrameObject *frame,
2828 int what, PyObject *arg)
Guido van Rossum96a42c81992-01-12 02:29:51 +00002829{
Fred Drake5755ce62001-06-27 19:19:46 +00002830 register PyThreadState *tstate = frame->f_tstate;
2831 int result;
2832 if (tstate->tracing)
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002833 return 0;
Guido van Rossuma027efa1997-05-05 20:56:21 +00002834 tstate->tracing++;
Fred Drake9e3ad782001-07-03 23:39:52 +00002835 tstate->use_tracing = 0;
Fred Drake5755ce62001-06-27 19:19:46 +00002836 result = func(obj, frame, what, arg);
Fred Drake9e3ad782001-07-03 23:39:52 +00002837 tstate->use_tracing = ((tstate->c_tracefunc != NULL)
2838 || (tstate->c_profilefunc != NULL));
Guido van Rossuma027efa1997-05-05 20:56:21 +00002839 tstate->tracing--;
Fred Drake5755ce62001-06-27 19:19:46 +00002840 return result;
Guido van Rossum96a42c81992-01-12 02:29:51 +00002841}
2842
Fred Drake5755ce62001-06-27 19:19:46 +00002843void
2844PyEval_SetProfile(Py_tracefunc func, PyObject *arg)
Fred Draked0838392001-06-16 21:02:31 +00002845{
Fred Drake5755ce62001-06-27 19:19:46 +00002846 PyThreadState *tstate = PyThreadState_Get();
2847 PyObject *temp = tstate->c_profileobj;
2848 Py_XINCREF(arg);
2849 tstate->c_profilefunc = NULL;
2850 tstate->c_profileobj = NULL;
Fred Drake9e3ad782001-07-03 23:39:52 +00002851 tstate->use_tracing = tstate->c_tracefunc != NULL;
Fred Drake5755ce62001-06-27 19:19:46 +00002852 Py_XDECREF(temp);
2853 tstate->c_profilefunc = func;
2854 tstate->c_profileobj = arg;
Fred Drake9e3ad782001-07-03 23:39:52 +00002855 tstate->use_tracing = (func != NULL) || (tstate->c_tracefunc != NULL);
Fred Drake5755ce62001-06-27 19:19:46 +00002856}
2857
2858void
2859PyEval_SetTrace(Py_tracefunc func, PyObject *arg)
2860{
2861 PyThreadState *tstate = PyThreadState_Get();
2862 PyObject *temp = tstate->c_traceobj;
2863 Py_XINCREF(arg);
2864 tstate->c_tracefunc = NULL;
2865 tstate->c_traceobj = NULL;
Fred Drake9e3ad782001-07-03 23:39:52 +00002866 tstate->use_tracing = tstate->c_profilefunc != NULL;
Fred Drake5755ce62001-06-27 19:19:46 +00002867 Py_XDECREF(temp);
2868 tstate->c_tracefunc = func;
2869 tstate->c_traceobj = arg;
Fred Drake9e3ad782001-07-03 23:39:52 +00002870 tstate->use_tracing = ((func != NULL)
2871 || (tstate->c_profilefunc != NULL));
Fred Draked0838392001-06-16 21:02:31 +00002872}
2873
Guido van Rossumb209a111997-04-29 18:18:01 +00002874PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002875PyEval_GetBuiltins(void)
Guido van Rossum6135a871995-01-09 17:53:26 +00002876{
Guido van Rossum25ce5661997-08-02 03:10:38 +00002877 PyThreadState *tstate = PyThreadState_Get();
2878 PyFrameObject *current_frame = tstate->frame;
Guido van Rossum6135a871995-01-09 17:53:26 +00002879 if (current_frame == NULL)
Guido van Rossum25ce5661997-08-02 03:10:38 +00002880 return tstate->interp->builtins;
Guido van Rossum6135a871995-01-09 17:53:26 +00002881 else
2882 return current_frame->f_builtins;
2883}
2884
Guido van Rossumb209a111997-04-29 18:18:01 +00002885PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002886PyEval_GetLocals(void)
Guido van Rossum5b722181993-03-30 17:46:03 +00002887{
Guido van Rossuma027efa1997-05-05 20:56:21 +00002888 PyFrameObject *current_frame = PyThreadState_Get()->frame;
Guido van Rossum5b722181993-03-30 17:46:03 +00002889 if (current_frame == NULL)
2890 return NULL;
Guido van Rossumb209a111997-04-29 18:18:01 +00002891 PyFrame_FastToLocals(current_frame);
Guido van Rossum5b722181993-03-30 17:46:03 +00002892 return current_frame->f_locals;
2893}
2894
Guido van Rossumb209a111997-04-29 18:18:01 +00002895PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002896PyEval_GetGlobals(void)
Guido van Rossum3f5da241990-12-20 15:06:42 +00002897{
Guido van Rossuma027efa1997-05-05 20:56:21 +00002898 PyFrameObject *current_frame = PyThreadState_Get()->frame;
Guido van Rossum3f5da241990-12-20 15:06:42 +00002899 if (current_frame == NULL)
2900 return NULL;
2901 else
2902 return current_frame->f_globals;
2903}
2904
Guido van Rossumb209a111997-04-29 18:18:01 +00002905PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002906PyEval_GetFrame(void)
Guido van Rossume59214e1994-08-30 08:01:59 +00002907{
Guido van Rossuma027efa1997-05-05 20:56:21 +00002908 PyFrameObject *current_frame = PyThreadState_Get()->frame;
Guido van Rossumb209a111997-04-29 18:18:01 +00002909 return (PyObject *)current_frame;
Guido van Rossume59214e1994-08-30 08:01:59 +00002910}
2911
Guido van Rossum6135a871995-01-09 17:53:26 +00002912int
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002913PyEval_GetRestricted(void)
Guido van Rossum6135a871995-01-09 17:53:26 +00002914{
Guido van Rossuma027efa1997-05-05 20:56:21 +00002915 PyFrameObject *current_frame = PyThreadState_Get()->frame;
Guido van Rossum6135a871995-01-09 17:53:26 +00002916 return current_frame == NULL ? 0 : current_frame->f_restricted;
2917}
2918
Guido van Rossumbe270261997-05-22 22:26:18 +00002919int
Tim Peters5ba58662001-07-16 02:29:45 +00002920PyEval_MergeCompilerFlags(PyCompilerFlags *cf)
Jeremy Hylton061d1062001-03-22 02:32:48 +00002921{
2922 PyFrameObject *current_frame = PyThreadState_Get()->frame;
Tim Peters5ba58662001-07-16 02:29:45 +00002923 int result = 0;
2924
2925 if (current_frame != NULL) {
2926 const int codeflags = current_frame->f_code->co_flags;
Tim Peterse2c18e92001-08-17 20:47:47 +00002927 const int compilerflags = codeflags & PyCF_MASK;
2928 if (compilerflags) {
Tim Peters5ba58662001-07-16 02:29:45 +00002929 result = 1;
Tim Peterse2c18e92001-08-17 20:47:47 +00002930 cf->cf_flags |= compilerflags;
Tim Peters5ba58662001-07-16 02:29:45 +00002931 }
2932 }
2933 return result;
Jeremy Hylton061d1062001-03-22 02:32:48 +00002934}
2935
2936int
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002937Py_FlushLine(void)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00002938{
Guido van Rossumb209a111997-04-29 18:18:01 +00002939 PyObject *f = PySys_GetObject("stdout");
Guido van Rossumbe270261997-05-22 22:26:18 +00002940 if (f == NULL)
2941 return 0;
2942 if (!PyFile_SoftSpace(f, 0))
2943 return 0;
2944 return PyFile_WriteString("\n", f);
Guido van Rossum10dc2e81990-11-18 17:27:39 +00002945}
2946
Guido van Rossum3f5da241990-12-20 15:06:42 +00002947
Guido van Rossum681d79a1995-07-18 14:51:37 +00002948/* External interface to call any callable object.
2949 The arg must be a tuple or NULL. */
Guido van Rossum83bf35c1991-07-27 21:32:34 +00002950
Guido van Rossumd7ed6831997-08-30 15:02:50 +00002951#undef PyEval_CallObject
2952/* for backward compatibility: export this interface */
2953
Guido van Rossumb209a111997-04-29 18:18:01 +00002954PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002955PyEval_CallObject(PyObject *func, PyObject *arg)
Guido van Rossum83bf35c1991-07-27 21:32:34 +00002956{
Guido van Rossumb209a111997-04-29 18:18:01 +00002957 return PyEval_CallObjectWithKeywords(func, arg, (PyObject *)NULL);
Guido van Rossum681d79a1995-07-18 14:51:37 +00002958}
Guido van Rossumd7ed6831997-08-30 15:02:50 +00002959#define PyEval_CallObject(func,arg) \
2960 PyEval_CallObjectWithKeywords(func, arg, (PyObject *)NULL)
Guido van Rossume59214e1994-08-30 08:01:59 +00002961
Guido van Rossumb209a111997-04-29 18:18:01 +00002962PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002963PyEval_CallObjectWithKeywords(PyObject *func, PyObject *arg, PyObject *kw)
Guido van Rossum681d79a1995-07-18 14:51:37 +00002964{
Jeremy Hylton52820442001-01-03 23:52:36 +00002965 PyObject *result;
Guido van Rossum681d79a1995-07-18 14:51:37 +00002966
2967 if (arg == NULL)
Guido van Rossumb209a111997-04-29 18:18:01 +00002968 arg = PyTuple_New(0);
2969 else if (!PyTuple_Check(arg)) {
Guido van Rossuma027efa1997-05-05 20:56:21 +00002970 PyErr_SetString(PyExc_TypeError,
2971 "argument list must be a tuple");
Guido van Rossum681d79a1995-07-18 14:51:37 +00002972 return NULL;
2973 }
2974 else
Guido van Rossumb209a111997-04-29 18:18:01 +00002975 Py_INCREF(arg);
Guido van Rossum681d79a1995-07-18 14:51:37 +00002976
Guido van Rossumb209a111997-04-29 18:18:01 +00002977 if (kw != NULL && !PyDict_Check(kw)) {
Guido van Rossuma027efa1997-05-05 20:56:21 +00002978 PyErr_SetString(PyExc_TypeError,
2979 "keyword list must be a dictionary");
Guido van Rossum25826c92000-04-21 21:17:39 +00002980 Py_DECREF(arg);
Guido van Rossume3e61c11995-08-04 04:14:47 +00002981 return NULL;
2982 }
2983
Tim Peters6d6c1a32001-08-02 04:15:00 +00002984 result = PyObject_Call(func, arg, kw);
Guido van Rossumb209a111997-04-29 18:18:01 +00002985 Py_DECREF(arg);
Jeremy Hylton52820442001-01-03 23:52:36 +00002986 return result;
2987}
2988
Tim Peters6d6c1a32001-08-02 04:15:00 +00002989char *
2990PyEval_GetFuncName(PyObject *func)
Jeremy Hylton512a2372001-04-11 13:52:29 +00002991{
2992 if (PyMethod_Check(func))
Tim Peters6d6c1a32001-08-02 04:15:00 +00002993 return PyEval_GetFuncName(PyMethod_GET_FUNCTION(func));
Jeremy Hylton512a2372001-04-11 13:52:29 +00002994 else if (PyFunction_Check(func))
2995 return PyString_AsString(((PyFunctionObject*)func)->func_name);
2996 else if (PyCFunction_Check(func))
2997 return ((PyCFunctionObject*)func)->m_ml->ml_name;
2998 else if (PyClass_Check(func))
2999 return PyString_AsString(((PyClassObject*)func)->cl_name);
3000 else if (PyInstance_Check(func)) {
3001 return PyString_AsString(
3002 ((PyInstanceObject*)func)->in_class->cl_name);
3003 } else {
3004 return func->ob_type->tp_name;
3005 }
3006}
3007
Tim Peters6d6c1a32001-08-02 04:15:00 +00003008char *
3009PyEval_GetFuncDesc(PyObject *func)
Jeremy Hylton512a2372001-04-11 13:52:29 +00003010{
3011 if (PyMethod_Check(func))
3012 return "()";
3013 else if (PyFunction_Check(func))
3014 return "()";
3015 else if (PyCFunction_Check(func))
3016 return "()";
3017 else if (PyClass_Check(func))
3018 return " constructor";
3019 else if (PyInstance_Check(func)) {
3020 return " instance";
3021 } else {
3022 return " object";
3023 }
3024}
3025
Jeremy Hylton52820442001-01-03 23:52:36 +00003026#define EXT_POP(STACK_POINTER) (*--(STACK_POINTER))
3027
3028/* The two fast_xxx() functions optimize calls for which no argument
3029 tuple is necessary; the objects are passed directly from the stack.
3030 fast_cfunction() is called for METH_OLDARGS functions.
3031 fast_function() is for functions with no special argument handling.
3032*/
3033
3034static PyObject *
3035fast_cfunction(PyObject *func, PyObject ***pp_stack, int na)
3036{
3037 PyCFunction meth = PyCFunction_GET_FUNCTION(func);
3038 PyObject *self = PyCFunction_GET_SELF(func);
Martin v. Löwise3eb1f22001-08-16 13:15:00 +00003039 int flags = PyCFunction_GET_FLAGS(func);
Jeremy Hylton52820442001-01-03 23:52:36 +00003040
Martin v. Löwise3eb1f22001-08-16 13:15:00 +00003041 switch (flags) {
3042 case METH_OLDARGS:
3043 if (na == 0)
3044 return (*meth)(self, NULL);
3045 else if (na == 1) {
3046 PyObject *arg = EXT_POP(*pp_stack);
3047 PyObject *result = (*meth)(self, arg);
3048 Py_DECREF(arg);
3049 return result;
3050 } else {
3051 PyObject *args = load_args(pp_stack, na);
3052 PyObject *result = (*meth)(self, args);
3053 Py_DECREF(args);
3054 return result;
3055 }
Martin v. Löwise3eb1f22001-08-16 13:15:00 +00003056 case METH_NOARGS:
3057 if (na == 0)
3058 return (*meth)(self, NULL);
3059 PyErr_Format(PyExc_TypeError,
3060 "%.200s() takes no arguments (%d given)",
3061 ((PyCFunctionObject*)func)->m_ml->ml_name, na);
3062 return NULL;
Martin v. Löwise3eb1f22001-08-16 13:15:00 +00003063 case METH_O:
3064 if (na == 1) {
3065 PyObject *arg = EXT_POP(*pp_stack);
3066 PyObject *result = (*meth)(self, arg);
3067 Py_DECREF(arg);
3068 return result;
3069 }
3070 PyErr_Format(PyExc_TypeError,
3071 "%.200s() takes exactly one argument (%d given)",
3072 ((PyCFunctionObject*)func)->m_ml->ml_name, na);
3073 return NULL;
Martin v. Löwise3eb1f22001-08-16 13:15:00 +00003074 default:
3075 fprintf(stderr, "%.200s() flags = %d\n",
3076 ((PyCFunctionObject*)func)->m_ml->ml_name, flags);
3077 PyErr_BadInternalCall();
3078 return NULL;
3079 }
Jeremy Hylton52820442001-01-03 23:52:36 +00003080}
3081
3082static PyObject *
Guido van Rossumac7be682001-01-17 15:42:30 +00003083fast_function(PyObject *func, PyObject ***pp_stack, int n, int na, int nk)
Jeremy Hylton52820442001-01-03 23:52:36 +00003084{
3085 PyObject *co = PyFunction_GET_CODE(func);
3086 PyObject *globals = PyFunction_GET_GLOBALS(func);
3087 PyObject *argdefs = PyFunction_GET_DEFAULTS(func);
Jeremy Hylton64949cb2001-01-25 20:06:59 +00003088 PyObject *closure = PyFunction_GET_CLOSURE(func);
Jeremy Hylton52820442001-01-03 23:52:36 +00003089 PyObject **d = NULL;
3090 int nd = 0;
3091
3092 if (argdefs != NULL) {
3093 d = &PyTuple_GET_ITEM(argdefs, 0);
3094 nd = ((PyTupleObject *)argdefs)->ob_size;
3095 }
Tim Peters6d6c1a32001-08-02 04:15:00 +00003096 return PyEval_EvalCodeEx((PyCodeObject *)co, globals,
Jeremy Hylton52820442001-01-03 23:52:36 +00003097 (PyObject *)NULL, (*pp_stack)-n, na,
Jeremy Hylton64949cb2001-01-25 20:06:59 +00003098 (*pp_stack)-2*nk, nk, d, nd,
3099 closure);
Jeremy Hylton52820442001-01-03 23:52:36 +00003100}
3101
3102static PyObject *
Ka-Ping Yee20579702001-01-15 22:14:16 +00003103update_keyword_args(PyObject *orig_kwdict, int nk, PyObject ***pp_stack,
3104 PyObject *func)
Jeremy Hylton52820442001-01-03 23:52:36 +00003105{
3106 PyObject *kwdict = NULL;
3107 if (orig_kwdict == NULL)
3108 kwdict = PyDict_New();
3109 else {
3110 kwdict = PyDict_Copy(orig_kwdict);
3111 Py_DECREF(orig_kwdict);
3112 }
3113 if (kwdict == NULL)
3114 return NULL;
3115 while (--nk >= 0) {
3116 int err;
3117 PyObject *value = EXT_POP(*pp_stack);
3118 PyObject *key = EXT_POP(*pp_stack);
3119 if (PyDict_GetItem(kwdict, key) != NULL) {
Guido van Rossumac7be682001-01-17 15:42:30 +00003120 PyErr_Format(PyExc_TypeError,
Ka-Ping Yee20579702001-01-15 22:14:16 +00003121 "%.200s%s got multiple values "
Jeremy Hylton512a2372001-04-11 13:52:29 +00003122 "for keyword argument '%.200s'",
Tim Peters6d6c1a32001-08-02 04:15:00 +00003123 PyEval_GetFuncName(func),
3124 PyEval_GetFuncDesc(func),
Jeremy Hylton512a2372001-04-11 13:52:29 +00003125 PyString_AsString(key));
Jeremy Hylton52820442001-01-03 23:52:36 +00003126 Py_DECREF(key);
3127 Py_DECREF(value);
3128 Py_DECREF(kwdict);
3129 return NULL;
3130 }
3131 err = PyDict_SetItem(kwdict, key, value);
3132 Py_DECREF(key);
3133 Py_DECREF(value);
3134 if (err) {
3135 Py_DECREF(kwdict);
3136 return NULL;
3137 }
3138 }
3139 return kwdict;
3140}
3141
3142static PyObject *
3143update_star_args(int nstack, int nstar, PyObject *stararg,
3144 PyObject ***pp_stack)
3145{
3146 PyObject *callargs, *w;
3147
3148 callargs = PyTuple_New(nstack + nstar);
3149 if (callargs == NULL) {
3150 return NULL;
3151 }
3152 if (nstar) {
3153 int i;
3154 for (i = 0; i < nstar; i++) {
3155 PyObject *a = PyTuple_GET_ITEM(stararg, i);
3156 Py_INCREF(a);
3157 PyTuple_SET_ITEM(callargs, nstack + i, a);
3158 }
3159 }
3160 while (--nstack >= 0) {
3161 w = EXT_POP(*pp_stack);
3162 PyTuple_SET_ITEM(callargs, nstack, w);
3163 }
3164 return callargs;
3165}
3166
3167static PyObject *
3168load_args(PyObject ***pp_stack, int na)
3169{
3170 PyObject *args = PyTuple_New(na);
3171 PyObject *w;
3172
3173 if (args == NULL)
3174 return NULL;
3175 while (--na >= 0) {
3176 w = EXT_POP(*pp_stack);
3177 PyTuple_SET_ITEM(args, na, w);
3178 }
3179 return args;
3180}
3181
3182static PyObject *
3183do_call(PyObject *func, PyObject ***pp_stack, int na, int nk)
3184{
3185 PyObject *callargs = NULL;
3186 PyObject *kwdict = NULL;
3187 PyObject *result = NULL;
3188
3189 if (nk > 0) {
Ka-Ping Yee20579702001-01-15 22:14:16 +00003190 kwdict = update_keyword_args(NULL, nk, pp_stack, func);
Jeremy Hylton52820442001-01-03 23:52:36 +00003191 if (kwdict == NULL)
3192 goto call_fail;
3193 }
3194 callargs = load_args(pp_stack, na);
3195 if (callargs == NULL)
3196 goto call_fail;
Tim Peters6d6c1a32001-08-02 04:15:00 +00003197 result = PyObject_Call(func, callargs, kwdict);
Jeremy Hylton52820442001-01-03 23:52:36 +00003198 call_fail:
3199 Py_XDECREF(callargs);
3200 Py_XDECREF(kwdict);
3201 return result;
3202}
3203
3204static PyObject *
3205ext_do_call(PyObject *func, PyObject ***pp_stack, int flags, int na, int nk)
3206{
3207 int nstar = 0;
3208 PyObject *callargs = NULL;
3209 PyObject *stararg = NULL;
3210 PyObject *kwdict = NULL;
3211 PyObject *result = NULL;
3212
3213 if (flags & CALL_FLAG_KW) {
3214 kwdict = EXT_POP(*pp_stack);
3215 if (!(kwdict && PyDict_Check(kwdict))) {
Ka-Ping Yee20579702001-01-15 22:14:16 +00003216 PyErr_Format(PyExc_TypeError,
Jeremy Hylton512a2372001-04-11 13:52:29 +00003217 "%s%s argument after ** "
3218 "must be a dictionary",
Tim Peters6d6c1a32001-08-02 04:15:00 +00003219 PyEval_GetFuncName(func),
3220 PyEval_GetFuncDesc(func));
Jeremy Hylton52820442001-01-03 23:52:36 +00003221 goto ext_call_fail;
3222 }
3223 }
3224 if (flags & CALL_FLAG_VAR) {
3225 stararg = EXT_POP(*pp_stack);
3226 if (!PyTuple_Check(stararg)) {
3227 PyObject *t = NULL;
3228 t = PySequence_Tuple(stararg);
3229 if (t == NULL) {
Jeremy Hylton512a2372001-04-11 13:52:29 +00003230 if (PyErr_ExceptionMatches(PyExc_TypeError)) {
3231 PyErr_Format(PyExc_TypeError,
3232 "%s%s argument after * "
3233 "must be a sequence",
Tim Peters6d6c1a32001-08-02 04:15:00 +00003234 PyEval_GetFuncName(func),
3235 PyEval_GetFuncDesc(func));
Jeremy Hylton512a2372001-04-11 13:52:29 +00003236 }
Jeremy Hylton52820442001-01-03 23:52:36 +00003237 goto ext_call_fail;
3238 }
3239 Py_DECREF(stararg);
3240 stararg = t;
3241 }
3242 nstar = PyTuple_GET_SIZE(stararg);
3243 }
3244 if (nk > 0) {
Ka-Ping Yee20579702001-01-15 22:14:16 +00003245 kwdict = update_keyword_args(kwdict, nk, pp_stack, func);
Jeremy Hylton52820442001-01-03 23:52:36 +00003246 if (kwdict == NULL)
3247 goto ext_call_fail;
3248 }
3249 callargs = update_star_args(na, nstar, stararg, pp_stack);
3250 if (callargs == NULL)
3251 goto ext_call_fail;
Tim Peters6d6c1a32001-08-02 04:15:00 +00003252 result = PyObject_Call(func, callargs, kwdict);
Jeremy Hylton52820442001-01-03 23:52:36 +00003253 ext_call_fail:
3254 Py_XDECREF(callargs);
3255 Py_XDECREF(kwdict);
3256 Py_XDECREF(stararg);
3257 return result;
3258}
3259
Guido van Rossum3b9c6671996-07-30 18:40:29 +00003260#define SLICE_ERROR_MSG \
3261 "standard sequence type does not support step size other than one"
3262
Guido van Rossumb209a111997-04-29 18:18:01 +00003263static PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003264loop_subscript(PyObject *v, PyObject *w)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003265{
Guido van Rossumb209a111997-04-29 18:18:01 +00003266 PySequenceMethods *sq = v->ob_type->tp_as_sequence;
Guido van Rossume59214e1994-08-30 08:01:59 +00003267 int i;
Guido van Rossum7e33c6e1998-05-22 00:52:29 +00003268 if (sq == NULL || sq->sq_item == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00003269 PyErr_SetString(PyExc_TypeError, "loop over non-sequence");
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003270 return NULL;
3271 }
Guido van Rossumb209a111997-04-29 18:18:01 +00003272 i = PyInt_AsLong(w);
Guido van Rossume59214e1994-08-30 08:01:59 +00003273 v = (*sq->sq_item)(v, i);
3274 if (v)
3275 return v;
Barry Warsaw4249f541997-08-22 21:26:19 +00003276 if (PyErr_ExceptionMatches(PyExc_IndexError))
Guido van Rossumb209a111997-04-29 18:18:01 +00003277 PyErr_Clear();
Guido van Rossume59214e1994-08-30 08:01:59 +00003278 return NULL;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003279}
3280
Guido van Rossum20c6add2000-05-08 14:06:50 +00003281/* Extract a slice index from a PyInt or PyLong, the index is bound to
3282 the range [-INT_MAX+1, INTMAX]. Returns 0 and an exception if there is
3283 and error. Returns 1 on success.*/
3284
3285int
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003286_PyEval_SliceIndex(PyObject *v, int *pi)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003287{
3288 if (v != NULL) {
Guido van Rossuma027efa1997-05-05 20:56:21 +00003289 long x;
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003290 if (PyInt_Check(v)) {
3291 x = PyInt_AsLong(v);
3292 } else if (PyLong_Check(v)) {
3293 x = PyLong_AsLong(v);
3294 if (x==-1 && PyErr_Occurred()) {
3295 PyObject *long_zero;
Guido van Rossumac7be682001-01-17 15:42:30 +00003296 int cmp;
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003297
Guido van Rossumac7be682001-01-17 15:42:30 +00003298 if (!PyErr_ExceptionMatches(
3299 PyExc_OverflowError)) {
3300 /* It's not an overflow error, so just
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003301 signal an error */
Guido van Rossum20c6add2000-05-08 14:06:50 +00003302 return 0;
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003303 }
3304
Guido van Rossumac7be682001-01-17 15:42:30 +00003305 /* Clear the OverflowError */
3306 PyErr_Clear();
3307
3308 /* It's an overflow error, so we need to
3309 check the sign of the long integer,
3310 set the value to INT_MAX or 0, and clear
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003311 the error. */
3312
3313 /* Create a long integer with a value of 0 */
Guido van Rossumac7be682001-01-17 15:42:30 +00003314 long_zero = PyLong_FromLong(0L);
Guido van Rossum20c6add2000-05-08 14:06:50 +00003315 if (long_zero == NULL) return 0;
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003316
3317 /* Check sign */
Guido van Rossumac7be682001-01-17 15:42:30 +00003318 cmp = PyObject_RichCompareBool(v, long_zero,
3319 Py_GT);
3320 Py_DECREF(long_zero);
3321 if (cmp < 0)
3322 return 0;
3323 else if (cmp > 0)
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003324 x = INT_MAX;
3325 else
3326 x = 0;
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003327 }
3328 } else {
Guido van Rossuma027efa1997-05-05 20:56:21 +00003329 PyErr_SetString(PyExc_TypeError,
Fred Drake661ea262000-10-24 19:57:45 +00003330 "slice indices must be integers");
Guido van Rossum20c6add2000-05-08 14:06:50 +00003331 return 0;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003332 }
Guido van Rossuma027efa1997-05-05 20:56:21 +00003333 /* Truncate -- very long indices are truncated anyway */
3334 if (x > INT_MAX)
3335 x = INT_MAX;
3336 else if (x < -INT_MAX)
3337 x = 0;
3338 *pi = x;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003339 }
Guido van Rossum20c6add2000-05-08 14:06:50 +00003340 return 1;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003341}
3342
Guido van Rossum50d756e2001-08-18 17:43:36 +00003343#undef ISINT
3344#define ISINT(x) ((x) == NULL || PyInt_Check(x) || PyLong_Check(x))
3345
Guido van Rossumb209a111997-04-29 18:18:01 +00003346static PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003347apply_slice(PyObject *u, PyObject *v, PyObject *w) /* return u[v:w] */
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003348{
Guido van Rossum50d756e2001-08-18 17:43:36 +00003349 PyTypeObject *tp = u->ob_type;
3350 PySequenceMethods *sq = tp->tp_as_sequence;
3351
3352 if (sq && sq->sq_slice && ISINT(v) && ISINT(w)) {
3353 int ilow = 0, ihigh = INT_MAX;
3354 if (!_PyEval_SliceIndex(v, &ilow))
3355 return NULL;
3356 if (!_PyEval_SliceIndex(w, &ihigh))
3357 return NULL;
3358 return PySequence_GetSlice(u, ilow, ihigh);
3359 }
3360 else {
3361 PyObject *slice = PySlice_New(v, w, NULL);
3362 if (slice != NULL)
3363 return PyObject_GetItem(u, slice);
3364 else
3365 return NULL;
3366 }
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003367}
Guido van Rossum3f5da241990-12-20 15:06:42 +00003368
3369static int
Guido van Rossumac7be682001-01-17 15:42:30 +00003370assign_slice(PyObject *u, PyObject *v, PyObject *w, PyObject *x)
3371 /* u[v:w] = x */
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003372{
Guido van Rossum50d756e2001-08-18 17:43:36 +00003373 PyTypeObject *tp = u->ob_type;
3374 PySequenceMethods *sq = tp->tp_as_sequence;
3375
3376 if (sq && sq->sq_slice && ISINT(v) && ISINT(w)) {
3377 int ilow = 0, ihigh = INT_MAX;
3378 if (!_PyEval_SliceIndex(v, &ilow))
3379 return -1;
3380 if (!_PyEval_SliceIndex(w, &ihigh))
3381 return -1;
3382 if (x == NULL)
3383 return PySequence_DelSlice(u, ilow, ihigh);
3384 else
3385 return PySequence_SetSlice(u, ilow, ihigh, x);
3386 }
3387 else {
3388 PyObject *slice = PySlice_New(v, w, NULL);
3389 if (slice != NULL) {
3390 if (x != NULL)
3391 return PyObject_SetItem(u, slice, x);
3392 else
3393 return PyObject_DelItem(u, slice);
3394 }
3395 else
3396 return -1;
3397 }
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003398}
3399
Guido van Rossumb209a111997-04-29 18:18:01 +00003400static PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003401cmp_outcome(int op, register PyObject *v, register PyObject *w)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003402{
Guido van Rossumac7be682001-01-17 15:42:30 +00003403 int res = 0;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003404 switch (op) {
Guido van Rossum3f5da241990-12-20 15:06:42 +00003405 case IS:
3406 case IS_NOT:
3407 res = (v == w);
Guido van Rossum04691fc1992-08-12 15:35:34 +00003408 if (op == (int) IS_NOT)
Guido van Rossum3f5da241990-12-20 15:06:42 +00003409 res = !res;
3410 break;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003411 case IN:
3412 case NOT_IN:
Guido van Rossum7e33c6e1998-05-22 00:52:29 +00003413 res = PySequence_Contains(w, v);
Guido van Rossum3f5da241990-12-20 15:06:42 +00003414 if (res < 0)
3415 return NULL;
Guido van Rossum04691fc1992-08-12 15:35:34 +00003416 if (op == (int) NOT_IN)
Guido van Rossum3f5da241990-12-20 15:06:42 +00003417 res = !res;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003418 break;
3419 case EXC_MATCH:
Barry Warsaw4249f541997-08-22 21:26:19 +00003420 res = PyErr_GivenExceptionMatches(v, w);
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003421 break;
3422 default:
Guido van Rossumac7be682001-01-17 15:42:30 +00003423 return PyObject_RichCompare(v, w, op);
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003424 }
Guido van Rossumb209a111997-04-29 18:18:01 +00003425 v = res ? Py_True : Py_False;
3426 Py_INCREF(v);
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003427 return v;
3428}
3429
Thomas Wouters52152252000-08-17 22:55:00 +00003430static PyObject *
3431import_from(PyObject *v, PyObject *name)
Guido van Rossume9736fc1990-11-18 17:33:06 +00003432{
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00003433 PyObject *x;
3434
3435 x = PyObject_GetAttr(v, name);
3436 if (x == NULL && PyErr_ExceptionMatches(PyExc_AttributeError)) {
Thomas Wouters52152252000-08-17 22:55:00 +00003437 PyErr_Format(PyExc_ImportError,
3438 "cannot import name %.230s",
3439 PyString_AsString(name));
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00003440 }
Thomas Wouters52152252000-08-17 22:55:00 +00003441 return x;
3442}
Guido van Rossumac7be682001-01-17 15:42:30 +00003443
Thomas Wouters52152252000-08-17 22:55:00 +00003444static int
3445import_all_from(PyObject *locals, PyObject *v)
3446{
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00003447 PyObject *all = PyObject_GetAttrString(v, "__all__");
3448 PyObject *dict, *name, *value;
3449 int skip_leading_underscores = 0;
3450 int pos, err;
Thomas Wouters52152252000-08-17 22:55:00 +00003451
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00003452 if (all == NULL) {
3453 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
3454 return -1; /* Unexpected error */
3455 PyErr_Clear();
3456 dict = PyObject_GetAttrString(v, "__dict__");
3457 if (dict == NULL) {
3458 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
3459 return -1;
3460 PyErr_SetString(PyExc_ImportError,
3461 "from-import-* object has no __dict__ and no __all__");
Guido van Rossum3f5da241990-12-20 15:06:42 +00003462 return -1;
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00003463 }
3464 all = PyMapping_Keys(dict);
3465 Py_DECREF(dict);
3466 if (all == NULL)
3467 return -1;
3468 skip_leading_underscores = 1;
Guido van Rossume9736fc1990-11-18 17:33:06 +00003469 }
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00003470
3471 for (pos = 0, err = 0; ; pos++) {
3472 name = PySequence_GetItem(all, pos);
3473 if (name == NULL) {
3474 if (!PyErr_ExceptionMatches(PyExc_IndexError))
3475 err = -1;
3476 else
3477 PyErr_Clear();
3478 break;
3479 }
3480 if (skip_leading_underscores &&
3481 PyString_Check(name) &&
3482 PyString_AS_STRING(name)[0] == '_')
3483 {
3484 Py_DECREF(name);
3485 continue;
3486 }
3487 value = PyObject_GetAttr(v, name);
3488 if (value == NULL)
3489 err = -1;
3490 else
3491 err = PyDict_SetItem(locals, name, value);
3492 Py_DECREF(name);
3493 Py_XDECREF(value);
3494 if (err != 0)
3495 break;
3496 }
3497 Py_DECREF(all);
3498 return err;
Guido van Rossume9736fc1990-11-18 17:33:06 +00003499}
3500
Guido van Rossumb209a111997-04-29 18:18:01 +00003501static PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003502build_class(PyObject *methods, PyObject *bases, PyObject *name)
Guido van Rossume9736fc1990-11-18 17:33:06 +00003503{
Guido van Rossum7851eea2001-09-12 19:19:18 +00003504 PyObject *metaclass = NULL, *result, *base;
Tim Peters6d6c1a32001-08-02 04:15:00 +00003505
3506 if (PyDict_Check(methods))
3507 metaclass = PyDict_GetItemString(methods, "__metaclass__");
Guido van Rossum7851eea2001-09-12 19:19:18 +00003508 if (metaclass != NULL)
3509 Py_INCREF(methods);
3510 else if (PyTuple_Check(bases) && PyTuple_GET_SIZE(bases) > 0) {
3511 base = PyTuple_GET_ITEM(bases, 0);
3512 metaclass = PyObject_GetAttrString(base, "__class__");
3513 if (metaclass == NULL) {
3514 PyErr_Clear();
3515 metaclass = (PyObject *)base->ob_type;
3516 Py_INCREF(metaclass);
Guido van Rossum25831651993-05-19 14:50:45 +00003517 }
3518 }
Guido van Rossum7851eea2001-09-12 19:19:18 +00003519 else {
3520 PyObject *g = PyEval_GetGlobals();
3521 if (g != NULL && PyDict_Check(g))
3522 metaclass = PyDict_GetItemString(g, "__metaclass__");
3523 if (metaclass == NULL)
3524 metaclass = (PyObject *) &PyClass_Type;
3525 Py_INCREF(metaclass);
3526 }
3527 result = PyObject_CallFunction(metaclass, "OOO", name, bases, methods);
3528 Py_DECREF(metaclass);
3529 return result;
Guido van Rossum25831651993-05-19 14:50:45 +00003530}
3531
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003532static int
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003533exec_statement(PyFrameObject *f, PyObject *prog, PyObject *globals,
3534 PyObject *locals)
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003535{
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003536 int n;
Guido van Rossumb209a111997-04-29 18:18:01 +00003537 PyObject *v;
Guido van Rossum681d79a1995-07-18 14:51:37 +00003538 int plain = 0;
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003539
Guido van Rossumb209a111997-04-29 18:18:01 +00003540 if (PyTuple_Check(prog) && globals == Py_None && locals == Py_None &&
3541 ((n = PyTuple_Size(prog)) == 2 || n == 3)) {
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003542 /* Backward compatibility hack */
Guido van Rossumb209a111997-04-29 18:18:01 +00003543 globals = PyTuple_GetItem(prog, 1);
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003544 if (n == 3)
Guido van Rossumb209a111997-04-29 18:18:01 +00003545 locals = PyTuple_GetItem(prog, 2);
3546 prog = PyTuple_GetItem(prog, 0);
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003547 }
Guido van Rossumb209a111997-04-29 18:18:01 +00003548 if (globals == Py_None) {
3549 globals = PyEval_GetGlobals();
3550 if (locals == Py_None) {
3551 locals = PyEval_GetLocals();
Guido van Rossum681d79a1995-07-18 14:51:37 +00003552 plain = 1;
3553 }
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003554 }
Guido van Rossumb209a111997-04-29 18:18:01 +00003555 else if (locals == Py_None)
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003556 locals = globals;
Guido van Rossumb209a111997-04-29 18:18:01 +00003557 if (!PyString_Check(prog) &&
Marc-André Lemburgd1ba4432000-09-19 21:04:18 +00003558 !PyUnicode_Check(prog) &&
Guido van Rossumb209a111997-04-29 18:18:01 +00003559 !PyCode_Check(prog) &&
3560 !PyFile_Check(prog)) {
3561 PyErr_SetString(PyExc_TypeError,
Guido van Rossumac7be682001-01-17 15:42:30 +00003562 "exec: arg 1 must be a string, file, or code object");
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003563 return -1;
3564 }
Fred Drake661ea262000-10-24 19:57:45 +00003565 if (!PyDict_Check(globals)) {
Guido van Rossumb209a111997-04-29 18:18:01 +00003566 PyErr_SetString(PyExc_TypeError,
Fred Drake661ea262000-10-24 19:57:45 +00003567 "exec: arg 2 must be a dictionary or None");
3568 return -1;
3569 }
3570 if (!PyDict_Check(locals)) {
3571 PyErr_SetString(PyExc_TypeError,
3572 "exec: arg 3 must be a dictionary or None");
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003573 return -1;
3574 }
Guido van Rossumb209a111997-04-29 18:18:01 +00003575 if (PyDict_GetItemString(globals, "__builtins__") == NULL)
Guido van Rossuma027efa1997-05-05 20:56:21 +00003576 PyDict_SetItemString(globals, "__builtins__", f->f_builtins);
Guido van Rossumb209a111997-04-29 18:18:01 +00003577 if (PyCode_Check(prog)) {
Guido van Rossuma400d8a2000-01-12 22:45:54 +00003578 v = PyEval_EvalCode((PyCodeObject *) prog, globals, locals);
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003579 }
Guido van Rossuma400d8a2000-01-12 22:45:54 +00003580 else if (PyFile_Check(prog)) {
Guido van Rossumb209a111997-04-29 18:18:01 +00003581 FILE *fp = PyFile_AsFile(prog);
3582 char *name = PyString_AsString(PyFile_Name(prog));
Tim Peters5ba58662001-07-16 02:29:45 +00003583 PyCompilerFlags cf;
3584 cf.cf_flags = 0;
3585 if (PyEval_MergeCompilerFlags(&cf))
Jeremy Hyltonbc320242001-03-22 02:47:58 +00003586 v = PyRun_FileFlags(fp, name, Py_file_input, globals,
3587 locals, &cf);
Tim Peters5ba58662001-07-16 02:29:45 +00003588 else
Jeremy Hyltonbc320242001-03-22 02:47:58 +00003589 v = PyRun_File(fp, name, Py_file_input, globals,
3590 locals);
Guido van Rossuma400d8a2000-01-12 22:45:54 +00003591 }
3592 else {
Marc-André Lemburgd1ba4432000-09-19 21:04:18 +00003593 char *str;
Tim Peters5ba58662001-07-16 02:29:45 +00003594 PyCompilerFlags cf;
Marc-André Lemburgd1ba4432000-09-19 21:04:18 +00003595 if (PyString_AsStringAndSize(prog, &str, NULL))
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003596 return -1;
Tim Peters5ba58662001-07-16 02:29:45 +00003597 cf.cf_flags = 0;
3598 if (PyEval_MergeCompilerFlags(&cf))
Jeremy Hyltonbc320242001-03-22 02:47:58 +00003599 v = PyRun_StringFlags(str, Py_file_input, globals,
3600 locals, &cf);
Tim Peters5ba58662001-07-16 02:29:45 +00003601 else
Jeremy Hyltonbc320242001-03-22 02:47:58 +00003602 v = PyRun_String(str, Py_file_input, globals, locals);
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003603 }
Guido van Rossuma400d8a2000-01-12 22:45:54 +00003604 if (plain)
3605 PyFrame_LocalsToFast(f, 0);
Guido van Rossum681d79a1995-07-18 14:51:37 +00003606 if (v == NULL)
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003607 return -1;
Guido van Rossumb209a111997-04-29 18:18:01 +00003608 Py_DECREF(v);
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003609 return 0;
3610}
Guido van Rossum24c13741995-02-14 09:42:43 +00003611
Guido van Rossumac7be682001-01-17 15:42:30 +00003612static void
Paul Prescode68140d2000-08-30 20:25:01 +00003613format_exc_check_arg(PyObject *exc, char *format_str, PyObject *obj)
3614{
3615 char *obj_str;
3616
3617 if (!obj)
3618 return;
3619
3620 obj_str = PyString_AsString(obj);
3621 if (!obj_str)
3622 return;
3623
3624 PyErr_Format(exc, format_str, obj_str);
3625}
Guido van Rossum950361c1997-01-24 13:49:28 +00003626
3627#ifdef DYNAMIC_EXECUTION_PROFILE
3628
3629PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003630getarray(long a[256])
Guido van Rossum950361c1997-01-24 13:49:28 +00003631{
3632 int i;
3633 PyObject *l = PyList_New(256);
3634 if (l == NULL) return NULL;
3635 for (i = 0; i < 256; i++) {
3636 PyObject *x = PyInt_FromLong(a[i]);
3637 if (x == NULL) {
3638 Py_DECREF(l);
3639 return NULL;
3640 }
3641 PyList_SetItem(l, i, x);
3642 }
3643 for (i = 0; i < 256; i++)
3644 a[i] = 0;
3645 return l;
3646}
3647
3648PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003649_Py_GetDXProfile(PyObject *self, PyObject *args)
Guido van Rossum950361c1997-01-24 13:49:28 +00003650{
3651#ifndef DXPAIRS
3652 return getarray(dxp);
3653#else
3654 int i;
3655 PyObject *l = PyList_New(257);
3656 if (l == NULL) return NULL;
3657 for (i = 0; i < 257; i++) {
3658 PyObject *x = getarray(dxpairs[i]);
3659 if (x == NULL) {
3660 Py_DECREF(l);
3661 return NULL;
3662 }
3663 PyList_SetItem(l, i, x);
3664 }
3665 return l;
3666#endif
3667}
3668
3669#endif