blob: 54671fe55d0f02ec82f8cfbb36edf9e688d7c625 (
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
|
/#
Copyright 2021 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
#/
/; is_space (charp c) [bool]
;return c == '\t' || c == '\n' || c == ' '
;/
/; break_token ({}charp dat, charp c) [bool]
/; if (len dat == 0)
;return false
;/
;return is_space(c)
;/
/; parse_reserved ({}charp dat) [{}Token]
;/
/; tokenize (tnsl.io.File fstr) [~{}Token]
;{}Token out = {}
;{}charp tdat = {}
/; loop (int i = fstr.read(); i !== -1) [i = fstr.read()]
/; if (break_token(tdat, i))
/; if (len tdat > 0)
;{}charp tmp = tdat
;Token ttk = {0, 0, 0, ~tmp}
;out.append(ttk)
;tdat = {}
;/
;; else if ( !is_space(i) )
;tdat.append(i)
;/
;/
;tnsl.io.println(tdat)
;return ~out
;/
|