summaryrefslogtreecommitdiff
path: root/Tools/clinic/clinic.py
diff options
context:
space:
mode:
authorLarry Hastings <larry@hastings.org>2014-01-22 03:05:49 -0800
committerLarry Hastings <larry@hastings.org>2014-01-22 03:05:49 -0800
commit419d5e474dce3ffbac3a6ee7f35dc5858941d43c (patch)
tree7e5cd13a1deb9a039054eb0cf8abe119a147d26d /Tools/clinic/clinic.py
parenta01d4d4104e699943bfe332ba279cc906341db0e (diff)
downloadcpython-419d5e474dce3ffbac3a6ee7f35dc5858941d43c.tar.gz
Two minor Argument Clinic bugfixes: use the name of the class in the
docstring for __new__ and __init__, and always use "goto exit" instead of returning "NULL" for failure to parse (as _new__ and __init__ return ints).
Diffstat (limited to 'Tools/clinic/clinic.py')
-rwxr-xr-xTools/clinic/clinic.py10
1 files changed, 7 insertions, 3 deletions
diff --git a/Tools/clinic/clinic.py b/Tools/clinic/clinic.py
index 289ec267c4..8fc2e1e823 100755
--- a/Tools/clinic/clinic.py
+++ b/Tools/clinic/clinic.py
@@ -913,7 +913,7 @@ __________________________________________________
s = """
case {count}:
if (!PyArg_ParseTuple(args, "{format_units}:{name}", {parse_arguments}))
- return NULL;
+ goto exit;
{group_booleans}
break;
"""[1:]
@@ -924,7 +924,7 @@ __________________________________________________
add(" default:\n")
s = ' PyErr_SetString(PyExc_TypeError, "{} requires {} to {} arguments");\n'
add(s.format(f.full_name, count_min, count_max))
- add(' return NULL;\n')
+ add(' goto exit;\n')
add("}}")
template_dict['option_group_parsing'] = output()
@@ -3401,7 +3401,11 @@ class DSLParser:
## docstring first line
##
- add(f.name)
+ if f.kind in (METHOD_NEW, METHOD_INIT):
+ assert f.cls
+ add(f.cls.name)
+ else:
+ add(f.name)
add('(')
# populate "right_bracket_count" field for every parameter