mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 18:54:53 +00:00 
			
		
		
		
	 4db62b1e14
			
		
	
	
		4db62b1e14
		
	
	
	
	
		
			
			Makefile.pre.in: add target future.o
Include/compile.h: define PyFutureFeaters and PyNode_Future()
                   add c_future slot to struct compiling
Include/symtable.h: add st_future slot to struct symtable
Python/future.c: implementation of PyNode_Future()
Python/compile.c: use PyNode_Future() for nested_scopes support
Python/symtable.c: include compile.h to pick up PyFutureFeatures decl
		
	
			
		
			
				
	
	
		
			150 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			150 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #include "Python.h"
 | |
| #include "compile.h"
 | |
| #include "symtable.h"
 | |
| #include "graminit.h"
 | |
| #include "structmember.h"
 | |
| 
 | |
| PyObject *
 | |
| PySymtableEntry_New(struct symtable *st, char *name, int type, int lineno)
 | |
| {
 | |
| 	PySymtableEntryObject *ste = NULL;
 | |
| 	PyObject *k, *v;
 | |
| 
 | |
| 	k = PyInt_FromLong(st->st_nscopes++);
 | |
| 	if (k == NULL)
 | |
| 		goto fail;
 | |
| 	v = PyDict_GetItem(st->st_symbols, k);
 | |
| 	if (v) /* XXX could check that name, type, lineno match */ {
 | |
| 		Py_INCREF(v);
 | |
| 		return v;
 | |
| 	}
 | |
| 	
 | |
| 	ste = (PySymtableEntryObject *)PyObject_New(PySymtableEntryObject,
 | |
| 						    &PySymtableEntry_Type);
 | |
| 	ste->ste_table = st;
 | |
| 	ste->ste_id = k;
 | |
| 
 | |
| 	v = PyString_FromString(name);
 | |
| 	if (v == NULL)
 | |
| 		goto fail;
 | |
| 	ste->ste_name = v;
 | |
| 	
 | |
| 	v = PyDict_New();
 | |
| 	if (v == NULL)
 | |
| 	    goto fail;
 | |
| 	ste->ste_symbols = v;
 | |
| 
 | |
| 	v = PyList_New(0);
 | |
| 	if (v == NULL)
 | |
| 	    goto fail;
 | |
| 	ste->ste_varnames = v;
 | |
| 
 | |
| 	v = PyList_New(0);
 | |
| 	if (v == NULL)
 | |
| 	    goto fail;
 | |
| 	ste->ste_children = v;
 | |
| 
 | |
| 	ste->ste_optimized = 0;
 | |
| 	ste->ste_lineno = lineno;
 | |
| 	switch (type) {
 | |
| 	case funcdef:
 | |
| 	case lambdef:
 | |
| 		ste->ste_type = TYPE_FUNCTION;
 | |
| 		break;
 | |
| 	case classdef:
 | |
| 		ste->ste_type = TYPE_CLASS;
 | |
| 		break;
 | |
| 	case single_input:
 | |
| 	case eval_input:
 | |
| 	case file_input:
 | |
| 		ste->ste_type = TYPE_MODULE;
 | |
| 		break;
 | |
| 	}
 | |
| 
 | |
| 	if (st->st_cur == NULL)
 | |
| 		ste->ste_nested = 0;
 | |
| 	else if (st->st_cur->ste_nested 
 | |
| 		 || st->st_cur->ste_type == TYPE_FUNCTION)
 | |
| 		ste->ste_nested = 1;
 | |
| 	else
 | |
| 		ste->ste_nested = 0;
 | |
| 	ste->ste_child_free = 0;
 | |
| 
 | |
| 	if (PyDict_SetItem(st->st_symbols, ste->ste_id, (PyObject *)ste) < 0)
 | |
| 	    goto fail;
 | |
| 	
 | |
| 	return (PyObject *)ste;
 | |
|  fail:
 | |
| 	Py_XDECREF(ste);
 | |
| 	return NULL;
 | |
| }
 | |
| 
 | |
| static PyObject *
 | |
| ste_repr(PySymtableEntryObject *ste)
 | |
| {
 | |
| 	char buf[256];
 | |
| 
 | |
| 	sprintf(buf, "<symtable entry %.100s(%ld), line %d>",
 | |
| 		PyString_AS_STRING(ste->ste_name),
 | |
| 		PyInt_AS_LONG(ste->ste_id),
 | |
| 		ste->ste_lineno);
 | |
| 	return PyString_FromString(buf);
 | |
| }
 | |
| 
 | |
| static void
 | |
| ste_dealloc(PySymtableEntryObject *ste)
 | |
| {
 | |
| 	ste->ste_table = NULL;
 | |
| 	Py_XDECREF(ste->ste_id);
 | |
| 	Py_XDECREF(ste->ste_name);
 | |
| 	Py_XDECREF(ste->ste_symbols);
 | |
| 	Py_XDECREF(ste->ste_varnames);
 | |
| 	Py_XDECREF(ste->ste_children);
 | |
| 	PyObject_Del(ste);
 | |
| }
 | |
| 
 | |
| #define OFF(x) offsetof(PySymtableEntryObject, x)
 | |
| 
 | |
| static struct memberlist ste_memberlist[] = {
 | |
| 	{"id",       T_OBJECT, OFF(ste_id), READONLY},
 | |
| 	{"name",     T_OBJECT, OFF(ste_name), READONLY},
 | |
| 	{"symbols",  T_OBJECT, OFF(ste_symbols), READONLY},
 | |
| 	{"varnames", T_OBJECT, OFF(ste_varnames), READONLY},
 | |
| 	{"children", T_OBJECT, OFF(ste_children), READONLY},
 | |
| 	{"type",     T_INT,    OFF(ste_type), READONLY},
 | |
| 	{"lineno",   T_INT,    OFF(ste_lineno), READONLY},
 | |
| 	{"optimized",T_INT,    OFF(ste_optimized), READONLY},
 | |
| 	{"nested",   T_INT,    OFF(ste_nested), READONLY},
 | |
| 	{NULL}
 | |
| };
 | |
| 
 | |
| static PyObject *
 | |
| ste_getattr(PySymtableEntryObject *ste, char *name)
 | |
| {
 | |
| 	return PyMember_Get((char *)ste, ste_memberlist, name);
 | |
| }
 | |
| 
 | |
| PyTypeObject PySymtableEntry_Type = {
 | |
| 	PyObject_HEAD_INIT(&PyType_Type)
 | |
| 	0,
 | |
| 	"symtable entry",
 | |
| 	sizeof(PySymtableEntryObject),
 | |
| 	0,
 | |
| 	(destructor)ste_dealloc,                /* tp_dealloc */
 | |
| 	0,                                      /* tp_print */
 | |
| 	(getattrfunc)ste_getattr,               /* tp_getattr */
 | |
| 	0,					/* tp_setattr */
 | |
| 	0,			                /* tp_compare */
 | |
| 	(reprfunc)ste_repr,			/* tp_repr */
 | |
| 	0,					/* tp_as_number */
 | |
| 	0,			                /* tp_as_sequence */
 | |
| 	0,					/* tp_as_mapping */
 | |
| 	0,					/* tp_hash */
 | |
| 	0,					/* tp_call */
 | |
| 	0,					/* tp_str */
 | |
| 	0,					/* tp_getattro */
 | |
| 	0,					/* tp_setattro */
 | |
| 	0,					/* tp_as_buffer */
 | |
| 	Py_TPFLAGS_DEFAULT,	                /* tp_flags */
 | |
|  	0,					/* tp_doc */
 | |
| };
 |