summaryrefslogtreecommitdiffstats
path: root/Parser
diff options
context:
space:
mode:
authorBatuhan Taşkaya <47358913+isidentical@users.noreply.github.com>2020-03-16 08:12:53 (GMT)
committerGitHub <noreply@github.com>2020-03-16 08:12:53 (GMT)
commit4ab362cec6dc68c798b3e354f687cf39e207b9a9 (patch)
treefd3e04e72101bda5ade2fc0ee4437974a53daa9b /Parser
parent5b66ec166b81c8a77286da2c0d17be3579c3069a (diff)
downloadcpython-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.py10
-rwxr-xr-xParser/asdl_c.py45
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)