mirror of
https://github.com/python/cpython.git
synced 2024-12-12 03:04:15 +08:00
37d66d7d4b
Add a new _PyCompilerFlags_INIT macro to initialize PyCompilerFlags variables, rather than initializing cf_flags and cf_feature_version explicitly in each variable.
127 lines
3.2 KiB
C
127 lines
3.2 KiB
C
#include "Python.h"
|
|
|
|
#include "code.h"
|
|
#include "Python-ast.h"
|
|
#include "symtable.h"
|
|
|
|
#include "clinic/symtablemodule.c.h"
|
|
/*[clinic input]
|
|
module _symtable
|
|
[clinic start generated code]*/
|
|
/*[clinic end generated code: output=da39a3ee5e6b4b0d input=f4685845a7100605]*/
|
|
|
|
|
|
/*[clinic input]
|
|
_symtable.symtable
|
|
|
|
source: object
|
|
filename: object(converter='PyUnicode_FSDecoder')
|
|
startstr: str
|
|
/
|
|
|
|
Return symbol and scope dictionaries used internally by compiler.
|
|
[clinic start generated code]*/
|
|
|
|
static PyObject *
|
|
_symtable_symtable_impl(PyObject *module, PyObject *source,
|
|
PyObject *filename, const char *startstr)
|
|
/*[clinic end generated code: output=59eb0d5fc7285ac4 input=9dd8a50c0c36a4d7]*/
|
|
{
|
|
struct symtable *st;
|
|
PyObject *t;
|
|
int start;
|
|
PyCompilerFlags cf = _PyCompilerFlags_INIT;
|
|
PyObject *source_copy = NULL;
|
|
|
|
cf.cf_flags = PyCF_SOURCE_IS_UTF8;
|
|
|
|
const char *str = _Py_SourceAsString(source, "symtable", "string or bytes", &cf, &source_copy);
|
|
if (str == NULL) {
|
|
return NULL;
|
|
}
|
|
|
|
if (strcmp(startstr, "exec") == 0)
|
|
start = Py_file_input;
|
|
else if (strcmp(startstr, "eval") == 0)
|
|
start = Py_eval_input;
|
|
else if (strcmp(startstr, "single") == 0)
|
|
start = Py_single_input;
|
|
else {
|
|
PyErr_SetString(PyExc_ValueError,
|
|
"symtable() arg 3 must be 'exec' or 'eval' or 'single'");
|
|
Py_DECREF(filename);
|
|
Py_XDECREF(source_copy);
|
|
return NULL;
|
|
}
|
|
st = _Py_SymtableStringObjectFlags(str, filename, start, &cf);
|
|
Py_DECREF(filename);
|
|
Py_XDECREF(source_copy);
|
|
if (st == NULL) {
|
|
return NULL;
|
|
}
|
|
t = (PyObject *)st->st_top;
|
|
Py_INCREF(t);
|
|
PyMem_Free((void *)st->st_future);
|
|
PySymtable_Free(st);
|
|
return t;
|
|
}
|
|
|
|
static PyMethodDef symtable_methods[] = {
|
|
_SYMTABLE_SYMTABLE_METHODDEF
|
|
{NULL, NULL} /* sentinel */
|
|
};
|
|
|
|
static struct PyModuleDef symtablemodule = {
|
|
PyModuleDef_HEAD_INIT,
|
|
"_symtable",
|
|
NULL,
|
|
-1,
|
|
symtable_methods,
|
|
NULL,
|
|
NULL,
|
|
NULL,
|
|
NULL
|
|
};
|
|
|
|
PyMODINIT_FUNC
|
|
PyInit__symtable(void)
|
|
{
|
|
PyObject *m;
|
|
|
|
if (PyType_Ready(&PySTEntry_Type) < 0)
|
|
return NULL;
|
|
|
|
m = PyModule_Create(&symtablemodule);
|
|
if (m == NULL)
|
|
return NULL;
|
|
PyModule_AddIntMacro(m, USE);
|
|
PyModule_AddIntMacro(m, DEF_GLOBAL);
|
|
PyModule_AddIntMacro(m, DEF_NONLOCAL);
|
|
PyModule_AddIntMacro(m, DEF_LOCAL);
|
|
PyModule_AddIntMacro(m, DEF_PARAM);
|
|
PyModule_AddIntMacro(m, DEF_FREE);
|
|
PyModule_AddIntMacro(m, DEF_FREE_CLASS);
|
|
PyModule_AddIntMacro(m, DEF_IMPORT);
|
|
PyModule_AddIntMacro(m, DEF_BOUND);
|
|
PyModule_AddIntMacro(m, DEF_ANNOT);
|
|
|
|
PyModule_AddIntConstant(m, "TYPE_FUNCTION", FunctionBlock);
|
|
PyModule_AddIntConstant(m, "TYPE_CLASS", ClassBlock);
|
|
PyModule_AddIntConstant(m, "TYPE_MODULE", ModuleBlock);
|
|
|
|
PyModule_AddIntMacro(m, LOCAL);
|
|
PyModule_AddIntMacro(m, GLOBAL_EXPLICIT);
|
|
PyModule_AddIntMacro(m, GLOBAL_IMPLICIT);
|
|
PyModule_AddIntMacro(m, FREE);
|
|
PyModule_AddIntMacro(m, CELL);
|
|
|
|
PyModule_AddIntConstant(m, "SCOPE_OFF", SCOPE_OFFSET);
|
|
PyModule_AddIntMacro(m, SCOPE_MASK);
|
|
|
|
if (PyErr_Occurred()) {
|
|
Py_DECREF(m);
|
|
m = 0;
|
|
}
|
|
return m;
|
|
}
|