factor/library/compiler/test/callbacks.factor

128 lines
2.9 KiB
Factor
Raw Normal View History

2006-02-11 02:30:18 -05:00
IN: temporary
2006-05-04 18:08:52 -04:00
USING: alien compiler errors inference io kernel kernel-internals
math memory namespaces test threads ;
2006-02-11 02:30:18 -05:00
: callback-1 "void" { } [ ] alien-callback ;
2006-02-11 02:30:18 -05:00
[ { 0 1 } ] [ [ callback-1 ] infer ] unit-test
[ t ] [ callback-1 alien? ] unit-test
FUNCTION: void callback_test_1 void* callback ;
2006-02-11 02:30:18 -05:00
[ ] [ callback-1 callback_test_1 ] unit-test
2006-02-13 17:16:34 -05:00
: callback-2 "void" { } [ [ 5 throw ] catch drop ] alien-callback ;
[ ] [ callback-2 callback_test_1 ] unit-test
2006-02-13 17:16:34 -05:00
: callback-3 "void" { } [ 5 "x" set ] alien-callback ;
2006-02-13 17:16:34 -05:00
[ t ] [
namestack*
3 "x" set callback-3 callback_test_1
namestack* eq?
] unit-test
[ 5 ] [
[
3 "x" set callback-3 callback_test_1 "x" get
] with-scope
] unit-test
: callback-4 "void" { } [ "Hello world" write ] alien-callback ;
2006-02-13 17:16:34 -05:00
[ "Hello world" ] [
[ callback-4 callback_test_1 ] string-out
] unit-test
: callback-5
"void" { } [ full-gc ] alien-callback ;
2006-02-13 17:16:34 -05:00
[ "testing" ] [
"testing" callback-5 callback_test_1
] unit-test
: callback-6
"void" { } [ [ continue ] callcc0 ] alien-callback ;
2006-02-13 17:16:34 -05:00
2006-02-23 01:33:15 -05:00
[ 1 2 3 ] [ callback-6 callback_test_1 1 2 3 ] unit-test
2006-02-13 17:16:34 -05:00
: callback-7
"void" { } [ yield "hi" print flush yield ] alien-callback ;
2006-02-13 17:16:34 -05:00
2006-02-23 01:33:15 -05:00
[ 1 2 3 ] [ callback-7 callback_test_1 1 2 3 ] unit-test
2006-02-13 22:20:39 -05:00
: callback-8
"void" { "int" "int" } [ / "x" set ] alien-callback ;
2006-02-13 22:20:39 -05:00
2006-02-13 22:47:42 -05:00
FUNCTION: void callback_test_2 void* callback int x int y ;
[ 3/4 ] [
[
"x" off callback-8 3 4 callback_test_2 "x" get
] with-scope
] unit-test
: callback-9
"void" { "int" "double" "int" }
[ + * "x" set ] alien-callback ;
2006-02-13 22:47:42 -05:00
FUNCTION: void callback_test_3 void* callback int x double y int z ;
2006-02-13 22:47:42 -05:00
[ 27.0 ] [
[
"x" off callback-9 3 4 5 callback_test_3 "x" get
] with-scope
] unit-test
: callback-11 "int" { } [ 1234 ] alien-callback ;
FUNCTION: int callback_test_5 void* callback ;
[ 1234 ] [ callback-11 callback_test_5 ] unit-test
: callback-12 "float" { } [ pi ] alien-callback ;
FUNCTION: float callback_test_6 void* callback ;
2006-02-19 01:35:14 -05:00
[ t ] [ callback-12 callback_test_6 pi - 0.00001 <= ] unit-test
2006-02-19 01:33:34 -05:00
: callback-13 "double" { } [ pi ] alien-callback ;
2006-02-19 01:33:34 -05:00
FUNCTION: double callback_test_7 void* callback ;
2006-02-19 01:33:34 -05:00
2006-02-19 01:35:14 -05:00
[ t ] [ callback-13 callback_test_7 pi = ] unit-test
2006-02-20 00:55:38 -05:00
2006-02-20 17:49:44 -05:00
: callback-10
"void"
{ "int" "int" "int" "int" "int" "int" "int" "int" "int" "int" }
[ datastack "stack" set ] alien-callback ;
2006-02-20 17:49:44 -05:00
FUNCTION: void callback_test_4 void* callback int a1 int a2 int a3 int a4 int a5 int a6 int a7 int a8 int a9 int a10 ;
2006-02-20 00:55:38 -05:00
[ V{ 1 2 3 4 5 6 7 8 9 10 } ] [
[
callback-10 1 2 3 4 5 6 7 8 9 10 callback_test_4
"stack" get
] with-scope
] unit-test
2006-03-10 22:16:46 -05:00
BEGIN-STRUCT: foo
FIELD: int x
FIELD: int y
END-STRUCT
: make-foo ( x y -- foo )
"foo" <c-object> [ set-foo-y ] keep [ set-foo-x ] keep ;
2006-03-11 03:26:55 -05:00
: callback-14
2006-03-10 22:16:46 -05:00
"int"
{ "foo" }
[ dup foo-x swap foo-y / ] alien-callback ;
2006-03-10 22:16:46 -05:00
FUNCTION: int callback_test_8 void* callback foo x ;
2006-03-10 22:16:46 -05:00
2006-03-11 03:26:55 -05:00
[ 5 ] [ callback-14 10 2 make-foo callback_test_8 ] unit-test