blob: 324ba66f2b0edb94d9862833eed659d3e7af7825 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
|
;; -*- compile-command: "guile -L ./src ./src/unit-tests/lexer/lexer-test.scm"; -*-
(use-modules (srfi srfi-64)
(modules lexer lexer))
(define (read-this str)
(set-current-input-port
(open-input-string str))
str)
(test-begin "lexer-harness")
(test-equal (read-this "")
'()
(read-tokens))
(test-equal (read-this "(")
'(left-paren)
(read-tokens))
(test-equal (read-this "((")
'(left-paren left-paren)
(read-tokens))
(test-equal (read-this "( )")
'(left-paren right-paren)
(read-tokens))
(test-equal (read-this "( {;} {((};})")
'(left-paren open-brace semi-colon close-brace open-brace left-paren left-paren close-brace semi-colon close-brace right-paren)
(read-tokens))
(test-equal (read-this "1")
'(1)
(read-tokens))
(test-equal (read-this "~+-")
'(complement add sub)
(read-tokens))
(test-equal (read-this "---")
'(decrement sub)
(read-tokens))
(test-equal (read-this "+--")
'(add decrement)
(read-tokens))
(test-equal (read-this "0")
'(0)
(read-tokens))
(test-equal (read-this "0011001")
'(11001)
(read-tokens))
(test-equal (read-this "12 {34")
'(12 open-brace 34)
(read-tokens))
(test-equal (read-this "34;")
'(34 semi-colon)
(read-tokens))
(test-error (read-this "3.4")
(read-tokens))
(test-equal (read-this "a")
'("a")
(read-tokens))
(test-equal (read-this "a_2")
'("a_2")
(read-tokens))
(test-error (read-this "1foo")
(read-tokens))
(test-equal (read-this "void")
'(void)
(read-tokens))
(test-equal (read-this "int main(void) {return 2;}")
'(int "main" left-paren void right-paren open-brace return 2 semi-colon close-brace)
(read-tokens))
(test-end "lexer-harness")
|