mirror of
				https://github.com/python/cpython.git
				synced 2025-11-03 19:34:08 +00:00 
			
		
		
		
	Add a new _PyCompilerFlags_INIT macro to initialize PyCompilerFlags variables, rather than initializing cf_flags and cf_feature_version explicitly in each variable.
		
			
				
	
	
		
			126 lines
		
	
	
	
		
			3.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			126 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;
 | 
						|
}
 |