-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdebugging.fs
65 lines (53 loc) · 1.62 KB
/
debugging.fs
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
REQUIRE util.fs
: bin. ( u -- )
BASE @ 2 BASE ! SWAP . BASE ! ;
: 2bin. ( ud -- )
BASE @ >R 2 BASE ! D. R> BASE ! ;
: .xt ( xt -- )
DUP >NAME ?DUP-IF .ID DROP ELSE xt-see THEN ;
VARIABLE n-forms
2VARIABLE timer
0 VALUE debug-mode?
128 1024 * CONSTANT depth-stack-limit
CREATE depth-stack depth-stack-limit CELLS ALLOT
0 VALUE depth-stack-depth
: depth-stack@ ( -- u )
depth-stack depth-stack-depth CELLS + @ ;
: depth-stack-push ( -- )
depth-stack-depth depth-stack-limit = ABORT" DEPTH STACK OVERFLOW!"
DEPTH depth-stack depth-stack-depth CELLS + !
depth-stack-depth 1+ TO depth-stack-depth ;
: depth-stack-check ( -- )
depth-stack-depth 1- TO depth-stack-depth
DEPTH depth-stack@ <> IF
." UNEXPECTED STACK DEPTH CHANGE! (" DEPTH . ." instead of " depth-stack@ . ." )" CR
-1 THROW
THEN ;
: debug-init
utime timer 2! ;
DEFER debug-bye
:noname
n-forms @ . ." wordforms generated in " utime timer 2@ D- D. ." μs." cr
\ trans-timer 2@ D. ." μs in transform." cr
; IS debug-bye
: \."
debug-mode? IF
POSTPONE ."
ELSE
POSTPONE \
THEN ; IMMEDIATE
: \.s
debug-mode? IF [CHAR] < ]]L EMIT DEPTH . [[ [CHAR] > ]]L EMIT DUP . [[ $2026 ]]L XEMIT CR [[ THEN ; IMMEDIATE
: \\." debug-mode? 1 > IF POSTPONE ." ELSE POSTPONE \ THEN ; IMMEDIATE
: .as ( -- )
\." AS:" slot-stack DUP @ HEX. CELL+ BEGIN DUP @ DUP HEX. WHILE CELL+ REPEAT DROP CR
;
: \stack-mark ( -- )
debug-mode? IF POSTPONE depth-stack-push THEN ; immediate
: \stack-check ( -- )
debug-mode? IF POSTPONE depth-stack-check THEN ; immediate
[IFUNDEF] SEE-THREADED
ALSO see-voc
: see-threaded SEE-THREADED ;
PREVIOUS
[THEN]