convert alien.struct fields to classes.struct fields; add tests
parent
59b804c2f6
commit
ba68c46182
|
@ -1,25 +1,25 @@
|
||||||
! (c)Joe Groff bsd license
|
! (c)Joe Groff bsd license
|
||||||
USING: accessors alien.c-types classes.c-types classes.struct
|
USING: accessors alien.c-types alien.structs.fields classes.c-types
|
||||||
combinators io.streams.string kernel libc math multiline namespaces
|
classes.struct combinators io.streams.string kernel libc literals math
|
||||||
prettyprint prettyprint.config see tools.test ;
|
multiline namespaces prettyprint prettyprint.config see tools.test ;
|
||||||
IN: classes.struct.tests
|
IN: classes.struct.tests
|
||||||
|
|
||||||
STRUCT: foo
|
STRUCT: struct-test-foo
|
||||||
{ x char }
|
{ x char }
|
||||||
{ y int initial: 123 }
|
{ y int initial: 123 }
|
||||||
{ z boolean } ;
|
{ z boolean } ;
|
||||||
|
|
||||||
STRUCT: bar
|
STRUCT: struct-test-bar
|
||||||
{ w ushort initial: HEX: ffff }
|
{ w ushort initial: HEX: ffff }
|
||||||
{ foo foo } ;
|
{ foo struct-test-foo } ;
|
||||||
|
|
||||||
[ 12 ] [ foo heap-size ] unit-test
|
[ 12 ] [ struct-test-foo heap-size ] unit-test
|
||||||
[ 16 ] [ bar heap-size ] unit-test
|
[ 16 ] [ struct-test-bar heap-size ] unit-test
|
||||||
[ 123 ] [ foo <struct> y>> ] unit-test
|
[ 123 ] [ struct-test-foo <struct> y>> ] unit-test
|
||||||
[ 123 ] [ bar <struct> foo>> y>> ] unit-test
|
[ 123 ] [ struct-test-bar <struct> foo>> y>> ] unit-test
|
||||||
|
|
||||||
[ 1 2 3 t ] [
|
[ 1 2 3 t ] [
|
||||||
1 2 3 t foo <struct-boa> bar <struct-boa>
|
1 2 3 t struct-test-foo <struct-boa> struct-test-bar <struct-boa>
|
||||||
{
|
{
|
||||||
[ w>> ]
|
[ w>> ]
|
||||||
[ foo>> x>> ]
|
[ foo>> x>> ]
|
||||||
|
@ -28,35 +28,85 @@ STRUCT: bar
|
||||||
} cleave
|
} cleave
|
||||||
] unit-test
|
] unit-test
|
||||||
|
|
||||||
[ 7654 ] [ S{ foo f 98 7654 f } y>> ] unit-test
|
[ 7654 ] [ S{ struct-test-foo f 98 7654 f } y>> ] unit-test
|
||||||
[ 7654 ] [ S{ foo { y 7654 } } y>> ] unit-test
|
[ 7654 ] [ S{ struct-test-foo { y 7654 } } y>> ] unit-test
|
||||||
|
|
||||||
UNION-STRUCT: float-and-bits
|
UNION-STRUCT: struct-test-float-and-bits
|
||||||
{ f single-float }
|
{ f single-float }
|
||||||
{ bits uint } ;
|
{ bits uint } ;
|
||||||
|
|
||||||
[ 1.0 ] [ float-and-bits <struct> 1.0 float>bits >>bits f>> ] unit-test
|
[ 1.0 ] [ struct-test-float-and-bits <struct> 1.0 float>bits >>bits f>> ] unit-test
|
||||||
[ 4 ] [ float-and-bits heap-size ] unit-test
|
[ 4 ] [ struct-test-float-and-bits heap-size ] unit-test
|
||||||
|
|
||||||
[ ] [ foo malloc-struct free ] unit-test
|
[ ] [ struct-test-foo malloc-struct free ] unit-test
|
||||||
|
|
||||||
[ "S{ foo { y 7654 } }" ]
|
[ "S{ struct-test-foo { y 7654 } }" ]
|
||||||
[ f boa-tuples? [ foo <struct> 7654 >>y [ pprint ] with-string-writer ] with-variable ] unit-test
|
[
|
||||||
|
f boa-tuples?
|
||||||
|
[ struct-test-foo <struct> 7654 >>y [ pprint ] with-string-writer ]
|
||||||
|
with-variable
|
||||||
|
] unit-test
|
||||||
|
|
||||||
[ "S{ foo f 0 7654 f }" ]
|
[ "S{ struct-test-foo f 0 7654 f }" ]
|
||||||
[ t boa-tuples? [ foo <struct> 7654 >>y [ pprint ] with-string-writer ] with-variable ] unit-test
|
[
|
||||||
|
t boa-tuples?
|
||||||
|
[ struct-test-foo <struct> 7654 >>y [ pprint ] with-string-writer ]
|
||||||
|
with-variable
|
||||||
|
] unit-test
|
||||||
|
|
||||||
[ <" USING: classes.c-types classes.struct kernel ;
|
[ <" USING: classes.c-types classes.struct kernel ;
|
||||||
IN: classes.struct.tests
|
IN: classes.struct.tests
|
||||||
STRUCT: foo
|
STRUCT: struct-test-foo
|
||||||
{ x char initial: 0 } { y int initial: 123 }
|
{ x char initial: 0 } { y int initial: 123 }
|
||||||
{ z boolean initial: f } ;
|
{ z boolean initial: f } ;
|
||||||
"> ]
|
"> ]
|
||||||
[ [ foo see ] with-string-writer ] unit-test
|
[ [ struct-test-foo see ] with-string-writer ] unit-test
|
||||||
|
|
||||||
[ <" USING: classes.c-types classes.struct ;
|
[ <" USING: classes.c-types classes.struct ;
|
||||||
IN: classes.struct.tests
|
IN: classes.struct.tests
|
||||||
UNION-STRUCT: float-and-bits
|
UNION-STRUCT: struct-test-float-and-bits
|
||||||
{ f single-float initial: 0.0 } { bits uint initial: 0 } ;
|
{ f single-float initial: 0.0 } { bits uint initial: 0 } ;
|
||||||
"> ]
|
"> ]
|
||||||
[ [ float-and-bits see ] with-string-writer ] unit-test
|
[ [ struct-test-float-and-bits see ] with-string-writer ] unit-test
|
||||||
|
|
||||||
|
[ {
|
||||||
|
T{ field-spec
|
||||||
|
{ name "x" }
|
||||||
|
{ offset 0 }
|
||||||
|
{ type $[ char c-type ] }
|
||||||
|
{ reader x>> }
|
||||||
|
{ writer (>>x) }
|
||||||
|
}
|
||||||
|
T{ field-spec
|
||||||
|
{ name "y" }
|
||||||
|
{ offset 4 }
|
||||||
|
{ type $[ int c-type ] }
|
||||||
|
{ reader y>> }
|
||||||
|
{ writer (>>y) }
|
||||||
|
}
|
||||||
|
T{ field-spec
|
||||||
|
{ name "z" }
|
||||||
|
{ offset 8 }
|
||||||
|
{ type $[ boolean c-type ] }
|
||||||
|
{ reader z>> }
|
||||||
|
{ writer (>>z) }
|
||||||
|
}
|
||||||
|
} ] [ "struct-test-foo" c-type fields>> ] unit-test
|
||||||
|
|
||||||
|
[ {
|
||||||
|
T{ field-spec
|
||||||
|
{ name "f" }
|
||||||
|
{ offset 0 }
|
||||||
|
{ type $[ single-float c-type ] }
|
||||||
|
{ reader f>> }
|
||||||
|
{ writer (>>f) }
|
||||||
|
}
|
||||||
|
T{ field-spec
|
||||||
|
{ name "bits" }
|
||||||
|
{ offset 0 }
|
||||||
|
{ type $[ uint c-type ] }
|
||||||
|
{ reader bits>> }
|
||||||
|
{ writer (>>bits) }
|
||||||
|
}
|
||||||
|
} ] [ "struct-test-float-and-bits" c-type fields>> ] unit-test
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,11 @@
|
||||||
! (c)Joe Groff bsd license
|
! (c)Joe Groff bsd license
|
||||||
USING: accessors alien alien.c-types alien.structs arrays
|
USING: accessors alien alien.c-types alien.structs alien.structs.fields arrays
|
||||||
byte-arrays classes classes.c-types classes.parser classes.tuple
|
byte-arrays classes classes.c-types classes.parser classes.tuple
|
||||||
classes.tuple.parser classes.tuple.private combinators
|
classes.tuple.parser classes.tuple.private combinators
|
||||||
combinators.smart fry generalizations generic.parser kernel
|
combinators.smart fry generalizations generic.parser kernel
|
||||||
kernel.private libc macros make math math.order parser
|
kernel.private libc macros make math math.order parser
|
||||||
quotations sequences slots slots.private struct-arrays words ;
|
quotations sequences slots slots.private struct-arrays words ;
|
||||||
|
FROM: slots => reader-word writer-word ;
|
||||||
IN: classes.struct
|
IN: classes.struct
|
||||||
|
|
||||||
! struct class
|
! struct class
|
||||||
|
@ -92,12 +93,23 @@ M: struct-class writer-quot
|
||||||
! Struct as c-type
|
! Struct as c-type
|
||||||
|
|
||||||
: slot>field ( slot -- field )
|
: slot>field ( slot -- field )
|
||||||
[ class>> c-type ] [ name>> ] bi 2array ;
|
field-spec new swap {
|
||||||
|
[ name>> >>name ]
|
||||||
|
[ offset>> >>offset ]
|
||||||
|
[ class>> c-type >>type ]
|
||||||
|
[ name>> reader-word >>reader ]
|
||||||
|
[ name>> writer-word >>writer ]
|
||||||
|
} cleave ;
|
||||||
|
|
||||||
: define-struct-for-class ( class -- )
|
: define-struct-for-class ( class -- )
|
||||||
[
|
[
|
||||||
[ name>> ] [ vocabulary>> ] [ struct-slots [ slot>field ] map ] tri
|
{
|
||||||
define-struct
|
[ name>> ]
|
||||||
|
[ "struct-size" word-prop ]
|
||||||
|
[ "struct-align" word-prop ]
|
||||||
|
[ struct-slots [ slot>field ] map ]
|
||||||
|
} cleave
|
||||||
|
(define-struct)
|
||||||
] [
|
] [
|
||||||
[ name>> c-type ]
|
[ name>> c-type ]
|
||||||
[ (unboxer-quot) >>unboxer-quot ]
|
[ (unboxer-quot) >>unboxer-quot ]
|
||||||
|
@ -171,8 +183,8 @@ M: struct-class direct-array-of
|
||||||
[ class>> c-type drop ] each ;
|
[ class>> c-type drop ] each ;
|
||||||
|
|
||||||
: (define-struct-class) ( class slots offsets-quot -- )
|
: (define-struct-class) ( class slots offsets-quot -- )
|
||||||
[ drop struct f define-tuple-class ] swap
|
[ drop struct f define-tuple-class ]
|
||||||
'[
|
swap '[
|
||||||
make-slots dup
|
make-slots dup
|
||||||
[ check-struct-slots ] _ [ struct-align [ align ] keep ] tri
|
[ check-struct-slots ] _ [ struct-align [ align ] keep ] tri
|
||||||
(struct-word-props)
|
(struct-word-props)
|
||||||
|
|
Loading…
Reference in New Issue