-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathstruct0x.fs
80 lines (58 loc) · 2.31 KB
/
struct0x.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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
\ implementation of Forth 200x structures
\ Copyright (C) 2007,2012,2014,2015,2016 Free Software Foundation, Inc.
\ This file is part of Gforth.
\ Gforth is free software; you can redistribute it and/or
\ modify it under the terms of the GNU General Public License
\ as published by the Free Software Foundation, either version 3
\ of the License, or (at your option) any later version.
\ This program is distributed in the hope that it will be useful,
\ but WITHOUT ANY WARRANTY; without even the implied warranty of
\ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
\ GNU General Public License for more details.
\ You should have received a copy of the GNU General Public License
\ along with this program. If not, see http://www.gnu.org/licenses/.
: standard+field ( n1 n2 "name" -- n3 ) \ X:structures plus-field
over if
(field) over , dup ,
else
create dozerofield over , dup ,
then
+ ;
: (sizeof) ( "name" -- size ) ' >body cell+ @ ;
: [sizeof] ( "name" -- size )
(sizeof) postpone Literal ; immediate compile-only
' (sizeof) comp' [sizeof] drop
interpret/compile: sizeof ( "field" -- size )
Defer +field
\ A number of things have field-like structure, but not
\ exactly field-like behavior. Objects, locals, etc.
\ Allow them to plug into +field.
: standard:field ( -- )
\g set +field to standard behavior
['] standard+field IS +field ;
standard:field
: extend-structure ( n "name" -- struct-sys n ) \ Gforth
\g extend an existing structure
standard:field >r 0 value lastxt >body r> ;
: begin-structure ( "name" -- struct-sys 0 ) \ X:structures
0 extend-structure ;
: end-structure ( struct-sys +n -- ) \ X:structures
swap ! ;
: cfield: ( u1 "name" -- u2 ) \ X:structures
1 +field ;
: wfield: ( u1 "name" -- u2 ) \ X:structures
1 + -2 and 2 +field ;
: lfield: ( u1 "name" -- u2 ) \ X:structures
3 + -4 and 4 +field ;
: xfield: ( offset -- offset' )
7 + -8 and 8 +field ;
: field: ( u1 "name" -- u2 ) \ X:structures
aligned cell +field ;
: 2field: ( u1 "name" -- u2 ) \ gforth
aligned 2 cells +field ;
: ffield: ( u1 "name" -- u2 ) \ X:structures
faligned 1 floats +field ;
: sffield: ( u1 "name" -- u2 ) \ X:structures
sfaligned 1 sfloats +field ;
: dffield: ( u1 "name" -- u2 ) \ X:structures
dfaligned 1 dfloats +field ;