blob: a8bd02440f5da15370cc55c136ed0f5209ab3376 [file] [log] [blame]
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001
2/* Python interpreter top-level routines, including init/exit */
3
Guido van Rossum82598051997-03-05 00:20:32 +00004#include "Python.h"
Guido van Rossum1984f1e1992-08-04 12:41:02 +00005
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00006#include "Python-ast.h"
Guido van Rossumd8faa362007-04-27 19:54:29 +00007#undef Yield /* undefine macro conflicting with winbase.h */
Guido van Rossum1984f1e1992-08-04 12:41:02 +00008#include "grammar.h"
9#include "node.h"
Fred Drake85f36392000-07-11 17:53:00 +000010#include "token.h"
Guido van Rossum1984f1e1992-08-04 12:41:02 +000011#include "parsetok.h"
Guido van Rossum1984f1e1992-08-04 12:41:02 +000012#include "errcode.h"
Jeremy Hylton3e0055f2005-10-20 19:59:25 +000013#include "code.h"
Jeremy Hylton4b38da62001-02-02 18:19:15 +000014#include "symtable.h"
Jeremy Hylton3e0055f2005-10-20 19:59:25 +000015#include "ast.h"
Guido van Rossumfdef2711994-09-14 13:31:04 +000016#include "marshal.h"
Martin v. Löwis790465f2008-04-05 20:41:37 +000017#include "osdefs.h"
Victor Stinner518e6102014-03-18 02:06:38 +010018#include <locale.h>
Guido van Rossum1984f1e1992-08-04 12:41:02 +000019
Thomas Wouters0e3f5912006-08-11 14:57:12 +000020#ifdef HAVE_SIGNAL_H
Guido van Rossuma9e7dc11992-10-18 18:53:57 +000021#include <signal.h>
Thomas Wouters0e3f5912006-08-11 14:57:12 +000022#endif
Guido van Rossuma9e7dc11992-10-18 18:53:57 +000023
Benjamin Peterson80a50ac2009-01-02 21:24:04 +000024#ifdef MS_WINDOWS
Martin v. Löwis5c88d812009-01-02 20:47:48 +000025#include "malloc.h" /* for alloca */
Benjamin Peterson80a50ac2009-01-02 21:24:04 +000026#endif
Martin v. Löwis5c88d812009-01-02 20:47:48 +000027
Martin v. Löwis73d538b2003-03-05 15:13:47 +000028#ifdef HAVE_LANGINFO_H
Martin v. Löwis73d538b2003-03-05 15:13:47 +000029#include <langinfo.h>
30#endif
31
Martin v. Löwis6238d2b2002-06-30 15:26:10 +000032#ifdef MS_WINDOWS
Guido van Rossuma44823b1995-03-14 15:01:17 +000033#undef BYTE
34#include "windows.h"
35#endif
36
Victor Stinnerbd303c12013-11-07 23:07:29 +010037_Py_IDENTIFIER(builtins);
Victor Stinner09054372013-11-06 22:41:44 +010038_Py_IDENTIFIER(excepthook);
Victor Stinner3f36a572013-11-12 21:39:02 +010039_Py_IDENTIFIER(flush);
Victor Stinnerbd303c12013-11-07 23:07:29 +010040_Py_IDENTIFIER(last_traceback);
Victor Stinner09054372013-11-06 22:41:44 +010041_Py_IDENTIFIER(last_type);
42_Py_IDENTIFIER(last_value);
Victor Stinnerbd303c12013-11-07 23:07:29 +010043_Py_IDENTIFIER(ps1);
44_Py_IDENTIFIER(ps2);
45_Py_IDENTIFIER(stdin);
46_Py_IDENTIFIER(stdout);
47_Py_IDENTIFIER(stderr);
Victor Stinnerefa7a0e2013-11-07 12:37:56 +010048_Py_static_string(PyId_string, "<string>");
Victor Stinner09054372013-11-06 22:41:44 +010049
Thomas Wouters49fd7fa2006-04-21 10:40:58 +000050#ifdef __cplusplus
51extern "C" {
Neal Norwitz4281cef2006-03-04 19:58:13 +000052#endif
53
Guido van Rossum82598051997-03-05 00:20:32 +000054extern grammar _PyParser_Grammar; /* From graminit.c */
Guido van Rossum1984f1e1992-08-04 12:41:02 +000055
Guido van Rossumb73cc041993-11-01 16:28:59 +000056/* Forward */
Amaury Forgeot d'Arc7fedbe52008-04-10 21:03:09 +000057static void flush_io(void);
Victor Stinner95701bd2013-11-06 18:41:07 +010058static PyObject *run_mod(mod_ty, PyObject *, PyObject *, PyObject *,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000059 PyCompilerFlags *, PyArena *);
Martin v. Löwis95292d62002-12-11 14:04:59 +000060static PyObject *run_pyc_file(FILE *, const char *, PyObject *, PyObject *,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000061 PyCompilerFlags *);
Tim Petersdbd9ba62000-07-09 03:09:57 +000062static void err_input(perrdetail *);
Victor Stinner7f2fee32011-04-05 00:39:01 +020063static void err_free(perrdetail *);
Guido van Rossumce3a72a2007-10-19 23:16:50 +000064
Guido van Rossum1984f1e1992-08-04 12:41:02 +000065/* Parse input from a file and execute it */
66
67int
Thomas Wouters4d70c3d2006-06-08 14:42:34 +000068PyRun_AnyFileExFlags(FILE *fp, const char *filename, int closeit,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000069 PyCompilerFlags *flags)
Jeremy Hyltonbc320242001-03-22 02:47:58 +000070{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000071 if (filename == NULL)
72 filename = "???";
73 if (Py_FdIsInteractive(fp, filename)) {
74 int err = PyRun_InteractiveLoopFlags(fp, filename, flags);
75 if (closeit)
76 fclose(fp);
77 return err;
78 }
79 else
80 return PyRun_SimpleFileExFlags(fp, filename, closeit, flags);
Guido van Rossum1984f1e1992-08-04 12:41:02 +000081}
82
83int
Victor Stinner95701bd2013-11-06 18:41:07 +010084PyRun_InteractiveLoopFlags(FILE *fp, const char *filename_str, PyCompilerFlags *flags)
Jeremy Hyltonbc320242001-03-22 02:47:58 +000085{
Victor Stinner95701bd2013-11-06 18:41:07 +010086 PyObject *filename, *v;
87 int ret, err;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000088 PyCompilerFlags local_flags;
Jeremy Hylton9f324e92001-03-01 22:59:14 +000089
Victor Stinner95701bd2013-11-06 18:41:07 +010090 filename = PyUnicode_DecodeFSDefault(filename_str);
91 if (filename == NULL) {
92 PyErr_Print();
93 return -1;
94 }
95
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000096 if (flags == NULL) {
97 flags = &local_flags;
98 local_flags.cf_flags = 0;
99 }
Victor Stinner09054372013-11-06 22:41:44 +0100100 v = _PySys_GetObjectId(&PyId_ps1);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000101 if (v == NULL) {
Victor Stinner09054372013-11-06 22:41:44 +0100102 _PySys_SetObjectId(&PyId_ps1, v = PyUnicode_FromString(">>> "));
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000103 Py_XDECREF(v);
104 }
Victor Stinner09054372013-11-06 22:41:44 +0100105 v = _PySys_GetObjectId(&PyId_ps2);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000106 if (v == NULL) {
Victor Stinner09054372013-11-06 22:41:44 +0100107 _PySys_SetObjectId(&PyId_ps2, v = PyUnicode_FromString("... "));
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000108 Py_XDECREF(v);
109 }
Victor Stinner95701bd2013-11-06 18:41:07 +0100110 err = -1;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000111 for (;;) {
Victor Stinner95701bd2013-11-06 18:41:07 +0100112 ret = PyRun_InteractiveOneObject(fp, filename, flags);
Nick Coghland6009512014-11-20 21:39:37 +1000113 _PY_DEBUG_PRINT_TOTAL_REFS();
Victor Stinner95701bd2013-11-06 18:41:07 +0100114 if (ret == E_EOF) {
115 err = 0;
116 break;
117 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000118 /*
119 if (ret == E_NOMEM)
Victor Stinner95701bd2013-11-06 18:41:07 +0100120 break;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000121 */
122 }
Victor Stinner95701bd2013-11-06 18:41:07 +0100123 Py_DECREF(filename);
124 return err;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000125}
126
Neil Schemenauerc24ea082002-03-22 23:53:36 +0000127/* compute parser flags based on compiler flags */
Benjamin Petersonf5b52242009-03-02 23:31:26 +0000128static int PARSER_FLAGS(PyCompilerFlags *flags)
129{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000130 int parser_flags = 0;
131 if (!flags)
132 return 0;
133 if (flags->cf_flags & PyCF_DONT_IMPLY_DEDENT)
134 parser_flags |= PyPARSE_DONT_IMPLY_DEDENT;
135 if (flags->cf_flags & PyCF_IGNORE_COOKIE)
136 parser_flags |= PyPARSE_IGNORE_COOKIE;
137 if (flags->cf_flags & CO_FUTURE_BARRY_AS_BDFL)
138 parser_flags |= PyPARSE_BARRY_AS_BDFL;
139 return parser_flags;
Benjamin Petersonf5b52242009-03-02 23:31:26 +0000140}
Neil Schemenauerc24ea082002-03-22 23:53:36 +0000141
Thomas Wouters89f507f2006-12-13 04:49:30 +0000142#if 0
143/* Keep an example of flags with future keyword support. */
144#define PARSER_FLAGS(flags) \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000145 ((flags) ? ((((flags)->cf_flags & PyCF_DONT_IMPLY_DEDENT) ? \
146 PyPARSE_DONT_IMPLY_DEDENT : 0) \
147 | ((flags)->cf_flags & CO_FUTURE_WITH_STATEMENT ? \
148 PyPARSE_WITH_IS_KEYWORD : 0)) : 0)
Thomas Wouters89f507f2006-12-13 04:49:30 +0000149#endif
150
Jeremy Hylton9f324e92001-03-01 22:59:14 +0000151int
Victor Stinner95701bd2013-11-06 18:41:07 +0100152PyRun_InteractiveOneObject(FILE *fp, PyObject *filename, PyCompilerFlags *flags)
Jeremy Hylton9f324e92001-03-01 22:59:14 +0000153{
Victor Stinner95701bd2013-11-06 18:41:07 +0100154 PyObject *m, *d, *v, *w, *oenc = NULL, *mod_name;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000155 mod_ty mod;
156 PyArena *arena;
157 char *ps1 = "", *ps2 = "", *enc = NULL;
158 int errcode = 0;
Martin v. Löwisbd928fe2011-10-14 10:20:37 +0200159 _Py_IDENTIFIER(encoding);
Victor Stinner95701bd2013-11-06 18:41:07 +0100160 _Py_IDENTIFIER(__main__);
161
162 mod_name = _PyUnicode_FromId(&PyId___main__); /* borrowed */
163 if (mod_name == NULL) {
164 PyErr_Print();
165 return -1;
166 }
Tim Petersfe2127d2001-07-16 05:37:24 +0000167
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000168 if (fp == stdin) {
Benjamin Petersonfe1b22a2013-04-29 10:23:08 -0400169 /* Fetch encoding from sys.stdin if possible. */
Victor Stinnerbd303c12013-11-07 23:07:29 +0100170 v = _PySys_GetObjectId(&PyId_stdin);
Benjamin Petersonfe1b22a2013-04-29 10:23:08 -0400171 if (v && v != Py_None) {
172 oenc = _PyObject_GetAttrId(v, &PyId_encoding);
173 if (oenc)
174 enc = _PyUnicode_AsString(oenc);
175 if (!enc)
176 PyErr_Clear();
177 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000178 }
Victor Stinner09054372013-11-06 22:41:44 +0100179 v = _PySys_GetObjectId(&PyId_ps1);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000180 if (v != NULL) {
181 v = PyObject_Str(v);
182 if (v == NULL)
183 PyErr_Clear();
Victor Stinner386fe712010-05-19 00:34:15 +0000184 else if (PyUnicode_Check(v)) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000185 ps1 = _PyUnicode_AsString(v);
Victor Stinner386fe712010-05-19 00:34:15 +0000186 if (ps1 == NULL) {
187 PyErr_Clear();
188 ps1 = "";
189 }
190 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000191 }
Victor Stinner09054372013-11-06 22:41:44 +0100192 w = _PySys_GetObjectId(&PyId_ps2);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000193 if (w != NULL) {
194 w = PyObject_Str(w);
195 if (w == NULL)
196 PyErr_Clear();
Victor Stinner386fe712010-05-19 00:34:15 +0000197 else if (PyUnicode_Check(w)) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000198 ps2 = _PyUnicode_AsString(w);
Victor Stinner386fe712010-05-19 00:34:15 +0000199 if (ps2 == NULL) {
200 PyErr_Clear();
201 ps2 = "";
202 }
203 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000204 }
205 arena = PyArena_New();
206 if (arena == NULL) {
207 Py_XDECREF(v);
208 Py_XDECREF(w);
209 Py_XDECREF(oenc);
210 return -1;
211 }
Victor Stinner95701bd2013-11-06 18:41:07 +0100212 mod = PyParser_ASTFromFileObject(fp, filename, enc,
213 Py_single_input, ps1, ps2,
214 flags, &errcode, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000215 Py_XDECREF(v);
216 Py_XDECREF(w);
217 Py_XDECREF(oenc);
218 if (mod == NULL) {
219 PyArena_Free(arena);
220 if (errcode == E_EOF) {
221 PyErr_Clear();
222 return E_EOF;
223 }
224 PyErr_Print();
225 return -1;
226 }
Victor Stinner95701bd2013-11-06 18:41:07 +0100227 m = PyImport_AddModuleObject(mod_name);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000228 if (m == NULL) {
229 PyArena_Free(arena);
230 return -1;
231 }
232 d = PyModule_GetDict(m);
233 v = run_mod(mod, filename, d, d, flags, arena);
234 PyArena_Free(arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000235 if (v == NULL) {
236 PyErr_Print();
Antoine Pitrou9845c7e2014-05-11 13:42:17 +0200237 flush_io();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000238 return -1;
239 }
240 Py_DECREF(v);
Antoine Pitrou9845c7e2014-05-11 13:42:17 +0200241 flush_io();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000242 return 0;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000243}
244
Victor Stinner95701bd2013-11-06 18:41:07 +0100245int
246PyRun_InteractiveOneFlags(FILE *fp, const char *filename_str, PyCompilerFlags *flags)
247{
248 PyObject *filename;
249 int res;
250
251 filename = PyUnicode_DecodeFSDefault(filename_str);
252 if (filename == NULL) {
253 PyErr_Print();
254 return -1;
255 }
256 res = PyRun_InteractiveOneObject(fp, filename, flags);
257 Py_DECREF(filename);
258 return res;
259}
260
261
Martin v. Löwisbe4c0f52001-01-04 20:30:56 +0000262/* Check whether a file maybe a pyc file: Look at the extension,
263 the file type, and, if we may close it, at the first few bytes. */
264
265static int
Martin v. Löwis95292d62002-12-11 14:04:59 +0000266maybe_pyc_file(FILE *fp, const char* filename, const char* ext, int closeit)
Martin v. Löwisbe4c0f52001-01-04 20:30:56 +0000267{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000268 if (strcmp(ext, ".pyc") == 0 || strcmp(ext, ".pyo") == 0)
269 return 1;
Martin v. Löwisbe4c0f52001-01-04 20:30:56 +0000270
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000271 /* Only look into the file if we are allowed to close it, since
272 it then should also be seekable. */
273 if (closeit) {
274 /* Read only two bytes of the magic. If the file was opened in
275 text mode, the bytes 3 and 4 of the magic (\r\n) might not
276 be read as they are on disk. */
277 unsigned int halfmagic = PyImport_GetMagicNumber() & 0xFFFF;
278 unsigned char buf[2];
279 /* Mess: In case of -x, the stream is NOT at its start now,
280 and ungetc() was used to push back the first newline,
281 which makes the current stream position formally undefined,
282 and a x-platform nightmare.
283 Unfortunately, we have no direct way to know whether -x
284 was specified. So we use a terrible hack: if the current
285 stream position is not 0, we assume -x was specified, and
286 give up. Bug 132850 on SourceForge spells out the
287 hopelessness of trying anything else (fseek and ftell
288 don't work predictably x-platform for text-mode files).
289 */
290 int ispyc = 0;
291 if (ftell(fp) == 0) {
292 if (fread(buf, 1, 2, fp) == 2 &&
293 ((unsigned int)buf[1]<<8 | buf[0]) == halfmagic)
294 ispyc = 1;
295 rewind(fp);
296 }
297 return ispyc;
298 }
299 return 0;
Tim Petersd08e3822003-04-17 15:24:21 +0000300}
Martin v. Löwisbe4c0f52001-01-04 20:30:56 +0000301
Antoine Pitrou32d483c2013-07-30 21:01:23 +0200302static int
303set_main_loader(PyObject *d, const char *filename, const char *loader_name)
Nick Coghlan85e729e2012-07-15 18:09:52 +1000304{
305 PyInterpreterState *interp;
306 PyThreadState *tstate;
Andrew Svetlov90c0eb22012-11-01 14:51:14 +0200307 PyObject *filename_obj, *loader_type, *loader;
Nick Coghlanb7a58942012-07-15 23:21:08 +1000308 int result = 0;
Andrew Svetlov90c0eb22012-11-01 14:51:14 +0200309
310 filename_obj = PyUnicode_DecodeFSDefault(filename);
311 if (filename_obj == NULL)
312 return -1;
Nick Coghlan85e729e2012-07-15 18:09:52 +1000313 /* Get current thread state and interpreter pointer */
314 tstate = PyThreadState_GET();
315 interp = tstate->interp;
Nick Coghlan3f94cbf2012-07-15 19:10:39 +1000316 loader_type = PyObject_GetAttrString(interp->importlib, loader_name);
317 if (loader_type == NULL) {
Andrew Svetlov90c0eb22012-11-01 14:51:14 +0200318 Py_DECREF(filename_obj);
Nick Coghlan3f94cbf2012-07-15 19:10:39 +1000319 return -1;
320 }
Andrew Svetlov90c0eb22012-11-01 14:51:14 +0200321 loader = PyObject_CallFunction(loader_type, "sN", "__main__", filename_obj);
Nick Coghlanb7a58942012-07-15 23:21:08 +1000322 Py_DECREF(loader_type);
323 if (loader == NULL) {
Nick Coghlan85e729e2012-07-15 18:09:52 +1000324 return -1;
325 }
Nick Coghlanb7a58942012-07-15 23:21:08 +1000326 if (PyDict_SetItemString(d, "__loader__", loader) < 0) {
327 result = -1;
328 }
Nick Coghlan85e729e2012-07-15 18:09:52 +1000329 Py_DECREF(loader);
Nick Coghlanb7a58942012-07-15 23:21:08 +1000330 return result;
Nick Coghlan85e729e2012-07-15 18:09:52 +1000331}
332
333int
Martin v. Löwis95292d62002-12-11 14:04:59 +0000334PyRun_SimpleFileExFlags(FILE *fp, const char *filename, int closeit,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000335 PyCompilerFlags *flags)
Jeremy Hyltonbc320242001-03-22 02:47:58 +0000336{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000337 PyObject *m, *d, *v;
338 const char *ext;
Hynek Schlawack5c6b3e22012-11-07 09:02:24 +0100339 int set_file_name = 0, ret = -1;
Victor Stinner0fcab4a2011-01-04 12:59:15 +0000340 size_t len;
Guido van Rossumfdef2711994-09-14 13:31:04 +0000341
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000342 m = PyImport_AddModule("__main__");
343 if (m == NULL)
344 return -1;
Hynek Schlawack5c6b3e22012-11-07 09:02:24 +0100345 Py_INCREF(m);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000346 d = PyModule_GetDict(m);
347 if (PyDict_GetItemString(d, "__file__") == NULL) {
348 PyObject *f;
Victor Stinner4c7c8c32010-10-16 13:14:10 +0000349 f = PyUnicode_DecodeFSDefault(filename);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000350 if (f == NULL)
Hynek Schlawack5c6b3e22012-11-07 09:02:24 +0100351 goto done;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000352 if (PyDict_SetItemString(d, "__file__", f) < 0) {
353 Py_DECREF(f);
Hynek Schlawack5c6b3e22012-11-07 09:02:24 +0100354 goto done;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000355 }
Barry Warsaw916048d2011-09-20 14:45:44 -0400356 if (PyDict_SetItemString(d, "__cached__", Py_None) < 0) {
357 Py_DECREF(f);
Hynek Schlawack5c6b3e22012-11-07 09:02:24 +0100358 goto done;
Barry Warsaw916048d2011-09-20 14:45:44 -0400359 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000360 set_file_name = 1;
361 Py_DECREF(f);
362 }
363 len = strlen(filename);
364 ext = filename + len - (len > 4 ? 4 : 0);
365 if (maybe_pyc_file(fp, filename, ext, closeit)) {
Christian Heimes04ac4c12012-09-11 15:47:28 +0200366 FILE *pyc_fp;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000367 /* Try to run a pyc file. First, re-open in binary */
368 if (closeit)
369 fclose(fp);
Victor Stinnerdaf45552013-08-28 00:53:59 +0200370 if ((pyc_fp = _Py_fopen(filename, "rb")) == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000371 fprintf(stderr, "python: Can't reopen .pyc file\n");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000372 goto done;
373 }
374 /* Turn on optimization if a .pyo file is given */
375 if (strcmp(ext, ".pyo") == 0)
376 Py_OptimizeFlag = 1;
Nick Coghlan85e729e2012-07-15 18:09:52 +1000377
378 if (set_main_loader(d, filename, "SourcelessFileLoader") < 0) {
379 fprintf(stderr, "python: failed to set __main__.__loader__\n");
380 ret = -1;
Christian Heimes04ac4c12012-09-11 15:47:28 +0200381 fclose(pyc_fp);
Nick Coghlan85e729e2012-07-15 18:09:52 +1000382 goto done;
383 }
Christian Heimes04ac4c12012-09-11 15:47:28 +0200384 v = run_pyc_file(pyc_fp, filename, d, d, flags);
385 fclose(pyc_fp);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000386 } else {
Nick Coghlan85e729e2012-07-15 18:09:52 +1000387 /* When running from stdin, leave __main__.__loader__ alone */
388 if (strcmp(filename, "<stdin>") != 0 &&
389 set_main_loader(d, filename, "SourceFileLoader") < 0) {
390 fprintf(stderr, "python: failed to set __main__.__loader__\n");
391 ret = -1;
392 goto done;
393 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000394 v = PyRun_FileExFlags(fp, filename, Py_file_input, d, d,
395 closeit, flags);
396 }
397 flush_io();
398 if (v == NULL) {
399 PyErr_Print();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000400 goto done;
401 }
402 Py_DECREF(v);
403 ret = 0;
Guido van Rossumd8faa362007-04-27 19:54:29 +0000404 done:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000405 if (set_file_name && PyDict_DelItemString(d, "__file__"))
406 PyErr_Clear();
Hynek Schlawack5c6b3e22012-11-07 09:02:24 +0100407 Py_DECREF(m);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000408 return ret;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000409}
410
411int
Martin v. Löwis95292d62002-12-11 14:04:59 +0000412PyRun_SimpleStringFlags(const char *command, PyCompilerFlags *flags)
Guido van Rossum393661d2001-08-31 17:40:15 +0000413{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000414 PyObject *m, *d, *v;
415 m = PyImport_AddModule("__main__");
416 if (m == NULL)
417 return -1;
418 d = PyModule_GetDict(m);
419 v = PyRun_StringFlags(command, Py_file_input, d, d, flags);
420 if (v == NULL) {
421 PyErr_Print();
422 return -1;
423 }
424 Py_DECREF(v);
425 return 0;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000426}
427
Barry Warsaw035574d1997-08-29 22:07:17 +0000428static int
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100429parse_syntax_error(PyObject *err, PyObject **message, PyObject **filename,
430 int *lineno, int *offset, PyObject **text)
Barry Warsaw035574d1997-08-29 22:07:17 +0000431{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000432 long hold;
433 PyObject *v;
Martin v. Löwisbd928fe2011-10-14 10:20:37 +0200434 _Py_IDENTIFIER(msg);
435 _Py_IDENTIFIER(filename);
436 _Py_IDENTIFIER(lineno);
437 _Py_IDENTIFIER(offset);
438 _Py_IDENTIFIER(text);
Barry Warsaw035574d1997-08-29 22:07:17 +0000439
Benjamin Peterson80d50422012-04-03 00:30:38 -0400440 *message = NULL;
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100441 *filename = NULL;
Benjamin Peterson80d50422012-04-03 00:30:38 -0400442
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000443 /* new style errors. `err' is an instance */
Benjamin Peterson0a9a6362012-04-03 00:35:36 -0400444 *message = _PyObject_GetAttrId(err, &PyId_msg);
Benjamin Peterson80d50422012-04-03 00:30:38 -0400445 if (!*message)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000446 goto finally;
Barry Warsaw035574d1997-08-29 22:07:17 +0000447
Benjamin Peterson0a9a6362012-04-03 00:35:36 -0400448 v = _PyObject_GetAttrId(err, &PyId_filename);
Benjamin Peterson80d50422012-04-03 00:30:38 -0400449 if (!v)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000450 goto finally;
Benjamin Peterson80d50422012-04-03 00:30:38 -0400451 if (v == Py_None) {
452 Py_DECREF(v);
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100453 *filename = _PyUnicode_FromId(&PyId_string);
454 if (*filename == NULL)
455 goto finally;
456 Py_INCREF(*filename);
Benjamin Peterson80d50422012-04-03 00:30:38 -0400457 }
458 else {
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100459 *filename = v;
Benjamin Peterson80d50422012-04-03 00:30:38 -0400460 }
Barry Warsaw035574d1997-08-29 22:07:17 +0000461
Benjamin Peterson0a9a6362012-04-03 00:35:36 -0400462 v = _PyObject_GetAttrId(err, &PyId_lineno);
Benjamin Peterson80d50422012-04-03 00:30:38 -0400463 if (!v)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000464 goto finally;
465 hold = PyLong_AsLong(v);
466 Py_DECREF(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000467 if (hold < 0 && PyErr_Occurred())
468 goto finally;
469 *lineno = (int)hold;
Barry Warsaw035574d1997-08-29 22:07:17 +0000470
Benjamin Peterson0a9a6362012-04-03 00:35:36 -0400471 v = _PyObject_GetAttrId(err, &PyId_offset);
Benjamin Peterson80d50422012-04-03 00:30:38 -0400472 if (!v)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000473 goto finally;
474 if (v == Py_None) {
475 *offset = -1;
476 Py_DECREF(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000477 } else {
478 hold = PyLong_AsLong(v);
479 Py_DECREF(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000480 if (hold < 0 && PyErr_Occurred())
481 goto finally;
482 *offset = (int)hold;
483 }
Barry Warsaw035574d1997-08-29 22:07:17 +0000484
Benjamin Peterson0a9a6362012-04-03 00:35:36 -0400485 v = _PyObject_GetAttrId(err, &PyId_text);
Benjamin Peterson80d50422012-04-03 00:30:38 -0400486 if (!v)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000487 goto finally;
Benjamin Peterson80d50422012-04-03 00:30:38 -0400488 if (v == Py_None) {
489 Py_DECREF(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000490 *text = NULL;
Benjamin Peterson80d50422012-04-03 00:30:38 -0400491 }
492 else {
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100493 *text = v;
Benjamin Peterson80d50422012-04-03 00:30:38 -0400494 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000495 return 1;
Barry Warsaw035574d1997-08-29 22:07:17 +0000496
497finally:
Benjamin Peterson80d50422012-04-03 00:30:38 -0400498 Py_XDECREF(*message);
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100499 Py_XDECREF(*filename);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000500 return 0;
Barry Warsaw035574d1997-08-29 22:07:17 +0000501}
502
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000503void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000504PyErr_Print(void)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000505{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000506 PyErr_PrintEx(1);
Guido van Rossuma61691e1998-02-06 22:27:24 +0000507}
508
Jeremy Hylton9f1b9932001-02-28 07:07:43 +0000509static void
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100510print_error_text(PyObject *f, int offset, PyObject *text_obj)
Jeremy Hylton9f1b9932001-02-28 07:07:43 +0000511{
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100512 char *text;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000513 char *nl;
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100514
515 text = _PyUnicode_AsString(text_obj);
516 if (text == NULL)
517 return;
518
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000519 if (offset >= 0) {
Victor Stinner98ea54c2014-08-15 23:30:40 +0200520 if (offset > 0 && (size_t)offset == strlen(text) && text[offset - 1] == '\n')
Benjamin Petersona95e9772010-10-29 03:28:14 +0000521 offset--;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000522 for (;;) {
523 nl = strchr(text, '\n');
524 if (nl == NULL || nl-text >= offset)
525 break;
526 offset -= (int)(nl+1-text);
527 text = nl+1;
528 }
529 while (*text == ' ' || *text == '\t') {
530 text++;
531 offset--;
532 }
533 }
534 PyFile_WriteString(" ", f);
535 PyFile_WriteString(text, f);
536 if (*text == '\0' || text[strlen(text)-1] != '\n')
537 PyFile_WriteString("\n", f);
538 if (offset == -1)
539 return;
540 PyFile_WriteString(" ", f);
Benjamin Petersona95e9772010-10-29 03:28:14 +0000541 while (--offset > 0)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000542 PyFile_WriteString(" ", f);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000543 PyFile_WriteString("^\n", f);
Jeremy Hylton9f1b9932001-02-28 07:07:43 +0000544}
545
Guido van Rossum66e8e862001-03-23 17:54:43 +0000546static void
547handle_system_exit(void)
Ka-Ping Yee26fabb02001-03-23 15:36:41 +0000548{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000549 PyObject *exception, *value, *tb;
550 int exitcode = 0;
Tim Peterscf615b52003-04-19 18:47:02 +0000551
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000552 if (Py_InspectFlag)
553 /* Don't exit if -i flag was given. This flag is set to 0
554 * when entering interactive mode for inspecting. */
555 return;
Guido van Rossumd8faa362007-04-27 19:54:29 +0000556
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000557 PyErr_Fetch(&exception, &value, &tb);
558 fflush(stdout);
559 if (value == NULL || value == Py_None)
560 goto done;
561 if (PyExceptionInstance_Check(value)) {
562 /* The error code should be in the `code' attribute. */
Martin v. Löwisbd928fe2011-10-14 10:20:37 +0200563 _Py_IDENTIFIER(code);
Martin v. Löwis1ee1b6f2011-10-10 18:11:30 +0200564 PyObject *code = _PyObject_GetAttrId(value, &PyId_code);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000565 if (code) {
566 Py_DECREF(value);
567 value = code;
568 if (value == Py_None)
569 goto done;
570 }
571 /* If we failed to dig out the 'code' attribute,
572 just let the else clause below print the error. */
573 }
574 if (PyLong_Check(value))
575 exitcode = (int)PyLong_AsLong(value);
576 else {
Victor Stinnerbd303c12013-11-07 23:07:29 +0100577 PyObject *sys_stderr = _PySys_GetObjectId(&PyId_stderr);
Nick Coghland979e432014-02-09 10:43:21 +1000578 /* We clear the exception here to avoid triggering the assertion
579 * in PyObject_Str that ensures it won't silently lose exception
580 * details.
581 */
582 PyErr_Clear();
Victor Stinner7126dbc2010-05-21 23:45:42 +0000583 if (sys_stderr != NULL && sys_stderr != Py_None) {
584 PyFile_WriteObject(value, sys_stderr, Py_PRINT_RAW);
585 } else {
586 PyObject_Print(value, stderr, Py_PRINT_RAW);
587 fflush(stderr);
588 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000589 PySys_WriteStderr("\n");
590 exitcode = 1;
591 }
Tim Peterscf615b52003-04-19 18:47:02 +0000592 done:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000593 /* Restore and clear the exception info, in order to properly decref
594 * the exception, value, and traceback. If we just exit instead,
595 * these leak, which confuses PYTHONDUMPREFS output, and may prevent
596 * some finalizers from running.
597 */
598 PyErr_Restore(exception, value, tb);
599 PyErr_Clear();
600 Py_Exit(exitcode);
601 /* NOTREACHED */
Ka-Ping Yee26fabb02001-03-23 15:36:41 +0000602}
603
604void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000605PyErr_PrintEx(int set_sys_last_vars)
Guido van Rossuma61691e1998-02-06 22:27:24 +0000606{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000607 PyObject *exception, *v, *tb, *hook;
Guido van Rossum66e8e862001-03-23 17:54:43 +0000608
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000609 if (PyErr_ExceptionMatches(PyExc_SystemExit)) {
610 handle_system_exit();
611 }
612 PyErr_Fetch(&exception, &v, &tb);
613 if (exception == NULL)
614 return;
615 PyErr_NormalizeException(&exception, &v, &tb);
616 if (tb == NULL) {
617 tb = Py_None;
618 Py_INCREF(tb);
619 }
620 PyException_SetTraceback(v, tb);
621 if (exception == NULL)
622 return;
623 /* Now we know v != NULL too */
624 if (set_sys_last_vars) {
Victor Stinner09054372013-11-06 22:41:44 +0100625 _PySys_SetObjectId(&PyId_last_type, exception);
626 _PySys_SetObjectId(&PyId_last_value, v);
627 _PySys_SetObjectId(&PyId_last_traceback, tb);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000628 }
Victor Stinner09054372013-11-06 22:41:44 +0100629 hook = _PySys_GetObjectId(&PyId_excepthook);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000630 if (hook) {
631 PyObject *args = PyTuple_Pack(3, exception, v, tb);
632 PyObject *result = PyEval_CallObject(hook, args);
633 if (result == NULL) {
634 PyObject *exception2, *v2, *tb2;
635 if (PyErr_ExceptionMatches(PyExc_SystemExit)) {
636 handle_system_exit();
637 }
638 PyErr_Fetch(&exception2, &v2, &tb2);
639 PyErr_NormalizeException(&exception2, &v2, &tb2);
640 /* It should not be possible for exception2 or v2
641 to be NULL. However PyErr_Display() can't
642 tolerate NULLs, so just be safe. */
643 if (exception2 == NULL) {
644 exception2 = Py_None;
645 Py_INCREF(exception2);
646 }
647 if (v2 == NULL) {
648 v2 = Py_None;
649 Py_INCREF(v2);
650 }
651 fflush(stdout);
652 PySys_WriteStderr("Error in sys.excepthook:\n");
653 PyErr_Display(exception2, v2, tb2);
654 PySys_WriteStderr("\nOriginal exception was:\n");
655 PyErr_Display(exception, v, tb);
656 Py_DECREF(exception2);
657 Py_DECREF(v2);
658 Py_XDECREF(tb2);
659 }
660 Py_XDECREF(result);
661 Py_XDECREF(args);
662 } else {
663 PySys_WriteStderr("sys.excepthook is missing\n");
664 PyErr_Display(exception, v, tb);
665 }
666 Py_XDECREF(exception);
667 Py_XDECREF(v);
668 Py_XDECREF(tb);
Ka-Ping Yeeb5c51322001-03-23 02:46:52 +0000669}
670
Benjamin Petersone6528212008-07-15 15:32:09 +0000671static void
672print_exception(PyObject *f, PyObject *value)
673{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000674 int err = 0;
675 PyObject *type, *tb;
Martin v. Löwis1c67dd92011-10-14 15:16:45 +0200676 _Py_IDENTIFIER(print_file_and_line);
Benjamin Petersone6528212008-07-15 15:32:09 +0000677
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000678 if (!PyExceptionInstance_Check(value)) {
Victor Stinner52ce3b02013-12-09 02:10:08 +0100679 err = PyFile_WriteString("TypeError: print_exception(): Exception expected for value, ", f);
680 err += PyFile_WriteString(Py_TYPE(value)->tp_name, f);
681 err += PyFile_WriteString(" found\n", f);
682 if (err)
683 PyErr_Clear();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000684 return;
685 }
Benjamin Peterson26582602008-08-23 20:08:07 +0000686
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000687 Py_INCREF(value);
688 fflush(stdout);
689 type = (PyObject *) Py_TYPE(value);
690 tb = PyException_GetTraceback(value);
691 if (tb && tb != Py_None)
692 err = PyTraceBack_Print(tb, f);
693 if (err == 0 &&
Martin v. Löwis1c67dd92011-10-14 15:16:45 +0200694 _PyObject_HasAttrId(value, &PyId_print_file_and_line))
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000695 {
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100696 PyObject *message, *filename, *text;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000697 int lineno, offset;
698 if (!parse_syntax_error(value, &message, &filename,
699 &lineno, &offset, &text))
700 PyErr_Clear();
701 else {
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100702 PyObject *line;
703
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000704 Py_DECREF(value);
705 value = message;
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100706
707 line = PyUnicode_FromFormat(" File \"%U\", line %d\n",
708 filename, lineno);
709 Py_DECREF(filename);
710 if (line != NULL) {
711 PyFile_WriteObject(line, f, Py_PRINT_RAW);
712 Py_DECREF(line);
713 }
714
715 if (text != NULL) {
716 print_error_text(f, offset, text);
717 Py_DECREF(text);
718 }
719
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000720 /* Can't be bothered to check all those
721 PyFile_WriteString() calls */
722 if (PyErr_Occurred())
723 err = -1;
724 }
725 }
726 if (err) {
727 /* Don't do anything else */
728 }
729 else {
730 PyObject* moduleName;
731 char* className;
Martin v. Löwisbd928fe2011-10-14 10:20:37 +0200732 _Py_IDENTIFIER(__module__);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000733 assert(PyExceptionClass_Check(type));
734 className = PyExceptionClass_Name(type);
735 if (className != NULL) {
736 char *dot = strrchr(className, '.');
737 if (dot != NULL)
738 className = dot+1;
739 }
Benjamin Petersone6528212008-07-15 15:32:09 +0000740
Martin v. Löwis1ee1b6f2011-10-10 18:11:30 +0200741 moduleName = _PyObject_GetAttrId(type, &PyId___module__);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000742 if (moduleName == NULL || !PyUnicode_Check(moduleName))
743 {
Victor Stinner13b21bd2011-05-26 14:25:13 +0200744 Py_XDECREF(moduleName);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000745 err = PyFile_WriteString("<unknown>", f);
746 }
747 else {
Victor Stinnerbd303c12013-11-07 23:07:29 +0100748 if (_PyUnicode_CompareWithId(moduleName, &PyId_builtins) != 0)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000749 {
Victor Stinner937114f2013-11-07 00:12:30 +0100750 err = PyFile_WriteObject(moduleName, f, Py_PRINT_RAW);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000751 err += PyFile_WriteString(".", f);
752 }
753 Py_DECREF(moduleName);
754 }
755 if (err == 0) {
756 if (className == NULL)
757 err = PyFile_WriteString("<unknown>", f);
758 else
759 err = PyFile_WriteString(className, f);
760 }
761 }
762 if (err == 0 && (value != Py_None)) {
763 PyObject *s = PyObject_Str(value);
764 /* only print colon if the str() of the
765 object is not the empty string
766 */
767 if (s == NULL)
768 err = -1;
769 else if (!PyUnicode_Check(s) ||
Victor Stinnere251d6d2011-11-20 19:20:00 +0100770 PyUnicode_GetLength(s) != 0)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000771 err = PyFile_WriteString(": ", f);
772 if (err == 0)
773 err = PyFile_WriteObject(s, f, Py_PRINT_RAW);
774 Py_XDECREF(s);
775 }
776 /* try to write a newline in any case */
777 err += PyFile_WriteString("\n", f);
778 Py_XDECREF(tb);
779 Py_DECREF(value);
780 /* If an error happened here, don't show it.
781 XXX This is wrong, but too many callers rely on this behavior. */
782 if (err != 0)
783 PyErr_Clear();
Benjamin Petersone6528212008-07-15 15:32:09 +0000784}
785
786static const char *cause_message =
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000787 "\nThe above exception was the direct cause "
788 "of the following exception:\n\n";
Benjamin Petersone6528212008-07-15 15:32:09 +0000789
790static const char *context_message =
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000791 "\nDuring handling of the above exception, "
792 "another exception occurred:\n\n";
Benjamin Petersone6528212008-07-15 15:32:09 +0000793
794static void
795print_exception_recursive(PyObject *f, PyObject *value, PyObject *seen)
796{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000797 int err = 0, res;
798 PyObject *cause, *context;
Benjamin Petersone6528212008-07-15 15:32:09 +0000799
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000800 if (seen != NULL) {
801 /* Exception chaining */
802 if (PySet_Add(seen, value) == -1)
803 PyErr_Clear();
804 else if (PyExceptionInstance_Check(value)) {
805 cause = PyException_GetCause(value);
806 context = PyException_GetContext(value);
Benjamin Petersond5a1c442012-05-14 22:09:31 -0700807 if (cause) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000808 res = PySet_Contains(seen, cause);
809 if (res == -1)
810 PyErr_Clear();
811 if (res == 0) {
812 print_exception_recursive(
813 f, cause, seen);
814 err |= PyFile_WriteString(
815 cause_message, f);
816 }
817 }
Benjamin Petersond5a1c442012-05-14 22:09:31 -0700818 else if (context &&
819 !((PyBaseExceptionObject *)value)->suppress_context) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000820 res = PySet_Contains(seen, context);
821 if (res == -1)
822 PyErr_Clear();
823 if (res == 0) {
824 print_exception_recursive(
825 f, context, seen);
826 err |= PyFile_WriteString(
827 context_message, f);
828 }
829 }
830 Py_XDECREF(context);
831 Py_XDECREF(cause);
832 }
833 }
834 print_exception(f, value);
835 if (err != 0)
836 PyErr_Clear();
Benjamin Petersone6528212008-07-15 15:32:09 +0000837}
838
Thomas Wouters477c8d52006-05-27 19:21:47 +0000839void
840PyErr_Display(PyObject *exception, PyObject *value, PyObject *tb)
Ka-Ping Yeeb5c51322001-03-23 02:46:52 +0000841{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000842 PyObject *seen;
Victor Stinnerbd303c12013-11-07 23:07:29 +0100843 PyObject *f = _PySys_GetObjectId(&PyId_stderr);
Antoine Pitrou24201d42013-10-13 21:53:13 +0200844 if (PyExceptionInstance_Check(value)
845 && tb != NULL && PyTraceBack_Check(tb)) {
846 /* Put the traceback on the exception, otherwise it won't get
847 displayed. See issue #18776. */
848 PyObject *cur_tb = PyException_GetTraceback(value);
849 if (cur_tb == NULL)
850 PyException_SetTraceback(value, tb);
851 else
852 Py_DECREF(cur_tb);
853 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000854 if (f == Py_None) {
855 /* pass */
856 }
857 else if (f == NULL) {
858 _PyObject_Dump(value);
859 fprintf(stderr, "lost sys.stderr\n");
860 }
861 else {
862 /* We choose to ignore seen being possibly NULL, and report
863 at least the main exception (it could be a MemoryError).
864 */
865 seen = PySet_New(NULL);
866 if (seen == NULL)
867 PyErr_Clear();
868 print_exception_recursive(f, value, seen);
869 Py_XDECREF(seen);
870 }
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000871}
872
Guido van Rossum82598051997-03-05 00:20:32 +0000873PyObject *
Thomas Wouters4d70c3d2006-06-08 14:42:34 +0000874PyRun_StringFlags(const char *str, int start, PyObject *globals,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000875 PyObject *locals, PyCompilerFlags *flags)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000876{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000877 PyObject *ret = NULL;
878 mod_ty mod;
Victor Stinner95701bd2013-11-06 18:41:07 +0100879 PyArena *arena;
Victor Stinner95701bd2013-11-06 18:41:07 +0100880 PyObject *filename;
881
882 filename = _PyUnicode_FromId(&PyId_string); /* borrowed */
883 if (filename == NULL)
884 return NULL;
885
886 arena = PyArena_New();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000887 if (arena == NULL)
888 return NULL;
Guido van Rossum98297ee2007-11-06 21:34:58 +0000889
Victor Stinner95701bd2013-11-06 18:41:07 +0100890 mod = PyParser_ASTFromStringObject(str, filename, start, flags, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000891 if (mod != NULL)
Victor Stinner95701bd2013-11-06 18:41:07 +0100892 ret = run_mod(mod, filename, globals, locals, flags, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000893 PyArena_Free(arena);
894 return ret;
Jeremy Hyltonbc320242001-03-22 02:47:58 +0000895}
896
897PyObject *
Victor Stinner95701bd2013-11-06 18:41:07 +0100898PyRun_FileExFlags(FILE *fp, const char *filename_str, int start, PyObject *globals,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000899 PyObject *locals, int closeit, PyCompilerFlags *flags)
Jeremy Hyltonbc320242001-03-22 02:47:58 +0000900{
Victor Stinner95701bd2013-11-06 18:41:07 +0100901 PyObject *ret = NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000902 mod_ty mod;
Victor Stinner95701bd2013-11-06 18:41:07 +0100903 PyArena *arena = NULL;
904 PyObject *filename;
Guido van Rossum98297ee2007-11-06 21:34:58 +0000905
Victor Stinner95701bd2013-11-06 18:41:07 +0100906 filename = PyUnicode_DecodeFSDefault(filename_str);
907 if (filename == NULL)
908 goto exit;
909
910 arena = PyArena_New();
911 if (arena == NULL)
912 goto exit;
913
914 mod = PyParser_ASTFromFileObject(fp, filename, NULL, start, 0, 0,
915 flags, NULL, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000916 if (closeit)
917 fclose(fp);
918 if (mod == NULL) {
Victor Stinner95701bd2013-11-06 18:41:07 +0100919 goto exit;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000920 }
921 ret = run_mod(mod, filename, globals, locals, flags, arena);
Victor Stinner95701bd2013-11-06 18:41:07 +0100922
923exit:
924 Py_XDECREF(filename);
925 if (arena != NULL)
926 PyArena_Free(arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000927 return ret;
Jeremy Hyltonbc320242001-03-22 02:47:58 +0000928}
929
Guido van Rossum6c193fa2007-12-05 05:14:58 +0000930static void
931flush_io(void)
932{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000933 PyObject *f, *r;
934 PyObject *type, *value, *traceback;
Amaury Forgeot d'Arc9ed77352008-04-04 23:25:27 +0000935
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000936 /* Save the current exception */
937 PyErr_Fetch(&type, &value, &traceback);
Amaury Forgeot d'Arc9ed77352008-04-04 23:25:27 +0000938
Victor Stinnerbd303c12013-11-07 23:07:29 +0100939 f = _PySys_GetObjectId(&PyId_stderr);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000940 if (f != NULL) {
Martin v. Löwisafe55bb2011-10-09 10:38:36 +0200941 r = _PyObject_CallMethodId(f, &PyId_flush, "");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000942 if (r)
943 Py_DECREF(r);
944 else
945 PyErr_Clear();
946 }
Victor Stinnerbd303c12013-11-07 23:07:29 +0100947 f = _PySys_GetObjectId(&PyId_stdout);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000948 if (f != NULL) {
Martin v. Löwisafe55bb2011-10-09 10:38:36 +0200949 r = _PyObject_CallMethodId(f, &PyId_flush, "");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000950 if (r)
951 Py_DECREF(r);
952 else
953 PyErr_Clear();
954 }
Amaury Forgeot d'Arc9ed77352008-04-04 23:25:27 +0000955
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000956 PyErr_Restore(type, value, traceback);
Guido van Rossum6c193fa2007-12-05 05:14:58 +0000957}
958
Guido van Rossum82598051997-03-05 00:20:32 +0000959static PyObject *
Victor Stinner95701bd2013-11-06 18:41:07 +0100960run_mod(mod_ty mod, PyObject *filename, PyObject *globals, PyObject *locals,
961 PyCompilerFlags *flags, PyArena *arena)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000962{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000963 PyCodeObject *co;
964 PyObject *v;
Victor Stinner95701bd2013-11-06 18:41:07 +0100965 co = PyAST_CompileObject(mod, filename, flags, -1, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000966 if (co == NULL)
967 return NULL;
Martin v. Löwis4d0d4712010-12-03 20:14:31 +0000968 v = PyEval_EvalCode((PyObject*)co, globals, locals);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000969 Py_DECREF(co);
970 return v;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000971}
972
Guido van Rossum82598051997-03-05 00:20:32 +0000973static PyObject *
Thomas Wouters4d70c3d2006-06-08 14:42:34 +0000974run_pyc_file(FILE *fp, const char *filename, PyObject *globals,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000975 PyObject *locals, PyCompilerFlags *flags)
Guido van Rossumfdef2711994-09-14 13:31:04 +0000976{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000977 PyCodeObject *co;
978 PyObject *v;
979 long magic;
980 long PyImport_GetMagicNumber(void);
Guido van Rossumfdef2711994-09-14 13:31:04 +0000981
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000982 magic = PyMarshal_ReadLongFromFile(fp);
983 if (magic != PyImport_GetMagicNumber()) {
Victor Stinner5200f552015-03-18 13:56:25 +0100984 if (!PyErr_Occurred())
985 PyErr_SetString(PyExc_RuntimeError,
986 "Bad magic number in .pyc file");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000987 return NULL;
988 }
Antoine Pitrou5136ac02012-01-13 18:52:16 +0100989 /* Skip mtime and size */
990 (void) PyMarshal_ReadLongFromFile(fp);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000991 (void) PyMarshal_ReadLongFromFile(fp);
Victor Stinner5200f552015-03-18 13:56:25 +0100992 if (PyErr_Occurred())
993 return NULL;
994
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000995 v = PyMarshal_ReadLastObjectFromFile(fp);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000996 if (v == NULL || !PyCode_Check(v)) {
997 Py_XDECREF(v);
998 PyErr_SetString(PyExc_RuntimeError,
999 "Bad code object in .pyc file");
1000 return NULL;
1001 }
1002 co = (PyCodeObject *)v;
Martin v. Löwis4d0d4712010-12-03 20:14:31 +00001003 v = PyEval_EvalCode((PyObject*)co, globals, locals);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001004 if (v && flags)
1005 flags->cf_flags |= (co->co_flags & PyCF_MASK);
1006 Py_DECREF(co);
1007 return v;
Guido van Rossumfdef2711994-09-14 13:31:04 +00001008}
1009
Guido van Rossum82598051997-03-05 00:20:32 +00001010PyObject *
Victor Stinner14e461d2013-08-26 22:28:21 +02001011Py_CompileStringObject(const char *str, PyObject *filename, int start,
1012 PyCompilerFlags *flags, int optimize)
Jeremy Hyltonbc320242001-03-22 02:47:58 +00001013{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001014 PyCodeObject *co;
1015 mod_ty mod;
1016 PyArena *arena = PyArena_New();
1017 if (arena == NULL)
1018 return NULL;
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001019
Victor Stinner14e461d2013-08-26 22:28:21 +02001020 mod = PyParser_ASTFromStringObject(str, filename, start, flags, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001021 if (mod == NULL) {
1022 PyArena_Free(arena);
1023 return NULL;
1024 }
1025 if (flags && (flags->cf_flags & PyCF_ONLY_AST)) {
1026 PyObject *result = PyAST_mod2obj(mod);
1027 PyArena_Free(arena);
1028 return result;
1029 }
Victor Stinner14e461d2013-08-26 22:28:21 +02001030 co = PyAST_CompileObject(mod, filename, flags, optimize, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001031 PyArena_Free(arena);
1032 return (PyObject *)co;
Guido van Rossum5b722181993-03-30 17:46:03 +00001033}
1034
Victor Stinner14e461d2013-08-26 22:28:21 +02001035PyObject *
1036Py_CompileStringExFlags(const char *str, const char *filename_str, int start,
1037 PyCompilerFlags *flags, int optimize)
1038{
1039 PyObject *filename, *co;
1040 filename = PyUnicode_DecodeFSDefault(filename_str);
1041 if (filename == NULL)
1042 return NULL;
1043 co = Py_CompileStringObject(str, filename, start, flags, optimize);
1044 Py_DECREF(filename);
1045 return co;
1046}
1047
Martin v. Löwis4d0d4712010-12-03 20:14:31 +00001048/* For use in Py_LIMITED_API */
1049#undef Py_CompileString
1050PyObject *
1051PyCompileString(const char *str, const char *filename, int start)
1052{
1053 return Py_CompileStringFlags(str, filename, start, NULL);
1054}
1055
Jeremy Hylton4b38da62001-02-02 18:19:15 +00001056struct symtable *
Victor Stinner14e461d2013-08-26 22:28:21 +02001057Py_SymtableStringObject(const char *str, PyObject *filename, int start)
Jeremy Hylton4b38da62001-02-02 18:19:15 +00001058{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001059 struct symtable *st;
1060 mod_ty mod;
1061 PyCompilerFlags flags;
Victor Stinner14e461d2013-08-26 22:28:21 +02001062 PyArena *arena;
1063
1064 arena = PyArena_New();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001065 if (arena == NULL)
1066 return NULL;
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001067
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001068 flags.cf_flags = 0;
Victor Stinner14e461d2013-08-26 22:28:21 +02001069 mod = PyParser_ASTFromStringObject(str, filename, start, &flags, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001070 if (mod == NULL) {
1071 PyArena_Free(arena);
1072 return NULL;
1073 }
Victor Stinner14e461d2013-08-26 22:28:21 +02001074 st = PySymtable_BuildObject(mod, filename, 0);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001075 PyArena_Free(arena);
1076 return st;
Jeremy Hylton4b38da62001-02-02 18:19:15 +00001077}
1078
Victor Stinner14e461d2013-08-26 22:28:21 +02001079struct symtable *
1080Py_SymtableString(const char *str, const char *filename_str, int start)
1081{
1082 PyObject *filename;
1083 struct symtable *st;
1084
1085 filename = PyUnicode_DecodeFSDefault(filename_str);
1086 if (filename == NULL)
1087 return NULL;
1088 st = Py_SymtableStringObject(str, filename, start);
1089 Py_DECREF(filename);
1090 return st;
1091}
1092
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001093/* Preferred access to parser is through AST. */
1094mod_ty
Victor Stinner14e461d2013-08-26 22:28:21 +02001095PyParser_ASTFromStringObject(const char *s, PyObject *filename, int start,
1096 PyCompilerFlags *flags, PyArena *arena)
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001097{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001098 mod_ty mod;
1099 PyCompilerFlags localflags;
1100 perrdetail err;
1101 int iflags = PARSER_FLAGS(flags);
Christian Heimes4d6ec852008-03-26 22:34:47 +00001102
Victor Stinner14e461d2013-08-26 22:28:21 +02001103 node *n = PyParser_ParseStringObject(s, filename,
1104 &_PyParser_Grammar, start, &err,
1105 &iflags);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001106 if (flags == NULL) {
1107 localflags.cf_flags = 0;
1108 flags = &localflags;
1109 }
1110 if (n) {
1111 flags->cf_flags |= iflags & PyCF_MASK;
Victor Stinner14e461d2013-08-26 22:28:21 +02001112 mod = PyAST_FromNodeObject(n, flags, filename, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001113 PyNode_Free(n);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001114 }
1115 else {
1116 err_input(&err);
Victor Stinner7f2fee32011-04-05 00:39:01 +02001117 mod = NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001118 }
Victor Stinner7f2fee32011-04-05 00:39:01 +02001119 err_free(&err);
1120 return mod;
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001121}
1122
1123mod_ty
Victor Stinner14e461d2013-08-26 22:28:21 +02001124PyParser_ASTFromString(const char *s, const char *filename_str, int start,
1125 PyCompilerFlags *flags, PyArena *arena)
1126{
1127 PyObject *filename;
1128 mod_ty mod;
1129 filename = PyUnicode_DecodeFSDefault(filename_str);
1130 if (filename == NULL)
1131 return NULL;
1132 mod = PyParser_ASTFromStringObject(s, filename, start, flags, arena);
1133 Py_DECREF(filename);
1134 return mod;
1135}
1136
1137mod_ty
1138PyParser_ASTFromFileObject(FILE *fp, PyObject *filename, const char* enc,
1139 int start, char *ps1,
1140 char *ps2, PyCompilerFlags *flags, int *errcode,
1141 PyArena *arena)
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001142{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001143 mod_ty mod;
1144 PyCompilerFlags localflags;
1145 perrdetail err;
1146 int iflags = PARSER_FLAGS(flags);
Christian Heimes4d6ec852008-03-26 22:34:47 +00001147
Victor Stinner14e461d2013-08-26 22:28:21 +02001148 node *n = PyParser_ParseFileObject(fp, filename, enc,
1149 &_PyParser_Grammar,
1150 start, ps1, ps2, &err, &iflags);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001151 if (flags == NULL) {
1152 localflags.cf_flags = 0;
1153 flags = &localflags;
1154 }
1155 if (n) {
1156 flags->cf_flags |= iflags & PyCF_MASK;
Victor Stinner14e461d2013-08-26 22:28:21 +02001157 mod = PyAST_FromNodeObject(n, flags, filename, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001158 PyNode_Free(n);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001159 }
1160 else {
1161 err_input(&err);
1162 if (errcode)
1163 *errcode = err.error;
Victor Stinner7f2fee32011-04-05 00:39:01 +02001164 mod = NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001165 }
Victor Stinner7f2fee32011-04-05 00:39:01 +02001166 err_free(&err);
1167 return mod;
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001168}
1169
Victor Stinner14e461d2013-08-26 22:28:21 +02001170mod_ty
1171PyParser_ASTFromFile(FILE *fp, const char *filename_str, const char* enc,
1172 int start, char *ps1,
1173 char *ps2, PyCompilerFlags *flags, int *errcode,
1174 PyArena *arena)
1175{
1176 mod_ty mod;
1177 PyObject *filename;
1178 filename = PyUnicode_DecodeFSDefault(filename_str);
1179 if (filename == NULL)
1180 return NULL;
1181 mod = PyParser_ASTFromFileObject(fp, filename, enc, start, ps1, ps2,
1182 flags, errcode, arena);
1183 Py_DECREF(filename);
1184 return mod;
1185}
1186
Guido van Rossuma110aa61994-08-29 12:50:44 +00001187/* Simplified interface to parsefile -- return node or set exception */
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001188
Guido van Rossuma110aa61994-08-29 12:50:44 +00001189node *
Martin v. Löwis95292d62002-12-11 14:04:59 +00001190PyParser_SimpleParseFileFlags(FILE *fp, const char *filename, int start, int flags)
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001191{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001192 perrdetail err;
1193 node *n = PyParser_ParseFileFlags(fp, filename, NULL,
1194 &_PyParser_Grammar,
1195 start, NULL, NULL, &err, flags);
1196 if (n == NULL)
1197 err_input(&err);
Victor Stinner7f2fee32011-04-05 00:39:01 +02001198 err_free(&err);
Thomas Wouters4d70c3d2006-06-08 14:42:34 +00001199
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001200 return n;
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001201}
1202
Guido van Rossuma110aa61994-08-29 12:50:44 +00001203/* Simplified interface to parsestring -- return node or set exception */
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001204
Guido van Rossuma110aa61994-08-29 12:50:44 +00001205node *
Martin v. Löwis95292d62002-12-11 14:04:59 +00001206PyParser_SimpleParseStringFlags(const char *str, int start, int flags)
Tim Petersfe2127d2001-07-16 05:37:24 +00001207{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001208 perrdetail err;
1209 node *n = PyParser_ParseStringFlags(str, &_PyParser_Grammar,
1210 start, &err, flags);
1211 if (n == NULL)
1212 err_input(&err);
Victor Stinner7f2fee32011-04-05 00:39:01 +02001213 err_free(&err);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001214 return n;
Tim Petersfe2127d2001-07-16 05:37:24 +00001215}
1216
1217node *
Martin v. Löwis95292d62002-12-11 14:04:59 +00001218PyParser_SimpleParseStringFlagsFilename(const char *str, const char *filename,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001219 int start, int flags)
Thomas Heller6b17abf2002-07-09 09:23:27 +00001220{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001221 perrdetail err;
1222 node *n = PyParser_ParseStringFlagsFilename(str, filename,
1223 &_PyParser_Grammar, start, &err, flags);
1224 if (n == NULL)
1225 err_input(&err);
Victor Stinner7f2fee32011-04-05 00:39:01 +02001226 err_free(&err);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001227 return n;
Thomas Heller6b17abf2002-07-09 09:23:27 +00001228}
1229
1230node *
Martin v. Löwis95292d62002-12-11 14:04:59 +00001231PyParser_SimpleParseStringFilename(const char *str, const char *filename, int start)
Thomas Heller6b17abf2002-07-09 09:23:27 +00001232{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001233 return PyParser_SimpleParseStringFlagsFilename(str, filename, start, 0);
Thomas Heller6b17abf2002-07-09 09:23:27 +00001234}
1235
Guido van Rossum66ebd912003-04-17 16:02:26 +00001236/* May want to move a more generalized form of this to parsetok.c or
1237 even parser modules. */
1238
1239void
Victor Stinner7f2fee32011-04-05 00:39:01 +02001240PyParser_ClearError(perrdetail *err)
1241{
1242 err_free(err);
1243}
1244
1245void
Guido van Rossum66ebd912003-04-17 16:02:26 +00001246PyParser_SetError(perrdetail *err)
1247{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001248 err_input(err);
Guido van Rossum66ebd912003-04-17 16:02:26 +00001249}
1250
Victor Stinner7f2fee32011-04-05 00:39:01 +02001251static void
1252err_free(perrdetail *err)
1253{
1254 Py_CLEAR(err->filename);
1255}
1256
Guido van Rossuma110aa61994-08-29 12:50:44 +00001257/* Set the error appropriate to the given input error code (see errcode.h) */
1258
1259static void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00001260err_input(perrdetail *err)
Guido van Rossuma110aa61994-08-29 12:50:44 +00001261{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001262 PyObject *v, *w, *errtype, *errtext;
1263 PyObject *msg_obj = NULL;
1264 char *msg = NULL;
Serhiy Storchaka65fd0592014-01-21 22:26:52 +02001265 int offset = err->offset;
Victor Stinner4c7c8c32010-10-16 13:14:10 +00001266
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001267 errtype = PyExc_SyntaxError;
1268 switch (err->error) {
1269 case E_ERROR:
1270 return;
1271 case E_SYNTAX:
1272 errtype = PyExc_IndentationError;
1273 if (err->expected == INDENT)
1274 msg = "expected an indented block";
1275 else if (err->token == INDENT)
1276 msg = "unexpected indent";
1277 else if (err->token == DEDENT)
1278 msg = "unexpected unindent";
1279 else {
1280 errtype = PyExc_SyntaxError;
1281 msg = "invalid syntax";
1282 }
1283 break;
1284 case E_TOKEN:
1285 msg = "invalid token";
1286 break;
1287 case E_EOFS:
1288 msg = "EOF while scanning triple-quoted string literal";
1289 break;
1290 case E_EOLS:
1291 msg = "EOL while scanning string literal";
1292 break;
1293 case E_INTR:
1294 if (!PyErr_Occurred())
1295 PyErr_SetNone(PyExc_KeyboardInterrupt);
1296 goto cleanup;
1297 case E_NOMEM:
1298 PyErr_NoMemory();
1299 goto cleanup;
1300 case E_EOF:
1301 msg = "unexpected EOF while parsing";
1302 break;
1303 case E_TABSPACE:
1304 errtype = PyExc_TabError;
1305 msg = "inconsistent use of tabs and spaces in indentation";
1306 break;
1307 case E_OVERFLOW:
1308 msg = "expression too long";
1309 break;
1310 case E_DEDENT:
1311 errtype = PyExc_IndentationError;
1312 msg = "unindent does not match any outer indentation level";
1313 break;
1314 case E_TOODEEP:
1315 errtype = PyExc_IndentationError;
1316 msg = "too many levels of indentation";
1317 break;
1318 case E_DECODE: {
1319 PyObject *type, *value, *tb;
1320 PyErr_Fetch(&type, &value, &tb);
1321 msg = "unknown decode error";
1322 if (value != NULL)
1323 msg_obj = PyObject_Str(value);
1324 Py_XDECREF(type);
1325 Py_XDECREF(value);
1326 Py_XDECREF(tb);
1327 break;
1328 }
1329 case E_LINECONT:
1330 msg = "unexpected character after line continuation character";
1331 break;
Martin v. Löwis47383402007-08-15 07:32:56 +00001332
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001333 case E_IDENTIFIER:
1334 msg = "invalid character in identifier";
1335 break;
Meador Ingefa21bf02012-01-19 01:08:41 -06001336 case E_BADSINGLE:
1337 msg = "multiple statements found while compiling a single statement";
1338 break;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001339 default:
1340 fprintf(stderr, "error=%d\n", err->error);
1341 msg = "unknown parsing error";
1342 break;
1343 }
1344 /* err->text may not be UTF-8 in case of decoding errors.
1345 Explicitly convert to an object. */
1346 if (!err->text) {
1347 errtext = Py_None;
1348 Py_INCREF(Py_None);
1349 } else {
Serhiy Storchaka65fd0592014-01-21 22:26:52 +02001350 errtext = PyUnicode_DecodeUTF8(err->text, err->offset,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001351 "replace");
Serhiy Storchaka65fd0592014-01-21 22:26:52 +02001352 if (errtext != NULL) {
1353 Py_ssize_t len = strlen(err->text);
1354 offset = (int)PyUnicode_GET_LENGTH(errtext);
1355 if (len != err->offset) {
1356 Py_DECREF(errtext);
1357 errtext = PyUnicode_DecodeUTF8(err->text, len,
1358 "replace");
1359 }
1360 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001361 }
Victor Stinner7f2fee32011-04-05 00:39:01 +02001362 v = Py_BuildValue("(OiiN)", err->filename,
Serhiy Storchaka65fd0592014-01-21 22:26:52 +02001363 err->lineno, offset, errtext);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001364 if (v != NULL) {
1365 if (msg_obj)
1366 w = Py_BuildValue("(OO)", msg_obj, v);
1367 else
1368 w = Py_BuildValue("(sO)", msg, v);
1369 } else
1370 w = NULL;
1371 Py_XDECREF(v);
1372 PyErr_SetObject(errtype, w);
1373 Py_XDECREF(w);
Georg Brandl3dbca812008-07-23 16:10:53 +00001374cleanup:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001375 Py_XDECREF(msg_obj);
1376 if (err->text != NULL) {
1377 PyObject_FREE(err->text);
1378 err->text = NULL;
1379 }
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001380}
1381
Fredrik Lundh2f15b252000-08-27 19:15:31 +00001382
Zachary Warec4821d62014-11-21 23:35:12 -06001383#if defined(USE_STACKCHECK)
1384#if defined(WIN32) && defined(_MSC_VER)
1385
1386/* Stack checking for Microsoft C */
1387
1388#include <malloc.h>
1389#include <excpt.h>
1390
1391/*
1392 * Return non-zero when we run out of memory on the stack; zero otherwise.
1393 */
1394int
1395PyOS_CheckStack(void)
1396{
1397 __try {
1398 /* alloca throws a stack overflow exception if there's
1399 not enough space left on the stack */
1400 alloca(PYOS_STACK_MARGIN * sizeof(void*));
1401 return 0;
1402 } __except (GetExceptionCode() == STATUS_STACK_OVERFLOW ?
1403 EXCEPTION_EXECUTE_HANDLER :
1404 EXCEPTION_CONTINUE_SEARCH) {
1405 int errcode = _resetstkoflw();
1406 if (errcode == 0)
1407 {
1408 Py_FatalError("Could not reset the stack!");
1409 }
1410 }
1411 return 1;
1412}
1413
1414#endif /* WIN32 && _MSC_VER */
1415
1416/* Alternate implementations can be added here... */
1417
1418#endif /* USE_STACKCHECK */
1419
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001420/* Deprecated C API functions still provided for binary compatiblity */
1421
1422#undef PyParser_SimpleParseFile
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001423PyAPI_FUNC(node *)
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001424PyParser_SimpleParseFile(FILE *fp, const char *filename, int start)
1425{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001426 return PyParser_SimpleParseFileFlags(fp, filename, start, 0);
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001427}
1428
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001429#undef PyParser_SimpleParseString
1430PyAPI_FUNC(node *)
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001431PyParser_SimpleParseString(const char *str, int start)
1432{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001433 return PyParser_SimpleParseStringFlags(str, start, 0);
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001434}
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001435
1436#undef PyRun_AnyFile
1437PyAPI_FUNC(int)
1438PyRun_AnyFile(FILE *fp, const char *name)
1439{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001440 return PyRun_AnyFileExFlags(fp, name, 0, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001441}
1442
1443#undef PyRun_AnyFileEx
1444PyAPI_FUNC(int)
1445PyRun_AnyFileEx(FILE *fp, const char *name, int closeit)
1446{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001447 return PyRun_AnyFileExFlags(fp, name, closeit, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001448}
1449
1450#undef PyRun_AnyFileFlags
1451PyAPI_FUNC(int)
1452PyRun_AnyFileFlags(FILE *fp, const char *name, PyCompilerFlags *flags)
1453{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001454 return PyRun_AnyFileExFlags(fp, name, 0, flags);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001455}
1456
1457#undef PyRun_File
1458PyAPI_FUNC(PyObject *)
1459PyRun_File(FILE *fp, const char *p, int s, PyObject *g, PyObject *l)
1460{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001461 return PyRun_FileExFlags(fp, p, s, g, l, 0, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001462}
1463
1464#undef PyRun_FileEx
1465PyAPI_FUNC(PyObject *)
1466PyRun_FileEx(FILE *fp, const char *p, int s, PyObject *g, PyObject *l, int c)
1467{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001468 return PyRun_FileExFlags(fp, p, s, g, l, c, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001469}
1470
1471#undef PyRun_FileFlags
1472PyAPI_FUNC(PyObject *)
1473PyRun_FileFlags(FILE *fp, const char *p, int s, PyObject *g, PyObject *l,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001474 PyCompilerFlags *flags)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001475{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001476 return PyRun_FileExFlags(fp, p, s, g, l, 0, flags);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001477}
1478
1479#undef PyRun_SimpleFile
1480PyAPI_FUNC(int)
1481PyRun_SimpleFile(FILE *f, const char *p)
1482{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001483 return PyRun_SimpleFileExFlags(f, p, 0, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001484}
1485
1486#undef PyRun_SimpleFileEx
1487PyAPI_FUNC(int)
1488PyRun_SimpleFileEx(FILE *f, const char *p, int c)
1489{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001490 return PyRun_SimpleFileExFlags(f, p, c, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001491}
1492
1493
1494#undef PyRun_String
1495PyAPI_FUNC(PyObject *)
1496PyRun_String(const char *str, int s, PyObject *g, PyObject *l)
1497{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001498 return PyRun_StringFlags(str, s, g, l, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001499}
1500
1501#undef PyRun_SimpleString
1502PyAPI_FUNC(int)
1503PyRun_SimpleString(const char *s)
1504{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001505 return PyRun_SimpleStringFlags(s, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001506}
1507
1508#undef Py_CompileString
1509PyAPI_FUNC(PyObject *)
1510Py_CompileString(const char *str, const char *p, int s)
1511{
Georg Brandl8334fd92010-12-04 10:26:46 +00001512 return Py_CompileStringExFlags(str, p, s, NULL, -1);
1513}
1514
1515#undef Py_CompileStringFlags
1516PyAPI_FUNC(PyObject *)
1517Py_CompileStringFlags(const char *str, const char *p, int s,
1518 PyCompilerFlags *flags)
1519{
1520 return Py_CompileStringExFlags(str, p, s, flags, -1);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001521}
1522
1523#undef PyRun_InteractiveOne
1524PyAPI_FUNC(int)
1525PyRun_InteractiveOne(FILE *f, const char *p)
1526{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001527 return PyRun_InteractiveOneFlags(f, p, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001528}
1529
1530#undef PyRun_InteractiveLoop
1531PyAPI_FUNC(int)
1532PyRun_InteractiveLoop(FILE *f, const char *p)
1533{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001534 return PyRun_InteractiveLoopFlags(f, p, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001535}
1536
1537#ifdef __cplusplus
1538}
1539#endif