forked from sayon/forthress
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdoc-engine.frt
74 lines (65 loc) · 1.63 KB
/
doc-engine.frt
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
(
This file implements Forthress documentation engine. To use it, place a
string on the stack before defining a new word, and use `wit-doc` after
semicolon to create documentation entry for the last word defined.
)
global doc-start
0 doc-start !
struct
cell% field >doc-next
cell% field >doc-addr
cell% field >doc-string
end-struct doc-header%
( word-address docstring )
: doc-word
swap
doc-header% allot >r
swap
r@ >doc-string !
doc-start @ r@ >doc-next !
r@ >doc-addr !
r> doc-start !
;
( string - )
: with-doc last_word @ cfa swap doc-word ;
g"
( addr - doc-header? )
Given an XT of a word, finds a relevant `doc-header` in the documentation DB
"
: doc-find
doc-start @
repeat
dup 0 = if 2drop 0 1 ( return 0 )
else
2dup >doc-addr @ = if
swap drop 1
else >doc-next @ 0
then
then
until
; with-doc
g"
( addr - )
Display documentation for the word address
"
: doc-show dup doc-find dup if
>doc-string @ dup if
cr
." # Documentation for " swap ? cr
prints cr
." ------" cr
else 2drop ." Error: empty documentation string " then
else drop ." No documentation for " ? cr then
; with-doc
g"
Alias for `doc-show`
"
: ?? doc-show ; with-doc
' doc-word g"
( word-address docstring )
Document an existing word with a documenting string. Prefer using global strings for that matter.
" doc-word
' doc-start g"
Global variable storing the address of documentation database.
The database itself is a linked list of `doc-header` structures.
" doc-word