2012-12-15 18:20:15 -05:00
|
|
|
from hy.lex.tokenize import tokenize
|
|
|
|
|
|
|
|
|
|
|
|
def test_list_lex():
|
2012-12-15 18:24:40 -05:00
|
|
|
"""test basic lexing of lists"""
|
2012-12-15 18:20:15 -05:00
|
|
|
fn = tokenize("(fn [1 2 3 4])")[0]
|
|
|
|
assert fn == [
|
|
|
|
"fn", ["1", "2", "3", "4"]
|
|
|
|
]
|
2012-12-15 18:24:06 -05:00
|
|
|
|
|
|
|
|
|
|
|
def test_list_recurse():
|
2012-12-15 18:24:40 -05:00
|
|
|
""" test we can recurse lists """
|
2012-12-15 18:24:06 -05:00
|
|
|
fn = tokenize("(fn [1 2 3 4 [5 6 7]])")[0]
|
|
|
|
assert fn == [
|
|
|
|
"fn", ["1", "2", "3", "4", ["5", "6", "7"]]
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
def test_double_rainbow():
|
2012-12-15 18:24:40 -05:00
|
|
|
""" DOUBLE LISTS """
|
2012-12-15 18:24:06 -05:00
|
|
|
fn = tokenize("(fn [1 2 3 4] [5 6 7])")[0]
|
|
|
|
assert fn == [
|
|
|
|
"fn", ["1", "2", "3", "4"], ["5", "6", "7"]
|
|
|
|
]
|
2012-12-15 18:38:34 -05:00
|
|
|
|
|
|
|
|
|
|
|
def test_string_in_list():
|
|
|
|
""" String in list """
|
|
|
|
fn = tokenize('(fn [1 2 "three four" 5])')[0]
|
|
|
|
assert fn == [
|
|
|
|
"fn", ["1", "2", "three four", "5"]
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
def test_list_recurse_with_comment():
|
|
|
|
""" test we can recurse lists """
|
|
|
|
fn = tokenize("""
|
|
|
|
(fn [1 ; this is a test
|
|
|
|
2 3 4 [5 6 7]])
|
|
|
|
""")[0]
|
|
|
|
assert fn == [
|
|
|
|
"fn", ["1", "2", "3", "4", ["5", "6", "7"]]
|
|
|
|
]
|