Added HyLambdaListKeyword tokens to the lexer
The name "lambda list keyword" is a historical artifact from the CLHS and not optimal (http://clhs.lisp.se/Body/26_glo_l.htm). The name may change at some point.
This commit is contained in:
parent
a878a7f7d5
commit
c200b4e3d1
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
from hy.models.expression import HyExpression
|
from hy.models.expression import HyExpression
|
||||||
from hy.models.integer import HyInteger
|
from hy.models.integer import HyInteger
|
||||||
|
from hy.models.lambdalist import HyLambdaListKeyword
|
||||||
from hy.models.symbol import HySymbol
|
from hy.models.symbol import HySymbol
|
||||||
from hy.models.string import HyString
|
from hy.models.string import HyString
|
||||||
from hy.models.dict import HyDict
|
from hy.models.dict import HyDict
|
||||||
@ -45,6 +46,7 @@ def _resolve_atom(obj):
|
|||||||
Resolve a bare atom into one of the following (in order):
|
Resolve a bare atom into one of the following (in order):
|
||||||
|
|
||||||
- Integer
|
- Integer
|
||||||
|
- LambdaListKeyword
|
||||||
- Symbol
|
- Symbol
|
||||||
"""
|
"""
|
||||||
try:
|
try:
|
||||||
@ -52,6 +54,9 @@ def _resolve_atom(obj):
|
|||||||
except ValueError:
|
except ValueError:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
if obj.startswith("&"):
|
||||||
|
return HyLambdaListKeyword(obj)
|
||||||
|
|
||||||
table = {
|
table = {
|
||||||
"true": "True",
|
"true": "True",
|
||||||
"false": "False",
|
"false": "False",
|
||||||
|
39
hy/models/lambdalist.py
Normal file
39
hy/models/lambdalist.py
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
# Copyright (c) 2013 James King <james@agentultra.com>
|
||||||
|
#
|
||||||
|
# Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
# copy of this software and associated documentation files (the "Software"),
|
||||||
|
# to deal in the Software without restriction, including without limitation
|
||||||
|
# the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||||
|
# and/or sell copies of the Software, and to permit persons to whom the
|
||||||
|
# Software is furnished to do so, subject to the following conditions:
|
||||||
|
#
|
||||||
|
# The above copyright notice and this permission notice shall be included in
|
||||||
|
# all copies or substantial portions of the Software.
|
||||||
|
#
|
||||||
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||||
|
# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||||
|
# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
|
# DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
|
from hy.models.string import HyString
|
||||||
|
|
||||||
|
|
||||||
|
class HyLambdaListKeyword(HyString):
|
||||||
|
"""
|
||||||
|
Hy LambdaListKeyword. Demarcates arguments in an argument list.
|
||||||
|
|
||||||
|
(defun my-fun (x &rest xs &optional (foo "default string")))
|
||||||
|
|
||||||
|
becomes:
|
||||||
|
|
||||||
|
def my_fun(x, *xs, foo="default string"):
|
||||||
|
pass
|
||||||
|
"""
|
||||||
|
|
||||||
|
_valid_types = ["&rest", "&optional", "&kwargs"]
|
||||||
|
|
||||||
|
def __init__(self, string):
|
||||||
|
self += string
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
from hy.models.expression import HyExpression
|
from hy.models.expression import HyExpression
|
||||||
from hy.models.integer import HyInteger
|
from hy.models.integer import HyInteger
|
||||||
|
from hy.models.lambdalist import HyLambdaListKeyword
|
||||||
from hy.models.symbol import HySymbol
|
from hy.models.symbol import HySymbol
|
||||||
from hy.models.string import HyString
|
from hy.models.string import HyString
|
||||||
from hy.models.dict import HyDict
|
from hy.models.dict import HyDict
|
||||||
@ -62,6 +63,14 @@ def test_lex_expression_integer():
|
|||||||
assert objs == [HyExpression([HySymbol("foo"), HyInteger(2)])]
|
assert objs == [HyExpression([HySymbol("foo"), HyInteger(2)])]
|
||||||
|
|
||||||
|
|
||||||
|
def test_lex_lambda_list_keyword():
|
||||||
|
""" Make sure expressions can produce lambda list keywords """
|
||||||
|
objs = tokenize("(x &rest xs)")
|
||||||
|
assert objs == [HyExpression([HySymbol("x"),
|
||||||
|
HyLambdaListKeyword("&rest"),
|
||||||
|
HySymbol("xs")])]
|
||||||
|
|
||||||
|
|
||||||
def test_lex_line_counting():
|
def test_lex_line_counting():
|
||||||
""" Make sure we can count lines / columns """
|
""" Make sure we can count lines / columns """
|
||||||
entry = tokenize("(foo (one two))")[0]
|
entry = tokenize("(foo (one two))")[0]
|
||||||
|
Loading…
Reference in New Issue
Block a user