blob: 5cf7c33c93ae670962600fc59a94c8026fe0fe34 [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;
Victor Stinner25420fe2017-11-20 18:12:22 -080094#ifdef Py_REF_DEBUG
95 int show_ref_count = PyThreadState_GET()->interp->core_config.show_ref_count;
96#endif
Jeremy Hylton9f324e92001-03-01 22:59:14 +000097
Victor Stinner95701bd2013-11-06 18:41:07 +010098 filename = PyUnicode_DecodeFSDefault(filename_str);
99 if (filename == NULL) {
100 PyErr_Print();
101 return -1;
102 }
103
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000104 if (flags == NULL) {
105 flags = &local_flags;
106 local_flags.cf_flags = 0;
107 }
Victor Stinner09054372013-11-06 22:41:44 +0100108 v = _PySys_GetObjectId(&PyId_ps1);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000109 if (v == NULL) {
Victor Stinner09054372013-11-06 22:41:44 +0100110 _PySys_SetObjectId(&PyId_ps1, v = PyUnicode_FromString(">>> "));
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000111 Py_XDECREF(v);
112 }
Victor Stinner09054372013-11-06 22:41:44 +0100113 v = _PySys_GetObjectId(&PyId_ps2);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000114 if (v == NULL) {
Victor Stinner09054372013-11-06 22:41:44 +0100115 _PySys_SetObjectId(&PyId_ps2, v = PyUnicode_FromString("... "));
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000116 Py_XDECREF(v);
117 }
xdegayee0582a32017-11-12 16:50:48 +0100118 err = 0;
119 do {
120 ret = PyRun_InteractiveOneObjectEx(fp, filename, flags);
121 if (ret == -1 && PyErr_Occurred()) {
122 /* Prevent an endless loop after multiple consecutive MemoryErrors
123 * while still allowing an interactive command to fail with a
124 * MemoryError. */
125 if (PyErr_ExceptionMatches(PyExc_MemoryError)) {
126 if (++nomem_count > 16) {
127 PyErr_Clear();
128 err = -1;
129 break;
130 }
131 } else {
132 nomem_count = 0;
133 }
134 PyErr_Print();
135 flush_io();
136 } else {
137 nomem_count = 0;
138 }
Eric Snowdae02762017-09-14 00:35:58 -0700139#ifdef Py_REF_DEBUG
Victor Stinner25420fe2017-11-20 18:12:22 -0800140 if (show_ref_count) {
Eric Snowdae02762017-09-14 00:35:58 -0700141 _PyDebug_PrintTotalRefs();
Victor Stinner25420fe2017-11-20 18:12:22 -0800142 }
Eric Snowdae02762017-09-14 00:35:58 -0700143#endif
xdegayee0582a32017-11-12 16:50:48 +0100144 } while (ret != E_EOF);
Victor Stinner95701bd2013-11-06 18:41:07 +0100145 Py_DECREF(filename);
146 return err;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000147}
148
Neil Schemenauerc24ea082002-03-22 23:53:36 +0000149/* compute parser flags based on compiler flags */
Benjamin Petersonf5b52242009-03-02 23:31:26 +0000150static int PARSER_FLAGS(PyCompilerFlags *flags)
151{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000152 int parser_flags = 0;
153 if (!flags)
154 return 0;
155 if (flags->cf_flags & PyCF_DONT_IMPLY_DEDENT)
156 parser_flags |= PyPARSE_DONT_IMPLY_DEDENT;
157 if (flags->cf_flags & PyCF_IGNORE_COOKIE)
158 parser_flags |= PyPARSE_IGNORE_COOKIE;
159 if (flags->cf_flags & CO_FUTURE_BARRY_AS_BDFL)
160 parser_flags |= PyPARSE_BARRY_AS_BDFL;
161 return parser_flags;
Benjamin Petersonf5b52242009-03-02 23:31:26 +0000162}
Neil Schemenauerc24ea082002-03-22 23:53:36 +0000163
Thomas Wouters89f507f2006-12-13 04:49:30 +0000164#if 0
165/* Keep an example of flags with future keyword support. */
166#define PARSER_FLAGS(flags) \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000167 ((flags) ? ((((flags)->cf_flags & PyCF_DONT_IMPLY_DEDENT) ? \
168 PyPARSE_DONT_IMPLY_DEDENT : 0) \
169 | ((flags)->cf_flags & CO_FUTURE_WITH_STATEMENT ? \
170 PyPARSE_WITH_IS_KEYWORD : 0)) : 0)
Thomas Wouters89f507f2006-12-13 04:49:30 +0000171#endif
172
xdegayee0582a32017-11-12 16:50:48 +0100173/* A PyRun_InteractiveOneObject() auxiliary function that does not print the
174 * error on failure. */
175static int
176PyRun_InteractiveOneObjectEx(FILE *fp, PyObject *filename,
177 PyCompilerFlags *flags)
Jeremy Hylton9f324e92001-03-01 22:59:14 +0000178{
Victor Stinner95701bd2013-11-06 18:41:07 +0100179 PyObject *m, *d, *v, *w, *oenc = NULL, *mod_name;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000180 mod_ty mod;
181 PyArena *arena;
Serhiy Storchaka85b0f5b2016-11-20 10:16:47 +0200182 const char *ps1 = "", *ps2 = "", *enc = NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000183 int errcode = 0;
Martin v. Löwisbd928fe2011-10-14 10:20:37 +0200184 _Py_IDENTIFIER(encoding);
Victor Stinner95701bd2013-11-06 18:41:07 +0100185 _Py_IDENTIFIER(__main__);
186
187 mod_name = _PyUnicode_FromId(&PyId___main__); /* borrowed */
188 if (mod_name == NULL) {
Victor Stinner95701bd2013-11-06 18:41:07 +0100189 return -1;
190 }
Tim Petersfe2127d2001-07-16 05:37:24 +0000191
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000192 if (fp == stdin) {
Benjamin Petersonfe1b22a2013-04-29 10:23:08 -0400193 /* Fetch encoding from sys.stdin if possible. */
Victor Stinnerbd303c12013-11-07 23:07:29 +0100194 v = _PySys_GetObjectId(&PyId_stdin);
Benjamin Petersonfe1b22a2013-04-29 10:23:08 -0400195 if (v && v != Py_None) {
196 oenc = _PyObject_GetAttrId(v, &PyId_encoding);
197 if (oenc)
Serhiy Storchaka06515832016-11-20 09:13:07 +0200198 enc = PyUnicode_AsUTF8(oenc);
Benjamin Petersonfe1b22a2013-04-29 10:23:08 -0400199 if (!enc)
200 PyErr_Clear();
201 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000202 }
Victor Stinner09054372013-11-06 22:41:44 +0100203 v = _PySys_GetObjectId(&PyId_ps1);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000204 if (v != NULL) {
205 v = PyObject_Str(v);
206 if (v == NULL)
207 PyErr_Clear();
Victor Stinner386fe712010-05-19 00:34:15 +0000208 else if (PyUnicode_Check(v)) {
Serhiy Storchaka06515832016-11-20 09:13:07 +0200209 ps1 = PyUnicode_AsUTF8(v);
Victor Stinner386fe712010-05-19 00:34:15 +0000210 if (ps1 == NULL) {
211 PyErr_Clear();
212 ps1 = "";
213 }
214 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000215 }
Victor Stinner09054372013-11-06 22:41:44 +0100216 w = _PySys_GetObjectId(&PyId_ps2);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000217 if (w != NULL) {
218 w = PyObject_Str(w);
219 if (w == NULL)
220 PyErr_Clear();
Victor Stinner386fe712010-05-19 00:34:15 +0000221 else if (PyUnicode_Check(w)) {
Serhiy Storchaka06515832016-11-20 09:13:07 +0200222 ps2 = PyUnicode_AsUTF8(w);
Victor Stinner386fe712010-05-19 00:34:15 +0000223 if (ps2 == NULL) {
224 PyErr_Clear();
225 ps2 = "";
226 }
227 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000228 }
229 arena = PyArena_New();
230 if (arena == NULL) {
231 Py_XDECREF(v);
232 Py_XDECREF(w);
233 Py_XDECREF(oenc);
234 return -1;
235 }
Victor Stinner95701bd2013-11-06 18:41:07 +0100236 mod = PyParser_ASTFromFileObject(fp, filename, enc,
237 Py_single_input, ps1, ps2,
238 flags, &errcode, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000239 Py_XDECREF(v);
240 Py_XDECREF(w);
241 Py_XDECREF(oenc);
242 if (mod == NULL) {
243 PyArena_Free(arena);
244 if (errcode == E_EOF) {
245 PyErr_Clear();
246 return E_EOF;
247 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000248 return -1;
249 }
Victor Stinner95701bd2013-11-06 18:41:07 +0100250 m = PyImport_AddModuleObject(mod_name);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000251 if (m == NULL) {
252 PyArena_Free(arena);
253 return -1;
254 }
255 d = PyModule_GetDict(m);
256 v = run_mod(mod, filename, d, d, flags, arena);
257 PyArena_Free(arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000258 if (v == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000259 return -1;
260 }
261 Py_DECREF(v);
Antoine Pitrou9845c7e2014-05-11 13:42:17 +0200262 flush_io();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000263 return 0;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000264}
265
Victor Stinner95701bd2013-11-06 18:41:07 +0100266int
xdegayee0582a32017-11-12 16:50:48 +0100267PyRun_InteractiveOneObject(FILE *fp, PyObject *filename, PyCompilerFlags *flags)
268{
269 int res;
270
271 res = PyRun_InteractiveOneObjectEx(fp, filename, flags);
272 if (res == -1) {
273 PyErr_Print();
274 flush_io();
275 }
276 return res;
277}
278
279int
Victor Stinner95701bd2013-11-06 18:41:07 +0100280PyRun_InteractiveOneFlags(FILE *fp, const char *filename_str, PyCompilerFlags *flags)
281{
282 PyObject *filename;
283 int res;
284
285 filename = PyUnicode_DecodeFSDefault(filename_str);
286 if (filename == NULL) {
287 PyErr_Print();
288 return -1;
289 }
290 res = PyRun_InteractiveOneObject(fp, filename, flags);
291 Py_DECREF(filename);
292 return res;
293}
294
295
Martin v. Löwisbe4c0f52001-01-04 20:30:56 +0000296/* Check whether a file maybe a pyc file: Look at the extension,
297 the file type, and, if we may close it, at the first few bytes. */
298
299static int
Martin v. Löwis95292d62002-12-11 14:04:59 +0000300maybe_pyc_file(FILE *fp, const char* filename, const char* ext, int closeit)
Martin v. Löwisbe4c0f52001-01-04 20:30:56 +0000301{
Brett Cannonf299abd2015-04-13 14:21:02 -0400302 if (strcmp(ext, ".pyc") == 0)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000303 return 1;
Martin v. Löwisbe4c0f52001-01-04 20:30:56 +0000304
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000305 /* Only look into the file if we are allowed to close it, since
306 it then should also be seekable. */
307 if (closeit) {
308 /* Read only two bytes of the magic. If the file was opened in
309 text mode, the bytes 3 and 4 of the magic (\r\n) might not
310 be read as they are on disk. */
311 unsigned int halfmagic = PyImport_GetMagicNumber() & 0xFFFF;
312 unsigned char buf[2];
313 /* Mess: In case of -x, the stream is NOT at its start now,
314 and ungetc() was used to push back the first newline,
315 which makes the current stream position formally undefined,
316 and a x-platform nightmare.
317 Unfortunately, we have no direct way to know whether -x
318 was specified. So we use a terrible hack: if the current
319 stream position is not 0, we assume -x was specified, and
320 give up. Bug 132850 on SourceForge spells out the
321 hopelessness of trying anything else (fseek and ftell
322 don't work predictably x-platform for text-mode files).
323 */
324 int ispyc = 0;
325 if (ftell(fp) == 0) {
326 if (fread(buf, 1, 2, fp) == 2 &&
327 ((unsigned int)buf[1]<<8 | buf[0]) == halfmagic)
328 ispyc = 1;
329 rewind(fp);
330 }
331 return ispyc;
332 }
333 return 0;
Tim Petersd08e3822003-04-17 15:24:21 +0000334}
Martin v. Löwisbe4c0f52001-01-04 20:30:56 +0000335
Antoine Pitrou32d483c2013-07-30 21:01:23 +0200336static int
337set_main_loader(PyObject *d, const char *filename, const char *loader_name)
Nick Coghlan85e729e2012-07-15 18:09:52 +1000338{
339 PyInterpreterState *interp;
340 PyThreadState *tstate;
Eric Snow32439d62015-05-02 19:15:18 -0600341 PyObject *filename_obj, *bootstrap, *loader_type = NULL, *loader;
Nick Coghlanb7a58942012-07-15 23:21:08 +1000342 int result = 0;
Andrew Svetlov90c0eb22012-11-01 14:51:14 +0200343
344 filename_obj = PyUnicode_DecodeFSDefault(filename);
345 if (filename_obj == NULL)
346 return -1;
Nick Coghlan85e729e2012-07-15 18:09:52 +1000347 /* Get current thread state and interpreter pointer */
348 tstate = PyThreadState_GET();
349 interp = tstate->interp;
Eric Snow32439d62015-05-02 19:15:18 -0600350 bootstrap = PyObject_GetAttrString(interp->importlib,
351 "_bootstrap_external");
352 if (bootstrap != NULL) {
353 loader_type = PyObject_GetAttrString(bootstrap, loader_name);
354 Py_DECREF(bootstrap);
355 }
Nick Coghlan3f94cbf2012-07-15 19:10:39 +1000356 if (loader_type == NULL) {
Andrew Svetlov90c0eb22012-11-01 14:51:14 +0200357 Py_DECREF(filename_obj);
Nick Coghlan3f94cbf2012-07-15 19:10:39 +1000358 return -1;
359 }
Andrew Svetlov90c0eb22012-11-01 14:51:14 +0200360 loader = PyObject_CallFunction(loader_type, "sN", "__main__", filename_obj);
Nick Coghlanb7a58942012-07-15 23:21:08 +1000361 Py_DECREF(loader_type);
362 if (loader == NULL) {
Nick Coghlan85e729e2012-07-15 18:09:52 +1000363 return -1;
364 }
Nick Coghlanb7a58942012-07-15 23:21:08 +1000365 if (PyDict_SetItemString(d, "__loader__", loader) < 0) {
366 result = -1;
367 }
Nick Coghlan85e729e2012-07-15 18:09:52 +1000368 Py_DECREF(loader);
Nick Coghlanb7a58942012-07-15 23:21:08 +1000369 return result;
Nick Coghlan85e729e2012-07-15 18:09:52 +1000370}
371
372int
Martin v. Löwis95292d62002-12-11 14:04:59 +0000373PyRun_SimpleFileExFlags(FILE *fp, const char *filename, int closeit,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000374 PyCompilerFlags *flags)
Jeremy Hyltonbc320242001-03-22 02:47:58 +0000375{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000376 PyObject *m, *d, *v;
377 const char *ext;
Hynek Schlawack5c6b3e22012-11-07 09:02:24 +0100378 int set_file_name = 0, ret = -1;
Victor Stinner0fcab4a2011-01-04 12:59:15 +0000379 size_t len;
Guido van Rossumfdef2711994-09-14 13:31:04 +0000380
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000381 m = PyImport_AddModule("__main__");
382 if (m == NULL)
383 return -1;
Hynek Schlawack5c6b3e22012-11-07 09:02:24 +0100384 Py_INCREF(m);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000385 d = PyModule_GetDict(m);
386 if (PyDict_GetItemString(d, "__file__") == NULL) {
387 PyObject *f;
Victor Stinner4c7c8c32010-10-16 13:14:10 +0000388 f = PyUnicode_DecodeFSDefault(filename);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000389 if (f == NULL)
Hynek Schlawack5c6b3e22012-11-07 09:02:24 +0100390 goto done;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000391 if (PyDict_SetItemString(d, "__file__", f) < 0) {
392 Py_DECREF(f);
Hynek Schlawack5c6b3e22012-11-07 09:02:24 +0100393 goto done;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000394 }
Barry Warsaw916048d2011-09-20 14:45:44 -0400395 if (PyDict_SetItemString(d, "__cached__", Py_None) < 0) {
396 Py_DECREF(f);
Hynek Schlawack5c6b3e22012-11-07 09:02:24 +0100397 goto done;
Barry Warsaw916048d2011-09-20 14:45:44 -0400398 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000399 set_file_name = 1;
400 Py_DECREF(f);
401 }
402 len = strlen(filename);
403 ext = filename + len - (len > 4 ? 4 : 0);
404 if (maybe_pyc_file(fp, filename, ext, closeit)) {
Christian Heimes04ac4c12012-09-11 15:47:28 +0200405 FILE *pyc_fp;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000406 /* Try to run a pyc file. First, re-open in binary */
407 if (closeit)
408 fclose(fp);
Victor Stinnerdaf45552013-08-28 00:53:59 +0200409 if ((pyc_fp = _Py_fopen(filename, "rb")) == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000410 fprintf(stderr, "python: Can't reopen .pyc file\n");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000411 goto done;
412 }
Nick Coghlan85e729e2012-07-15 18:09:52 +1000413
414 if (set_main_loader(d, filename, "SourcelessFileLoader") < 0) {
415 fprintf(stderr, "python: failed to set __main__.__loader__\n");
416 ret = -1;
Christian Heimes04ac4c12012-09-11 15:47:28 +0200417 fclose(pyc_fp);
Nick Coghlan85e729e2012-07-15 18:09:52 +1000418 goto done;
419 }
Christian Heimes04ac4c12012-09-11 15:47:28 +0200420 v = run_pyc_file(pyc_fp, filename, d, d, flags);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000421 } else {
Nick Coghlan85e729e2012-07-15 18:09:52 +1000422 /* When running from stdin, leave __main__.__loader__ alone */
423 if (strcmp(filename, "<stdin>") != 0 &&
424 set_main_loader(d, filename, "SourceFileLoader") < 0) {
425 fprintf(stderr, "python: failed to set __main__.__loader__\n");
426 ret = -1;
427 goto done;
428 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000429 v = PyRun_FileExFlags(fp, filename, Py_file_input, d, d,
430 closeit, flags);
431 }
432 flush_io();
433 if (v == NULL) {
434 PyErr_Print();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000435 goto done;
436 }
437 Py_DECREF(v);
438 ret = 0;
Guido van Rossumd8faa362007-04-27 19:54:29 +0000439 done:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000440 if (set_file_name && PyDict_DelItemString(d, "__file__"))
441 PyErr_Clear();
Hynek Schlawack5c6b3e22012-11-07 09:02:24 +0100442 Py_DECREF(m);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000443 return ret;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000444}
445
446int
Martin v. Löwis95292d62002-12-11 14:04:59 +0000447PyRun_SimpleStringFlags(const char *command, PyCompilerFlags *flags)
Guido van Rossum393661d2001-08-31 17:40:15 +0000448{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000449 PyObject *m, *d, *v;
450 m = PyImport_AddModule("__main__");
451 if (m == NULL)
452 return -1;
453 d = PyModule_GetDict(m);
454 v = PyRun_StringFlags(command, Py_file_input, d, d, flags);
455 if (v == NULL) {
456 PyErr_Print();
457 return -1;
458 }
459 Py_DECREF(v);
460 return 0;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000461}
462
Barry Warsaw035574d1997-08-29 22:07:17 +0000463static int
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100464parse_syntax_error(PyObject *err, PyObject **message, PyObject **filename,
465 int *lineno, int *offset, PyObject **text)
Barry Warsaw035574d1997-08-29 22:07:17 +0000466{
Serhiy Storchaka56f6e762015-09-06 21:25:30 +0300467 int hold;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000468 PyObject *v;
Martin v. Löwisbd928fe2011-10-14 10:20:37 +0200469 _Py_IDENTIFIER(msg);
470 _Py_IDENTIFIER(filename);
471 _Py_IDENTIFIER(lineno);
472 _Py_IDENTIFIER(offset);
473 _Py_IDENTIFIER(text);
Barry Warsaw035574d1997-08-29 22:07:17 +0000474
Benjamin Peterson80d50422012-04-03 00:30:38 -0400475 *message = NULL;
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100476 *filename = NULL;
Benjamin Peterson80d50422012-04-03 00:30:38 -0400477
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000478 /* new style errors. `err' is an instance */
Benjamin Peterson0a9a6362012-04-03 00:35:36 -0400479 *message = _PyObject_GetAttrId(err, &PyId_msg);
Benjamin Peterson80d50422012-04-03 00:30:38 -0400480 if (!*message)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000481 goto finally;
Barry Warsaw035574d1997-08-29 22:07:17 +0000482
Benjamin Peterson0a9a6362012-04-03 00:35:36 -0400483 v = _PyObject_GetAttrId(err, &PyId_filename);
Benjamin Peterson80d50422012-04-03 00:30:38 -0400484 if (!v)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000485 goto finally;
Benjamin Peterson80d50422012-04-03 00:30:38 -0400486 if (v == Py_None) {
487 Py_DECREF(v);
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100488 *filename = _PyUnicode_FromId(&PyId_string);
489 if (*filename == NULL)
490 goto finally;
491 Py_INCREF(*filename);
Benjamin Peterson80d50422012-04-03 00:30:38 -0400492 }
493 else {
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100494 *filename = v;
Benjamin Peterson80d50422012-04-03 00:30:38 -0400495 }
Barry Warsaw035574d1997-08-29 22:07:17 +0000496
Benjamin Peterson0a9a6362012-04-03 00:35:36 -0400497 v = _PyObject_GetAttrId(err, &PyId_lineno);
Benjamin Peterson80d50422012-04-03 00:30:38 -0400498 if (!v)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000499 goto finally;
Serhiy Storchaka56f6e762015-09-06 21:25:30 +0300500 hold = _PyLong_AsInt(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000501 Py_DECREF(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000502 if (hold < 0 && PyErr_Occurred())
503 goto finally;
Serhiy Storchaka56f6e762015-09-06 21:25:30 +0300504 *lineno = hold;
Barry Warsaw035574d1997-08-29 22:07:17 +0000505
Benjamin Peterson0a9a6362012-04-03 00:35:36 -0400506 v = _PyObject_GetAttrId(err, &PyId_offset);
Benjamin Peterson80d50422012-04-03 00:30:38 -0400507 if (!v)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000508 goto finally;
509 if (v == Py_None) {
510 *offset = -1;
511 Py_DECREF(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000512 } else {
Serhiy Storchaka56f6e762015-09-06 21:25:30 +0300513 hold = _PyLong_AsInt(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000514 Py_DECREF(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000515 if (hold < 0 && PyErr_Occurred())
516 goto finally;
Serhiy Storchaka56f6e762015-09-06 21:25:30 +0300517 *offset = hold;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000518 }
Barry Warsaw035574d1997-08-29 22:07:17 +0000519
Benjamin Peterson0a9a6362012-04-03 00:35:36 -0400520 v = _PyObject_GetAttrId(err, &PyId_text);
Benjamin Peterson80d50422012-04-03 00:30:38 -0400521 if (!v)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000522 goto finally;
Benjamin Peterson80d50422012-04-03 00:30:38 -0400523 if (v == Py_None) {
524 Py_DECREF(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000525 *text = NULL;
Benjamin Peterson80d50422012-04-03 00:30:38 -0400526 }
527 else {
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100528 *text = v;
Benjamin Peterson80d50422012-04-03 00:30:38 -0400529 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000530 return 1;
Barry Warsaw035574d1997-08-29 22:07:17 +0000531
532finally:
Benjamin Peterson80d50422012-04-03 00:30:38 -0400533 Py_XDECREF(*message);
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100534 Py_XDECREF(*filename);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000535 return 0;
Barry Warsaw035574d1997-08-29 22:07:17 +0000536}
537
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000538void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000539PyErr_Print(void)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000540{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000541 PyErr_PrintEx(1);
Guido van Rossuma61691e1998-02-06 22:27:24 +0000542}
543
Jeremy Hylton9f1b9932001-02-28 07:07:43 +0000544static void
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100545print_error_text(PyObject *f, int offset, PyObject *text_obj)
Jeremy Hylton9f1b9932001-02-28 07:07:43 +0000546{
Serhiy Storchaka85b0f5b2016-11-20 10:16:47 +0200547 const char *text;
548 const char *nl;
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100549
Serhiy Storchaka06515832016-11-20 09:13:07 +0200550 text = PyUnicode_AsUTF8(text_obj);
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100551 if (text == NULL)
552 return;
553
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000554 if (offset >= 0) {
Victor Stinner98ea54c2014-08-15 23:30:40 +0200555 if (offset > 0 && (size_t)offset == strlen(text) && text[offset - 1] == '\n')
Benjamin Petersona95e9772010-10-29 03:28:14 +0000556 offset--;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000557 for (;;) {
558 nl = strchr(text, '\n');
559 if (nl == NULL || nl-text >= offset)
560 break;
561 offset -= (int)(nl+1-text);
562 text = nl+1;
563 }
Martin Panterca3263c2016-12-11 00:18:36 +0000564 while (*text == ' ' || *text == '\t' || *text == '\f') {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000565 text++;
566 offset--;
567 }
568 }
569 PyFile_WriteString(" ", f);
570 PyFile_WriteString(text, f);
571 if (*text == '\0' || text[strlen(text)-1] != '\n')
572 PyFile_WriteString("\n", f);
573 if (offset == -1)
574 return;
575 PyFile_WriteString(" ", f);
Benjamin Petersona95e9772010-10-29 03:28:14 +0000576 while (--offset > 0)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000577 PyFile_WriteString(" ", f);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000578 PyFile_WriteString("^\n", f);
Jeremy Hylton9f1b9932001-02-28 07:07:43 +0000579}
580
Guido van Rossum66e8e862001-03-23 17:54:43 +0000581static void
582handle_system_exit(void)
Ka-Ping Yee26fabb02001-03-23 15:36:41 +0000583{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000584 PyObject *exception, *value, *tb;
585 int exitcode = 0;
Tim Peterscf615b52003-04-19 18:47:02 +0000586
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000587 if (Py_InspectFlag)
588 /* Don't exit if -i flag was given. This flag is set to 0
589 * when entering interactive mode for inspecting. */
590 return;
Guido van Rossumd8faa362007-04-27 19:54:29 +0000591
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000592 PyErr_Fetch(&exception, &value, &tb);
593 fflush(stdout);
594 if (value == NULL || value == Py_None)
595 goto done;
596 if (PyExceptionInstance_Check(value)) {
597 /* The error code should be in the `code' attribute. */
Martin v. Löwisbd928fe2011-10-14 10:20:37 +0200598 _Py_IDENTIFIER(code);
Martin v. Löwis1ee1b6f2011-10-10 18:11:30 +0200599 PyObject *code = _PyObject_GetAttrId(value, &PyId_code);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000600 if (code) {
601 Py_DECREF(value);
602 value = code;
603 if (value == Py_None)
604 goto done;
605 }
606 /* If we failed to dig out the 'code' attribute,
607 just let the else clause below print the error. */
608 }
609 if (PyLong_Check(value))
610 exitcode = (int)PyLong_AsLong(value);
611 else {
Victor Stinnerbd303c12013-11-07 23:07:29 +0100612 PyObject *sys_stderr = _PySys_GetObjectId(&PyId_stderr);
Nick Coghland979e432014-02-09 10:43:21 +1000613 /* We clear the exception here to avoid triggering the assertion
614 * in PyObject_Str that ensures it won't silently lose exception
615 * details.
616 */
617 PyErr_Clear();
Victor Stinner7126dbc2010-05-21 23:45:42 +0000618 if (sys_stderr != NULL && sys_stderr != Py_None) {
619 PyFile_WriteObject(value, sys_stderr, Py_PRINT_RAW);
620 } else {
621 PyObject_Print(value, stderr, Py_PRINT_RAW);
622 fflush(stderr);
623 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000624 PySys_WriteStderr("\n");
625 exitcode = 1;
626 }
Tim Peterscf615b52003-04-19 18:47:02 +0000627 done:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000628 /* Restore and clear the exception info, in order to properly decref
629 * the exception, value, and traceback. If we just exit instead,
630 * these leak, which confuses PYTHONDUMPREFS output, and may prevent
631 * some finalizers from running.
632 */
633 PyErr_Restore(exception, value, tb);
634 PyErr_Clear();
635 Py_Exit(exitcode);
636 /* NOTREACHED */
Ka-Ping Yee26fabb02001-03-23 15:36:41 +0000637}
638
639void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000640PyErr_PrintEx(int set_sys_last_vars)
Guido van Rossuma61691e1998-02-06 22:27:24 +0000641{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000642 PyObject *exception, *v, *tb, *hook;
Guido van Rossum66e8e862001-03-23 17:54:43 +0000643
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000644 if (PyErr_ExceptionMatches(PyExc_SystemExit)) {
645 handle_system_exit();
646 }
647 PyErr_Fetch(&exception, &v, &tb);
648 if (exception == NULL)
649 return;
650 PyErr_NormalizeException(&exception, &v, &tb);
651 if (tb == NULL) {
652 tb = Py_None;
653 Py_INCREF(tb);
654 }
655 PyException_SetTraceback(v, tb);
656 if (exception == NULL)
657 return;
658 /* Now we know v != NULL too */
659 if (set_sys_last_vars) {
xdegaye66caacf2017-10-23 18:08:41 +0200660 if (_PySys_SetObjectId(&PyId_last_type, exception) < 0) {
661 PyErr_Clear();
662 }
663 if (_PySys_SetObjectId(&PyId_last_value, v) < 0) {
664 PyErr_Clear();
665 }
666 if (_PySys_SetObjectId(&PyId_last_traceback, tb) < 0) {
667 PyErr_Clear();
668 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000669 }
Victor Stinner09054372013-11-06 22:41:44 +0100670 hook = _PySys_GetObjectId(&PyId_excepthook);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000671 if (hook) {
Victor Stinner71cb64a2016-08-20 00:57:43 +0200672 PyObject* stack[3];
673 PyObject *result;
674
675 stack[0] = exception;
676 stack[1] = v;
677 stack[2] = tb;
Victor Stinner559bb6a2016-08-22 22:48:54 +0200678 result = _PyObject_FastCall(hook, stack, 3);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000679 if (result == NULL) {
680 PyObject *exception2, *v2, *tb2;
681 if (PyErr_ExceptionMatches(PyExc_SystemExit)) {
682 handle_system_exit();
683 }
684 PyErr_Fetch(&exception2, &v2, &tb2);
685 PyErr_NormalizeException(&exception2, &v2, &tb2);
686 /* It should not be possible for exception2 or v2
687 to be NULL. However PyErr_Display() can't
688 tolerate NULLs, so just be safe. */
689 if (exception2 == NULL) {
690 exception2 = Py_None;
691 Py_INCREF(exception2);
692 }
693 if (v2 == NULL) {
694 v2 = Py_None;
695 Py_INCREF(v2);
696 }
697 fflush(stdout);
698 PySys_WriteStderr("Error in sys.excepthook:\n");
699 PyErr_Display(exception2, v2, tb2);
700 PySys_WriteStderr("\nOriginal exception was:\n");
701 PyErr_Display(exception, v, tb);
702 Py_DECREF(exception2);
703 Py_DECREF(v2);
704 Py_XDECREF(tb2);
705 }
706 Py_XDECREF(result);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000707 } else {
708 PySys_WriteStderr("sys.excepthook is missing\n");
709 PyErr_Display(exception, v, tb);
710 }
711 Py_XDECREF(exception);
712 Py_XDECREF(v);
713 Py_XDECREF(tb);
Ka-Ping Yeeb5c51322001-03-23 02:46:52 +0000714}
715
Benjamin Petersone6528212008-07-15 15:32:09 +0000716static void
717print_exception(PyObject *f, PyObject *value)
718{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000719 int err = 0;
720 PyObject *type, *tb;
Martin v. Löwis1c67dd92011-10-14 15:16:45 +0200721 _Py_IDENTIFIER(print_file_and_line);
Benjamin Petersone6528212008-07-15 15:32:09 +0000722
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000723 if (!PyExceptionInstance_Check(value)) {
Victor Stinner52ce3b02013-12-09 02:10:08 +0100724 err = PyFile_WriteString("TypeError: print_exception(): Exception expected for value, ", f);
725 err += PyFile_WriteString(Py_TYPE(value)->tp_name, f);
726 err += PyFile_WriteString(" found\n", f);
727 if (err)
728 PyErr_Clear();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000729 return;
730 }
Benjamin Peterson26582602008-08-23 20:08:07 +0000731
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000732 Py_INCREF(value);
733 fflush(stdout);
734 type = (PyObject *) Py_TYPE(value);
735 tb = PyException_GetTraceback(value);
736 if (tb && tb != Py_None)
737 err = PyTraceBack_Print(tb, f);
738 if (err == 0 &&
Martin v. Löwis1c67dd92011-10-14 15:16:45 +0200739 _PyObject_HasAttrId(value, &PyId_print_file_and_line))
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000740 {
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100741 PyObject *message, *filename, *text;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000742 int lineno, offset;
743 if (!parse_syntax_error(value, &message, &filename,
744 &lineno, &offset, &text))
745 PyErr_Clear();
746 else {
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100747 PyObject *line;
748
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000749 Py_DECREF(value);
750 value = message;
Victor Stinnerefa7a0e2013-11-07 12:37:56 +0100751
752 line = PyUnicode_FromFormat(" File \"%U\", line %d\n",
753 filename, lineno);
754 Py_DECREF(filename);
755 if (line != NULL) {
756 PyFile_WriteObject(line, f, Py_PRINT_RAW);
757 Py_DECREF(line);
758 }
759
760 if (text != NULL) {
761 print_error_text(f, offset, text);
762 Py_DECREF(text);
763 }
764
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000765 /* Can't be bothered to check all those
766 PyFile_WriteString() calls */
767 if (PyErr_Occurred())
768 err = -1;
769 }
770 }
771 if (err) {
772 /* Don't do anything else */
773 }
774 else {
775 PyObject* moduleName;
Serhiy Storchakaceeef102018-06-15 11:09:43 +0300776 const char *className;
Martin v. Löwisbd928fe2011-10-14 10:20:37 +0200777 _Py_IDENTIFIER(__module__);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000778 assert(PyExceptionClass_Check(type));
779 className = PyExceptionClass_Name(type);
780 if (className != NULL) {
Serhiy Storchakaceeef102018-06-15 11:09:43 +0300781 const char *dot = strrchr(className, '.');
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000782 if (dot != NULL)
783 className = dot+1;
784 }
Benjamin Petersone6528212008-07-15 15:32:09 +0000785
Martin v. Löwis1ee1b6f2011-10-10 18:11:30 +0200786 moduleName = _PyObject_GetAttrId(type, &PyId___module__);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000787 if (moduleName == NULL || !PyUnicode_Check(moduleName))
788 {
Victor Stinner13b21bd2011-05-26 14:25:13 +0200789 Py_XDECREF(moduleName);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000790 err = PyFile_WriteString("<unknown>", f);
791 }
792 else {
Serhiy Storchakaf5894dd2016-11-16 15:40:39 +0200793 if (!_PyUnicode_EqualToASCIIId(moduleName, &PyId_builtins))
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000794 {
Victor Stinner937114f2013-11-07 00:12:30 +0100795 err = PyFile_WriteObject(moduleName, f, Py_PRINT_RAW);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000796 err += PyFile_WriteString(".", f);
797 }
798 Py_DECREF(moduleName);
799 }
800 if (err == 0) {
801 if (className == NULL)
802 err = PyFile_WriteString("<unknown>", f);
803 else
804 err = PyFile_WriteString(className, f);
805 }
806 }
807 if (err == 0 && (value != Py_None)) {
808 PyObject *s = PyObject_Str(value);
809 /* only print colon if the str() of the
810 object is not the empty string
811 */
Martin Panter3263f682016-02-28 03:16:11 +0000812 if (s == NULL) {
813 PyErr_Clear();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000814 err = -1;
Martin Panter3263f682016-02-28 03:16:11 +0000815 PyFile_WriteString(": <exception str() failed>", f);
816 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000817 else if (!PyUnicode_Check(s) ||
Victor Stinnere251d6d2011-11-20 19:20:00 +0100818 PyUnicode_GetLength(s) != 0)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000819 err = PyFile_WriteString(": ", f);
820 if (err == 0)
821 err = PyFile_WriteObject(s, f, Py_PRINT_RAW);
822 Py_XDECREF(s);
823 }
824 /* try to write a newline in any case */
Martin Panter3263f682016-02-28 03:16:11 +0000825 if (err < 0) {
826 PyErr_Clear();
827 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000828 err += PyFile_WriteString("\n", f);
829 Py_XDECREF(tb);
830 Py_DECREF(value);
831 /* If an error happened here, don't show it.
832 XXX This is wrong, but too many callers rely on this behavior. */
833 if (err != 0)
834 PyErr_Clear();
Benjamin Petersone6528212008-07-15 15:32:09 +0000835}
836
Serhiy Storchaka2d06e842015-12-25 19:53:18 +0200837static const char cause_message[] =
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000838 "\nThe above exception was the direct cause "
839 "of the following exception:\n\n";
Benjamin Petersone6528212008-07-15 15:32:09 +0000840
Serhiy Storchaka2d06e842015-12-25 19:53:18 +0200841static const char context_message[] =
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000842 "\nDuring handling of the above exception, "
843 "another exception occurred:\n\n";
Benjamin Petersone6528212008-07-15 15:32:09 +0000844
845static void
846print_exception_recursive(PyObject *f, PyObject *value, PyObject *seen)
847{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000848 int err = 0, res;
849 PyObject *cause, *context;
Benjamin Petersone6528212008-07-15 15:32:09 +0000850
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000851 if (seen != NULL) {
852 /* Exception chaining */
Zane Bitterde860732017-10-17 17:29:39 -0400853 PyObject *value_id = PyLong_FromVoidPtr(value);
854 if (value_id == NULL || PySet_Add(seen, value_id) == -1)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000855 PyErr_Clear();
856 else if (PyExceptionInstance_Check(value)) {
Zane Bitterde860732017-10-17 17:29:39 -0400857 PyObject *check_id = NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000858 cause = PyException_GetCause(value);
859 context = PyException_GetContext(value);
Benjamin Petersond5a1c442012-05-14 22:09:31 -0700860 if (cause) {
Zane Bitterde860732017-10-17 17:29:39 -0400861 check_id = PyLong_FromVoidPtr(cause);
862 if (check_id == NULL) {
863 res = -1;
864 } else {
865 res = PySet_Contains(seen, check_id);
866 Py_DECREF(check_id);
867 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000868 if (res == -1)
869 PyErr_Clear();
870 if (res == 0) {
871 print_exception_recursive(
872 f, cause, seen);
873 err |= PyFile_WriteString(
874 cause_message, f);
875 }
876 }
Benjamin Petersond5a1c442012-05-14 22:09:31 -0700877 else if (context &&
878 !((PyBaseExceptionObject *)value)->suppress_context) {
Zane Bitterde860732017-10-17 17:29:39 -0400879 check_id = PyLong_FromVoidPtr(context);
880 if (check_id == NULL) {
881 res = -1;
882 } else {
883 res = PySet_Contains(seen, check_id);
884 Py_DECREF(check_id);
885 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000886 if (res == -1)
887 PyErr_Clear();
888 if (res == 0) {
889 print_exception_recursive(
890 f, context, seen);
891 err |= PyFile_WriteString(
892 context_message, f);
893 }
894 }
895 Py_XDECREF(context);
896 Py_XDECREF(cause);
897 }
Zane Bitterde860732017-10-17 17:29:39 -0400898 Py_XDECREF(value_id);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000899 }
900 print_exception(f, value);
901 if (err != 0)
902 PyErr_Clear();
Benjamin Petersone6528212008-07-15 15:32:09 +0000903}
904
Thomas Wouters477c8d52006-05-27 19:21:47 +0000905void
906PyErr_Display(PyObject *exception, PyObject *value, PyObject *tb)
Ka-Ping Yeeb5c51322001-03-23 02:46:52 +0000907{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000908 PyObject *seen;
Victor Stinnerbd303c12013-11-07 23:07:29 +0100909 PyObject *f = _PySys_GetObjectId(&PyId_stderr);
Antoine Pitrou24201d42013-10-13 21:53:13 +0200910 if (PyExceptionInstance_Check(value)
911 && tb != NULL && PyTraceBack_Check(tb)) {
912 /* Put the traceback on the exception, otherwise it won't get
913 displayed. See issue #18776. */
914 PyObject *cur_tb = PyException_GetTraceback(value);
915 if (cur_tb == NULL)
916 PyException_SetTraceback(value, tb);
917 else
918 Py_DECREF(cur_tb);
919 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000920 if (f == Py_None) {
921 /* pass */
922 }
923 else if (f == NULL) {
924 _PyObject_Dump(value);
925 fprintf(stderr, "lost sys.stderr\n");
926 }
927 else {
928 /* We choose to ignore seen being possibly NULL, and report
929 at least the main exception (it could be a MemoryError).
930 */
931 seen = PySet_New(NULL);
932 if (seen == NULL)
933 PyErr_Clear();
934 print_exception_recursive(f, value, seen);
935 Py_XDECREF(seen);
936 }
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000937}
938
Guido van Rossum82598051997-03-05 00:20:32 +0000939PyObject *
Thomas Wouters4d70c3d2006-06-08 14:42:34 +0000940PyRun_StringFlags(const char *str, int start, PyObject *globals,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000941 PyObject *locals, PyCompilerFlags *flags)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000942{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000943 PyObject *ret = NULL;
944 mod_ty mod;
Victor Stinner95701bd2013-11-06 18:41:07 +0100945 PyArena *arena;
Victor Stinner95701bd2013-11-06 18:41:07 +0100946 PyObject *filename;
947
948 filename = _PyUnicode_FromId(&PyId_string); /* borrowed */
949 if (filename == NULL)
950 return NULL;
951
952 arena = PyArena_New();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000953 if (arena == NULL)
954 return NULL;
Guido van Rossum98297ee2007-11-06 21:34:58 +0000955
Victor Stinner95701bd2013-11-06 18:41:07 +0100956 mod = PyParser_ASTFromStringObject(str, filename, start, flags, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000957 if (mod != NULL)
Victor Stinner95701bd2013-11-06 18:41:07 +0100958 ret = run_mod(mod, filename, globals, locals, flags, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000959 PyArena_Free(arena);
960 return ret;
Jeremy Hyltonbc320242001-03-22 02:47:58 +0000961}
962
963PyObject *
Victor Stinner95701bd2013-11-06 18:41:07 +0100964PyRun_FileExFlags(FILE *fp, const char *filename_str, int start, PyObject *globals,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000965 PyObject *locals, int closeit, PyCompilerFlags *flags)
Jeremy Hyltonbc320242001-03-22 02:47:58 +0000966{
Victor Stinner95701bd2013-11-06 18:41:07 +0100967 PyObject *ret = NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000968 mod_ty mod;
Victor Stinner95701bd2013-11-06 18:41:07 +0100969 PyArena *arena = NULL;
970 PyObject *filename;
Guido van Rossum98297ee2007-11-06 21:34:58 +0000971
Victor Stinner95701bd2013-11-06 18:41:07 +0100972 filename = PyUnicode_DecodeFSDefault(filename_str);
973 if (filename == NULL)
974 goto exit;
975
976 arena = PyArena_New();
977 if (arena == NULL)
978 goto exit;
979
980 mod = PyParser_ASTFromFileObject(fp, filename, NULL, start, 0, 0,
981 flags, NULL, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000982 if (closeit)
983 fclose(fp);
984 if (mod == NULL) {
Victor Stinner95701bd2013-11-06 18:41:07 +0100985 goto exit;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000986 }
987 ret = run_mod(mod, filename, globals, locals, flags, arena);
Victor Stinner95701bd2013-11-06 18:41:07 +0100988
989exit:
990 Py_XDECREF(filename);
991 if (arena != NULL)
992 PyArena_Free(arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000993 return ret;
Jeremy Hyltonbc320242001-03-22 02:47:58 +0000994}
995
Guido van Rossum6c193fa2007-12-05 05:14:58 +0000996static void
997flush_io(void)
998{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000999 PyObject *f, *r;
1000 PyObject *type, *value, *traceback;
Amaury Forgeot d'Arc9ed77352008-04-04 23:25:27 +00001001
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001002 /* Save the current exception */
1003 PyErr_Fetch(&type, &value, &traceback);
Amaury Forgeot d'Arc9ed77352008-04-04 23:25:27 +00001004
Victor Stinnerbd303c12013-11-07 23:07:29 +01001005 f = _PySys_GetObjectId(&PyId_stderr);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001006 if (f != NULL) {
Victor Stinner3466bde2016-09-05 18:16:01 -07001007 r = _PyObject_CallMethodId(f, &PyId_flush, NULL);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001008 if (r)
1009 Py_DECREF(r);
1010 else
1011 PyErr_Clear();
1012 }
Victor Stinnerbd303c12013-11-07 23:07:29 +01001013 f = _PySys_GetObjectId(&PyId_stdout);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001014 if (f != NULL) {
Victor Stinner3466bde2016-09-05 18:16:01 -07001015 r = _PyObject_CallMethodId(f, &PyId_flush, NULL);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001016 if (r)
1017 Py_DECREF(r);
1018 else
1019 PyErr_Clear();
1020 }
Amaury Forgeot d'Arc9ed77352008-04-04 23:25:27 +00001021
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001022 PyErr_Restore(type, value, traceback);
Guido van Rossum6c193fa2007-12-05 05:14:58 +00001023}
1024
Guido van Rossum82598051997-03-05 00:20:32 +00001025static PyObject *
Victor Stinner95701bd2013-11-06 18:41:07 +01001026run_mod(mod_ty mod, PyObject *filename, PyObject *globals, PyObject *locals,
1027 PyCompilerFlags *flags, PyArena *arena)
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001028{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001029 PyCodeObject *co;
1030 PyObject *v;
Victor Stinner95701bd2013-11-06 18:41:07 +01001031 co = PyAST_CompileObject(mod, filename, flags, -1, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001032 if (co == NULL)
1033 return NULL;
Martin v. Löwis4d0d4712010-12-03 20:14:31 +00001034 v = PyEval_EvalCode((PyObject*)co, globals, locals);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001035 Py_DECREF(co);
1036 return v;
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001037}
1038
Guido van Rossum82598051997-03-05 00:20:32 +00001039static PyObject *
Thomas Wouters4d70c3d2006-06-08 14:42:34 +00001040run_pyc_file(FILE *fp, const char *filename, PyObject *globals,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001041 PyObject *locals, PyCompilerFlags *flags)
Guido van Rossumfdef2711994-09-14 13:31:04 +00001042{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001043 PyCodeObject *co;
1044 PyObject *v;
1045 long magic;
1046 long PyImport_GetMagicNumber(void);
Guido van Rossumfdef2711994-09-14 13:31:04 +00001047
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001048 magic = PyMarshal_ReadLongFromFile(fp);
1049 if (magic != PyImport_GetMagicNumber()) {
Victor Stinner5200f552015-03-18 13:56:25 +01001050 if (!PyErr_Occurred())
1051 PyErr_SetString(PyExc_RuntimeError,
1052 "Bad magic number in .pyc file");
Zackery Spytzea737752018-06-23 21:15:24 -06001053 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001054 }
Benjamin Peterson42aa93b2017-12-09 10:26:52 -08001055 /* Skip the rest of the header. */
1056 (void) PyMarshal_ReadLongFromFile(fp);
Antoine Pitrou5136ac02012-01-13 18:52:16 +01001057 (void) PyMarshal_ReadLongFromFile(fp);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001058 (void) PyMarshal_ReadLongFromFile(fp);
Zackery Spytzea737752018-06-23 21:15:24 -06001059 if (PyErr_Occurred()) {
1060 goto error;
1061 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001062 v = PyMarshal_ReadLastObjectFromFile(fp);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001063 if (v == NULL || !PyCode_Check(v)) {
1064 Py_XDECREF(v);
1065 PyErr_SetString(PyExc_RuntimeError,
1066 "Bad code object in .pyc file");
Zackery Spytzea737752018-06-23 21:15:24 -06001067 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001068 }
Zackery Spytzea737752018-06-23 21:15:24 -06001069 fclose(fp);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001070 co = (PyCodeObject *)v;
Martin v. Löwis4d0d4712010-12-03 20:14:31 +00001071 v = PyEval_EvalCode((PyObject*)co, globals, locals);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001072 if (v && flags)
1073 flags->cf_flags |= (co->co_flags & PyCF_MASK);
1074 Py_DECREF(co);
1075 return v;
Zackery Spytzea737752018-06-23 21:15:24 -06001076error:
1077 fclose(fp);
1078 return NULL;
Guido van Rossumfdef2711994-09-14 13:31:04 +00001079}
1080
Guido van Rossum82598051997-03-05 00:20:32 +00001081PyObject *
Victor Stinner14e461d2013-08-26 22:28:21 +02001082Py_CompileStringObject(const char *str, PyObject *filename, int start,
1083 PyCompilerFlags *flags, int optimize)
Jeremy Hyltonbc320242001-03-22 02:47:58 +00001084{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001085 PyCodeObject *co;
1086 mod_ty mod;
1087 PyArena *arena = PyArena_New();
1088 if (arena == NULL)
1089 return NULL;
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001090
Victor Stinner14e461d2013-08-26 22:28:21 +02001091 mod = PyParser_ASTFromStringObject(str, filename, start, flags, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001092 if (mod == NULL) {
1093 PyArena_Free(arena);
1094 return NULL;
1095 }
1096 if (flags && (flags->cf_flags & PyCF_ONLY_AST)) {
1097 PyObject *result = PyAST_mod2obj(mod);
1098 PyArena_Free(arena);
1099 return result;
1100 }
Victor Stinner14e461d2013-08-26 22:28:21 +02001101 co = PyAST_CompileObject(mod, filename, flags, optimize, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001102 PyArena_Free(arena);
1103 return (PyObject *)co;
Guido van Rossum5b722181993-03-30 17:46:03 +00001104}
1105
Victor Stinner14e461d2013-08-26 22:28:21 +02001106PyObject *
1107Py_CompileStringExFlags(const char *str, const char *filename_str, int start,
1108 PyCompilerFlags *flags, int optimize)
1109{
1110 PyObject *filename, *co;
1111 filename = PyUnicode_DecodeFSDefault(filename_str);
1112 if (filename == NULL)
1113 return NULL;
1114 co = Py_CompileStringObject(str, filename, start, flags, optimize);
1115 Py_DECREF(filename);
1116 return co;
1117}
1118
Martin v. Löwis4d0d4712010-12-03 20:14:31 +00001119/* For use in Py_LIMITED_API */
1120#undef Py_CompileString
1121PyObject *
1122PyCompileString(const char *str, const char *filename, int start)
1123{
1124 return Py_CompileStringFlags(str, filename, start, NULL);
1125}
1126
Jeremy Hylton4b38da62001-02-02 18:19:15 +00001127struct symtable *
Victor Stinner14e461d2013-08-26 22:28:21 +02001128Py_SymtableStringObject(const char *str, PyObject *filename, int start)
Jeremy Hylton4b38da62001-02-02 18:19:15 +00001129{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001130 struct symtable *st;
1131 mod_ty mod;
1132 PyCompilerFlags flags;
Victor Stinner14e461d2013-08-26 22:28:21 +02001133 PyArena *arena;
1134
1135 arena = PyArena_New();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001136 if (arena == NULL)
1137 return NULL;
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001138
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001139 flags.cf_flags = 0;
Victor Stinner14e461d2013-08-26 22:28:21 +02001140 mod = PyParser_ASTFromStringObject(str, filename, start, &flags, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001141 if (mod == NULL) {
1142 PyArena_Free(arena);
1143 return NULL;
1144 }
Victor Stinner14e461d2013-08-26 22:28:21 +02001145 st = PySymtable_BuildObject(mod, filename, 0);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001146 PyArena_Free(arena);
1147 return st;
Jeremy Hylton4b38da62001-02-02 18:19:15 +00001148}
1149
Victor Stinner14e461d2013-08-26 22:28:21 +02001150struct symtable *
1151Py_SymtableString(const char *str, const char *filename_str, int start)
1152{
1153 PyObject *filename;
1154 struct symtable *st;
1155
1156 filename = PyUnicode_DecodeFSDefault(filename_str);
1157 if (filename == NULL)
1158 return NULL;
1159 st = Py_SymtableStringObject(str, filename, start);
1160 Py_DECREF(filename);
1161 return st;
1162}
1163
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001164/* Preferred access to parser is through AST. */
1165mod_ty
Victor Stinner14e461d2013-08-26 22:28:21 +02001166PyParser_ASTFromStringObject(const char *s, PyObject *filename, int start,
1167 PyCompilerFlags *flags, PyArena *arena)
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001168{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001169 mod_ty mod;
1170 PyCompilerFlags localflags;
1171 perrdetail err;
1172 int iflags = PARSER_FLAGS(flags);
Christian Heimes4d6ec852008-03-26 22:34:47 +00001173
Victor Stinner14e461d2013-08-26 22:28:21 +02001174 node *n = PyParser_ParseStringObject(s, filename,
1175 &_PyParser_Grammar, start, &err,
1176 &iflags);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001177 if (flags == NULL) {
1178 localflags.cf_flags = 0;
1179 flags = &localflags;
1180 }
1181 if (n) {
1182 flags->cf_flags |= iflags & PyCF_MASK;
Victor Stinner14e461d2013-08-26 22:28:21 +02001183 mod = PyAST_FromNodeObject(n, flags, filename, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001184 PyNode_Free(n);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001185 }
1186 else {
1187 err_input(&err);
Victor Stinner7f2fee32011-04-05 00:39:01 +02001188 mod = NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001189 }
Victor Stinner7f2fee32011-04-05 00:39:01 +02001190 err_free(&err);
1191 return mod;
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001192}
1193
1194mod_ty
Victor Stinner14e461d2013-08-26 22:28:21 +02001195PyParser_ASTFromString(const char *s, const char *filename_str, int start,
1196 PyCompilerFlags *flags, PyArena *arena)
1197{
1198 PyObject *filename;
1199 mod_ty mod;
1200 filename = PyUnicode_DecodeFSDefault(filename_str);
1201 if (filename == NULL)
1202 return NULL;
1203 mod = PyParser_ASTFromStringObject(s, filename, start, flags, arena);
1204 Py_DECREF(filename);
1205 return mod;
1206}
1207
1208mod_ty
1209PyParser_ASTFromFileObject(FILE *fp, PyObject *filename, const char* enc,
Serhiy Storchakaef1585e2015-12-25 20:01:53 +02001210 int start, const char *ps1,
1211 const char *ps2, PyCompilerFlags *flags, int *errcode,
Victor Stinner14e461d2013-08-26 22:28:21 +02001212 PyArena *arena)
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001213{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001214 mod_ty mod;
1215 PyCompilerFlags localflags;
1216 perrdetail err;
1217 int iflags = PARSER_FLAGS(flags);
Christian Heimes4d6ec852008-03-26 22:34:47 +00001218
Victor Stinner14e461d2013-08-26 22:28:21 +02001219 node *n = PyParser_ParseFileObject(fp, filename, enc,
1220 &_PyParser_Grammar,
1221 start, ps1, ps2, &err, &iflags);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001222 if (flags == NULL) {
1223 localflags.cf_flags = 0;
1224 flags = &localflags;
1225 }
1226 if (n) {
1227 flags->cf_flags |= iflags & PyCF_MASK;
Victor Stinner14e461d2013-08-26 22:28:21 +02001228 mod = PyAST_FromNodeObject(n, flags, filename, arena);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001229 PyNode_Free(n);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001230 }
1231 else {
1232 err_input(&err);
1233 if (errcode)
1234 *errcode = err.error;
Victor Stinner7f2fee32011-04-05 00:39:01 +02001235 mod = NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001236 }
Victor Stinner7f2fee32011-04-05 00:39:01 +02001237 err_free(&err);
1238 return mod;
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001239}
1240
Victor Stinner14e461d2013-08-26 22:28:21 +02001241mod_ty
1242PyParser_ASTFromFile(FILE *fp, const char *filename_str, const char* enc,
Serhiy Storchakaef1585e2015-12-25 20:01:53 +02001243 int start, const char *ps1,
1244 const char *ps2, PyCompilerFlags *flags, int *errcode,
Victor Stinner14e461d2013-08-26 22:28:21 +02001245 PyArena *arena)
1246{
1247 mod_ty mod;
1248 PyObject *filename;
1249 filename = PyUnicode_DecodeFSDefault(filename_str);
1250 if (filename == NULL)
1251 return NULL;
1252 mod = PyParser_ASTFromFileObject(fp, filename, enc, start, ps1, ps2,
1253 flags, errcode, arena);
1254 Py_DECREF(filename);
1255 return mod;
1256}
1257
Guido van Rossuma110aa61994-08-29 12:50:44 +00001258/* Simplified interface to parsefile -- return node or set exception */
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001259
Guido van Rossuma110aa61994-08-29 12:50:44 +00001260node *
Martin v. Löwis95292d62002-12-11 14:04:59 +00001261PyParser_SimpleParseFileFlags(FILE *fp, const char *filename, int start, int flags)
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001262{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001263 perrdetail err;
1264 node *n = PyParser_ParseFileFlags(fp, filename, NULL,
1265 &_PyParser_Grammar,
1266 start, NULL, NULL, &err, flags);
1267 if (n == NULL)
1268 err_input(&err);
Victor Stinner7f2fee32011-04-05 00:39:01 +02001269 err_free(&err);
Thomas Wouters4d70c3d2006-06-08 14:42:34 +00001270
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001271 return n;
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001272}
1273
Guido van Rossuma110aa61994-08-29 12:50:44 +00001274/* Simplified interface to parsestring -- return node or set exception */
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001275
Guido van Rossuma110aa61994-08-29 12:50:44 +00001276node *
Martin v. Löwis95292d62002-12-11 14:04:59 +00001277PyParser_SimpleParseStringFlags(const char *str, int start, int flags)
Tim Petersfe2127d2001-07-16 05:37:24 +00001278{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001279 perrdetail err;
1280 node *n = PyParser_ParseStringFlags(str, &_PyParser_Grammar,
1281 start, &err, flags);
1282 if (n == NULL)
1283 err_input(&err);
Victor Stinner7f2fee32011-04-05 00:39:01 +02001284 err_free(&err);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001285 return n;
Tim Petersfe2127d2001-07-16 05:37:24 +00001286}
1287
1288node *
Martin v. Löwis95292d62002-12-11 14:04:59 +00001289PyParser_SimpleParseStringFlagsFilename(const char *str, const char *filename,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001290 int start, int flags)
Thomas Heller6b17abf2002-07-09 09:23:27 +00001291{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001292 perrdetail err;
1293 node *n = PyParser_ParseStringFlagsFilename(str, filename,
1294 &_PyParser_Grammar, start, &err, flags);
1295 if (n == NULL)
1296 err_input(&err);
Victor Stinner7f2fee32011-04-05 00:39:01 +02001297 err_free(&err);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001298 return n;
Thomas Heller6b17abf2002-07-09 09:23:27 +00001299}
1300
1301node *
Martin v. Löwis95292d62002-12-11 14:04:59 +00001302PyParser_SimpleParseStringFilename(const char *str, const char *filename, int start)
Thomas Heller6b17abf2002-07-09 09:23:27 +00001303{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001304 return PyParser_SimpleParseStringFlagsFilename(str, filename, start, 0);
Thomas Heller6b17abf2002-07-09 09:23:27 +00001305}
1306
Guido van Rossum66ebd912003-04-17 16:02:26 +00001307/* May want to move a more generalized form of this to parsetok.c or
1308 even parser modules. */
1309
1310void
Victor Stinner7f2fee32011-04-05 00:39:01 +02001311PyParser_ClearError(perrdetail *err)
1312{
1313 err_free(err);
1314}
1315
1316void
Guido van Rossum66ebd912003-04-17 16:02:26 +00001317PyParser_SetError(perrdetail *err)
1318{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001319 err_input(err);
Guido van Rossum66ebd912003-04-17 16:02:26 +00001320}
1321
Victor Stinner7f2fee32011-04-05 00:39:01 +02001322static void
1323err_free(perrdetail *err)
1324{
1325 Py_CLEAR(err->filename);
1326}
1327
Guido van Rossuma110aa61994-08-29 12:50:44 +00001328/* Set the error appropriate to the given input error code (see errcode.h) */
1329
1330static void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00001331err_input(perrdetail *err)
Guido van Rossuma110aa61994-08-29 12:50:44 +00001332{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001333 PyObject *v, *w, *errtype, *errtext;
1334 PyObject *msg_obj = NULL;
Serhiy Storchakae2f92de2017-11-11 13:06:26 +02001335 const char *msg = NULL;
Serhiy Storchaka65fd0592014-01-21 22:26:52 +02001336 int offset = err->offset;
Victor Stinner4c7c8c32010-10-16 13:14:10 +00001337
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001338 errtype = PyExc_SyntaxError;
1339 switch (err->error) {
1340 case E_ERROR:
1341 return;
1342 case E_SYNTAX:
1343 errtype = PyExc_IndentationError;
1344 if (err->expected == INDENT)
1345 msg = "expected an indented block";
1346 else if (err->token == INDENT)
1347 msg = "unexpected indent";
1348 else if (err->token == DEDENT)
1349 msg = "unexpected unindent";
1350 else {
1351 errtype = PyExc_SyntaxError;
1352 msg = "invalid syntax";
1353 }
1354 break;
1355 case E_TOKEN:
1356 msg = "invalid token";
1357 break;
1358 case E_EOFS:
1359 msg = "EOF while scanning triple-quoted string literal";
1360 break;
1361 case E_EOLS:
1362 msg = "EOL while scanning string literal";
1363 break;
1364 case E_INTR:
1365 if (!PyErr_Occurred())
1366 PyErr_SetNone(PyExc_KeyboardInterrupt);
1367 goto cleanup;
1368 case E_NOMEM:
1369 PyErr_NoMemory();
1370 goto cleanup;
1371 case E_EOF:
1372 msg = "unexpected EOF while parsing";
1373 break;
1374 case E_TABSPACE:
1375 errtype = PyExc_TabError;
1376 msg = "inconsistent use of tabs and spaces in indentation";
1377 break;
1378 case E_OVERFLOW:
1379 msg = "expression too long";
1380 break;
1381 case E_DEDENT:
1382 errtype = PyExc_IndentationError;
1383 msg = "unindent does not match any outer indentation level";
1384 break;
1385 case E_TOODEEP:
1386 errtype = PyExc_IndentationError;
1387 msg = "too many levels of indentation";
1388 break;
1389 case E_DECODE: {
1390 PyObject *type, *value, *tb;
1391 PyErr_Fetch(&type, &value, &tb);
1392 msg = "unknown decode error";
1393 if (value != NULL)
1394 msg_obj = PyObject_Str(value);
1395 Py_XDECREF(type);
1396 Py_XDECREF(value);
1397 Py_XDECREF(tb);
1398 break;
1399 }
1400 case E_LINECONT:
1401 msg = "unexpected character after line continuation character";
1402 break;
Martin v. Löwis47383402007-08-15 07:32:56 +00001403
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001404 case E_IDENTIFIER:
1405 msg = "invalid character in identifier";
1406 break;
Meador Ingefa21bf02012-01-19 01:08:41 -06001407 case E_BADSINGLE:
1408 msg = "multiple statements found while compiling a single statement";
1409 break;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001410 default:
1411 fprintf(stderr, "error=%d\n", err->error);
1412 msg = "unknown parsing error";
1413 break;
1414 }
1415 /* err->text may not be UTF-8 in case of decoding errors.
1416 Explicitly convert to an object. */
1417 if (!err->text) {
1418 errtext = Py_None;
1419 Py_INCREF(Py_None);
1420 } else {
Serhiy Storchaka65fd0592014-01-21 22:26:52 +02001421 errtext = PyUnicode_DecodeUTF8(err->text, err->offset,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001422 "replace");
Serhiy Storchaka65fd0592014-01-21 22:26:52 +02001423 if (errtext != NULL) {
1424 Py_ssize_t len = strlen(err->text);
1425 offset = (int)PyUnicode_GET_LENGTH(errtext);
1426 if (len != err->offset) {
1427 Py_DECREF(errtext);
1428 errtext = PyUnicode_DecodeUTF8(err->text, len,
1429 "replace");
1430 }
1431 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001432 }
Victor Stinner7f2fee32011-04-05 00:39:01 +02001433 v = Py_BuildValue("(OiiN)", err->filename,
Serhiy Storchaka65fd0592014-01-21 22:26:52 +02001434 err->lineno, offset, errtext);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001435 if (v != NULL) {
1436 if (msg_obj)
1437 w = Py_BuildValue("(OO)", msg_obj, v);
1438 else
1439 w = Py_BuildValue("(sO)", msg, v);
1440 } else
1441 w = NULL;
1442 Py_XDECREF(v);
1443 PyErr_SetObject(errtype, w);
1444 Py_XDECREF(w);
Georg Brandl3dbca812008-07-23 16:10:53 +00001445cleanup:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001446 Py_XDECREF(msg_obj);
1447 if (err->text != NULL) {
1448 PyObject_FREE(err->text);
1449 err->text = NULL;
1450 }
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001451}
1452
Fredrik Lundh2f15b252000-08-27 19:15:31 +00001453
Zachary Warec4821d62014-11-21 23:35:12 -06001454#if defined(USE_STACKCHECK)
1455#if defined(WIN32) && defined(_MSC_VER)
1456
1457/* Stack checking for Microsoft C */
1458
1459#include <malloc.h>
1460#include <excpt.h>
1461
1462/*
1463 * Return non-zero when we run out of memory on the stack; zero otherwise.
1464 */
1465int
1466PyOS_CheckStack(void)
1467{
1468 __try {
1469 /* alloca throws a stack overflow exception if there's
1470 not enough space left on the stack */
1471 alloca(PYOS_STACK_MARGIN * sizeof(void*));
1472 return 0;
1473 } __except (GetExceptionCode() == STATUS_STACK_OVERFLOW ?
1474 EXCEPTION_EXECUTE_HANDLER :
1475 EXCEPTION_CONTINUE_SEARCH) {
1476 int errcode = _resetstkoflw();
1477 if (errcode == 0)
1478 {
1479 Py_FatalError("Could not reset the stack!");
1480 }
1481 }
1482 return 1;
1483}
1484
1485#endif /* WIN32 && _MSC_VER */
1486
1487/* Alternate implementations can be added here... */
1488
1489#endif /* USE_STACKCHECK */
1490
Martin Panter46f50722016-05-26 05:35:26 +00001491/* Deprecated C API functions still provided for binary compatibility */
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001492
1493#undef PyParser_SimpleParseFile
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001494PyAPI_FUNC(node *)
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001495PyParser_SimpleParseFile(FILE *fp, const char *filename, int start)
1496{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001497 return PyParser_SimpleParseFileFlags(fp, filename, start, 0);
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001498}
1499
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001500#undef PyParser_SimpleParseString
1501PyAPI_FUNC(node *)
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001502PyParser_SimpleParseString(const char *str, int start)
1503{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001504 return PyParser_SimpleParseStringFlags(str, start, 0);
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00001505}
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001506
1507#undef PyRun_AnyFile
1508PyAPI_FUNC(int)
1509PyRun_AnyFile(FILE *fp, const char *name)
1510{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001511 return PyRun_AnyFileExFlags(fp, name, 0, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001512}
1513
1514#undef PyRun_AnyFileEx
1515PyAPI_FUNC(int)
1516PyRun_AnyFileEx(FILE *fp, const char *name, int closeit)
1517{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001518 return PyRun_AnyFileExFlags(fp, name, closeit, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001519}
1520
1521#undef PyRun_AnyFileFlags
1522PyAPI_FUNC(int)
1523PyRun_AnyFileFlags(FILE *fp, const char *name, PyCompilerFlags *flags)
1524{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001525 return PyRun_AnyFileExFlags(fp, name, 0, flags);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001526}
1527
1528#undef PyRun_File
1529PyAPI_FUNC(PyObject *)
1530PyRun_File(FILE *fp, const char *p, int s, PyObject *g, PyObject *l)
1531{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001532 return PyRun_FileExFlags(fp, p, s, g, l, 0, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001533}
1534
1535#undef PyRun_FileEx
1536PyAPI_FUNC(PyObject *)
1537PyRun_FileEx(FILE *fp, const char *p, int s, PyObject *g, PyObject *l, int c)
1538{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001539 return PyRun_FileExFlags(fp, p, s, g, l, c, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001540}
1541
1542#undef PyRun_FileFlags
1543PyAPI_FUNC(PyObject *)
1544PyRun_FileFlags(FILE *fp, const char *p, int s, PyObject *g, PyObject *l,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001545 PyCompilerFlags *flags)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001546{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001547 return PyRun_FileExFlags(fp, p, s, g, l, 0, flags);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001548}
1549
1550#undef PyRun_SimpleFile
1551PyAPI_FUNC(int)
1552PyRun_SimpleFile(FILE *f, const char *p)
1553{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001554 return PyRun_SimpleFileExFlags(f, p, 0, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001555}
1556
1557#undef PyRun_SimpleFileEx
1558PyAPI_FUNC(int)
1559PyRun_SimpleFileEx(FILE *f, const char *p, int c)
1560{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001561 return PyRun_SimpleFileExFlags(f, p, c, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001562}
1563
1564
1565#undef PyRun_String
1566PyAPI_FUNC(PyObject *)
1567PyRun_String(const char *str, int s, PyObject *g, PyObject *l)
1568{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001569 return PyRun_StringFlags(str, s, g, l, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001570}
1571
1572#undef PyRun_SimpleString
1573PyAPI_FUNC(int)
1574PyRun_SimpleString(const char *s)
1575{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001576 return PyRun_SimpleStringFlags(s, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001577}
1578
1579#undef Py_CompileString
1580PyAPI_FUNC(PyObject *)
1581Py_CompileString(const char *str, const char *p, int s)
1582{
Georg Brandl8334fd92010-12-04 10:26:46 +00001583 return Py_CompileStringExFlags(str, p, s, NULL, -1);
1584}
1585
1586#undef Py_CompileStringFlags
1587PyAPI_FUNC(PyObject *)
1588Py_CompileStringFlags(const char *str, const char *p, int s,
1589 PyCompilerFlags *flags)
1590{
1591 return Py_CompileStringExFlags(str, p, s, flags, -1);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001592}
1593
1594#undef PyRun_InteractiveOne
1595PyAPI_FUNC(int)
1596PyRun_InteractiveOne(FILE *f, const char *p)
1597{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001598 return PyRun_InteractiveOneFlags(f, p, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001599}
1600
1601#undef PyRun_InteractiveLoop
1602PyAPI_FUNC(int)
1603PyRun_InteractiveLoop(FILE *f, const char *p)
1604{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001605 return PyRun_InteractiveLoopFlags(f, p, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001606}
1607
1608#ifdef __cplusplus
1609}
1610#endif