Let argument destructuring work with docstrings
This commit is contained in:
parent
cfdd321f9a
commit
907e72681f
1
NEWS
1
NEWS
@ -44,6 +44,7 @@ Changes from 0.13.0
|
|||||||
instead of silently ignoring them
|
instead of silently ignoring them
|
||||||
* Multiple expressions are now allowed in the else clause of
|
* Multiple expressions are now allowed in the else clause of
|
||||||
a for loop
|
a for loop
|
||||||
|
* Argument destructuring no longer interferes with function docstrings.
|
||||||
|
|
||||||
[ Misc. Improvements ]
|
[ Misc. Improvements ]
|
||||||
* `read`, `read_str`, and `eval` are exposed and documented as top-level
|
* `read`, `read_str`, and `eval` are exposed and documented as top-level
|
||||||
|
@ -1881,6 +1881,10 @@ class HyASTCompiler(object):
|
|||||||
force_functiondef = expression.pop(0) == "fn*"
|
force_functiondef = expression.pop(0) == "fn*"
|
||||||
|
|
||||||
arglist = expression.pop(0)
|
arglist = expression.pop(0)
|
||||||
|
docstring = None
|
||||||
|
if len(expression) > 1 and isinstance(expression[0], str_type):
|
||||||
|
docstring = expression.pop(0)
|
||||||
|
|
||||||
if not isinstance(arglist, HyList):
|
if not isinstance(arglist, HyList):
|
||||||
raise HyTypeError(expression,
|
raise HyTypeError(expression,
|
||||||
"First argument to `fn' must be a list")
|
"First argument to `fn' must be a list")
|
||||||
@ -1901,6 +1905,11 @@ class HyASTCompiler(object):
|
|||||||
) + expression
|
) + expression
|
||||||
expression = expression.replace(arg[0])
|
expression = expression.replace(arg[0])
|
||||||
|
|
||||||
|
# Docstrings must come at the start, so ensure that happens even if we
|
||||||
|
# generate anonymous variables.
|
||||||
|
if docstring is not None:
|
||||||
|
expression.insert(0, docstring)
|
||||||
|
|
||||||
if PY3:
|
if PY3:
|
||||||
# Python 3.4+ requires that args are an ast.arg object, rather
|
# Python 3.4+ requires that args are an ast.arg object, rather
|
||||||
# than an ast.Name or bare string.
|
# than an ast.Name or bare string.
|
||||||
|
@ -1660,3 +1660,24 @@
|
|||||||
[_42 6])
|
[_42 6])
|
||||||
(setv x (XYZ))
|
(setv x (XYZ))
|
||||||
(assert (= (. x _42) 6)))
|
(assert (= (. x _42) 6)))
|
||||||
|
|
||||||
|
(defn test-docstrings []
|
||||||
|
"Make sure docstrings in functions work and don't clash with return values"
|
||||||
|
(defn f [] "docstring" 5)
|
||||||
|
(assert (= (. f __doc__) "docstring"))
|
||||||
|
|
||||||
|
; destructuring and the implicit variables it creates
|
||||||
|
; shouldn't interfere with docstrings
|
||||||
|
; (https://github.com/hylang/hy/issues/1409)
|
||||||
|
(defn f2 [[a b]] "docstring" 5)
|
||||||
|
(assert (= (. f2 __doc__) "docstring"))
|
||||||
|
|
||||||
|
; a single string is the return value, not a docstring
|
||||||
|
; (https://github.com/hylang/hy/issues/1402)
|
||||||
|
(defn f3 [] "not a docstring")
|
||||||
|
(assert (none? (. f3 __doc__)))
|
||||||
|
(assert (= (f3) "not a docstring"))
|
||||||
|
|
||||||
|
(defn f4 [[a b]] "not a docstring")
|
||||||
|
(assert (none? (. f4 __doc__)))
|
||||||
|
(assert (= (f4 [1 2]) "not a docstring")))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user