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
|
/##
Copyright 2021-2022 Kyle Gunger
This file is licensed under the CDDL 1.0 (the License)
and may only be used in accordance with the License.
You should have received a copy of the License with this
software/source code. If you did not, a copy can be found
at the following URL:
https://opensource.org/licenses/CDDL-1.0
THIS SOFTWARE/SOURCE CODE IS PROVIDED "AS IS" WITH NO
WARRANTY, GUARANTEE, OR CLAIM OF FITNESS FOR ANY PURPOSE
EXPRESS OR IMPLIED
#/
/; tree_list_value [{}Node]
;{}Node out = {}
;return out
;/
/; tree_list_type [{}Node]
;{}Node out = {}
;return out
;/
/; tree_list_statement (~{}Token tok, ~int cur) [{}Node]
;{}Node out = {}
/; loop (cur` < len tok`) [cur` = cur` + 1]
;Node stmt = tree_statement(tok, cur)
;out.append(stmt)
;Token tmp = tok`{cur`}
/; if (string_equate(tmp.data, "]") || string_equate(tmp.data, ")"))
;cur` = cur` + 1
;break
;; else if (string_equate(tmp.data, ";") == false)
;create_panic("Unexpected token in list of statements")
;/
;/
;return out
;/
/; tree_list_params (~{}Token tok, ~int cur) [{}Node]
;{}Node out = {}
/; if (string_equate(tok`{cur`}.data, ")"))
;return out
;/
/; if (type_then_name(tok, cur) == false)
;create_panic("Parameter list must start with a type and name combo.")
;/
/; loop (cur` < len tok`) [cur` = cur` + 1]
;Node tmp
/; if (type_then_name(tok, cur))
;tmp = tree_type(tok, cur)
;out.append(tmp)
;/
;tmp = tree_value(tok, cur)
/; if (string_equate(tok`{cur`}.data, ")"))
;cur` = cur` + 1
;break
;; else if (string_equate(tok`{cur`}.data, ",") == false)
;create_panic("A value in a list of params must be followed with a comma")
;/
;/
;return out
;/
|