blob: bbbdcf3455a7928b04a15ee3aabc3d61306a1a7b [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
Tim Peters6d6c1a32001-08-02 04:15:00 +0000195static struct memberlist gen_memberlist[] = {
196 {"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. */
Guido van Rossum66b0e9c2001-03-21 19:17:22 +00002220 PyFrame_BlockSetup(f, b->b_type, b->b_level,
Jeremy Hylton3faa52e2001-02-01 22:48:12 +00002221 b->b_handler);
2222 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 }
Guido van Rossum1ae940a1995-01-02 19:04:15 +00002258 PUSH(tb);
Guido van Rossum374a9221991-04-04 10:40:29 +00002259 PUSH(val);
2260 PUSH(exc);
2261 }
2262 else {
Jeremy Hylton3faa52e2001-02-01 22:48:12 +00002263 if (why == WHY_RETURN ||
2264 why == CONTINUE_LOOP)
Guido van Rossum374a9221991-04-04 10:40:29 +00002265 PUSH(retval);
Guido van Rossumb209a111997-04-29 18:18:01 +00002266 v = PyInt_FromLong((long)why);
Guido van Rossum374a9221991-04-04 10:40:29 +00002267 PUSH(v);
2268 }
2269 why = WHY_NOT;
2270 JUMPTO(b->b_handler);
2271 break;
2272 }
2273 } /* unwind stack */
2274
2275 /* End the loop if we still have an error (or return) */
Guido van Rossumac7be682001-01-17 15:42:30 +00002276
Guido van Rossum374a9221991-04-04 10:40:29 +00002277 if (why != WHY_NOT)
2278 break;
Guido van Rossumac7be682001-01-17 15:42:30 +00002279
Guido van Rossum374a9221991-04-04 10:40:29 +00002280 } /* main loop */
Guido van Rossumac7be682001-01-17 15:42:30 +00002281
Tim Peters5ca576e2001-06-18 22:08:13 +00002282 if (why != WHY_RETURN && why != WHY_YIELD)
Guido van Rossum96a42c81992-01-12 02:29:51 +00002283 retval = NULL;
Guido van Rossumac7be682001-01-17 15:42:30 +00002284
Fred Drake9e3ad782001-07-03 23:39:52 +00002285 if (tstate->use_tracing) {
2286 if (tstate->c_tracefunc
2287 && (why == WHY_RETURN || why == WHY_YIELD)) {
2288 if (call_trace(tstate->c_tracefunc,
2289 tstate->c_traceobj, f,
2290 PyTrace_RETURN, retval)) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002291 Py_XDECREF(retval);
Guido van Rossum96a42c81992-01-12 02:29:51 +00002292 retval = NULL;
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002293 why = WHY_EXCEPTION;
Guido van Rossum96a42c81992-01-12 02:29:51 +00002294 }
Guido van Rossum96a42c81992-01-12 02:29:51 +00002295 }
Fred Drake9e3ad782001-07-03 23:39:52 +00002296 if (tstate->c_profilefunc
2297 && (why == WHY_RETURN || why == WHY_YIELD)) {
2298 if (call_trace(tstate->c_profilefunc,
2299 tstate->c_profileobj, f,
2300 PyTrace_RETURN, retval)) {
2301 Py_XDECREF(retval);
2302 retval = NULL;
2303 why = WHY_EXCEPTION;
2304 }
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002305 }
Guido van Rossum96a42c81992-01-12 02:29:51 +00002306 }
Guido van Rossuma4240131997-01-21 21:18:36 +00002307
Guido van Rossuma027efa1997-05-05 20:56:21 +00002308 reset_exc_info(tstate);
2309
Tim Peters5ca576e2001-06-18 22:08:13 +00002310 /* pop frame */
Guido van Rossuma027efa1997-05-05 20:56:21 +00002311 --tstate->recursion_depth;
Guido van Rossuma027efa1997-05-05 20:56:21 +00002312 tstate->frame = f->f_back;
Guido van Rossumac7be682001-01-17 15:42:30 +00002313
Guido van Rossum96a42c81992-01-12 02:29:51 +00002314 return retval;
Guido van Rossum374a9221991-04-04 10:40:29 +00002315}
2316
Tim Peters6d6c1a32001-08-02 04:15:00 +00002317PyObject *
2318PyEval_EvalCodeEx(PyCodeObject *co, PyObject *globals, PyObject *locals,
Tim Peters5ca576e2001-06-18 22:08:13 +00002319 PyObject **args, int argcount, PyObject **kws, int kwcount,
2320 PyObject **defs, int defcount, PyObject *closure)
2321{
2322 register PyFrameObject *f;
2323 register PyObject *retval = NULL;
2324 register PyObject **fastlocals, **freevars;
2325 PyThreadState *tstate = PyThreadState_GET();
2326 PyObject *x, *u;
2327
2328 if (globals == NULL) {
Jeremy Hylton910d7d42001-08-12 21:52:24 +00002329 PyErr_SetString(PyExc_SystemError,
2330 "PyEval_EvalCodeEx: NULL globals");
Tim Peters5ca576e2001-06-18 22:08:13 +00002331 return NULL;
2332 }
2333
2334 f = PyFrame_New(tstate, /*back*/
2335 co, /*code*/
2336 globals, locals);
2337 if (f == NULL)
2338 return NULL;
2339
2340 fastlocals = f->f_localsplus;
2341 freevars = f->f_localsplus + f->f_nlocals;
2342
2343 if (co->co_argcount > 0 ||
2344 co->co_flags & (CO_VARARGS | CO_VARKEYWORDS)) {
2345 int i;
2346 int n = argcount;
2347 PyObject *kwdict = NULL;
2348 if (co->co_flags & CO_VARKEYWORDS) {
2349 kwdict = PyDict_New();
2350 if (kwdict == NULL)
2351 goto fail;
2352 i = co->co_argcount;
2353 if (co->co_flags & CO_VARARGS)
2354 i++;
2355 SETLOCAL(i, kwdict);
2356 }
2357 if (argcount > co->co_argcount) {
2358 if (!(co->co_flags & CO_VARARGS)) {
2359 PyErr_Format(PyExc_TypeError,
2360 "%.200s() takes %s %d "
2361 "%sargument%s (%d given)",
2362 PyString_AsString(co->co_name),
2363 defcount ? "at most" : "exactly",
2364 co->co_argcount,
2365 kwcount ? "non-keyword " : "",
2366 co->co_argcount == 1 ? "" : "s",
2367 argcount);
2368 goto fail;
2369 }
2370 n = co->co_argcount;
2371 }
2372 for (i = 0; i < n; i++) {
2373 x = args[i];
2374 Py_INCREF(x);
2375 SETLOCAL(i, x);
2376 }
2377 if (co->co_flags & CO_VARARGS) {
2378 u = PyTuple_New(argcount - n);
2379 if (u == NULL)
2380 goto fail;
2381 SETLOCAL(co->co_argcount, u);
2382 for (i = n; i < argcount; i++) {
2383 x = args[i];
2384 Py_INCREF(x);
2385 PyTuple_SET_ITEM(u, i-n, x);
2386 }
2387 }
2388 for (i = 0; i < kwcount; i++) {
2389 PyObject *keyword = kws[2*i];
2390 PyObject *value = kws[2*i + 1];
2391 int j;
2392 if (keyword == NULL || !PyString_Check(keyword)) {
2393 PyErr_Format(PyExc_TypeError,
2394 "%.200s() keywords must be strings",
2395 PyString_AsString(co->co_name));
2396 goto fail;
2397 }
2398 /* XXX slow -- speed up using dictionary? */
2399 for (j = 0; j < co->co_argcount; j++) {
2400 PyObject *nm = PyTuple_GET_ITEM(
2401 co->co_varnames, j);
2402 int cmp = PyObject_RichCompareBool(
2403 keyword, nm, Py_EQ);
2404 if (cmp > 0)
2405 break;
2406 else if (cmp < 0)
2407 goto fail;
2408 }
2409 /* Check errors from Compare */
2410 if (PyErr_Occurred())
2411 goto fail;
2412 if (j >= co->co_argcount) {
2413 if (kwdict == NULL) {
2414 PyErr_Format(PyExc_TypeError,
2415 "%.200s() got an unexpected "
2416 "keyword argument '%.400s'",
2417 PyString_AsString(co->co_name),
2418 PyString_AsString(keyword));
2419 goto fail;
2420 }
2421 PyDict_SetItem(kwdict, keyword, value);
2422 }
2423 else {
2424 if (GETLOCAL(j) != NULL) {
2425 PyErr_Format(PyExc_TypeError,
2426 "%.200s() got multiple "
2427 "values for keyword "
2428 "argument '%.400s'",
2429 PyString_AsString(co->co_name),
2430 PyString_AsString(keyword));
2431 goto fail;
2432 }
2433 Py_INCREF(value);
2434 SETLOCAL(j, value);
2435 }
2436 }
2437 if (argcount < co->co_argcount) {
2438 int m = co->co_argcount - defcount;
2439 for (i = argcount; i < m; i++) {
2440 if (GETLOCAL(i) == NULL) {
2441 PyErr_Format(PyExc_TypeError,
2442 "%.200s() takes %s %d "
2443 "%sargument%s (%d given)",
2444 PyString_AsString(co->co_name),
2445 ((co->co_flags & CO_VARARGS) ||
2446 defcount) ? "at least"
2447 : "exactly",
2448 m, kwcount ? "non-keyword " : "",
2449 m == 1 ? "" : "s", i);
2450 goto fail;
2451 }
2452 }
2453 if (n > m)
2454 i = n - m;
2455 else
2456 i = 0;
2457 for (; i < defcount; i++) {
2458 if (GETLOCAL(m+i) == NULL) {
2459 PyObject *def = defs[i];
2460 Py_INCREF(def);
2461 SETLOCAL(m+i, def);
2462 }
2463 }
2464 }
2465 }
2466 else {
2467 if (argcount > 0 || kwcount > 0) {
2468 PyErr_Format(PyExc_TypeError,
2469 "%.200s() takes no arguments (%d given)",
2470 PyString_AsString(co->co_name),
2471 argcount + kwcount);
2472 goto fail;
2473 }
2474 }
2475 /* Allocate and initialize storage for cell vars, and copy free
2476 vars into frame. This isn't too efficient right now. */
2477 if (f->f_ncells) {
2478 int i = 0, j = 0, nargs, found;
2479 char *cellname, *argname;
2480 PyObject *c;
2481
2482 nargs = co->co_argcount;
2483 if (co->co_flags & CO_VARARGS)
2484 nargs++;
2485 if (co->co_flags & CO_VARKEYWORDS)
2486 nargs++;
2487
2488 /* Check for cells that shadow args */
2489 for (i = 0; i < f->f_ncells && j < nargs; ++i) {
2490 cellname = PyString_AS_STRING(
2491 PyTuple_GET_ITEM(co->co_cellvars, i));
2492 found = 0;
2493 while (j < nargs) {
2494 argname = PyString_AS_STRING(
2495 PyTuple_GET_ITEM(co->co_varnames, j));
2496 if (strcmp(cellname, argname) == 0) {
2497 c = PyCell_New(GETLOCAL(j));
2498 if (c == NULL)
2499 goto fail;
2500 GETLOCAL(f->f_nlocals + i) = c;
2501 found = 1;
2502 break;
2503 }
2504 j++;
2505 }
2506 if (found == 0) {
2507 c = PyCell_New(NULL);
2508 if (c == NULL)
2509 goto fail;
2510 SETLOCAL(f->f_nlocals + i, c);
2511 }
2512 }
2513 /* Initialize any that are left */
2514 while (i < f->f_ncells) {
2515 c = PyCell_New(NULL);
2516 if (c == NULL)
2517 goto fail;
2518 SETLOCAL(f->f_nlocals + i, c);
2519 i++;
2520 }
2521 }
2522 if (f->f_nfreevars) {
2523 int i;
2524 for (i = 0; i < f->f_nfreevars; ++i) {
2525 PyObject *o = PyTuple_GET_ITEM(closure, i);
2526 Py_INCREF(o);
2527 freevars[f->f_ncells + i] = o;
2528 }
2529 }
2530
Tim Peters5ca576e2001-06-18 22:08:13 +00002531 if (co->co_flags & CO_GENERATOR) {
Neil Schemenauer2b13ce82001-06-21 02:41:10 +00002532 /* Don't need to keep the reference to f_back, it will be set
2533 * when the generator is resumed. */
Tim Peters5ba58662001-07-16 02:29:45 +00002534 Py_XDECREF(f->f_back);
Neil Schemenauer2b13ce82001-06-21 02:41:10 +00002535 f->f_back = NULL;
2536
2537 /* Create a new generator that owns the ready to run frame
2538 * and return that as the value. */
Tim Peters5ca576e2001-06-18 22:08:13 +00002539 return gen_new(f);
2540 }
2541
2542 retval = eval_frame(f);
2543
2544 fail: /* Jump here from prelude on failure */
2545
2546 Py_DECREF(f);
2547 return retval;
2548}
2549
2550
Guido van Rossuma027efa1997-05-05 20:56:21 +00002551static void
Guido van Rossumac7be682001-01-17 15:42:30 +00002552set_exc_info(PyThreadState *tstate,
2553 PyObject *type, PyObject *value, PyObject *tb)
Guido van Rossuma027efa1997-05-05 20:56:21 +00002554{
2555 PyFrameObject *frame;
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002556 PyObject *tmp_type, *tmp_value, *tmp_tb;
Barry Warsaw4249f541997-08-22 21:26:19 +00002557
Guido van Rossuma027efa1997-05-05 20:56:21 +00002558 frame = tstate->frame;
2559 if (frame->f_exc_type == NULL) {
2560 /* This frame didn't catch an exception before */
2561 /* Save previous exception of this thread in this frame */
Guido van Rossuma027efa1997-05-05 20:56:21 +00002562 if (tstate->exc_type == NULL) {
2563 Py_INCREF(Py_None);
2564 tstate->exc_type = Py_None;
2565 }
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002566 tmp_type = frame->f_exc_type;
2567 tmp_value = frame->f_exc_value;
2568 tmp_tb = frame->f_exc_traceback;
Guido van Rossuma027efa1997-05-05 20:56:21 +00002569 Py_XINCREF(tstate->exc_type);
2570 Py_XINCREF(tstate->exc_value);
2571 Py_XINCREF(tstate->exc_traceback);
2572 frame->f_exc_type = tstate->exc_type;
2573 frame->f_exc_value = tstate->exc_value;
2574 frame->f_exc_traceback = tstate->exc_traceback;
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002575 Py_XDECREF(tmp_type);
2576 Py_XDECREF(tmp_value);
2577 Py_XDECREF(tmp_tb);
Guido van Rossuma027efa1997-05-05 20:56:21 +00002578 }
2579 /* Set new exception for this thread */
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002580 tmp_type = tstate->exc_type;
2581 tmp_value = tstate->exc_value;
2582 tmp_tb = tstate->exc_traceback;
Guido van Rossuma027efa1997-05-05 20:56:21 +00002583 Py_XINCREF(type);
2584 Py_XINCREF(value);
2585 Py_XINCREF(tb);
2586 tstate->exc_type = type;
2587 tstate->exc_value = value;
2588 tstate->exc_traceback = tb;
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002589 Py_XDECREF(tmp_type);
2590 Py_XDECREF(tmp_value);
2591 Py_XDECREF(tmp_tb);
Guido van Rossuma027efa1997-05-05 20:56:21 +00002592 /* For b/w compatibility */
2593 PySys_SetObject("exc_type", type);
2594 PySys_SetObject("exc_value", value);
2595 PySys_SetObject("exc_traceback", tb);
2596}
2597
2598static void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002599reset_exc_info(PyThreadState *tstate)
Guido van Rossuma027efa1997-05-05 20:56:21 +00002600{
2601 PyFrameObject *frame;
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002602 PyObject *tmp_type, *tmp_value, *tmp_tb;
Guido van Rossuma027efa1997-05-05 20:56:21 +00002603 frame = tstate->frame;
2604 if (frame->f_exc_type != NULL) {
2605 /* This frame caught an exception */
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002606 tmp_type = tstate->exc_type;
2607 tmp_value = tstate->exc_value;
2608 tmp_tb = tstate->exc_traceback;
Guido van Rossuma027efa1997-05-05 20:56:21 +00002609 Py_XINCREF(frame->f_exc_type);
2610 Py_XINCREF(frame->f_exc_value);
2611 Py_XINCREF(frame->f_exc_traceback);
2612 tstate->exc_type = frame->f_exc_type;
2613 tstate->exc_value = frame->f_exc_value;
2614 tstate->exc_traceback = frame->f_exc_traceback;
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002615 Py_XDECREF(tmp_type);
2616 Py_XDECREF(tmp_value);
2617 Py_XDECREF(tmp_tb);
Guido van Rossuma027efa1997-05-05 20:56:21 +00002618 /* For b/w compatibility */
2619 PySys_SetObject("exc_type", frame->f_exc_type);
2620 PySys_SetObject("exc_value", frame->f_exc_value);
2621 PySys_SetObject("exc_traceback", frame->f_exc_traceback);
2622 }
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002623 tmp_type = frame->f_exc_type;
2624 tmp_value = frame->f_exc_value;
2625 tmp_tb = frame->f_exc_traceback;
Guido van Rossuma027efa1997-05-05 20:56:21 +00002626 frame->f_exc_type = NULL;
2627 frame->f_exc_value = NULL;
2628 frame->f_exc_traceback = NULL;
Guido van Rossumdf4c3081997-05-20 17:06:11 +00002629 Py_XDECREF(tmp_type);
2630 Py_XDECREF(tmp_value);
2631 Py_XDECREF(tmp_tb);
Guido van Rossuma027efa1997-05-05 20:56:21 +00002632}
2633
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002634/* Logic for the raise statement (too complicated for inlining).
2635 This *consumes* a reference count to each of its arguments. */
Guido van Rossum1aa14831997-01-21 05:34:20 +00002636static enum why_code
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002637do_raise(PyObject *type, PyObject *value, PyObject *tb)
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002638{
Guido van Rossumd295f121998-04-09 21:39:57 +00002639 if (type == NULL) {
2640 /* Reraise */
2641 PyThreadState *tstate = PyThreadState_Get();
2642 type = tstate->exc_type == NULL ? Py_None : tstate->exc_type;
2643 value = tstate->exc_value;
2644 tb = tstate->exc_traceback;
2645 Py_XINCREF(type);
2646 Py_XINCREF(value);
2647 Py_XINCREF(tb);
2648 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002649
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002650 /* We support the following forms of raise:
2651 raise <class>, <classinstance>
2652 raise <class>, <argument tuple>
2653 raise <class>, None
2654 raise <class>, <argument>
2655 raise <classinstance>, None
2656 raise <string>, <object>
2657 raise <string>, None
2658
2659 An omitted second argument is the same as None.
2660
2661 In addition, raise <tuple>, <anything> is the same as
2662 raising the tuple's first item (and it better have one!);
2663 this rule is applied recursively.
2664
2665 Finally, an optional third argument can be supplied, which
2666 gives the traceback to be substituted (useful when
2667 re-raising an exception after examining it). */
2668
2669 /* First, check the traceback argument, replacing None with
2670 NULL. */
Guido van Rossumb209a111997-04-29 18:18:01 +00002671 if (tb == Py_None) {
2672 Py_DECREF(tb);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002673 tb = NULL;
2674 }
2675 else if (tb != NULL && !PyTraceBack_Check(tb)) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002676 PyErr_SetString(PyExc_TypeError,
Fred Drake661ea262000-10-24 19:57:45 +00002677 "raise: arg 3 must be a traceback or None");
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002678 goto raise_error;
2679 }
2680
2681 /* Next, replace a missing value with None */
2682 if (value == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002683 value = Py_None;
2684 Py_INCREF(value);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002685 }
2686
2687 /* Next, repeatedly, replace a tuple exception with its first item */
Guido van Rossumb209a111997-04-29 18:18:01 +00002688 while (PyTuple_Check(type) && PyTuple_Size(type) > 0) {
2689 PyObject *tmp = type;
2690 type = PyTuple_GET_ITEM(type, 0);
2691 Py_INCREF(type);
2692 Py_DECREF(tmp);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002693 }
2694
Barry Warsaw4249f541997-08-22 21:26:19 +00002695 if (PyString_Check(type))
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002696 ;
Barry Warsaw4249f541997-08-22 21:26:19 +00002697
2698 else if (PyClass_Check(type))
2699 PyErr_NormalizeException(&type, &value, &tb);
2700
Guido van Rossumb209a111997-04-29 18:18:01 +00002701 else if (PyInstance_Check(type)) {
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002702 /* Raising an instance. The value should be a dummy. */
Guido van Rossumb209a111997-04-29 18:18:01 +00002703 if (value != Py_None) {
2704 PyErr_SetString(PyExc_TypeError,
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002705 "instance exception may not have a separate value");
2706 goto raise_error;
2707 }
2708 else {
2709 /* Normalize to raise <class>, <instance> */
Guido van Rossumb209a111997-04-29 18:18:01 +00002710 Py_DECREF(value);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002711 value = type;
Guido van Rossumb209a111997-04-29 18:18:01 +00002712 type = (PyObject*) ((PyInstanceObject*)type)->in_class;
2713 Py_INCREF(type);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002714 }
2715 }
2716 else {
2717 /* Not something you can raise. You get an exception
2718 anyway, just not what you specified :-) */
Jeremy Hylton960d9482001-04-27 02:25:33 +00002719 PyErr_Format(PyExc_TypeError,
2720 "exceptions must be strings, classes, or "
2721 "instances, not %s", type->ob_type->tp_name);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002722 goto raise_error;
2723 }
Guido van Rossumb209a111997-04-29 18:18:01 +00002724 PyErr_Restore(type, value, tb);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002725 if (tb == NULL)
2726 return WHY_EXCEPTION;
2727 else
2728 return WHY_RERAISE;
2729 raise_error:
Guido van Rossumb209a111997-04-29 18:18:01 +00002730 Py_XDECREF(value);
2731 Py_XDECREF(type);
2732 Py_XDECREF(tb);
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00002733 return WHY_EXCEPTION;
2734}
2735
Tim Petersd6d010b2001-06-21 02:49:55 +00002736/* Iterate v argcnt times and store the results on the stack (via decreasing
2737 sp). Return 1 for success, 0 if error. */
2738
Barry Warsawe42b18f1997-08-25 22:13:04 +00002739static int
Tim Petersd6d010b2001-06-21 02:49:55 +00002740unpack_iterable(PyObject *v, int argcnt, PyObject **sp)
Barry Warsawe42b18f1997-08-25 22:13:04 +00002741{
Tim Petersd6d010b2001-06-21 02:49:55 +00002742 int i = 0;
2743 PyObject *it; /* iter(v) */
Barry Warsawe42b18f1997-08-25 22:13:04 +00002744 PyObject *w;
Guido van Rossumac7be682001-01-17 15:42:30 +00002745
Tim Petersd6d010b2001-06-21 02:49:55 +00002746 assert(v != NULL);
2747
2748 it = PyObject_GetIter(v);
2749 if (it == NULL)
2750 goto Error;
2751
2752 for (; i < argcnt; i++) {
2753 w = PyIter_Next(it);
2754 if (w == NULL) {
2755 /* Iterator done, via error or exhaustion. */
2756 if (!PyErr_Occurred()) {
2757 PyErr_Format(PyExc_ValueError,
2758 "need more than %d value%s to unpack",
2759 i, i == 1 ? "" : "s");
2760 }
2761 goto Error;
Barry Warsawe42b18f1997-08-25 22:13:04 +00002762 }
2763 *--sp = w;
2764 }
Tim Petersd6d010b2001-06-21 02:49:55 +00002765
2766 /* We better have exhausted the iterator now. */
2767 w = PyIter_Next(it);
2768 if (w == NULL) {
2769 if (PyErr_Occurred())
2770 goto Error;
2771 Py_DECREF(it);
2772 return 1;
Barry Warsawe42b18f1997-08-25 22:13:04 +00002773 }
Tim Petersd6d010b2001-06-21 02:49:55 +00002774 PyErr_SetString(PyExc_ValueError, "too many values to unpack");
Barry Warsawe42b18f1997-08-25 22:13:04 +00002775 /* fall through */
Tim Petersd6d010b2001-06-21 02:49:55 +00002776Error:
Barry Warsaw91010551997-08-25 22:30:51 +00002777 for (; i > 0; i--, sp++)
2778 Py_DECREF(*sp);
Tim Petersd6d010b2001-06-21 02:49:55 +00002779 Py_XDECREF(it);
Barry Warsawe42b18f1997-08-25 22:13:04 +00002780 return 0;
2781}
2782
2783
Guido van Rossum96a42c81992-01-12 02:29:51 +00002784#ifdef LLTRACE
Guido van Rossum3f5da241990-12-20 15:06:42 +00002785static int
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002786prtrace(PyObject *v, char *str)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00002787{
Guido van Rossum3f5da241990-12-20 15:06:42 +00002788 printf("%s ", str);
Guido van Rossumb209a111997-04-29 18:18:01 +00002789 if (PyObject_Print(v, stdout, 0) != 0)
2790 PyErr_Clear(); /* Don't know what else to do */
Guido van Rossum3f5da241990-12-20 15:06:42 +00002791 printf("\n");
Guido van Rossumcc229ea2000-05-04 00:55:17 +00002792 return 1;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00002793}
Guido van Rossum3f5da241990-12-20 15:06:42 +00002794#endif
Guido van Rossum10dc2e81990-11-18 17:27:39 +00002795
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002796static void
Fred Drake5755ce62001-06-27 19:19:46 +00002797call_exc_trace(Py_tracefunc func, PyObject *self, PyFrameObject *f)
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002798{
Guido van Rossumb209a111997-04-29 18:18:01 +00002799 PyObject *type, *value, *traceback, *arg;
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002800 int err;
Guido van Rossumb209a111997-04-29 18:18:01 +00002801 PyErr_Fetch(&type, &value, &traceback);
Guido van Rossumbd9ccca1992-04-09 14:58:08 +00002802 if (value == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002803 value = Py_None;
2804 Py_INCREF(value);
Guido van Rossumbd9ccca1992-04-09 14:58:08 +00002805 }
Guido van Rossumb209a111997-04-29 18:18:01 +00002806 arg = Py_BuildValue("(OOO)", type, value, traceback);
Guido van Rossum1ae940a1995-01-02 19:04:15 +00002807 if (arg == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00002808 PyErr_Restore(type, value, traceback);
Guido van Rossum1ae940a1995-01-02 19:04:15 +00002809 return;
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002810 }
Fred Drake5755ce62001-06-27 19:19:46 +00002811 err = call_trace(func, self, f, PyTrace_EXCEPTION, arg);
Guido van Rossumb209a111997-04-29 18:18:01 +00002812 Py_DECREF(arg);
Guido van Rossum1ae940a1995-01-02 19:04:15 +00002813 if (err == 0)
Guido van Rossumb209a111997-04-29 18:18:01 +00002814 PyErr_Restore(type, value, traceback);
Guido van Rossum1ae940a1995-01-02 19:04:15 +00002815 else {
Guido van Rossumb209a111997-04-29 18:18:01 +00002816 Py_XDECREF(type);
2817 Py_XDECREF(value);
2818 Py_XDECREF(traceback);
Guido van Rossum1ae940a1995-01-02 19:04:15 +00002819 }
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002820}
2821
2822static int
Fred Drake5755ce62001-06-27 19:19:46 +00002823call_trace(Py_tracefunc func, PyObject *obj, PyFrameObject *frame,
2824 int what, PyObject *arg)
Guido van Rossum96a42c81992-01-12 02:29:51 +00002825{
Fred Drake5755ce62001-06-27 19:19:46 +00002826 register PyThreadState *tstate = frame->f_tstate;
2827 int result;
2828 if (tstate->tracing)
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00002829 return 0;
Guido van Rossuma027efa1997-05-05 20:56:21 +00002830 tstate->tracing++;
Fred Drake9e3ad782001-07-03 23:39:52 +00002831 tstate->use_tracing = 0;
Fred Drake5755ce62001-06-27 19:19:46 +00002832 result = func(obj, frame, what, arg);
Fred Drake9e3ad782001-07-03 23:39:52 +00002833 tstate->use_tracing = ((tstate->c_tracefunc != NULL)
2834 || (tstate->c_profilefunc != NULL));
Guido van Rossuma027efa1997-05-05 20:56:21 +00002835 tstate->tracing--;
Fred Drake5755ce62001-06-27 19:19:46 +00002836 return result;
Guido van Rossum96a42c81992-01-12 02:29:51 +00002837}
2838
Fred Drake5755ce62001-06-27 19:19:46 +00002839void
2840PyEval_SetProfile(Py_tracefunc func, PyObject *arg)
Fred Draked0838392001-06-16 21:02:31 +00002841{
Fred Drake5755ce62001-06-27 19:19:46 +00002842 PyThreadState *tstate = PyThreadState_Get();
2843 PyObject *temp = tstate->c_profileobj;
2844 Py_XINCREF(arg);
2845 tstate->c_profilefunc = NULL;
2846 tstate->c_profileobj = NULL;
Fred Drake9e3ad782001-07-03 23:39:52 +00002847 tstate->use_tracing = tstate->c_tracefunc != NULL;
Fred Drake5755ce62001-06-27 19:19:46 +00002848 Py_XDECREF(temp);
2849 tstate->c_profilefunc = func;
2850 tstate->c_profileobj = arg;
Fred Drake9e3ad782001-07-03 23:39:52 +00002851 tstate->use_tracing = (func != NULL) || (tstate->c_tracefunc != NULL);
Fred Drake5755ce62001-06-27 19:19:46 +00002852}
2853
2854void
2855PyEval_SetTrace(Py_tracefunc func, PyObject *arg)
2856{
2857 PyThreadState *tstate = PyThreadState_Get();
2858 PyObject *temp = tstate->c_traceobj;
2859 Py_XINCREF(arg);
2860 tstate->c_tracefunc = NULL;
2861 tstate->c_traceobj = NULL;
Fred Drake9e3ad782001-07-03 23:39:52 +00002862 tstate->use_tracing = tstate->c_profilefunc != NULL;
Fred Drake5755ce62001-06-27 19:19:46 +00002863 Py_XDECREF(temp);
2864 tstate->c_tracefunc = func;
2865 tstate->c_traceobj = arg;
Fred Drake9e3ad782001-07-03 23:39:52 +00002866 tstate->use_tracing = ((func != NULL)
2867 || (tstate->c_profilefunc != NULL));
Fred Draked0838392001-06-16 21:02:31 +00002868}
2869
Guido van Rossumb209a111997-04-29 18:18:01 +00002870PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002871PyEval_GetBuiltins(void)
Guido van Rossum6135a871995-01-09 17:53:26 +00002872{
Guido van Rossum25ce5661997-08-02 03:10:38 +00002873 PyThreadState *tstate = PyThreadState_Get();
2874 PyFrameObject *current_frame = tstate->frame;
Guido van Rossum6135a871995-01-09 17:53:26 +00002875 if (current_frame == NULL)
Guido van Rossum25ce5661997-08-02 03:10:38 +00002876 return tstate->interp->builtins;
Guido van Rossum6135a871995-01-09 17:53:26 +00002877 else
2878 return current_frame->f_builtins;
2879}
2880
Guido van Rossumb209a111997-04-29 18:18:01 +00002881PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002882PyEval_GetLocals(void)
Guido van Rossum5b722181993-03-30 17:46:03 +00002883{
Guido van Rossuma027efa1997-05-05 20:56:21 +00002884 PyFrameObject *current_frame = PyThreadState_Get()->frame;
Guido van Rossum5b722181993-03-30 17:46:03 +00002885 if (current_frame == NULL)
2886 return NULL;
Guido van Rossumb209a111997-04-29 18:18:01 +00002887 PyFrame_FastToLocals(current_frame);
Guido van Rossum5b722181993-03-30 17:46:03 +00002888 return current_frame->f_locals;
2889}
2890
Guido van Rossumb209a111997-04-29 18:18:01 +00002891PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002892PyEval_GetGlobals(void)
Guido van Rossum3f5da241990-12-20 15:06:42 +00002893{
Guido van Rossuma027efa1997-05-05 20:56:21 +00002894 PyFrameObject *current_frame = PyThreadState_Get()->frame;
Guido van Rossum3f5da241990-12-20 15:06:42 +00002895 if (current_frame == NULL)
2896 return NULL;
2897 else
2898 return current_frame->f_globals;
2899}
2900
Guido van Rossumb209a111997-04-29 18:18:01 +00002901PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002902PyEval_GetFrame(void)
Guido van Rossume59214e1994-08-30 08:01:59 +00002903{
Guido van Rossuma027efa1997-05-05 20:56:21 +00002904 PyFrameObject *current_frame = PyThreadState_Get()->frame;
Guido van Rossumb209a111997-04-29 18:18:01 +00002905 return (PyObject *)current_frame;
Guido van Rossume59214e1994-08-30 08:01:59 +00002906}
2907
Guido van Rossum6135a871995-01-09 17:53:26 +00002908int
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002909PyEval_GetRestricted(void)
Guido van Rossum6135a871995-01-09 17:53:26 +00002910{
Guido van Rossuma027efa1997-05-05 20:56:21 +00002911 PyFrameObject *current_frame = PyThreadState_Get()->frame;
Guido van Rossum6135a871995-01-09 17:53:26 +00002912 return current_frame == NULL ? 0 : current_frame->f_restricted;
2913}
2914
Guido van Rossumbe270261997-05-22 22:26:18 +00002915int
Tim Peters5ba58662001-07-16 02:29:45 +00002916PyEval_MergeCompilerFlags(PyCompilerFlags *cf)
Jeremy Hylton061d1062001-03-22 02:32:48 +00002917{
2918 PyFrameObject *current_frame = PyThreadState_Get()->frame;
Tim Peters5ba58662001-07-16 02:29:45 +00002919 int result = 0;
2920
2921 if (current_frame != NULL) {
2922 const int codeflags = current_frame->f_code->co_flags;
Tim Peterse2c18e92001-08-17 20:47:47 +00002923 const int compilerflags = codeflags & PyCF_MASK;
2924 if (compilerflags) {
Tim Peters5ba58662001-07-16 02:29:45 +00002925 result = 1;
Tim Peterse2c18e92001-08-17 20:47:47 +00002926 cf->cf_flags |= compilerflags;
Tim Peters5ba58662001-07-16 02:29:45 +00002927 }
2928 }
2929 return result;
Jeremy Hylton061d1062001-03-22 02:32:48 +00002930}
2931
2932int
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002933Py_FlushLine(void)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00002934{
Guido van Rossumb209a111997-04-29 18:18:01 +00002935 PyObject *f = PySys_GetObject("stdout");
Guido van Rossumbe270261997-05-22 22:26:18 +00002936 if (f == NULL)
2937 return 0;
2938 if (!PyFile_SoftSpace(f, 0))
2939 return 0;
2940 return PyFile_WriteString("\n", f);
Guido van Rossum10dc2e81990-11-18 17:27:39 +00002941}
2942
Guido van Rossum3f5da241990-12-20 15:06:42 +00002943
Guido van Rossum681d79a1995-07-18 14:51:37 +00002944/* External interface to call any callable object.
2945 The arg must be a tuple or NULL. */
Guido van Rossum83bf35c1991-07-27 21:32:34 +00002946
Guido van Rossumd7ed6831997-08-30 15:02:50 +00002947#undef PyEval_CallObject
2948/* for backward compatibility: export this interface */
2949
Guido van Rossumb209a111997-04-29 18:18:01 +00002950PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002951PyEval_CallObject(PyObject *func, PyObject *arg)
Guido van Rossum83bf35c1991-07-27 21:32:34 +00002952{
Guido van Rossumb209a111997-04-29 18:18:01 +00002953 return PyEval_CallObjectWithKeywords(func, arg, (PyObject *)NULL);
Guido van Rossum681d79a1995-07-18 14:51:37 +00002954}
Guido van Rossumd7ed6831997-08-30 15:02:50 +00002955#define PyEval_CallObject(func,arg) \
2956 PyEval_CallObjectWithKeywords(func, arg, (PyObject *)NULL)
Guido van Rossume59214e1994-08-30 08:01:59 +00002957
Guido van Rossumb209a111997-04-29 18:18:01 +00002958PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00002959PyEval_CallObjectWithKeywords(PyObject *func, PyObject *arg, PyObject *kw)
Guido van Rossum681d79a1995-07-18 14:51:37 +00002960{
Jeremy Hylton52820442001-01-03 23:52:36 +00002961 PyObject *result;
Guido van Rossum681d79a1995-07-18 14:51:37 +00002962
2963 if (arg == NULL)
Guido van Rossumb209a111997-04-29 18:18:01 +00002964 arg = PyTuple_New(0);
2965 else if (!PyTuple_Check(arg)) {
Guido van Rossuma027efa1997-05-05 20:56:21 +00002966 PyErr_SetString(PyExc_TypeError,
2967 "argument list must be a tuple");
Guido van Rossum681d79a1995-07-18 14:51:37 +00002968 return NULL;
2969 }
2970 else
Guido van Rossumb209a111997-04-29 18:18:01 +00002971 Py_INCREF(arg);
Guido van Rossum681d79a1995-07-18 14:51:37 +00002972
Guido van Rossumb209a111997-04-29 18:18:01 +00002973 if (kw != NULL && !PyDict_Check(kw)) {
Guido van Rossuma027efa1997-05-05 20:56:21 +00002974 PyErr_SetString(PyExc_TypeError,
2975 "keyword list must be a dictionary");
Guido van Rossum25826c92000-04-21 21:17:39 +00002976 Py_DECREF(arg);
Guido van Rossume3e61c11995-08-04 04:14:47 +00002977 return NULL;
2978 }
2979
Tim Peters6d6c1a32001-08-02 04:15:00 +00002980 result = PyObject_Call(func, arg, kw);
Guido van Rossumb209a111997-04-29 18:18:01 +00002981 Py_DECREF(arg);
Jeremy Hylton52820442001-01-03 23:52:36 +00002982 return result;
2983}
2984
Tim Peters6d6c1a32001-08-02 04:15:00 +00002985char *
2986PyEval_GetFuncName(PyObject *func)
Jeremy Hylton512a2372001-04-11 13:52:29 +00002987{
2988 if (PyMethod_Check(func))
Tim Peters6d6c1a32001-08-02 04:15:00 +00002989 return PyEval_GetFuncName(PyMethod_GET_FUNCTION(func));
Jeremy Hylton512a2372001-04-11 13:52:29 +00002990 else if (PyFunction_Check(func))
2991 return PyString_AsString(((PyFunctionObject*)func)->func_name);
2992 else if (PyCFunction_Check(func))
2993 return ((PyCFunctionObject*)func)->m_ml->ml_name;
2994 else if (PyClass_Check(func))
2995 return PyString_AsString(((PyClassObject*)func)->cl_name);
2996 else if (PyInstance_Check(func)) {
2997 return PyString_AsString(
2998 ((PyInstanceObject*)func)->in_class->cl_name);
2999 } else {
3000 return func->ob_type->tp_name;
3001 }
3002}
3003
Tim Peters6d6c1a32001-08-02 04:15:00 +00003004char *
3005PyEval_GetFuncDesc(PyObject *func)
Jeremy Hylton512a2372001-04-11 13:52:29 +00003006{
3007 if (PyMethod_Check(func))
3008 return "()";
3009 else if (PyFunction_Check(func))
3010 return "()";
3011 else if (PyCFunction_Check(func))
3012 return "()";
3013 else if (PyClass_Check(func))
3014 return " constructor";
3015 else if (PyInstance_Check(func)) {
3016 return " instance";
3017 } else {
3018 return " object";
3019 }
3020}
3021
Jeremy Hylton52820442001-01-03 23:52:36 +00003022#define EXT_POP(STACK_POINTER) (*--(STACK_POINTER))
3023
3024/* The two fast_xxx() functions optimize calls for which no argument
3025 tuple is necessary; the objects are passed directly from the stack.
3026 fast_cfunction() is called for METH_OLDARGS functions.
3027 fast_function() is for functions with no special argument handling.
3028*/
3029
3030static PyObject *
3031fast_cfunction(PyObject *func, PyObject ***pp_stack, int na)
3032{
3033 PyCFunction meth = PyCFunction_GET_FUNCTION(func);
3034 PyObject *self = PyCFunction_GET_SELF(func);
Martin v. Löwise3eb1f22001-08-16 13:15:00 +00003035 int flags = PyCFunction_GET_FLAGS(func);
Jeremy Hylton52820442001-01-03 23:52:36 +00003036
Martin v. Löwise3eb1f22001-08-16 13:15:00 +00003037 switch (flags) {
3038 case METH_OLDARGS:
3039 if (na == 0)
3040 return (*meth)(self, NULL);
3041 else if (na == 1) {
3042 PyObject *arg = EXT_POP(*pp_stack);
3043 PyObject *result = (*meth)(self, arg);
3044 Py_DECREF(arg);
3045 return result;
3046 } else {
3047 PyObject *args = load_args(pp_stack, na);
3048 PyObject *result = (*meth)(self, args);
3049 Py_DECREF(args);
3050 return result;
3051 }
Martin v. Löwise3eb1f22001-08-16 13:15:00 +00003052 case METH_NOARGS:
3053 if (na == 0)
3054 return (*meth)(self, NULL);
3055 PyErr_Format(PyExc_TypeError,
3056 "%.200s() takes no arguments (%d given)",
3057 ((PyCFunctionObject*)func)->m_ml->ml_name, na);
3058 return NULL;
Martin v. Löwise3eb1f22001-08-16 13:15:00 +00003059 case METH_O:
3060 if (na == 1) {
3061 PyObject *arg = EXT_POP(*pp_stack);
3062 PyObject *result = (*meth)(self, arg);
3063 Py_DECREF(arg);
3064 return result;
3065 }
3066 PyErr_Format(PyExc_TypeError,
3067 "%.200s() takes exactly one argument (%d given)",
3068 ((PyCFunctionObject*)func)->m_ml->ml_name, na);
3069 return NULL;
Martin v. Löwise3eb1f22001-08-16 13:15:00 +00003070 default:
3071 fprintf(stderr, "%.200s() flags = %d\n",
3072 ((PyCFunctionObject*)func)->m_ml->ml_name, flags);
3073 PyErr_BadInternalCall();
3074 return NULL;
3075 }
Jeremy Hylton52820442001-01-03 23:52:36 +00003076}
3077
3078static PyObject *
Guido van Rossumac7be682001-01-17 15:42:30 +00003079fast_function(PyObject *func, PyObject ***pp_stack, int n, int na, int nk)
Jeremy Hylton52820442001-01-03 23:52:36 +00003080{
3081 PyObject *co = PyFunction_GET_CODE(func);
3082 PyObject *globals = PyFunction_GET_GLOBALS(func);
3083 PyObject *argdefs = PyFunction_GET_DEFAULTS(func);
Jeremy Hylton64949cb2001-01-25 20:06:59 +00003084 PyObject *closure = PyFunction_GET_CLOSURE(func);
Jeremy Hylton52820442001-01-03 23:52:36 +00003085 PyObject **d = NULL;
3086 int nd = 0;
3087
3088 if (argdefs != NULL) {
3089 d = &PyTuple_GET_ITEM(argdefs, 0);
3090 nd = ((PyTupleObject *)argdefs)->ob_size;
3091 }
Tim Peters6d6c1a32001-08-02 04:15:00 +00003092 return PyEval_EvalCodeEx((PyCodeObject *)co, globals,
Jeremy Hylton52820442001-01-03 23:52:36 +00003093 (PyObject *)NULL, (*pp_stack)-n, na,
Jeremy Hylton64949cb2001-01-25 20:06:59 +00003094 (*pp_stack)-2*nk, nk, d, nd,
3095 closure);
Jeremy Hylton52820442001-01-03 23:52:36 +00003096}
3097
3098static PyObject *
Ka-Ping Yee20579702001-01-15 22:14:16 +00003099update_keyword_args(PyObject *orig_kwdict, int nk, PyObject ***pp_stack,
3100 PyObject *func)
Jeremy Hylton52820442001-01-03 23:52:36 +00003101{
3102 PyObject *kwdict = NULL;
3103 if (orig_kwdict == NULL)
3104 kwdict = PyDict_New();
3105 else {
3106 kwdict = PyDict_Copy(orig_kwdict);
3107 Py_DECREF(orig_kwdict);
3108 }
3109 if (kwdict == NULL)
3110 return NULL;
3111 while (--nk >= 0) {
3112 int err;
3113 PyObject *value = EXT_POP(*pp_stack);
3114 PyObject *key = EXT_POP(*pp_stack);
3115 if (PyDict_GetItem(kwdict, key) != NULL) {
Guido van Rossumac7be682001-01-17 15:42:30 +00003116 PyErr_Format(PyExc_TypeError,
Ka-Ping Yee20579702001-01-15 22:14:16 +00003117 "%.200s%s got multiple values "
Jeremy Hylton512a2372001-04-11 13:52:29 +00003118 "for keyword argument '%.200s'",
Tim Peters6d6c1a32001-08-02 04:15:00 +00003119 PyEval_GetFuncName(func),
3120 PyEval_GetFuncDesc(func),
Jeremy Hylton512a2372001-04-11 13:52:29 +00003121 PyString_AsString(key));
Jeremy Hylton52820442001-01-03 23:52:36 +00003122 Py_DECREF(key);
3123 Py_DECREF(value);
3124 Py_DECREF(kwdict);
3125 return NULL;
3126 }
3127 err = PyDict_SetItem(kwdict, key, value);
3128 Py_DECREF(key);
3129 Py_DECREF(value);
3130 if (err) {
3131 Py_DECREF(kwdict);
3132 return NULL;
3133 }
3134 }
3135 return kwdict;
3136}
3137
3138static PyObject *
3139update_star_args(int nstack, int nstar, PyObject *stararg,
3140 PyObject ***pp_stack)
3141{
3142 PyObject *callargs, *w;
3143
3144 callargs = PyTuple_New(nstack + nstar);
3145 if (callargs == NULL) {
3146 return NULL;
3147 }
3148 if (nstar) {
3149 int i;
3150 for (i = 0; i < nstar; i++) {
3151 PyObject *a = PyTuple_GET_ITEM(stararg, i);
3152 Py_INCREF(a);
3153 PyTuple_SET_ITEM(callargs, nstack + i, a);
3154 }
3155 }
3156 while (--nstack >= 0) {
3157 w = EXT_POP(*pp_stack);
3158 PyTuple_SET_ITEM(callargs, nstack, w);
3159 }
3160 return callargs;
3161}
3162
3163static PyObject *
3164load_args(PyObject ***pp_stack, int na)
3165{
3166 PyObject *args = PyTuple_New(na);
3167 PyObject *w;
3168
3169 if (args == NULL)
3170 return NULL;
3171 while (--na >= 0) {
3172 w = EXT_POP(*pp_stack);
3173 PyTuple_SET_ITEM(args, na, w);
3174 }
3175 return args;
3176}
3177
3178static PyObject *
3179do_call(PyObject *func, PyObject ***pp_stack, int na, int nk)
3180{
3181 PyObject *callargs = NULL;
3182 PyObject *kwdict = NULL;
3183 PyObject *result = NULL;
3184
3185 if (nk > 0) {
Ka-Ping Yee20579702001-01-15 22:14:16 +00003186 kwdict = update_keyword_args(NULL, nk, pp_stack, func);
Jeremy Hylton52820442001-01-03 23:52:36 +00003187 if (kwdict == NULL)
3188 goto call_fail;
3189 }
3190 callargs = load_args(pp_stack, na);
3191 if (callargs == NULL)
3192 goto call_fail;
Tim Peters6d6c1a32001-08-02 04:15:00 +00003193 result = PyObject_Call(func, callargs, kwdict);
Jeremy Hylton52820442001-01-03 23:52:36 +00003194 call_fail:
3195 Py_XDECREF(callargs);
3196 Py_XDECREF(kwdict);
3197 return result;
3198}
3199
3200static PyObject *
3201ext_do_call(PyObject *func, PyObject ***pp_stack, int flags, int na, int nk)
3202{
3203 int nstar = 0;
3204 PyObject *callargs = NULL;
3205 PyObject *stararg = NULL;
3206 PyObject *kwdict = NULL;
3207 PyObject *result = NULL;
3208
3209 if (flags & CALL_FLAG_KW) {
3210 kwdict = EXT_POP(*pp_stack);
3211 if (!(kwdict && PyDict_Check(kwdict))) {
Ka-Ping Yee20579702001-01-15 22:14:16 +00003212 PyErr_Format(PyExc_TypeError,
Jeremy Hylton512a2372001-04-11 13:52:29 +00003213 "%s%s argument after ** "
3214 "must be a dictionary",
Tim Peters6d6c1a32001-08-02 04:15:00 +00003215 PyEval_GetFuncName(func),
3216 PyEval_GetFuncDesc(func));
Jeremy Hylton52820442001-01-03 23:52:36 +00003217 goto ext_call_fail;
3218 }
3219 }
3220 if (flags & CALL_FLAG_VAR) {
3221 stararg = EXT_POP(*pp_stack);
3222 if (!PyTuple_Check(stararg)) {
3223 PyObject *t = NULL;
3224 t = PySequence_Tuple(stararg);
3225 if (t == NULL) {
Jeremy Hylton512a2372001-04-11 13:52:29 +00003226 if (PyErr_ExceptionMatches(PyExc_TypeError)) {
3227 PyErr_Format(PyExc_TypeError,
3228 "%s%s argument after * "
3229 "must be a sequence",
Tim Peters6d6c1a32001-08-02 04:15:00 +00003230 PyEval_GetFuncName(func),
3231 PyEval_GetFuncDesc(func));
Jeremy Hylton512a2372001-04-11 13:52:29 +00003232 }
Jeremy Hylton52820442001-01-03 23:52:36 +00003233 goto ext_call_fail;
3234 }
3235 Py_DECREF(stararg);
3236 stararg = t;
3237 }
3238 nstar = PyTuple_GET_SIZE(stararg);
3239 }
3240 if (nk > 0) {
Ka-Ping Yee20579702001-01-15 22:14:16 +00003241 kwdict = update_keyword_args(kwdict, nk, pp_stack, func);
Jeremy Hylton52820442001-01-03 23:52:36 +00003242 if (kwdict == NULL)
3243 goto ext_call_fail;
3244 }
3245 callargs = update_star_args(na, nstar, stararg, pp_stack);
3246 if (callargs == NULL)
3247 goto ext_call_fail;
Tim Peters6d6c1a32001-08-02 04:15:00 +00003248 result = PyObject_Call(func, callargs, kwdict);
Jeremy Hylton52820442001-01-03 23:52:36 +00003249 ext_call_fail:
3250 Py_XDECREF(callargs);
3251 Py_XDECREF(kwdict);
3252 Py_XDECREF(stararg);
3253 return result;
3254}
3255
Guido van Rossum3b9c6671996-07-30 18:40:29 +00003256#define SLICE_ERROR_MSG \
3257 "standard sequence type does not support step size other than one"
3258
Guido van Rossumb209a111997-04-29 18:18:01 +00003259static PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003260loop_subscript(PyObject *v, PyObject *w)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003261{
Guido van Rossumb209a111997-04-29 18:18:01 +00003262 PySequenceMethods *sq = v->ob_type->tp_as_sequence;
Guido van Rossume59214e1994-08-30 08:01:59 +00003263 int i;
Guido van Rossum7e33c6e1998-05-22 00:52:29 +00003264 if (sq == NULL || sq->sq_item == NULL) {
Guido van Rossumb209a111997-04-29 18:18:01 +00003265 PyErr_SetString(PyExc_TypeError, "loop over non-sequence");
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003266 return NULL;
3267 }
Guido van Rossumb209a111997-04-29 18:18:01 +00003268 i = PyInt_AsLong(w);
Guido van Rossume59214e1994-08-30 08:01:59 +00003269 v = (*sq->sq_item)(v, i);
3270 if (v)
3271 return v;
Barry Warsaw4249f541997-08-22 21:26:19 +00003272 if (PyErr_ExceptionMatches(PyExc_IndexError))
Guido van Rossumb209a111997-04-29 18:18:01 +00003273 PyErr_Clear();
Guido van Rossume59214e1994-08-30 08:01:59 +00003274 return NULL;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003275}
3276
Guido van Rossum20c6add2000-05-08 14:06:50 +00003277/* Extract a slice index from a PyInt or PyLong, the index is bound to
3278 the range [-INT_MAX+1, INTMAX]. Returns 0 and an exception if there is
3279 and error. Returns 1 on success.*/
3280
3281int
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003282_PyEval_SliceIndex(PyObject *v, int *pi)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003283{
3284 if (v != NULL) {
Guido van Rossuma027efa1997-05-05 20:56:21 +00003285 long x;
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003286 if (PyInt_Check(v)) {
3287 x = PyInt_AsLong(v);
3288 } else if (PyLong_Check(v)) {
3289 x = PyLong_AsLong(v);
3290 if (x==-1 && PyErr_Occurred()) {
3291 PyObject *long_zero;
Guido van Rossumac7be682001-01-17 15:42:30 +00003292 int cmp;
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003293
Guido van Rossumac7be682001-01-17 15:42:30 +00003294 if (!PyErr_ExceptionMatches(
3295 PyExc_OverflowError)) {
3296 /* It's not an overflow error, so just
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003297 signal an error */
Guido van Rossum20c6add2000-05-08 14:06:50 +00003298 return 0;
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003299 }
3300
Guido van Rossumac7be682001-01-17 15:42:30 +00003301 /* Clear the OverflowError */
3302 PyErr_Clear();
3303
3304 /* It's an overflow error, so we need to
3305 check the sign of the long integer,
3306 set the value to INT_MAX or 0, and clear
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003307 the error. */
3308
3309 /* Create a long integer with a value of 0 */
Guido van Rossumac7be682001-01-17 15:42:30 +00003310 long_zero = PyLong_FromLong(0L);
Guido van Rossum20c6add2000-05-08 14:06:50 +00003311 if (long_zero == NULL) return 0;
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003312
3313 /* Check sign */
Guido van Rossumac7be682001-01-17 15:42:30 +00003314 cmp = PyObject_RichCompareBool(v, long_zero,
3315 Py_GT);
3316 Py_DECREF(long_zero);
3317 if (cmp < 0)
3318 return 0;
3319 else if (cmp > 0)
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003320 x = INT_MAX;
3321 else
3322 x = 0;
Andrew M. Kuchling2194b162000-02-23 22:18:48 +00003323 }
3324 } else {
Guido van Rossuma027efa1997-05-05 20:56:21 +00003325 PyErr_SetString(PyExc_TypeError,
Fred Drake661ea262000-10-24 19:57:45 +00003326 "slice indices must be integers");
Guido van Rossum20c6add2000-05-08 14:06:50 +00003327 return 0;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003328 }
Guido van Rossuma027efa1997-05-05 20:56:21 +00003329 /* Truncate -- very long indices are truncated anyway */
3330 if (x > INT_MAX)
3331 x = INT_MAX;
3332 else if (x < -INT_MAX)
3333 x = 0;
3334 *pi = x;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003335 }
Guido van Rossum20c6add2000-05-08 14:06:50 +00003336 return 1;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003337}
3338
Guido van Rossum50d756e2001-08-18 17:43:36 +00003339#undef ISINT
3340#define ISINT(x) ((x) == NULL || PyInt_Check(x) || PyLong_Check(x))
3341
Guido van Rossumb209a111997-04-29 18:18:01 +00003342static PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003343apply_slice(PyObject *u, PyObject *v, PyObject *w) /* return u[v:w] */
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003344{
Guido van Rossum50d756e2001-08-18 17:43:36 +00003345 PyTypeObject *tp = u->ob_type;
3346 PySequenceMethods *sq = tp->tp_as_sequence;
3347
3348 if (sq && sq->sq_slice && ISINT(v) && ISINT(w)) {
3349 int ilow = 0, ihigh = INT_MAX;
3350 if (!_PyEval_SliceIndex(v, &ilow))
3351 return NULL;
3352 if (!_PyEval_SliceIndex(w, &ihigh))
3353 return NULL;
3354 return PySequence_GetSlice(u, ilow, ihigh);
3355 }
3356 else {
3357 PyObject *slice = PySlice_New(v, w, NULL);
3358 if (slice != NULL)
3359 return PyObject_GetItem(u, slice);
3360 else
3361 return NULL;
3362 }
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003363}
Guido van Rossum3f5da241990-12-20 15:06:42 +00003364
3365static int
Guido van Rossumac7be682001-01-17 15:42:30 +00003366assign_slice(PyObject *u, PyObject *v, PyObject *w, PyObject *x)
3367 /* u[v:w] = x */
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003368{
Guido van Rossum50d756e2001-08-18 17:43:36 +00003369 PyTypeObject *tp = u->ob_type;
3370 PySequenceMethods *sq = tp->tp_as_sequence;
3371
3372 if (sq && sq->sq_slice && ISINT(v) && ISINT(w)) {
3373 int ilow = 0, ihigh = INT_MAX;
3374 if (!_PyEval_SliceIndex(v, &ilow))
3375 return -1;
3376 if (!_PyEval_SliceIndex(w, &ihigh))
3377 return -1;
3378 if (x == NULL)
3379 return PySequence_DelSlice(u, ilow, ihigh);
3380 else
3381 return PySequence_SetSlice(u, ilow, ihigh, x);
3382 }
3383 else {
3384 PyObject *slice = PySlice_New(v, w, NULL);
3385 if (slice != NULL) {
3386 if (x != NULL)
3387 return PyObject_SetItem(u, slice, x);
3388 else
3389 return PyObject_DelItem(u, slice);
3390 }
3391 else
3392 return -1;
3393 }
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003394}
3395
Guido van Rossumb209a111997-04-29 18:18:01 +00003396static PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003397cmp_outcome(int op, register PyObject *v, register PyObject *w)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003398{
Guido van Rossumac7be682001-01-17 15:42:30 +00003399 int res = 0;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003400 switch (op) {
Guido van Rossum3f5da241990-12-20 15:06:42 +00003401 case IS:
3402 case IS_NOT:
3403 res = (v == w);
Guido van Rossum04691fc1992-08-12 15:35:34 +00003404 if (op == (int) IS_NOT)
Guido van Rossum3f5da241990-12-20 15:06:42 +00003405 res = !res;
3406 break;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003407 case IN:
3408 case NOT_IN:
Guido van Rossum7e33c6e1998-05-22 00:52:29 +00003409 res = PySequence_Contains(w, v);
Guido van Rossum3f5da241990-12-20 15:06:42 +00003410 if (res < 0)
3411 return NULL;
Guido van Rossum04691fc1992-08-12 15:35:34 +00003412 if (op == (int) NOT_IN)
Guido van Rossum3f5da241990-12-20 15:06:42 +00003413 res = !res;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003414 break;
3415 case EXC_MATCH:
Barry Warsaw4249f541997-08-22 21:26:19 +00003416 res = PyErr_GivenExceptionMatches(v, w);
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003417 break;
3418 default:
Guido van Rossumac7be682001-01-17 15:42:30 +00003419 return PyObject_RichCompare(v, w, op);
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003420 }
Guido van Rossumb209a111997-04-29 18:18:01 +00003421 v = res ? Py_True : Py_False;
3422 Py_INCREF(v);
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003423 return v;
3424}
3425
Thomas Wouters52152252000-08-17 22:55:00 +00003426static PyObject *
3427import_from(PyObject *v, PyObject *name)
Guido van Rossume9736fc1990-11-18 17:33:06 +00003428{
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00003429 PyObject *x;
3430
3431 x = PyObject_GetAttr(v, name);
3432 if (x == NULL && PyErr_ExceptionMatches(PyExc_AttributeError)) {
Thomas Wouters52152252000-08-17 22:55:00 +00003433 PyErr_Format(PyExc_ImportError,
3434 "cannot import name %.230s",
3435 PyString_AsString(name));
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00003436 }
Thomas Wouters52152252000-08-17 22:55:00 +00003437 return x;
3438}
Guido van Rossumac7be682001-01-17 15:42:30 +00003439
Thomas Wouters52152252000-08-17 22:55:00 +00003440static int
3441import_all_from(PyObject *locals, PyObject *v)
3442{
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00003443 PyObject *all = PyObject_GetAttrString(v, "__all__");
3444 PyObject *dict, *name, *value;
3445 int skip_leading_underscores = 0;
3446 int pos, err;
Thomas Wouters52152252000-08-17 22:55:00 +00003447
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00003448 if (all == NULL) {
3449 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
3450 return -1; /* Unexpected error */
3451 PyErr_Clear();
3452 dict = PyObject_GetAttrString(v, "__dict__");
3453 if (dict == NULL) {
3454 if (!PyErr_ExceptionMatches(PyExc_AttributeError))
3455 return -1;
3456 PyErr_SetString(PyExc_ImportError,
3457 "from-import-* object has no __dict__ and no __all__");
Guido van Rossum3f5da241990-12-20 15:06:42 +00003458 return -1;
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00003459 }
3460 all = PyMapping_Keys(dict);
3461 Py_DECREF(dict);
3462 if (all == NULL)
3463 return -1;
3464 skip_leading_underscores = 1;
Guido van Rossume9736fc1990-11-18 17:33:06 +00003465 }
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00003466
3467 for (pos = 0, err = 0; ; pos++) {
3468 name = PySequence_GetItem(all, pos);
3469 if (name == NULL) {
3470 if (!PyErr_ExceptionMatches(PyExc_IndexError))
3471 err = -1;
3472 else
3473 PyErr_Clear();
3474 break;
3475 }
3476 if (skip_leading_underscores &&
3477 PyString_Check(name) &&
3478 PyString_AS_STRING(name)[0] == '_')
3479 {
3480 Py_DECREF(name);
3481 continue;
3482 }
3483 value = PyObject_GetAttr(v, name);
3484 if (value == NULL)
3485 err = -1;
3486 else
3487 err = PyDict_SetItem(locals, name, value);
3488 Py_DECREF(name);
3489 Py_XDECREF(value);
3490 if (err != 0)
3491 break;
3492 }
3493 Py_DECREF(all);
3494 return err;
Guido van Rossume9736fc1990-11-18 17:33:06 +00003495}
3496
Guido van Rossumb209a111997-04-29 18:18:01 +00003497static PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003498build_class(PyObject *methods, PyObject *bases, PyObject *name)
Guido van Rossume9736fc1990-11-18 17:33:06 +00003499{
Guido van Rossum7851eea2001-09-12 19:19:18 +00003500 PyObject *metaclass = NULL, *result, *base;
Tim Peters6d6c1a32001-08-02 04:15:00 +00003501
3502 if (PyDict_Check(methods))
3503 metaclass = PyDict_GetItemString(methods, "__metaclass__");
Guido van Rossum7851eea2001-09-12 19:19:18 +00003504 if (metaclass != NULL)
3505 Py_INCREF(methods);
3506 else if (PyTuple_Check(bases) && PyTuple_GET_SIZE(bases) > 0) {
3507 base = PyTuple_GET_ITEM(bases, 0);
3508 metaclass = PyObject_GetAttrString(base, "__class__");
3509 if (metaclass == NULL) {
3510 PyErr_Clear();
3511 metaclass = (PyObject *)base->ob_type;
3512 Py_INCREF(metaclass);
Guido van Rossum25831651993-05-19 14:50:45 +00003513 }
3514 }
Guido van Rossum7851eea2001-09-12 19:19:18 +00003515 else {
3516 PyObject *g = PyEval_GetGlobals();
3517 if (g != NULL && PyDict_Check(g))
3518 metaclass = PyDict_GetItemString(g, "__metaclass__");
3519 if (metaclass == NULL)
3520 metaclass = (PyObject *) &PyClass_Type;
3521 Py_INCREF(metaclass);
3522 }
3523 result = PyObject_CallFunction(metaclass, "OOO", name, bases, methods);
3524 Py_DECREF(metaclass);
3525 return result;
Guido van Rossum25831651993-05-19 14:50:45 +00003526}
3527
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003528static int
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003529exec_statement(PyFrameObject *f, PyObject *prog, PyObject *globals,
3530 PyObject *locals)
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003531{
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003532 int n;
Guido van Rossumb209a111997-04-29 18:18:01 +00003533 PyObject *v;
Guido van Rossum681d79a1995-07-18 14:51:37 +00003534 int plain = 0;
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003535
Guido van Rossumb209a111997-04-29 18:18:01 +00003536 if (PyTuple_Check(prog) && globals == Py_None && locals == Py_None &&
3537 ((n = PyTuple_Size(prog)) == 2 || n == 3)) {
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003538 /* Backward compatibility hack */
Guido van Rossumb209a111997-04-29 18:18:01 +00003539 globals = PyTuple_GetItem(prog, 1);
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003540 if (n == 3)
Guido van Rossumb209a111997-04-29 18:18:01 +00003541 locals = PyTuple_GetItem(prog, 2);
3542 prog = PyTuple_GetItem(prog, 0);
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003543 }
Guido van Rossumb209a111997-04-29 18:18:01 +00003544 if (globals == Py_None) {
3545 globals = PyEval_GetGlobals();
3546 if (locals == Py_None) {
3547 locals = PyEval_GetLocals();
Guido van Rossum681d79a1995-07-18 14:51:37 +00003548 plain = 1;
3549 }
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003550 }
Guido van Rossumb209a111997-04-29 18:18:01 +00003551 else if (locals == Py_None)
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003552 locals = globals;
Guido van Rossumb209a111997-04-29 18:18:01 +00003553 if (!PyString_Check(prog) &&
Marc-André Lemburgd1ba4432000-09-19 21:04:18 +00003554 !PyUnicode_Check(prog) &&
Guido van Rossumb209a111997-04-29 18:18:01 +00003555 !PyCode_Check(prog) &&
3556 !PyFile_Check(prog)) {
3557 PyErr_SetString(PyExc_TypeError,
Guido van Rossumac7be682001-01-17 15:42:30 +00003558 "exec: arg 1 must be a string, file, or code object");
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003559 return -1;
3560 }
Fred Drake661ea262000-10-24 19:57:45 +00003561 if (!PyDict_Check(globals)) {
Guido van Rossumb209a111997-04-29 18:18:01 +00003562 PyErr_SetString(PyExc_TypeError,
Fred Drake661ea262000-10-24 19:57:45 +00003563 "exec: arg 2 must be a dictionary or None");
3564 return -1;
3565 }
3566 if (!PyDict_Check(locals)) {
3567 PyErr_SetString(PyExc_TypeError,
3568 "exec: arg 3 must be a dictionary or None");
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003569 return -1;
3570 }
Guido van Rossumb209a111997-04-29 18:18:01 +00003571 if (PyDict_GetItemString(globals, "__builtins__") == NULL)
Guido van Rossuma027efa1997-05-05 20:56:21 +00003572 PyDict_SetItemString(globals, "__builtins__", f->f_builtins);
Guido van Rossumb209a111997-04-29 18:18:01 +00003573 if (PyCode_Check(prog)) {
Guido van Rossuma400d8a2000-01-12 22:45:54 +00003574 v = PyEval_EvalCode((PyCodeObject *) prog, globals, locals);
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003575 }
Guido van Rossuma400d8a2000-01-12 22:45:54 +00003576 else if (PyFile_Check(prog)) {
Guido van Rossumb209a111997-04-29 18:18:01 +00003577 FILE *fp = PyFile_AsFile(prog);
3578 char *name = PyString_AsString(PyFile_Name(prog));
Tim Peters5ba58662001-07-16 02:29:45 +00003579 PyCompilerFlags cf;
3580 cf.cf_flags = 0;
3581 if (PyEval_MergeCompilerFlags(&cf))
Jeremy Hyltonbc320242001-03-22 02:47:58 +00003582 v = PyRun_FileFlags(fp, name, Py_file_input, globals,
3583 locals, &cf);
Tim Peters5ba58662001-07-16 02:29:45 +00003584 else
Jeremy Hyltonbc320242001-03-22 02:47:58 +00003585 v = PyRun_File(fp, name, Py_file_input, globals,
3586 locals);
Guido van Rossuma400d8a2000-01-12 22:45:54 +00003587 }
3588 else {
Marc-André Lemburgd1ba4432000-09-19 21:04:18 +00003589 char *str;
Tim Peters5ba58662001-07-16 02:29:45 +00003590 PyCompilerFlags cf;
Marc-André Lemburgd1ba4432000-09-19 21:04:18 +00003591 if (PyString_AsStringAndSize(prog, &str, NULL))
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003592 return -1;
Tim Peters5ba58662001-07-16 02:29:45 +00003593 cf.cf_flags = 0;
3594 if (PyEval_MergeCompilerFlags(&cf))
Jeremy Hyltonbc320242001-03-22 02:47:58 +00003595 v = PyRun_StringFlags(str, Py_file_input, globals,
3596 locals, &cf);
Tim Peters5ba58662001-07-16 02:29:45 +00003597 else
Jeremy Hyltonbc320242001-03-22 02:47:58 +00003598 v = PyRun_String(str, Py_file_input, globals, locals);
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003599 }
Guido van Rossuma400d8a2000-01-12 22:45:54 +00003600 if (plain)
3601 PyFrame_LocalsToFast(f, 0);
Guido van Rossum681d79a1995-07-18 14:51:37 +00003602 if (v == NULL)
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003603 return -1;
Guido van Rossumb209a111997-04-29 18:18:01 +00003604 Py_DECREF(v);
Guido van Rossumdb3165e1993-10-18 17:06:59 +00003605 return 0;
3606}
Guido van Rossum24c13741995-02-14 09:42:43 +00003607
Guido van Rossumac7be682001-01-17 15:42:30 +00003608static void
Paul Prescode68140d2000-08-30 20:25:01 +00003609format_exc_check_arg(PyObject *exc, char *format_str, PyObject *obj)
3610{
3611 char *obj_str;
3612
3613 if (!obj)
3614 return;
3615
3616 obj_str = PyString_AsString(obj);
3617 if (!obj_str)
3618 return;
3619
3620 PyErr_Format(exc, format_str, obj_str);
3621}
Guido van Rossum950361c1997-01-24 13:49:28 +00003622
3623#ifdef DYNAMIC_EXECUTION_PROFILE
3624
3625PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003626getarray(long a[256])
Guido van Rossum950361c1997-01-24 13:49:28 +00003627{
3628 int i;
3629 PyObject *l = PyList_New(256);
3630 if (l == NULL) return NULL;
3631 for (i = 0; i < 256; i++) {
3632 PyObject *x = PyInt_FromLong(a[i]);
3633 if (x == NULL) {
3634 Py_DECREF(l);
3635 return NULL;
3636 }
3637 PyList_SetItem(l, i, x);
3638 }
3639 for (i = 0; i < 256; i++)
3640 a[i] = 0;
3641 return l;
3642}
3643
3644PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00003645_Py_GetDXProfile(PyObject *self, PyObject *args)
Guido van Rossum950361c1997-01-24 13:49:28 +00003646{
3647#ifndef DXPAIRS
3648 return getarray(dxp);
3649#else
3650 int i;
3651 PyObject *l = PyList_New(257);
3652 if (l == NULL) return NULL;
3653 for (i = 0; i < 257; i++) {
3654 PyObject *x = getarray(dxpairs[i]);
3655 if (x == NULL) {
3656 Py_DECREF(l);
3657 return NULL;
3658 }
3659 PyList_SetItem(l, i, x);
3660 }
3661 return l;
3662#endif
3663}
3664
3665#endif