blob: c3234920d57ef908597310e578ba8c21bf5f610a [file] [log] [blame]
Jeremy Hylton5e7cb242001-02-02 18:24:26 +00001#include "Python.h"
2
Jeremy Hylton3e0055f2005-10-20 19:59:25 +00003#include "Python-ast.h"
Victor Stinner28ad12f2021-03-19 12:41:49 +01004#include "pycore_symtable.h" // struct symtable
Jeremy Hylton5e7cb242001-02-02 18:24:26 +00005
Serhiy Storchaka5106ad12017-02-04 12:13:20 +02006#include "clinic/symtablemodule.c.h"
7/*[clinic input]
8module _symtable
9[clinic start generated code]*/
10/*[clinic end generated code: output=da39a3ee5e6b4b0d input=f4685845a7100605]*/
11
12
13/*[clinic input]
14_symtable.symtable
15
Dino Viehland41540692019-05-28 16:21:17 -070016 source: object
Serhiy Storchaka5106ad12017-02-04 12:13:20 +020017 filename: object(converter='PyUnicode_FSDecoder')
18 startstr: str
19 /
20
21Return symbol and scope dictionaries used internally by compiler.
22[clinic start generated code]*/
23
Jeremy Hylton5e7cb242001-02-02 18:24:26 +000024static PyObject *
Dino Viehland41540692019-05-28 16:21:17 -070025_symtable_symtable_impl(PyObject *module, PyObject *source,
Serhiy Storchaka5106ad12017-02-04 12:13:20 +020026 PyObject *filename, const char *startstr)
Dino Viehland41540692019-05-28 16:21:17 -070027/*[clinic end generated code: output=59eb0d5fc7285ac4 input=9dd8a50c0c36a4d7]*/
Jeremy Hylton5e7cb242001-02-02 18:24:26 +000028{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000029 struct symtable *st;
30 PyObject *t;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000031 int start;
Victor Stinner37d66d72019-06-13 02:16:41 +020032 PyCompilerFlags cf = _PyCompilerFlags_INIT;
Dino Viehland41540692019-05-28 16:21:17 -070033 PyObject *source_copy = NULL;
34
35 cf.cf_flags = PyCF_SOURCE_IS_UTF8;
Dino Viehland41540692019-05-28 16:21:17 -070036
37 const char *str = _Py_SourceAsString(source, "symtable", "string or bytes", &cf, &source_copy);
38 if (str == NULL) {
39 return NULL;
40 }
Jeremy Hylton5e7cb242001-02-02 18:24:26 +000041
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000042 if (strcmp(startstr, "exec") == 0)
43 start = Py_file_input;
44 else if (strcmp(startstr, "eval") == 0)
45 start = Py_eval_input;
46 else if (strcmp(startstr, "single") == 0)
47 start = Py_single_input;
48 else {
49 PyErr_SetString(PyExc_ValueError,
50 "symtable() arg 3 must be 'exec' or 'eval' or 'single'");
Victor Stinner14e461d2013-08-26 22:28:21 +020051 Py_DECREF(filename);
Dino Viehland41540692019-05-28 16:21:17 -070052 Py_XDECREF(source_copy);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000053 return NULL;
54 }
Dino Viehland41540692019-05-28 16:21:17 -070055 st = _Py_SymtableStringObjectFlags(str, filename, start, &cf);
Victor Stinner14e461d2013-08-26 22:28:21 +020056 Py_DECREF(filename);
Dino Viehland41540692019-05-28 16:21:17 -070057 Py_XDECREF(source_copy);
58 if (st == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000059 return NULL;
Dino Viehland41540692019-05-28 16:21:17 -070060 }
Benjamin Peterson89d8cd92013-10-26 13:13:51 -040061 t = (PyObject *)st->st_top;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000062 Py_INCREF(t);
63 PyMem_Free((void *)st->st_future);
Victor Stinner28ad12f2021-03-19 12:41:49 +010064 _PySymtable_Free(st);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000065 return t;
Jeremy Hylton5e7cb242001-02-02 18:24:26 +000066}
67
68static PyMethodDef symtable_methods[] = {
Serhiy Storchaka5106ad12017-02-04 12:13:20 +020069 _SYMTABLE_SYMTABLE_METHODDEF
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000070 {NULL, NULL} /* sentinel */
Jeremy Hylton5e7cb242001-02-02 18:24:26 +000071};
72
Christian Heimesc7011012020-11-18 16:03:51 +010073static int
74symtable_init_stentry_type(PyObject *m)
75{
76 return PyType_Ready(&PySTEntry_Type);
77}
78
79static int
80symtable_init_constants(PyObject *m)
81{
82 if (PyModule_AddIntMacro(m, USE) < 0) return -1;
83 if (PyModule_AddIntMacro(m, DEF_GLOBAL) < 0) return -1;
84 if (PyModule_AddIntMacro(m, DEF_NONLOCAL) < 0) return -1;
85 if (PyModule_AddIntMacro(m, DEF_LOCAL) < 0) return -1;
86 if (PyModule_AddIntMacro(m, DEF_PARAM) < 0) return -1;
87 if (PyModule_AddIntMacro(m, DEF_FREE) < 0) return -1;
88 if (PyModule_AddIntMacro(m, DEF_FREE_CLASS) < 0) return -1;
89 if (PyModule_AddIntMacro(m, DEF_IMPORT) < 0) return -1;
90 if (PyModule_AddIntMacro(m, DEF_BOUND) < 0) return -1;
91 if (PyModule_AddIntMacro(m, DEF_ANNOT) < 0) return -1;
92
93 if (PyModule_AddIntConstant(m, "TYPE_FUNCTION", FunctionBlock) < 0)
94 return -1;
95 if (PyModule_AddIntConstant(m, "TYPE_CLASS", ClassBlock) < 0) return -1;
96 if (PyModule_AddIntConstant(m, "TYPE_MODULE", ModuleBlock) < 0)
97 return -1;
98
99 if (PyModule_AddIntMacro(m, LOCAL) < 0) return -1;
100 if (PyModule_AddIntMacro(m, GLOBAL_EXPLICIT) < 0) return -1;
101 if (PyModule_AddIntMacro(m, GLOBAL_IMPLICIT) < 0) return -1;
102 if (PyModule_AddIntMacro(m, FREE) < 0) return -1;
103 if (PyModule_AddIntMacro(m, CELL) < 0) return -1;
104
105 if (PyModule_AddIntConstant(m, "SCOPE_OFF", SCOPE_OFFSET) < 0) return -1;
106 if (PyModule_AddIntMacro(m, SCOPE_MASK) < 0) return -1;
107
108 return 0;
109}
110
111static PyModuleDef_Slot symtable_slots[] = {
112 {Py_mod_exec, symtable_init_stentry_type},
113 {Py_mod_exec, symtable_init_constants},
114 {0, NULL}
115};
116
Martin v. Löwis1a214512008-06-11 05:26:20 +0000117static struct PyModuleDef symtablemodule = {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000118 PyModuleDef_HEAD_INIT,
Christian Heimesc7011012020-11-18 16:03:51 +0100119 .m_name = "_symtable",
120 .m_size = 0,
121 .m_methods = symtable_methods,
122 .m_slots = symtable_slots,
Martin v. Löwis1a214512008-06-11 05:26:20 +0000123};
124
Mark Hammondfe51c6d2002-08-02 02:27:13 +0000125PyMODINIT_FUNC
Martin v. Löwis1a214512008-06-11 05:26:20 +0000126PyInit__symtable(void)
Jeremy Hylton5e7cb242001-02-02 18:24:26 +0000127{
Christian Heimesc7011012020-11-18 16:03:51 +0100128 return PyModuleDef_Init(&symtablemodule);
Jeremy Hylton5e7cb242001-02-02 18:24:26 +0000129}