diff options
author | Batuhan Taşkaya <47358913+isidentical@users.noreply.github.com> | 2020-03-16 08:12:53 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-03-16 08:12:53 (GMT) |
commit | 4ab362cec6dc68c798b3e354f687cf39e207b9a9 (patch) | |
tree | fd3e04e72101bda5ade2fc0ee4437974a53daa9b /Parser | |
parent | 5b66ec166b81c8a77286da2c0d17be3579c3069a (diff) | |
download | cpython-4ab362cec6dc68c798b3e354f687cf39e207b9a9.zip cpython-4ab362cec6dc68c798b3e354f687cf39e207b9a9.tar.gz cpython-4ab362cec6dc68c798b3e354f687cf39e207b9a9.tar.bz2 |
bpo-39638: Keep ASDL signatures in the AST nodes (GH-18515)
Diffstat (limited to 'Parser')
-rw-r--r-- | Parser/asdl.py | 10 | ||||
-rwxr-xr-x | Parser/asdl_c.py | 45 |
2 files changed, 47 insertions, 8 deletions
diff --git a/Parser/asdl.py b/Parser/asdl.py index 62f5c19..5416377 100644 --- a/Parser/asdl.py +++ b/Parser/asdl.py @@ -72,6 +72,16 @@ class Field(AST): self.seq = seq self.opt = opt + def __str__(self): + if self.seq: + extra = "*" + elif self.opt: + extra = "?" + else: + extra = "" + + return "{}{} {}".format(self.type, extra, self.name) + def __repr__(self): if self.seq: extra = ", seq=True" diff --git a/Parser/asdl_c.py b/Parser/asdl_c.py index 016c12d..478f0e8 100755 --- a/Parser/asdl_c.py +++ b/Parser/asdl_c.py @@ -60,6 +60,9 @@ def reflow_lines(s, depth): lines.append(padding + cur) return lines +def reflow_c_string(s, depth): + return '"%s"' % s.replace('\n', '\\n"\n%s"' % (' ' * depth * TABSIZE)) + def is_simple(sum): """Return True if a sum is a simple. @@ -71,6 +74,21 @@ def is_simple(sum): return False return True +def asdl_of(name, obj): + if isinstance(obj, asdl.Product) or isinstance(obj, asdl.Constructor): + fields = ", ".join(map(str, obj.fields)) + if fields: + fields = "({})".format(fields) + return "{}{}".format(name, fields) + else: + if is_simple(obj): + types = " | ".join(type.name for type in obj.types) + else: + sep = "\n{}| ".format(" " * (len(name) + 1)) + types = sep.join( + asdl_of(type.name, type) for type in obj.types + ) + return "{} = {}".format(name, types) class EmitVisitor(asdl.VisitorBase): """Visit that emits lines""" @@ -764,7 +782,7 @@ static PyType_Spec AST_type_spec = { }; static PyObject * -make_type(const char *type, PyObject* base, const char* const* fields, int num_fields) +make_type(const char *type, PyObject* base, const char* const* fields, int num_fields, const char *doc) { PyObject *fnames, *result; int i; @@ -778,11 +796,12 @@ make_type(const char *type, PyObject* base, const char* const* fields, int num_f } PyTuple_SET_ITEM(fnames, i, field); } - result = PyObject_CallFunction((PyObject*)&PyType_Type, "s(O){OOOO}", + result = PyObject_CallFunction((PyObject*)&PyType_Type, "s(O){OOOOOs}", type, base, astmodulestate_global->_fields, fnames, astmodulestate_global->__module__, - astmodulestate_global->_ast); + astmodulestate_global->_ast, + astmodulestate_global->__doc__, doc); Py_DECREF(fnames); return result; } @@ -947,8 +966,9 @@ static int add_ast_fields(void) fields = name+"_fields" else: fields = "NULL" - self.emit('state->%s_type = make_type("%s", state->AST_type, %s, %d);' % + self.emit('state->%s_type = make_type("%s", state->AST_type, %s, %d,' % (name, name, fields, len(prod.fields)), 1) + self.emit('%s);' % reflow_c_string(asdl_of(name, prod), 2), 2, reflow=False) self.emit("if (!state->%s_type) return 0;" % name, 1) self.emit_type("AST_type") self.emit_type("%s_type" % name) @@ -961,8 +981,9 @@ static int add_ast_fields(void) self.emit_defaults(name, prod.attributes, 1) def visitSum(self, sum, name): - self.emit('state->%s_type = make_type("%s", state->AST_type, NULL, 0);' % + self.emit('state->%s_type = make_type("%s", state->AST_type, NULL, 0,' % (name, name), 1) + self.emit('%s);' % reflow_c_string(asdl_of(name, sum), 2), 2, reflow=False) self.emit_type("%s_type" % name) self.emit("if (!state->%s_type) return 0;" % name, 1) if sum.attributes: @@ -980,8 +1001,9 @@ static int add_ast_fields(void) fields = cons.name+"_fields" else: fields = "NULL" - self.emit('state->%s_type = make_type("%s", state->%s_type, %s, %d);' % + self.emit('state->%s_type = make_type("%s", state->%s_type, %s, %d,' % (cons.name, cons.name, name, fields, len(cons.fields)), 1) + self.emit('%s);' % reflow_c_string(asdl_of(cons.name, cons), 2), 2, reflow=False) self.emit("if (!state->%s_type) return 0;" % cons.name, 1) self.emit_type("%s_type" % cons.name) self.emit_defaults(cons.name, cons.fields, 1) @@ -1279,8 +1301,15 @@ def generate_module_def(f, mod): visitor.visit(mod) visitor_list.add(visitor) - state_strings = set(["__dict__", "_attributes", "_fields", "__module__", "_ast"]) - module_state = set(["__dict__", "_attributes", "_fields", "__module__", "_ast"]) + state_strings = { + "_ast", + "_fields", + "__doc__", + "__dict__", + "__module__", + "_attributes", + } + module_state = state_strings.copy() for visitor in visitor_list: for identifier in visitor.identifiers: module_state.add(identifier) |