blob: 90b29cb101651e1c05744124f503c32bb1727462 [file] [log] [blame]
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001
Eric Snowc7ec9982017-05-23 23:00:52 -07002/* Top level execution of Python code (including in __main__) */
3
4/* To help control the interfaces between the startup, execution and
5 * shutdown code, the phases are split across separate modules (boostrap,
6 * pythonrun, shutdown)
7 */
8
9/* TODO: Cull includes following phase split */
Guido van Rossum1984f1e1992-08-04 12:41:02 +000010
Guido van Rossum82598051997-03-05 00:20:32 +000011#include "Python.h"
Guido van Rossum1984f1e1992-08-04 12:41:02 +000012
Jeremy Hylton3e0055f2005-10-20 19:59:25 +000013#include "Python-ast.h"
Guido van Rossumd8faa362007-04-27 19:54:29 +000014#undef Yield /* undefine macro conflicting with winbase.h */
Eric Snow2ebc5ce2017-09-07 23:51:28 -060015#include "internal/pystate.h"
Guido van Rossum1984f1e1992-08-04 12:41:02 +000016#include "grammar.h"
17#include "node.h"
Fred Drake85f36392000-07-11 17:53:00 +000018#include "token.h"
Guido van Rossum1984f1e1992-08-04 12:41:02 +000019#include "parsetok.h"
Guido van Rossum1984f1e1992-08-04 12:41:02 +000020#include "errcode.h"
Jeremy Hylton3e0055f2005-10-20 19:59:25 +000021#include "code.h"
Jeremy Hylton4b38da62001-02-02 18:19:15 +000022#include "symtable.h"
Jeremy Hylton3e0055f2005-10-20 19:59:25 +000023#include "ast.h"
Guido van Rossumfdef2711994-09-14 13:31:04 +000024#include "marshal.h"
Martin v. Löwis790465f2008-04-05 20:41:37 +000025#include "osdefs.h"
Victor Stinner518e6102014-03-18 02:06:38 +010026#include <locale.h>
Guido van Rossum1984f1e1992-08-04 12:41:02 +000027
Thomas Wouters0e3f5912006-08-11 14:57:12 +000028#ifdef HAVE_SIGNAL_H
Guido van Rossuma9e7dc11992-10-18 18:53:57 +000029#include <signal.h>
Thomas Wouters0e3f5912006-08-11 14:57:12 +000030#endif
Guido van Rossuma9e7dc11992-10-18 18:53:57 +000031
Benjamin Peterson80a50ac2009-01-02 21:24:04 +000032#ifdef MS_WINDOWS
Martin v. Löwis5c88d812009-01-02 20:47:48 +000033#include "malloc.h" /* for alloca */
Benjamin Peterson80a50ac2009-01-02 21:24:04 +000034#endif
Martin v. Löwis5c88d812009-01-02 20:47:48 +000035
Martin v. Löwis6238d2b2002-06-30 15:26:10 +000036#ifdef MS_WINDOWS
Guido van Rossuma44823b1995-03-14 15:01:17 +000037#undef BYTE
38#include "windows.h"
39#endif
40
Victor Stinnerbd303c12013-11-07 23:07:29 +010041_Py_IDENTIFIER(builtins);
Victor Stinner09054372013-11-06 22:41:44 +010042_Py_IDENTIFIER(excepthook);
Victor Stinner3f36a572013-11-12 21:39:02 +010043_Py_IDENTIFIER(flush);
Victor Stinnerbd303c12013-11-07 23:07:29 +010044_Py_IDENTIFIER(last_traceback);
Victor Stinner09054372013-11-06 22:41:44 +010045_Py_IDENTIFIER(last_type);
46_Py_IDENTIFIER(last_value);
Victor Stinnerbd303c12013-11-07 23:07:29 +010047_Py_IDENTIFIER(ps1);
48_Py_IDENTIFIER(ps2);
49_Py_IDENTIFIER(stdin);
50_Py_IDENTIFIER(stdout);
51_Py_IDENTIFIER(stderr);
Victor Stinnerefa7a0e2013-11-07 12:37:56 +010052_Py_static_string(PyId_string, "<string>");
Victor Stinner09054372013-11-06 22:41:44 +010053
Thomas Wouters49fd7fa2006-04-21 10:40:58 +000054#ifdef __cplusplus
55extern "C" {
Neal Norwitz4281cef2006-03-04 19:58:13 +000056#endif
57
Guido van Rossum82598051997-03-05 00:20:32 +000058extern grammar _PyParser_Grammar; /* From graminit.c */
Guido van Rossum1984f1e1992-08-04 12:41:02 +000059
Guido van Rossumb73cc041993-11-01 16:28:59 +000060/* Forward */
Amaury Forgeot d'Arc7fedbe52008-04-10 21:03:09 +000061static void flush_io(void);
Victor Stinner95701bd2013-11-06 18:41:07 +010062static PyObject *run_mod(mod_ty, PyObject *, PyObject *, PyObject *,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000063 PyCompilerFlags *, PyArena *);
Martin v. Löwis95292d62002-12-11 14:04:59 +000064static PyObject *run_pyc_file(FILE *, const char *, PyObject *, PyObject *,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000065 PyCompilerFlags *);
Tim Petersdbd9ba62000-07-09 03:09:57 +000066static void err_input(perrdetail *);
Victor Stinner7f2fee32011-04-05 00:39:01 +020067static void err_free(perrdetail *);
xdegayee0582a32017-11-12 16:50:48 +010068static int PyRun_InteractiveOneObjectEx(FILE *, PyObject *, PyCompilerFlags *);
Guido van Rossumce3a72a2007-10-19 23:16:50 +000069
Guido van Rossum1984f1e1992-08-04 12:41:02 +000070/* Parse input from a file and execute it */
Guido van Rossum1984f1e1992-08-04 12:41:02 +000071int
Thomas Wouters4d70c3d2006-06-08 14:42:34 +000072PyRun_AnyFileExFlags(FILE *fp, const char *filename, int closeit,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000073 PyCompilerFlags *flags)
Jeremy Hyltonbc320242001-03-22 02:47:58 +000074{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000075 if (filename == NULL)
76 filename = "???";
77 if (Py_FdIsInteractive(fp, filename)) {
78 int err = PyRun_InteractiveLoopFlags(fp, filename, flags);
79 if (closeit)
80 fclose(fp);
81 return err;
82 }
83 else
84 return PyRun_SimpleFileExFlags(fp, filename, closeit, flags);
Guido van Rossum1984f1e1992-08-04 12:41:02 +000085}
86
87int
Victor Stinner95701bd2013-11-06 18:41:07 +010088PyRun_InteractiveLoopFlags(FILE *fp, const char *filename_str, PyCompilerFlags *flags)
Jeremy Hyltonbc320242001-03-22 02:47:58 +000089{
Victor Stinner95701bd2013-11-06 18:41:07 +010090 PyObject *filename, *v;
91 int ret, err;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000092 PyCompilerFlags local_flags;
xdegayee0582a32017-11-12 16:50:48 +010093 int nomem_count = 0;
Jeremy Hylton9f324e92001-03-01 22:59:14 +000094
Victor Stinner95701bd2013-11-06 18:41:07 +010095 filename = PyUnicode_DecodeFSDefault(filename_str);
96 if (filename == NULL) {
97 PyErr_Print();
98 return -1;
99 }
100
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000101 if (flags == NULL) {
102 flags = &local_flags;
103 local_flags.cf_flags = 0;
104 }
Victor Stinner09054372013-11-06 22:41:44 +0100105 v = _PySys_GetObjectId(&PyId_ps1);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000106 if (v == NULL) {
Victor Stinner09054372013-11-06 22:41:44 +0100107 _PySys_SetObjectId(&PyId_ps1, v = PyUnicode_FromString(">>> "));
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000108 Py_XDECREF(v);
109 }
Victor Stinner09054372013-11-06 22:41:44 +0100110 v = _PySys_GetObjectId(&PyId_ps2);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000111 if (v == NULL) {
Victor Stinner09054372013-11-06 22:41:44 +0100112 _PySys_SetObjectId(&PyId_ps2, v = PyUnicode_FromString("... "));
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000113 Py_XDECREF(v);
114 }
xdegayee0582a32017-11-12 16:50:48 +0100115 err = 0;
116 do {
117 ret = PyRun_InteractiveOneObjectEx(fp, filename, flags);
118 if (ret == -1 && PyErr_Occurred()) {
119 /* Prevent an endless loop after multiple consecutive MemoryErrors
120 * while still allowing an interactive command to fail with a
121 * MemoryError. */
122 if (PyErr_ExceptionMatches(PyExc_MemoryError)) {
123 if (++nomem_count > 16) {
124 PyErr_Clear();
125 err = -1;
126 break;
127 }
128 } else {
129 nomem_count = 0;
130 }
131 PyErr_Print();
132 flush_io();
133 } else {
134 nomem_count = 0;
135 }
Eric Snowdae02762017-09-14 00:35:58 -0700136#ifdef Py_REF_DEBUG
137 if (_PyDebug_XOptionShowRefCount() == Py_True)
138 _PyDebug_PrintTotalRefs();
139#endif
xdegayee0582a32017-11-12 16:50:48 +0100140 } while (ret != E_EOF);
Victor Stinner95701bd2013-11-06 18:41:07 +0100141 Py_DECREF(filename);
142 return err;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000143}
144
Neil Schemenauerc24ea082002-03-22 23:53:36 +0000145/* compute parser flags based on compiler flags */
Benjamin Petersonf5b52242009-03-02 23:31:26 +0000146static int PARSER_FLAGS(PyCompilerFlags *flags)
147{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000148 int parser_flags = 0;
149 if (!flags)
150 return 0;
151 if (flags->cf_flags & PyCF_DONT_IMPLY_DEDENT)
152 parser_flags |= PyPARSE_DONT_IMPLY_DEDENT;
153 if (flags->cf_flags & PyCF_IGNORE_COOKIE)
154 parser_flags |= PyPARSE_IGNORE_COOKIE;
155 if (flags->cf_flags & CO_FUTURE_BARRY_AS_BDFL)
156 parser_flags |= PyPARSE_BARRY_AS_BDFL;
157 return parser_flags;
Benjamin Petersonf5b52242009-03-02 23:31:26 +0000158}
Neil Schemenauerc24ea082002-03-22 23:53:36 +0000159
Thomas Wouters89f507f2006-12-13 04:49:30 +0000160#if 0
161/* Keep an example of flags with future keyword support. */
162#define PARSER_FLAGS(flags) \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000163 ((flags) ? ((((flags)->cf_flags & PyCF_DONT_IMPLY_DEDENT) ? \
164 PyPARSE_DONT_IMPLY_DEDENT : 0) \
165 | ((flags)->cf_flags & CO_FUTURE_WITH_STATEMENT ? \
166 PyPARSE_WITH_IS_KEYWORD : 0)) : 0)
Thomas Wouters89f507f2006-12-13 04:49:30 +0000167#endif
168
xdegayee0582a32017-11-12 16:50:48 +0100169/* A PyRun_InteractiveOneObject() auxiliary function that does not print the
170 * error on failure. */
171static int
172PyRun_InteractiveOneObjectEx(FILE *fp, PyObject *filename,
173 PyCompilerFlags *flags)
Jeremy Hylton9f324e92001-03-01 22:59:14 +0000174{
Victor Stinner95701bd2013-11-06 18:41:07 +0100175 PyObject *m, *d, *v, *w, *oenc = NULL, *mod_name;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000176 mod_ty mod;
177 PyArena *arena;
Serhiy Storchaka85b0f5b2016-11-20 10:16:47 +0200178 const char *ps1 = "", *ps2 = "", *enc = NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000179 int errcode = 0;
Martin v. Löwisbd928fe2011-10-14 10:20:37 +0200180 _Py_IDENTIFIER(encoding);
Victor Stinner95701bd2013-11-06 18:41:07 +0100181 _Py_IDENTIFIER(__main__);
182
183 mod_name = _PyUnicode_FromId(&PyId___main__); /* borrowed */
184 if (mod_name == NULL) {
Victor Stinner95701bd2013-11-06 18:41:07 +0100185 return -1;
186 }
Tim Petersfe2127d2001-07-16 05:37:24 +0000187
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000188 if (fp == stdin) {
Benjamin Petersonfe1b22a2013-04-29 10:23:08 -0400189 /* Fetch encoding from sys.stdin if possible. */
Victor Stinnerbd303c12013-11-07 23:07:29 +0100190 v = _PySys_GetObjectId(&PyId_stdin);
Benjamin Petersonfe1b22a2013-04-29 10:23:08 -0400191 if (v && v != Py_None) {
192 oenc = _PyObject_GetAttrId(v, &PyId_encoding);
193 if (oenc)
Serhiy Storchaka06515832016-11-20 09:13:07 +0200194 enc = PyUnicode_AsUTF8(oenc);
Benjamin Petersonfe1b22a2013-04-29 10:23:08 -0400195 if (!enc)
196 PyErr_Clear();
197 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000198 }
Victor Stinner09054372013-11-06 22:41:44 +0100199 v = _PySys_GetObjectId(&PyId_ps1);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000200 if (v != NULL) {
201 v = PyObject_Str(v);
202 if (v == NULL)
203 PyErr_Clear();
Victor Stinner386fe712010-05-19 00:34:15 +0000204 else if (PyUnicode_Check(v)) {
Serhiy Storchaka06515832016-11-20 09:13:07 +0200205 ps1 = PyUnicode_AsUTF8(v);
Victor Stinner386fe712010-05-19 00:34:15 +0000206 if (ps1 == NULL) {
207 PyErr_Clear();
208 ps1 = "";
209 }
210 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000211 }
Victor Stinner09054372013-11-06 22:41:44 +0100212 w = _PySys_GetObjectId(&PyId_ps2);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000213 if (w != NULL) {
214 w = PyObject_Str(w);
215 if (w == NULL)
216 PyErr_Clear();
Victor Stinner386fe712010-05-19 00:34:15 +0000217 else if (PyUnicode_Check(w)) {
Serhiy Storchaka06515832016-11-20 09:13:07 +0200218 ps2 = PyUnicode_AsUTF8(w);
Victor Stinner386fe712010-05-19 00:34:15 +0000219 if (ps2 == NULL) {
220 PyErr_Clear();
221 ps2 = "";
222 }
223 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000224 }
225 arena = PyArena_New();
226 if (arena == NULL) {
227 Py_XDECREF(v);
228 Py_XDECREF(w);
229 Py_XDECREF(oenc);
230 return -1;
231 }
Victor Stinner95701bd2013-11-06 18:41:07 +0100232 mod = PyParser_ASTFromFileObject(fp, filename, enc,
233 Py_single_input, ps1, ps2,
234 flags, &errcode, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000235 Py_XDECREF(v);
236 Py_XDECREF(w);
237 Py_XDECREF(oenc);
238 if (mod == NULL) {
239 PyArena_Free(arena);
240 if (errcode == E_EOF) {
241 PyErr_Clear();
242 return E_EOF;
243 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000244 return -1;
245 }
Victor Stinner95701bd2013-11-06 18:41:07 +0100246 m = PyImport_AddModuleObject(mod_name);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000247 if (m == NULL) {
248 PyArena_Free(arena);
249 return -1;
250 }
251 d = PyModule_GetDict(m);
252 v = run_mod(mod, filename, d, d, flags, arena);
253 PyArena_Free(arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000254 if (v == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000255 return -1;
256 }
257 Py_DECREF(v);
Antoine Pitrou9845c7e2014-05-11 13:42:17 +0200258 flush_io();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000259 return 0;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000260}
261
Victor Stinner95701bd2013-11-06 18:41:07 +0100262int
xdegayee0582a32017-11-12 16:50:48 +0100263PyRun_InteractiveOneObject(FILE *fp, PyObject *filename, PyCompilerFlags *flags)
264{
265 int res;
266
267 res = PyRun_InteractiveOneObjectEx(fp, filename, flags);
268 if (res == -1) {
269 PyErr_Print();
270 flush_io();
271 }
272 return res;
273}
274
275int
Victor Stinner95701bd2013-11-06 18:41:07 +0100276PyRun_InteractiveOneFlags(FILE *fp, const char *filename_str, PyCompilerFlags *flags)
277{
278 PyObject *filename;
279 int res;
280
281 filename = PyUnicode_DecodeFSDefault(filename_str);
282 if (filename == NULL) {
283 PyErr_Print();
284 return -1;
285 }
286 res = PyRun_InteractiveOneObject(fp, filename, flags);
287 Py_DECREF(filename);
288 return res;
289}
290
291
Martin v. Löwisbe4c0f52001-01-04 20:30:56 +0000292/* Check whether a file maybe a pyc file: Look at the extension,
293 the file type, and, if we may close it, at the first few bytes. */
294
295static int
Martin v. Löwis95292d62002-12-11 14:04:59 +0000296maybe_pyc_file(FILE *fp, const char* filename, const char* ext, int closeit)
Martin v. Löwisbe4c0f52001-01-04 20:30:56 +0000297{
Brett Cannonf299abd2015-04-13 14:21:02 -0400298 if (strcmp(ext, ".pyc") == 0)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000299 return 1;
Martin v. Löwisbe4c0f52001-01-04 20:30:56 +0000300
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000301 /* Only look into the file if we are allowed to close it, since
302 it then should also be seekable. */
303 if (closeit) {
304 /* Read only two bytes of the magic. If the file was opened in
305 text mode, the bytes 3 and 4 of the magic (\r\n) might not
306 be read as they are on disk. */
307 unsigned int halfmagic = PyImport_GetMagicNumber() & 0xFFFF;
308 unsigned char buf[2];
309 /* Mess: In case of -x, the stream is NOT at its start now,
310 and ungetc() was used to push back the first newline,
311 which makes the current stream position formally undefined,
312 and a x-platform nightmare.
313 Unfortunately, we have no direct way to know whether -x
314 was specified. So we use a terrible hack: if the current
315 stream position is not 0, we assume -x was specified, and
316 give up. Bug 132850 on SourceForge spells out the
317 hopelessness of trying anything else (fseek and ftell
318 don't work predictably x-platform for text-mode files).
319 */
320 int ispyc = 0;
321 if (ftell(fp) == 0) {
322 if (fread(buf, 1, 2, fp) == 2 &&
323 ((unsigned int)buf[1]<<8 | buf[0]) == halfmagic)
324 ispyc = 1;
325 rewind(fp);
326 }
327 return ispyc;
328 }
329 return 0;
Tim Petersd08e3822003-04-17 15:24:21 +0000330}
Martin v. Löwisbe4c0f52001-01-04 20:30:56 +0000331
Antoine Pitrou32d483c2013-07-30 21:01:23 +0200332static int
333set_main_loader(PyObject *d, const char *filename, const char *loader_name)
Nick Coghlan85e729e2012-07-15 18:09:52 +1000334{
335 PyInterpreterState *interp;
336 PyThreadState *tstate;
Eric Snow32439d62015-05-02 19:15:18 -0600337 PyObject *filename_obj, *bootstrap, *loader_type = NULL, *loader;
Nick Coghlanb7a58942012-07-15 23:21:08 +1000338 int result = 0;
Andrew Svetlov90c0eb22012-11-01 14:51:14 +0200339
340 filename_obj = PyUnicode_DecodeFSDefault(filename);
341 if (filename_obj == NULL)
342 return -1;
Nick Coghlan85e729e2012-07-15 18:09:52 +1000343 /* Get current thread state and interpreter pointer */
344 tstate = PyThreadState_GET();
345 interp = tstate->interp;
Eric Snow32439d62015-05-02 19:15:18 -0600346 bootstrap = PyObject_GetAttrString(interp->importlib,
347 "_bootstrap_external");
348 if (bootstrap != NULL) {
349 loader_type = PyObject_GetAttrString(bootstrap, loader_name);
350 Py_DECREF(bootstrap);
351 }
Nick Coghlan3f94cbf2012-07-15 19:10:39 +1000352 if (loader_type == NULL) {
Andrew Svetlov90c0eb22012-11-01 14:51:14 +0200353 Py_DECREF(filename_obj);
Nick Coghlan3f94cbf2012-07-15 19:10:39 +1000354 return -1;
355 }
Andrew Svetlov90c0eb22012-11-01 14:51:14 +0200356 loader = PyObject_CallFunction(loader_type, "sN", "__main__", filename_obj);
Nick Coghlanb7a58942012-07-15 23:21:08 +1000357 Py_DECREF(loader_type);
358 if (loader == NULL) {
Nick Coghlan85e729e2012-07-15 18:09:52 +1000359 return -1;
360 }
Nick Coghlanb7a58942012-07-15 23:21:08 +1000361 if (PyDict_SetItemString(d, "__loader__", loader) < 0) {
362 result = -1;
363 }
Nick Coghlan85e729e2012-07-15 18:09:52 +1000364 Py_DECREF(loader);
Nick Coghlanb7a58942012-07-15 23:21:08 +1000365 return result;
Nick Coghlan85e729e2012-07-15 18:09:52 +1000366}
367
368int
Martin v. Löwis95292d62002-12-11 14:04:59 +0000369PyRun_SimpleFileExFlags(FILE *fp, const char *filename, int closeit,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000370 PyCompilerFlags *flags)
Jeremy Hyltonbc320242001-03-22 02:47:58 +0000371{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000372 PyObject *m, *d, *v;
373 const char *ext;
Hynek Schlawack5c6b3e22012-11-07 09:02:24 +0100374 int set_file_name = 0, ret = -1;
Victor Stinner0fcab4a2011-01-04 12:59:15 +0000375 size_t len;
Guido van Rossumfdef2711994-09-14 13:31:04 +0000376
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000377 m = PyImport_AddModule("__main__");
378 if (m == NULL)
379 return -1;
Hynek Schlawack5c6b3e22012-11-07 09:02:24 +0100380 Py_INCREF(m);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000381 d = PyModule_GetDict(m);
382 if (PyDict_GetItemString(d, "__file__") == NULL) {
383 PyObject *f;
Victor Stinner4c7c8c32010-10-16 13:14:10 +0000384 f = PyUnicode_DecodeFSDefault(filename);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000385 if (f == NULL)
Hynek Schlawack5c6b3e22012-11-07 09:02:24 +0100386 goto done;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000387 if (PyDict_SetItemString(d, "__file__", f) < 0) {
388 Py_DECREF(f);
Hynek Schlawack5c6b3e22012-11-07 09:02:24 +0100389 goto done;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000390 }
Barry Warsaw916048d2011-09-20 14:45:44 -0400391 if (PyDict_SetItemString(d, "__cached__", Py_None) < 0) {
392 Py_DECREF(f);
Hynek Schlawack5c6b3e22012-11-07 09:02:24 +0100393 goto done;
Barry Warsaw916048d2011-09-20 14:45:44 -0400394 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000395 set_file_name = 1;
396 Py_DECREF(f);
397 }
398 len = strlen(filename);
399 ext = filename + len - (len > 4 ? 4 : 0);
400 if (maybe_pyc_file(fp, filename, ext, closeit)) {
Christian Heimes04ac4c12012-09-11 15:47:28 +0200401 FILE *pyc_fp;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000402 /* Try to run a pyc file. First, re-open in binary */
403 if (closeit)
404 fclose(fp);
Victor Stinnerdaf45552013-08-28 00:53:59 +0200405 if ((pyc_fp = _Py_fopen(filename, "rb")) == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000406 fprintf(stderr, "python: Can't reopen .pyc file\n");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000407 goto done;
408 }
Nick Coghlan85e729e2012-07-15 18:09:52 +1000409
410 if (set_main_loader(d, filename, "SourcelessFileLoader") < 0) {
411 fprintf(stderr, "python: failed to set __main__.__loader__\n");
412 ret = -1;
Christian Heimes04ac4c12012-09-11 15:47:28 +0200413 fclose(pyc_fp);
Nick Coghlan85e729e2012-07-15 18:09:52 +1000414 goto done;
415 }
Christian Heimes04ac4c12012-09-11 15:47:28 +0200416 v = run_pyc_file(pyc_fp, filename, d, d, flags);
417 fclose(pyc_fp);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000418 } else {
Nick Coghlan85e729e2012-07-15 18:09:52 +1000419 /* When running from stdin, leave __main__.__loader__ alone */
420 if (strcmp(filename, "<stdin>") != 0 &&
421 set_main_loader(d, filename, "SourceFileLoader") < 0) {
422 fprintf(stderr, "python: failed to set __main__.__loader__\n");
423 ret = -1;
424 goto done;
425 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000426 v = PyRun_FileExFlags(fp, filename, Py_file_input, d, d,
427 closeit, flags);
428 }
429 flush_io();
430 if (v == NULL) {
431 PyErr_Print();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000432 goto done;
433 }
434 Py_DECREF(v);
435 ret = 0;
Guido van Rossumd8faa362007-04-27 19:54:29 +0000436 done:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000437 if (set_file_name && PyDict_DelItemString(d, "__file__"))
438 PyErr_Clear();
Hynek Schlawack5c6b3e22012-11-07 09:02:24 +0100439 Py_DECREF(m);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000440 return ret;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000441}
442
443int
Martin v. Löwis95292d62002-12-11 14:04:59 +0000444PyRun_SimpleStringFlags(const char *command, PyCompilerFlags *flags)
Guido van Rossum393661d2001-08-31 17:40:15 +0000445{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000446 PyObject *m, *d, *v;
447 m = PyImport_AddModule("__main__");
448 if (m == NULL)
449 return -1;
450 d = PyModule_GetDict(m);
451 v = PyRun_StringFlags(command, Py_file_input, d, d, flags);
452 if (v == NULL) {
453 PyErr_Print();
454 return -1;
455 }
456 Py_DECREF(v);
457 return 0;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000458}
459
Barry Warsaw035574d1997-08-29 22:07:17 +0000460static int
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100461parse_syntax_error(PyObject *err, PyObject **message, PyObject **filename,
462 int *lineno, int *offset, PyObject **text)
Barry Warsaw035574d1997-08-29 22:07:17 +0000463{
Serhiy Storchaka56f6e762015-09-06 21:25:30 +0300464 int hold;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000465 PyObject *v;
Martin v. Löwisbd928fe2011-10-14 10:20:37 +0200466 _Py_IDENTIFIER(msg);
467 _Py_IDENTIFIER(filename);
468 _Py_IDENTIFIER(lineno);
469 _Py_IDENTIFIER(offset);
470 _Py_IDENTIFIER(text);
Barry Warsaw035574d1997-08-29 22:07:17 +0000471
Benjamin Peterson80d50422012-04-03 00:30:38 -0400472 *message = NULL;
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100473 *filename = NULL;
Benjamin Peterson80d50422012-04-03 00:30:38 -0400474
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000475 /* new style errors. `err' is an instance */
Benjamin Peterson0a9a6362012-04-03 00:35:36 -0400476 *message = _PyObject_GetAttrId(err, &PyId_msg);
Benjamin Peterson80d50422012-04-03 00:30:38 -0400477 if (!*message)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000478 goto finally;
Barry Warsaw035574d1997-08-29 22:07:17 +0000479
Benjamin Peterson0a9a6362012-04-03 00:35:36 -0400480 v = _PyObject_GetAttrId(err, &PyId_filename);
Benjamin Peterson80d50422012-04-03 00:30:38 -0400481 if (!v)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000482 goto finally;
Benjamin Peterson80d50422012-04-03 00:30:38 -0400483 if (v == Py_None) {
484 Py_DECREF(v);
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100485 *filename = _PyUnicode_FromId(&PyId_string);
486 if (*filename == NULL)
487 goto finally;
488 Py_INCREF(*filename);
Benjamin Peterson80d50422012-04-03 00:30:38 -0400489 }
490 else {
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100491 *filename = v;
Benjamin Peterson80d50422012-04-03 00:30:38 -0400492 }
Barry Warsaw035574d1997-08-29 22:07:17 +0000493
Benjamin Peterson0a9a6362012-04-03 00:35:36 -0400494 v = _PyObject_GetAttrId(err, &PyId_lineno);
Benjamin Peterson80d50422012-04-03 00:30:38 -0400495 if (!v)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000496 goto finally;
Serhiy Storchaka56f6e762015-09-06 21:25:30 +0300497 hold = _PyLong_AsInt(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000498 Py_DECREF(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000499 if (hold < 0 && PyErr_Occurred())
500 goto finally;
Serhiy Storchaka56f6e762015-09-06 21:25:30 +0300501 *lineno = hold;
Barry Warsaw035574d1997-08-29 22:07:17 +0000502
Benjamin Peterson0a9a6362012-04-03 00:35:36 -0400503 v = _PyObject_GetAttrId(err, &PyId_offset);
Benjamin Peterson80d50422012-04-03 00:30:38 -0400504 if (!v)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000505 goto finally;
506 if (v == Py_None) {
507 *offset = -1;
508 Py_DECREF(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000509 } else {
Serhiy Storchaka56f6e762015-09-06 21:25:30 +0300510 hold = _PyLong_AsInt(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000511 Py_DECREF(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000512 if (hold < 0 && PyErr_Occurred())
513 goto finally;
Serhiy Storchaka56f6e762015-09-06 21:25:30 +0300514 *offset = hold;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000515 }
Barry Warsaw035574d1997-08-29 22:07:17 +0000516
Benjamin Peterson0a9a6362012-04-03 00:35:36 -0400517 v = _PyObject_GetAttrId(err, &PyId_text);
Benjamin Peterson80d50422012-04-03 00:30:38 -0400518 if (!v)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000519 goto finally;
Benjamin Peterson80d50422012-04-03 00:30:38 -0400520 if (v == Py_None) {
521 Py_DECREF(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000522 *text = NULL;
Benjamin Peterson80d50422012-04-03 00:30:38 -0400523 }
524 else {
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100525 *text = v;
Benjamin Peterson80d50422012-04-03 00:30:38 -0400526 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000527 return 1;
Barry Warsaw035574d1997-08-29 22:07:17 +0000528
529finally:
Benjamin Peterson80d50422012-04-03 00:30:38 -0400530 Py_XDECREF(*message);
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100531 Py_XDECREF(*filename);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000532 return 0;
Barry Warsaw035574d1997-08-29 22:07:17 +0000533}
534
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000535void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000536PyErr_Print(void)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000537{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000538 PyErr_PrintEx(1);
Guido van Rossuma61691e1998-02-06 22:27:24 +0000539}
540
Jeremy Hylton9f1b9932001-02-28 07:07:43 +0000541static void
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100542print_error_text(PyObject *f, int offset, PyObject *text_obj)
Jeremy Hylton9f1b9932001-02-28 07:07:43 +0000543{
Serhiy Storchaka85b0f5b2016-11-20 10:16:47 +0200544 const char *text;
545 const char *nl;
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100546
Serhiy Storchaka06515832016-11-20 09:13:07 +0200547 text = PyUnicode_AsUTF8(text_obj);
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100548 if (text == NULL)
549 return;
550
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000551 if (offset >= 0) {
Victor Stinner98ea54c2014-08-15 23:30:40 +0200552 if (offset > 0 && (size_t)offset == strlen(text) && text[offset - 1] == '\n')
Benjamin Petersona95e9772010-10-29 03:28:14 +0000553 offset--;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000554 for (;;) {
555 nl = strchr(text, '\n');
556 if (nl == NULL || nl-text >= offset)
557 break;
558 offset -= (int)(nl+1-text);
559 text = nl+1;
560 }
Martin Panterca3263c2016-12-11 00:18:36 +0000561 while (*text == ' ' || *text == '\t' || *text == '\f') {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000562 text++;
563 offset--;
564 }
565 }
566 PyFile_WriteString(" ", f);
567 PyFile_WriteString(text, f);
568 if (*text == '\0' || text[strlen(text)-1] != '\n')
569 PyFile_WriteString("\n", f);
570 if (offset == -1)
571 return;
572 PyFile_WriteString(" ", f);
Benjamin Petersona95e9772010-10-29 03:28:14 +0000573 while (--offset > 0)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000574 PyFile_WriteString(" ", f);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000575 PyFile_WriteString("^\n", f);
Jeremy Hylton9f1b9932001-02-28 07:07:43 +0000576}
577
Guido van Rossum66e8e862001-03-23 17:54:43 +0000578static void
579handle_system_exit(void)
Ka-Ping Yee26fabb02001-03-23 15:36:41 +0000580{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000581 PyObject *exception, *value, *tb;
582 int exitcode = 0;
Tim Peterscf615b52003-04-19 18:47:02 +0000583
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000584 if (Py_InspectFlag)
585 /* Don't exit if -i flag was given. This flag is set to 0
586 * when entering interactive mode for inspecting. */
587 return;
Guido van Rossumd8faa362007-04-27 19:54:29 +0000588
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000589 PyErr_Fetch(&exception, &value, &tb);
590 fflush(stdout);
591 if (value == NULL || value == Py_None)
592 goto done;
593 if (PyExceptionInstance_Check(value)) {
594 /* The error code should be in the `code' attribute. */
Martin v. Löwisbd928fe2011-10-14 10:20:37 +0200595 _Py_IDENTIFIER(code);
Martin v. Löwis1ee1b6f2011-10-10 18:11:30 +0200596 PyObject *code = _PyObject_GetAttrId(value, &PyId_code);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000597 if (code) {
598 Py_DECREF(value);
599 value = code;
600 if (value == Py_None)
601 goto done;
602 }
603 /* If we failed to dig out the 'code' attribute,
604 just let the else clause below print the error. */
605 }
606 if (PyLong_Check(value))
607 exitcode = (int)PyLong_AsLong(value);
608 else {
Victor Stinnerbd303c12013-11-07 23:07:29 +0100609 PyObject *sys_stderr = _PySys_GetObjectId(&PyId_stderr);
Nick Coghland979e432014-02-09 10:43:21 +1000610 /* We clear the exception here to avoid triggering the assertion
611 * in PyObject_Str that ensures it won't silently lose exception
612 * details.
613 */
614 PyErr_Clear();
Victor Stinner7126dbc2010-05-21 23:45:42 +0000615 if (sys_stderr != NULL && sys_stderr != Py_None) {
616 PyFile_WriteObject(value, sys_stderr, Py_PRINT_RAW);
617 } else {
618 PyObject_Print(value, stderr, Py_PRINT_RAW);
619 fflush(stderr);
620 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000621 PySys_WriteStderr("\n");
622 exitcode = 1;
623 }
Tim Peterscf615b52003-04-19 18:47:02 +0000624 done:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000625 /* Restore and clear the exception info, in order to properly decref
626 * the exception, value, and traceback. If we just exit instead,
627 * these leak, which confuses PYTHONDUMPREFS output, and may prevent
628 * some finalizers from running.
629 */
630 PyErr_Restore(exception, value, tb);
631 PyErr_Clear();
632 Py_Exit(exitcode);
633 /* NOTREACHED */
Ka-Ping Yee26fabb02001-03-23 15:36:41 +0000634}
635
636void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000637PyErr_PrintEx(int set_sys_last_vars)
Guido van Rossuma61691e1998-02-06 22:27:24 +0000638{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000639 PyObject *exception, *v, *tb, *hook;
Guido van Rossum66e8e862001-03-23 17:54:43 +0000640
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000641 if (PyErr_ExceptionMatches(PyExc_SystemExit)) {
642 handle_system_exit();
643 }
644 PyErr_Fetch(&exception, &v, &tb);
645 if (exception == NULL)
646 return;
647 PyErr_NormalizeException(&exception, &v, &tb);
648 if (tb == NULL) {
649 tb = Py_None;
650 Py_INCREF(tb);
651 }
652 PyException_SetTraceback(v, tb);
653 if (exception == NULL)
654 return;
655 /* Now we know v != NULL too */
656 if (set_sys_last_vars) {
xdegaye66caacf2017-10-23 18:08:41 +0200657 if (_PySys_SetObjectId(&PyId_last_type, exception) < 0) {
658 PyErr_Clear();
659 }
660 if (_PySys_SetObjectId(&PyId_last_value, v) < 0) {
661 PyErr_Clear();
662 }
663 if (_PySys_SetObjectId(&PyId_last_traceback, tb) < 0) {
664 PyErr_Clear();
665 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000666 }
Victor Stinner09054372013-11-06 22:41:44 +0100667 hook = _PySys_GetObjectId(&PyId_excepthook);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000668 if (hook) {
Victor Stinner71cb64a2016-08-20 00:57:43 +0200669 PyObject* stack[3];
670 PyObject *result;
671
672 stack[0] = exception;
673 stack[1] = v;
674 stack[2] = tb;
Victor Stinner559bb6a2016-08-22 22:48:54 +0200675 result = _PyObject_FastCall(hook, stack, 3);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000676 if (result == NULL) {
677 PyObject *exception2, *v2, *tb2;
678 if (PyErr_ExceptionMatches(PyExc_SystemExit)) {
679 handle_system_exit();
680 }
681 PyErr_Fetch(&exception2, &v2, &tb2);
682 PyErr_NormalizeException(&exception2, &v2, &tb2);
683 /* It should not be possible for exception2 or v2
684 to be NULL. However PyErr_Display() can't
685 tolerate NULLs, so just be safe. */
686 if (exception2 == NULL) {
687 exception2 = Py_None;
688 Py_INCREF(exception2);
689 }
690 if (v2 == NULL) {
691 v2 = Py_None;
692 Py_INCREF(v2);
693 }
694 fflush(stdout);
695 PySys_WriteStderr("Error in sys.excepthook:\n");
696 PyErr_Display(exception2, v2, tb2);
697 PySys_WriteStderr("\nOriginal exception was:\n");
698 PyErr_Display(exception, v, tb);
699 Py_DECREF(exception2);
700 Py_DECREF(v2);
701 Py_XDECREF(tb2);
702 }
703 Py_XDECREF(result);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000704 } else {
705 PySys_WriteStderr("sys.excepthook is missing\n");
706 PyErr_Display(exception, v, tb);
707 }
708 Py_XDECREF(exception);
709 Py_XDECREF(v);
710 Py_XDECREF(tb);
Ka-Ping Yeeb5c51322001-03-23 02:46:52 +0000711}
712
Benjamin Petersone6528212008-07-15 15:32:09 +0000713static void
714print_exception(PyObject *f, PyObject *value)
715{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000716 int err = 0;
717 PyObject *type, *tb;
Martin v. Löwis1c67dd92011-10-14 15:16:45 +0200718 _Py_IDENTIFIER(print_file_and_line);
Benjamin Petersone6528212008-07-15 15:32:09 +0000719
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000720 if (!PyExceptionInstance_Check(value)) {
Victor Stinner52ce3b02013-12-09 02:10:08 +0100721 err = PyFile_WriteString("TypeError: print_exception(): Exception expected for value, ", f);
722 err += PyFile_WriteString(Py_TYPE(value)->tp_name, f);
723 err += PyFile_WriteString(" found\n", f);
724 if (err)
725 PyErr_Clear();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000726 return;
727 }
Benjamin Peterson26582602008-08-23 20:08:07 +0000728
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000729 Py_INCREF(value);
730 fflush(stdout);
731 type = (PyObject *) Py_TYPE(value);
732 tb = PyException_GetTraceback(value);
733 if (tb && tb != Py_None)
734 err = PyTraceBack_Print(tb, f);
735 if (err == 0 &&
Martin v. Löwis1c67dd92011-10-14 15:16:45 +0200736 _PyObject_HasAttrId(value, &PyId_print_file_and_line))
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000737 {
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100738 PyObject *message, *filename, *text;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000739 int lineno, offset;
740 if (!parse_syntax_error(value, &message, &filename,
741 &lineno, &offset, &text))
742 PyErr_Clear();
743 else {
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100744 PyObject *line;
745
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000746 Py_DECREF(value);
747 value = message;
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100748
749 line = PyUnicode_FromFormat(" File \"%U\", line %d\n",
750 filename, lineno);
751 Py_DECREF(filename);
752 if (line != NULL) {
753 PyFile_WriteObject(line, f, Py_PRINT_RAW);
754 Py_DECREF(line);
755 }
756
757 if (text != NULL) {
758 print_error_text(f, offset, text);
759 Py_DECREF(text);
760 }
761
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000762 /* Can't be bothered to check all those
763 PyFile_WriteString() calls */
764 if (PyErr_Occurred())
765 err = -1;
766 }
767 }
768 if (err) {
769 /* Don't do anything else */
770 }
771 else {
772 PyObject* moduleName;
773 char* className;
Martin v. Löwisbd928fe2011-10-14 10:20:37 +0200774 _Py_IDENTIFIER(__module__);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000775 assert(PyExceptionClass_Check(type));
776 className = PyExceptionClass_Name(type);
777 if (className != NULL) {
778 char *dot = strrchr(className, '.');
779 if (dot != NULL)
780 className = dot+1;
781 }
Benjamin Petersone6528212008-07-15 15:32:09 +0000782
Martin v. Löwis1ee1b6f2011-10-10 18:11:30 +0200783 moduleName = _PyObject_GetAttrId(type, &PyId___module__);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000784 if (moduleName == NULL || !PyUnicode_Check(moduleName))
785 {
Victor Stinner13b21bd2011-05-26 14:25:13 +0200786 Py_XDECREF(moduleName);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000787 err = PyFile_WriteString("<unknown>", f);
788 }
789 else {
Serhiy Storchakaf5894dd2016-11-16 15:40:39 +0200790 if (!_PyUnicode_EqualToASCIIId(moduleName, &PyId_builtins))
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000791 {
Victor Stinner937114f2013-11-07 00:12:30 +0100792 err = PyFile_WriteObject(moduleName, f, Py_PRINT_RAW);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000793 err += PyFile_WriteString(".", f);
794 }
795 Py_DECREF(moduleName);
796 }
797 if (err == 0) {
798 if (className == NULL)
799 err = PyFile_WriteString("<unknown>", f);
800 else
801 err = PyFile_WriteString(className, f);
802 }
803 }
804 if (err == 0 && (value != Py_None)) {
805 PyObject *s = PyObject_Str(value);
806 /* only print colon if the str() of the
807 object is not the empty string
808 */
Martin Panter3263f682016-02-28 03:16:11 +0000809 if (s == NULL) {
810 PyErr_Clear();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000811 err = -1;
Martin Panter3263f682016-02-28 03:16:11 +0000812 PyFile_WriteString(": <exception str() failed>", f);
813 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000814 else if (!PyUnicode_Check(s) ||
Victor Stinnere251d6d2011-11-20 19:20:00 +0100815 PyUnicode_GetLength(s) != 0)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000816 err = PyFile_WriteString(": ", f);
817 if (err == 0)
818 err = PyFile_WriteObject(s, f, Py_PRINT_RAW);
819 Py_XDECREF(s);
820 }
821 /* try to write a newline in any case */
Martin Panter3263f682016-02-28 03:16:11 +0000822 if (err < 0) {
823 PyErr_Clear();
824 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000825 err += PyFile_WriteString("\n", f);
826 Py_XDECREF(tb);
827 Py_DECREF(value);
828 /* If an error happened here, don't show it.
829 XXX This is wrong, but too many callers rely on this behavior. */
830 if (err != 0)
831 PyErr_Clear();
Benjamin Petersone6528212008-07-15 15:32:09 +0000832}
833
Serhiy Storchaka2d06e842015-12-25 19:53:18 +0200834static const char cause_message[] =
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000835 "\nThe above exception was the direct cause "
836 "of the following exception:\n\n";
Benjamin Petersone6528212008-07-15 15:32:09 +0000837
Serhiy Storchaka2d06e842015-12-25 19:53:18 +0200838static const char context_message[] =
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000839 "\nDuring handling of the above exception, "
840 "another exception occurred:\n\n";
Benjamin Petersone6528212008-07-15 15:32:09 +0000841
842static void
843print_exception_recursive(PyObject *f, PyObject *value, PyObject *seen)
844{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000845 int err = 0, res;
846 PyObject *cause, *context;
Benjamin Petersone6528212008-07-15 15:32:09 +0000847
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000848 if (seen != NULL) {
849 /* Exception chaining */
Zane Bitterde860732017-10-17 17:29:39 -0400850 PyObject *value_id = PyLong_FromVoidPtr(value);
851 if (value_id == NULL || PySet_Add(seen, value_id) == -1)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000852 PyErr_Clear();
853 else if (PyExceptionInstance_Check(value)) {
Zane Bitterde860732017-10-17 17:29:39 -0400854 PyObject *check_id = NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000855 cause = PyException_GetCause(value);
856 context = PyException_GetContext(value);
Benjamin Petersond5a1c442012-05-14 22:09:31 -0700857 if (cause) {
Zane Bitterde860732017-10-17 17:29:39 -0400858 check_id = PyLong_FromVoidPtr(cause);
859 if (check_id == NULL) {
860 res = -1;
861 } else {
862 res = PySet_Contains(seen, check_id);
863 Py_DECREF(check_id);
864 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000865 if (res == -1)
866 PyErr_Clear();
867 if (res == 0) {
868 print_exception_recursive(
869 f, cause, seen);
870 err |= PyFile_WriteString(
871 cause_message, f);
872 }
873 }
Benjamin Petersond5a1c442012-05-14 22:09:31 -0700874 else if (context &&
875 !((PyBaseExceptionObject *)value)->suppress_context) {
Zane Bitterde860732017-10-17 17:29:39 -0400876 check_id = PyLong_FromVoidPtr(context);
877 if (check_id == NULL) {
878 res = -1;
879 } else {
880 res = PySet_Contains(seen, check_id);
881 Py_DECREF(check_id);
882 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000883 if (res == -1)
884 PyErr_Clear();
885 if (res == 0) {
886 print_exception_recursive(
887 f, context, seen);
888 err |= PyFile_WriteString(
889 context_message, f);
890 }
891 }
892 Py_XDECREF(context);
893 Py_XDECREF(cause);
894 }
Zane Bitterde860732017-10-17 17:29:39 -0400895 Py_XDECREF(value_id);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000896 }
897 print_exception(f, value);
898 if (err != 0)
899 PyErr_Clear();
Benjamin Petersone6528212008-07-15 15:32:09 +0000900}
901
Thomas Wouters477c8d52006-05-27 19:21:47 +0000902void
903PyErr_Display(PyObject *exception, PyObject *value, PyObject *tb)
Ka-Ping Yeeb5c51322001-03-23 02:46:52 +0000904{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000905 PyObject *seen;
Victor Stinnerbd303c12013-11-07 23:07:29 +0100906 PyObject *f = _PySys_GetObjectId(&PyId_stderr);
Antoine Pitrou24201d42013-10-13 21:53:13 +0200907 if (PyExceptionInstance_Check(value)
908 && tb != NULL && PyTraceBack_Check(tb)) {
909 /* Put the traceback on the exception, otherwise it won't get
910 displayed. See issue #18776. */
911 PyObject *cur_tb = PyException_GetTraceback(value);
912 if (cur_tb == NULL)
913 PyException_SetTraceback(value, tb);
914 else
915 Py_DECREF(cur_tb);
916 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000917 if (f == Py_None) {
918 /* pass */
919 }
920 else if (f == NULL) {
921 _PyObject_Dump(value);
922 fprintf(stderr, "lost sys.stderr\n");
923 }
924 else {
925 /* We choose to ignore seen being possibly NULL, and report
926 at least the main exception (it could be a MemoryError).
927 */
928 seen = PySet_New(NULL);
929 if (seen == NULL)
930 PyErr_Clear();
931 print_exception_recursive(f, value, seen);
932 Py_XDECREF(seen);
933 }
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000934}
935
Guido van Rossum82598051997-03-05 00:20:32 +0000936PyObject *
Thomas Wouters4d70c3d2006-06-08 14:42:34 +0000937PyRun_StringFlags(const char *str, int start, PyObject *globals,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000938 PyObject *locals, PyCompilerFlags *flags)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000939{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000940 PyObject *ret = NULL;
941 mod_ty mod;
Victor Stinner95701bd2013-11-06 18:41:07 +0100942 PyArena *arena;
Victor Stinner95701bd2013-11-06 18:41:07 +0100943 PyObject *filename;
944
945 filename = _PyUnicode_FromId(&PyId_string); /* borrowed */
946 if (filename == NULL)
947 return NULL;
948
949 arena = PyArena_New();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000950 if (arena == NULL)
951 return NULL;
Guido van Rossum98297ee2007-11-06 21:34:58 +0000952
Victor Stinner95701bd2013-11-06 18:41:07 +0100953 mod = PyParser_ASTFromStringObject(str, filename, start, flags, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000954 if (mod != NULL)
Victor Stinner95701bd2013-11-06 18:41:07 +0100955 ret = run_mod(mod, filename, globals, locals, flags, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000956 PyArena_Free(arena);
957 return ret;
Jeremy Hyltonbc320242001-03-22 02:47:58 +0000958}
959
960PyObject *
Victor Stinner95701bd2013-11-06 18:41:07 +0100961PyRun_FileExFlags(FILE *fp, const char *filename_str, int start, PyObject *globals,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000962 PyObject *locals, int closeit, PyCompilerFlags *flags)
Jeremy Hyltonbc320242001-03-22 02:47:58 +0000963{
Victor Stinner95701bd2013-11-06 18:41:07 +0100964 PyObject *ret = NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000965 mod_ty mod;
Victor Stinner95701bd2013-11-06 18:41:07 +0100966 PyArena *arena = NULL;
967 PyObject *filename;
Guido van Rossum98297ee2007-11-06 21:34:58 +0000968
Victor Stinner95701bd2013-11-06 18:41:07 +0100969 filename = PyUnicode_DecodeFSDefault(filename_str);
970 if (filename == NULL)
971 goto exit;
972
973 arena = PyArena_New();
974 if (arena == NULL)
975 goto exit;
976
977 mod = PyParser_ASTFromFileObject(fp, filename, NULL, start, 0, 0,
978 flags, NULL, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000979 if (closeit)
980 fclose(fp);
981 if (mod == NULL) {
Victor Stinner95701bd2013-11-06 18:41:07 +0100982 goto exit;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000983 }
984 ret = run_mod(mod, filename, globals, locals, flags, arena);
Victor Stinner95701bd2013-11-06 18:41:07 +0100985
986exit:
987 Py_XDECREF(filename);
988 if (arena != NULL)
989 PyArena_Free(arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000990 return ret;
Jeremy Hyltonbc320242001-03-22 02:47:58 +0000991}
992
Guido van Rossum6c193fa2007-12-05 05:14:58 +0000993static void
994flush_io(void)
995{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000996 PyObject *f, *r;
997 PyObject *type, *value, *traceback;
Amaury Forgeot d'Arc9ed77352008-04-04 23:25:27 +0000998
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000999 /* Save the current exception */
1000 PyErr_Fetch(&type, &value, &traceback);
Amaury Forgeot d'Arc9ed77352008-04-04 23:25:27 +00001001
Victor Stinnerbd303c12013-11-07 23:07:29 +01001002 f = _PySys_GetObjectId(&PyId_stderr);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001003 if (f != NULL) {
Victor Stinner3466bde2016-09-05 18:16:01 -07001004 r = _PyObject_CallMethodId(f, &PyId_flush, NULL);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001005 if (r)
1006 Py_DECREF(r);
1007 else
1008 PyErr_Clear();
1009 }
Victor Stinnerbd303c12013-11-07 23:07:29 +01001010 f = _PySys_GetObjectId(&PyId_stdout);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001011 if (f != NULL) {
Victor Stinner3466bde2016-09-05 18:16:01 -07001012 r = _PyObject_CallMethodId(f, &PyId_flush, NULL);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001013 if (r)
1014 Py_DECREF(r);
1015 else
1016 PyErr_Clear();
1017 }
Amaury Forgeot d'Arc9ed77352008-04-04 23:25:27 +00001018
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001019 PyErr_Restore(type, value, traceback);
Guido van Rossum6c193fa2007-12-05 05:14:58 +00001020}
1021
Guido van Rossum82598051997-03-05 00:20:32 +00001022static PyObject *
Victor Stinner95701bd2013-11-06 18:41:07 +01001023run_mod(mod_ty mod, PyObject *filename, PyObject *globals, PyObject *locals,
1024 PyCompilerFlags *flags, PyArena *arena)
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001025{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001026 PyCodeObject *co;
1027 PyObject *v;
Victor Stinner95701bd2013-11-06 18:41:07 +01001028 co = PyAST_CompileObject(mod, filename, flags, -1, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001029 if (co == NULL)
1030 return NULL;
Martin v. Löwis4d0d4712010-12-03 20:14:31 +00001031 v = PyEval_EvalCode((PyObject*)co, globals, locals);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001032 Py_DECREF(co);
1033 return v;
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001034}
1035
Guido van Rossum82598051997-03-05 00:20:32 +00001036static PyObject *
Thomas Wouters4d70c3d2006-06-08 14:42:34 +00001037run_pyc_file(FILE *fp, const char *filename, PyObject *globals,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001038 PyObject *locals, PyCompilerFlags *flags)
Guido van Rossumfdef2711994-09-14 13:31:04 +00001039{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001040 PyCodeObject *co;
1041 PyObject *v;
1042 long magic;
1043 long PyImport_GetMagicNumber(void);
Guido van Rossumfdef2711994-09-14 13:31:04 +00001044
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001045 magic = PyMarshal_ReadLongFromFile(fp);
1046 if (magic != PyImport_GetMagicNumber()) {
Victor Stinner5200f552015-03-18 13:56:25 +01001047 if (!PyErr_Occurred())
1048 PyErr_SetString(PyExc_RuntimeError,
1049 "Bad magic number in .pyc file");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001050 return NULL;
1051 }
Antoine Pitrou5136ac02012-01-13 18:52:16 +01001052 /* Skip mtime and size */
1053 (void) PyMarshal_ReadLongFromFile(fp);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001054 (void) PyMarshal_ReadLongFromFile(fp);
Victor Stinner5200f552015-03-18 13:56:25 +01001055 if (PyErr_Occurred())
1056 return NULL;
1057
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001058 v = PyMarshal_ReadLastObjectFromFile(fp);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001059 if (v == NULL || !PyCode_Check(v)) {
1060 Py_XDECREF(v);
1061 PyErr_SetString(PyExc_RuntimeError,
1062 "Bad code object in .pyc file");
1063 return NULL;
1064 }
1065 co = (PyCodeObject *)v;
Martin v. Löwis4d0d4712010-12-03 20:14:31 +00001066 v = PyEval_EvalCode((PyObject*)co, globals, locals);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001067 if (v && flags)
1068 flags->cf_flags |= (co->co_flags & PyCF_MASK);
1069 Py_DECREF(co);
1070 return v;
Guido van Rossumfdef2711994-09-14 13:31:04 +00001071}
1072
Guido van Rossum82598051997-03-05 00:20:32 +00001073PyObject *
Victor Stinner14e461d2013-08-26 22:28:21 +02001074Py_CompileStringObject(const char *str, PyObject *filename, int start,
1075 PyCompilerFlags *flags, int optimize)
Jeremy Hyltonbc320242001-03-22 02:47:58 +00001076{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001077 PyCodeObject *co;
1078 mod_ty mod;
1079 PyArena *arena = PyArena_New();
1080 if (arena == NULL)
1081 return NULL;
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001082
Victor Stinner14e461d2013-08-26 22:28:21 +02001083 mod = PyParser_ASTFromStringObject(str, filename, start, flags, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001084 if (mod == NULL) {
1085 PyArena_Free(arena);
1086 return NULL;
1087 }
1088 if (flags && (flags->cf_flags & PyCF_ONLY_AST)) {
1089 PyObject *result = PyAST_mod2obj(mod);
1090 PyArena_Free(arena);
1091 return result;
1092 }
Victor Stinner14e461d2013-08-26 22:28:21 +02001093 co = PyAST_CompileObject(mod, filename, flags, optimize, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001094 PyArena_Free(arena);
1095 return (PyObject *)co;
Guido van Rossum5b722181993-03-30 17:46:03 +00001096}
1097
Victor Stinner14e461d2013-08-26 22:28:21 +02001098PyObject *
1099Py_CompileStringExFlags(const char *str, const char *filename_str, int start,
1100 PyCompilerFlags *flags, int optimize)
1101{
1102 PyObject *filename, *co;
1103 filename = PyUnicode_DecodeFSDefault(filename_str);
1104 if (filename == NULL)
1105 return NULL;
1106 co = Py_CompileStringObject(str, filename, start, flags, optimize);
1107 Py_DECREF(filename);
1108 return co;
1109}
1110
Martin v. Löwis4d0d4712010-12-03 20:14:31 +00001111/* For use in Py_LIMITED_API */
1112#undef Py_CompileString
1113PyObject *
1114PyCompileString(const char *str, const char *filename, int start)
1115{
1116 return Py_CompileStringFlags(str, filename, start, NULL);
1117}
1118
Jeremy Hylton4b38da62001-02-02 18:19:15 +00001119struct symtable *
Victor Stinner14e461d2013-08-26 22:28:21 +02001120Py_SymtableStringObject(const char *str, PyObject *filename, int start)
Jeremy Hylton4b38da62001-02-02 18:19:15 +00001121{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001122 struct symtable *st;
1123 mod_ty mod;
1124 PyCompilerFlags flags;
Victor Stinner14e461d2013-08-26 22:28:21 +02001125 PyArena *arena;
1126
1127 arena = PyArena_New();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001128 if (arena == NULL)
1129 return NULL;
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001130
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001131 flags.cf_flags = 0;
Victor Stinner14e461d2013-08-26 22:28:21 +02001132 mod = PyParser_ASTFromStringObject(str, filename, start, &flags, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001133 if (mod == NULL) {
1134 PyArena_Free(arena);
1135 return NULL;
1136 }
Victor Stinner14e461d2013-08-26 22:28:21 +02001137 st = PySymtable_BuildObject(mod, filename, 0);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001138 PyArena_Free(arena);
1139 return st;
Jeremy Hylton4b38da62001-02-02 18:19:15 +00001140}
1141
Victor Stinner14e461d2013-08-26 22:28:21 +02001142struct symtable *
1143Py_SymtableString(const char *str, const char *filename_str, int start)
1144{
1145 PyObject *filename;
1146 struct symtable *st;
1147
1148 filename = PyUnicode_DecodeFSDefault(filename_str);
1149 if (filename == NULL)
1150 return NULL;
1151 st = Py_SymtableStringObject(str, filename, start);
1152 Py_DECREF(filename);
1153 return st;
1154}
1155
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001156/* Preferred access to parser is through AST. */
1157mod_ty
Victor Stinner14e461d2013-08-26 22:28:21 +02001158PyParser_ASTFromStringObject(const char *s, PyObject *filename, int start,
1159 PyCompilerFlags *flags, PyArena *arena)
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001160{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001161 mod_ty mod;
1162 PyCompilerFlags localflags;
1163 perrdetail err;
1164 int iflags = PARSER_FLAGS(flags);
Christian Heimes4d6ec852008-03-26 22:34:47 +00001165
Victor Stinner14e461d2013-08-26 22:28:21 +02001166 node *n = PyParser_ParseStringObject(s, filename,
1167 &_PyParser_Grammar, start, &err,
1168 &iflags);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001169 if (flags == NULL) {
1170 localflags.cf_flags = 0;
1171 flags = &localflags;
1172 }
1173 if (n) {
1174 flags->cf_flags |= iflags & PyCF_MASK;
Victor Stinner14e461d2013-08-26 22:28:21 +02001175 mod = PyAST_FromNodeObject(n, flags, filename, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001176 PyNode_Free(n);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001177 }
1178 else {
1179 err_input(&err);
Victor Stinner7f2fee32011-04-05 00:39:01 +02001180 mod = NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001181 }
Victor Stinner7f2fee32011-04-05 00:39:01 +02001182 err_free(&err);
1183 return mod;
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001184}
1185
1186mod_ty
Victor Stinner14e461d2013-08-26 22:28:21 +02001187PyParser_ASTFromString(const char *s, const char *filename_str, int start,
1188 PyCompilerFlags *flags, PyArena *arena)
1189{
1190 PyObject *filename;
1191 mod_ty mod;
1192 filename = PyUnicode_DecodeFSDefault(filename_str);
1193 if (filename == NULL)
1194 return NULL;
1195 mod = PyParser_ASTFromStringObject(s, filename, start, flags, arena);
1196 Py_DECREF(filename);
1197 return mod;
1198}
1199
1200mod_ty
1201PyParser_ASTFromFileObject(FILE *fp, PyObject *filename, const char* enc,
Serhiy Storchakaef1585e2015-12-25 20:01:53 +02001202 int start, const char *ps1,
1203 const char *ps2, PyCompilerFlags *flags, int *errcode,
Victor Stinner14e461d2013-08-26 22:28:21 +02001204 PyArena *arena)
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001205{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001206 mod_ty mod;
1207 PyCompilerFlags localflags;
1208 perrdetail err;
1209 int iflags = PARSER_FLAGS(flags);
Christian Heimes4d6ec852008-03-26 22:34:47 +00001210
Victor Stinner14e461d2013-08-26 22:28:21 +02001211 node *n = PyParser_ParseFileObject(fp, filename, enc,
1212 &_PyParser_Grammar,
1213 start, ps1, ps2, &err, &iflags);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001214 if (flags == NULL) {
1215 localflags.cf_flags = 0;
1216 flags = &localflags;
1217 }
1218 if (n) {
1219 flags->cf_flags |= iflags & PyCF_MASK;
Victor Stinner14e461d2013-08-26 22:28:21 +02001220 mod = PyAST_FromNodeObject(n, flags, filename, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001221 PyNode_Free(n);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001222 }
1223 else {
1224 err_input(&err);
1225 if (errcode)
1226 *errcode = err.error;
Victor Stinner7f2fee32011-04-05 00:39:01 +02001227 mod = NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001228 }
Victor Stinner7f2fee32011-04-05 00:39:01 +02001229 err_free(&err);
1230 return mod;
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001231}
1232
Victor Stinner14e461d2013-08-26 22:28:21 +02001233mod_ty
1234PyParser_ASTFromFile(FILE *fp, const char *filename_str, const char* enc,
Serhiy Storchakaef1585e2015-12-25 20:01:53 +02001235 int start, const char *ps1,
1236 const char *ps2, PyCompilerFlags *flags, int *errcode,
Victor Stinner14e461d2013-08-26 22:28:21 +02001237 PyArena *arena)
1238{
1239 mod_ty mod;
1240 PyObject *filename;
1241 filename = PyUnicode_DecodeFSDefault(filename_str);
1242 if (filename == NULL)
1243 return NULL;
1244 mod = PyParser_ASTFromFileObject(fp, filename, enc, start, ps1, ps2,
1245 flags, errcode, arena);
1246 Py_DECREF(filename);
1247 return mod;
1248}
1249
Guido van Rossuma110aa61994-08-29 12:50:44 +00001250/* Simplified interface to parsefile -- return node or set exception */
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001251
Guido van Rossuma110aa61994-08-29 12:50:44 +00001252node *
Martin v. Löwis95292d62002-12-11 14:04:59 +00001253PyParser_SimpleParseFileFlags(FILE *fp, const char *filename, int start, int flags)
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001254{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001255 perrdetail err;
1256 node *n = PyParser_ParseFileFlags(fp, filename, NULL,
1257 &_PyParser_Grammar,
1258 start, NULL, NULL, &err, flags);
1259 if (n == NULL)
1260 err_input(&err);
Victor Stinner7f2fee32011-04-05 00:39:01 +02001261 err_free(&err);
Thomas Wouters4d70c3d2006-06-08 14:42:34 +00001262
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001263 return n;
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001264}
1265
Guido van Rossuma110aa61994-08-29 12:50:44 +00001266/* Simplified interface to parsestring -- return node or set exception */
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001267
Guido van Rossuma110aa61994-08-29 12:50:44 +00001268node *
Martin v. Löwis95292d62002-12-11 14:04:59 +00001269PyParser_SimpleParseStringFlags(const char *str, int start, int flags)
Tim Petersfe2127d2001-07-16 05:37:24 +00001270{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001271 perrdetail err;
1272 node *n = PyParser_ParseStringFlags(str, &_PyParser_Grammar,
1273 start, &err, flags);
1274 if (n == NULL)
1275 err_input(&err);
Victor Stinner7f2fee32011-04-05 00:39:01 +02001276 err_free(&err);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001277 return n;
Tim Petersfe2127d2001-07-16 05:37:24 +00001278}
1279
1280node *
Martin v. Löwis95292d62002-12-11 14:04:59 +00001281PyParser_SimpleParseStringFlagsFilename(const char *str, const char *filename,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001282 int start, int flags)
Thomas Heller6b17abf2002-07-09 09:23:27 +00001283{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001284 perrdetail err;
1285 node *n = PyParser_ParseStringFlagsFilename(str, filename,
1286 &_PyParser_Grammar, start, &err, flags);
1287 if (n == NULL)
1288 err_input(&err);
Victor Stinner7f2fee32011-04-05 00:39:01 +02001289 err_free(&err);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001290 return n;
Thomas Heller6b17abf2002-07-09 09:23:27 +00001291}
1292
1293node *
Martin v. Löwis95292d62002-12-11 14:04:59 +00001294PyParser_SimpleParseStringFilename(const char *str, const char *filename, int start)
Thomas Heller6b17abf2002-07-09 09:23:27 +00001295{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001296 return PyParser_SimpleParseStringFlagsFilename(str, filename, start, 0);
Thomas Heller6b17abf2002-07-09 09:23:27 +00001297}
1298
Guido van Rossum66ebd912003-04-17 16:02:26 +00001299/* May want to move a more generalized form of this to parsetok.c or
1300 even parser modules. */
1301
1302void
Victor Stinner7f2fee32011-04-05 00:39:01 +02001303PyParser_ClearError(perrdetail *err)
1304{
1305 err_free(err);
1306}
1307
1308void
Guido van Rossum66ebd912003-04-17 16:02:26 +00001309PyParser_SetError(perrdetail *err)
1310{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001311 err_input(err);
Guido van Rossum66ebd912003-04-17 16:02:26 +00001312}
1313
Victor Stinner7f2fee32011-04-05 00:39:01 +02001314static void
1315err_free(perrdetail *err)
1316{
1317 Py_CLEAR(err->filename);
1318}
1319
Guido van Rossuma110aa61994-08-29 12:50:44 +00001320/* Set the error appropriate to the given input error code (see errcode.h) */
1321
1322static void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00001323err_input(perrdetail *err)
Guido van Rossuma110aa61994-08-29 12:50:44 +00001324{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001325 PyObject *v, *w, *errtype, *errtext;
1326 PyObject *msg_obj = NULL;
Serhiy Storchakae2f92de2017-11-11 13:06:26 +02001327 const char *msg = NULL;
Serhiy Storchaka65fd0592014-01-21 22:26:52 +02001328 int offset = err->offset;
Victor Stinner4c7c8c32010-10-16 13:14:10 +00001329
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001330 errtype = PyExc_SyntaxError;
1331 switch (err->error) {
1332 case E_ERROR:
1333 return;
1334 case E_SYNTAX:
1335 errtype = PyExc_IndentationError;
1336 if (err->expected == INDENT)
1337 msg = "expected an indented block";
1338 else if (err->token == INDENT)
1339 msg = "unexpected indent";
1340 else if (err->token == DEDENT)
1341 msg = "unexpected unindent";
1342 else {
1343 errtype = PyExc_SyntaxError;
1344 msg = "invalid syntax";
1345 }
1346 break;
1347 case E_TOKEN:
1348 msg = "invalid token";
1349 break;
1350 case E_EOFS:
1351 msg = "EOF while scanning triple-quoted string literal";
1352 break;
1353 case E_EOLS:
1354 msg = "EOL while scanning string literal";
1355 break;
1356 case E_INTR:
1357 if (!PyErr_Occurred())
1358 PyErr_SetNone(PyExc_KeyboardInterrupt);
1359 goto cleanup;
1360 case E_NOMEM:
1361 PyErr_NoMemory();
1362 goto cleanup;
1363 case E_EOF:
1364 msg = "unexpected EOF while parsing";
1365 break;
1366 case E_TABSPACE:
1367 errtype = PyExc_TabError;
1368 msg = "inconsistent use of tabs and spaces in indentation";
1369 break;
1370 case E_OVERFLOW:
1371 msg = "expression too long";
1372 break;
1373 case E_DEDENT:
1374 errtype = PyExc_IndentationError;
1375 msg = "unindent does not match any outer indentation level";
1376 break;
1377 case E_TOODEEP:
1378 errtype = PyExc_IndentationError;
1379 msg = "too many levels of indentation";
1380 break;
1381 case E_DECODE: {
1382 PyObject *type, *value, *tb;
1383 PyErr_Fetch(&type, &value, &tb);
1384 msg = "unknown decode error";
1385 if (value != NULL)
1386 msg_obj = PyObject_Str(value);
1387 Py_XDECREF(type);
1388 Py_XDECREF(value);
1389 Py_XDECREF(tb);
1390 break;
1391 }
1392 case E_LINECONT:
1393 msg = "unexpected character after line continuation character";
1394 break;
Martin v. Löwis47383402007-08-15 07:32:56 +00001395
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001396 case E_IDENTIFIER:
1397 msg = "invalid character in identifier";
1398 break;
Meador Ingefa21bf02012-01-19 01:08:41 -06001399 case E_BADSINGLE:
1400 msg = "multiple statements found while compiling a single statement";
1401 break;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001402 default:
1403 fprintf(stderr, "error=%d\n", err->error);
1404 msg = "unknown parsing error";
1405 break;
1406 }
1407 /* err->text may not be UTF-8 in case of decoding errors.
1408 Explicitly convert to an object. */
1409 if (!err->text) {
1410 errtext = Py_None;
1411 Py_INCREF(Py_None);
1412 } else {
Serhiy Storchaka65fd0592014-01-21 22:26:52 +02001413 errtext = PyUnicode_DecodeUTF8(err->text, err->offset,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001414 "replace");
Serhiy Storchaka65fd0592014-01-21 22:26:52 +02001415 if (errtext != NULL) {
1416 Py_ssize_t len = strlen(err->text);
1417 offset = (int)PyUnicode_GET_LENGTH(errtext);
1418 if (len != err->offset) {
1419 Py_DECREF(errtext);
1420 errtext = PyUnicode_DecodeUTF8(err->text, len,
1421 "replace");
1422 }
1423 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001424 }
Victor Stinner7f2fee32011-04-05 00:39:01 +02001425 v = Py_BuildValue("(OiiN)", err->filename,
Serhiy Storchaka65fd0592014-01-21 22:26:52 +02001426 err->lineno, offset, errtext);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001427 if (v != NULL) {
1428 if (msg_obj)
1429 w = Py_BuildValue("(OO)", msg_obj, v);
1430 else
1431 w = Py_BuildValue("(sO)", msg, v);
1432 } else
1433 w = NULL;
1434 Py_XDECREF(v);
1435 PyErr_SetObject(errtype, w);
1436 Py_XDECREF(w);
Georg Brandl3dbca812008-07-23 16:10:53 +00001437cleanup:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001438 Py_XDECREF(msg_obj);
1439 if (err->text != NULL) {
1440 PyObject_FREE(err->text);
1441 err->text = NULL;
1442 }
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001443}
1444
Fredrik Lundh2f15b252000-08-27 19:15:31 +00001445
Zachary Warec4821d62014-11-21 23:35:12 -06001446#if defined(USE_STACKCHECK)
1447#if defined(WIN32) && defined(_MSC_VER)
1448
1449/* Stack checking for Microsoft C */
1450
1451#include <malloc.h>
1452#include <excpt.h>
1453
1454/*
1455 * Return non-zero when we run out of memory on the stack; zero otherwise.
1456 */
1457int
1458PyOS_CheckStack(void)
1459{
1460 __try {
1461 /* alloca throws a stack overflow exception if there's
1462 not enough space left on the stack */
1463 alloca(PYOS_STACK_MARGIN * sizeof(void*));
1464 return 0;
1465 } __except (GetExceptionCode() == STATUS_STACK_OVERFLOW ?
1466 EXCEPTION_EXECUTE_HANDLER :
1467 EXCEPTION_CONTINUE_SEARCH) {
1468 int errcode = _resetstkoflw();
1469 if (errcode == 0)
1470 {
1471 Py_FatalError("Could not reset the stack!");
1472 }
1473 }
1474 return 1;
1475}
1476
1477#endif /* WIN32 && _MSC_VER */
1478
1479/* Alternate implementations can be added here... */
1480
1481#endif /* USE_STACKCHECK */
1482
Martin Panter46f50722016-05-26 05:35:26 +00001483/* Deprecated C API functions still provided for binary compatibility */
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001484
1485#undef PyParser_SimpleParseFile
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001486PyAPI_FUNC(node *)
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001487PyParser_SimpleParseFile(FILE *fp, const char *filename, int start)
1488{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001489 return PyParser_SimpleParseFileFlags(fp, filename, start, 0);
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001490}
1491
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001492#undef PyParser_SimpleParseString
1493PyAPI_FUNC(node *)
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001494PyParser_SimpleParseString(const char *str, int start)
1495{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001496 return PyParser_SimpleParseStringFlags(str, start, 0);
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001497}
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001498
1499#undef PyRun_AnyFile
1500PyAPI_FUNC(int)
1501PyRun_AnyFile(FILE *fp, const char *name)
1502{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001503 return PyRun_AnyFileExFlags(fp, name, 0, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001504}
1505
1506#undef PyRun_AnyFileEx
1507PyAPI_FUNC(int)
1508PyRun_AnyFileEx(FILE *fp, const char *name, int closeit)
1509{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001510 return PyRun_AnyFileExFlags(fp, name, closeit, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001511}
1512
1513#undef PyRun_AnyFileFlags
1514PyAPI_FUNC(int)
1515PyRun_AnyFileFlags(FILE *fp, const char *name, PyCompilerFlags *flags)
1516{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001517 return PyRun_AnyFileExFlags(fp, name, 0, flags);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001518}
1519
1520#undef PyRun_File
1521PyAPI_FUNC(PyObject *)
1522PyRun_File(FILE *fp, const char *p, int s, PyObject *g, PyObject *l)
1523{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001524 return PyRun_FileExFlags(fp, p, s, g, l, 0, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001525}
1526
1527#undef PyRun_FileEx
1528PyAPI_FUNC(PyObject *)
1529PyRun_FileEx(FILE *fp, const char *p, int s, PyObject *g, PyObject *l, int c)
1530{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001531 return PyRun_FileExFlags(fp, p, s, g, l, c, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001532}
1533
1534#undef PyRun_FileFlags
1535PyAPI_FUNC(PyObject *)
1536PyRun_FileFlags(FILE *fp, const char *p, int s, PyObject *g, PyObject *l,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001537 PyCompilerFlags *flags)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001538{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001539 return PyRun_FileExFlags(fp, p, s, g, l, 0, flags);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001540}
1541
1542#undef PyRun_SimpleFile
1543PyAPI_FUNC(int)
1544PyRun_SimpleFile(FILE *f, const char *p)
1545{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001546 return PyRun_SimpleFileExFlags(f, p, 0, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001547}
1548
1549#undef PyRun_SimpleFileEx
1550PyAPI_FUNC(int)
1551PyRun_SimpleFileEx(FILE *f, const char *p, int c)
1552{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001553 return PyRun_SimpleFileExFlags(f, p, c, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001554}
1555
1556
1557#undef PyRun_String
1558PyAPI_FUNC(PyObject *)
1559PyRun_String(const char *str, int s, PyObject *g, PyObject *l)
1560{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001561 return PyRun_StringFlags(str, s, g, l, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001562}
1563
1564#undef PyRun_SimpleString
1565PyAPI_FUNC(int)
1566PyRun_SimpleString(const char *s)
1567{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001568 return PyRun_SimpleStringFlags(s, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001569}
1570
1571#undef Py_CompileString
1572PyAPI_FUNC(PyObject *)
1573Py_CompileString(const char *str, const char *p, int s)
1574{
Georg Brandl8334fd92010-12-04 10:26:46 +00001575 return Py_CompileStringExFlags(str, p, s, NULL, -1);
1576}
1577
1578#undef Py_CompileStringFlags
1579PyAPI_FUNC(PyObject *)
1580Py_CompileStringFlags(const char *str, const char *p, int s,
1581 PyCompilerFlags *flags)
1582{
1583 return Py_CompileStringExFlags(str, p, s, flags, -1);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001584}
1585
1586#undef PyRun_InteractiveOne
1587PyAPI_FUNC(int)
1588PyRun_InteractiveOne(FILE *f, const char *p)
1589{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001590 return PyRun_InteractiveOneFlags(f, p, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001591}
1592
1593#undef PyRun_InteractiveLoop
1594PyAPI_FUNC(int)
1595PyRun_InteractiveLoop(FILE *f, const char *p)
1596{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001597 return PyRun_InteractiveLoopFlags(f, p, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001598}
1599
1600#ifdef __cplusplus
1601}
1602#endif