2009-08-28 20:02:59 -04:00
|
|
|
USING: accessors arrays compiler.units kernel kernel.private
|
|
|
|
math math.constants math.private math.integers.private sequences
|
|
|
|
strings tools.test words continuations sequences.private
|
|
|
|
hashtables.private byte-arrays system random layouts vectors
|
2008-07-02 16:57:38 -04:00
|
|
|
sbufs strings.private slots.private alien math.order
|
2009-09-17 23:07:21 -04:00
|
|
|
alien.accessors alien.c-types alien.data alien.syntax alien.strings
|
2010-01-22 06:39:56 -05:00
|
|
|
namespaces libc io.encodings.ascii classes compiler.test ;
|
2009-09-16 10:20:47 -04:00
|
|
|
FROM: math => float ;
|
2009-04-26 01:51:47 -04:00
|
|
|
IN: compiler.tests.intrinsics
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
! Make sure that intrinsic ops compile to correct code.
|
2007-12-24 21:54:45 -05:00
|
|
|
[ ] [ 1 [ drop ] compile-call ] unit-test
|
|
|
|
[ ] [ 1 2 [ 2drop ] compile-call ] unit-test
|
|
|
|
[ ] [ 1 2 3 [ 3drop ] compile-call ] unit-test
|
|
|
|
[ 1 1 ] [ 1 [ dup ] compile-call ] unit-test
|
|
|
|
[ 1 2 1 2 ] [ 1 2 [ 2dup ] compile-call ] unit-test
|
|
|
|
[ 1 2 3 1 2 3 ] [ 1 2 3 [ 3dup ] compile-call ] unit-test
|
|
|
|
[ 2 3 1 ] [ 1 2 3 [ rot ] compile-call ] unit-test
|
|
|
|
[ 3 1 2 ] [ 1 2 3 [ -rot ] compile-call ] unit-test
|
|
|
|
[ 1 1 2 ] [ 1 2 [ dupd ] compile-call ] unit-test
|
|
|
|
[ 2 1 3 ] [ 1 2 3 [ swapd ] compile-call ] unit-test
|
|
|
|
[ 2 ] [ 1 2 [ nip ] compile-call ] unit-test
|
|
|
|
[ 3 ] [ 1 2 3 [ 2nip ] compile-call ] unit-test
|
|
|
|
[ 1 2 1 ] [ 1 2 [ over ] compile-call ] unit-test
|
|
|
|
[ 1 2 3 1 ] [ 1 2 3 [ pick ] compile-call ] unit-test
|
|
|
|
[ 2 1 ] [ 1 2 [ swap ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ 1 ] [ { 1 2 } [ 2 slot ] compile-call ] unit-test
|
|
|
|
[ 1 ] [ [ { 1 2 } 2 slot ] compile-call ] unit-test
|
2008-11-06 07:27:27 -05:00
|
|
|
|
|
|
|
[ { f f } ] [ 2 f <array> ] unit-test
|
|
|
|
|
2008-10-22 00:17:32 -04:00
|
|
|
[ 3 ] [ 3 1 2 2array [ { array } declare [ 2 set-slot ] keep ] compile-call first ] unit-test
|
2007-12-24 21:54:45 -05:00
|
|
|
[ 3 ] [ 3 1 2 [ 2array [ 2 set-slot ] keep ] compile-call first ] unit-test
|
|
|
|
[ 3 ] [ [ 3 1 2 2array [ 2 set-slot ] keep ] compile-call first ] unit-test
|
|
|
|
[ 3 ] [ 3 1 2 2array [ [ 3 set-slot ] keep ] compile-call second ] unit-test
|
|
|
|
[ 3 ] [ 3 1 2 [ 2array [ 3 set-slot ] keep ] compile-call second ] unit-test
|
|
|
|
[ 3 ] [ [ 3 1 2 2array [ 3 set-slot ] keep ] compile-call second ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
! Write barrier hits on the wrong value were causing segfaults
|
2007-12-24 21:54:45 -05:00
|
|
|
[ -3 ] [ -3 1 2 [ 2array [ 3 set-slot ] keep ] compile-call second ] unit-test
|
|
|
|
|
2008-11-06 07:27:27 -05:00
|
|
|
[ CHAR: a ] [ 0 "abc" [ string-nth ] compile-call ] unit-test
|
|
|
|
[ CHAR: a ] [ 0 [ "abc" string-nth ] compile-call ] unit-test
|
|
|
|
[ CHAR: a ] [ [ 0 "abc" string-nth ] compile-call ] unit-test
|
|
|
|
[ CHAR: b ] [ 1 "abc" [ string-nth ] compile-call ] unit-test
|
|
|
|
[ CHAR: b ] [ 1 [ "abc" string-nth ] compile-call ] unit-test
|
|
|
|
[ CHAR: b ] [ [ 1 "abc" string-nth ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ HEX: 123456 ] [ 0 "\u123456bc" [ string-nth ] compile-call ] unit-test
|
|
|
|
[ HEX: 123456 ] [ 0 [ "\u123456bc" string-nth ] compile-call ] unit-test
|
|
|
|
[ HEX: 123456 ] [ [ 0 "\u123456bc" string-nth ] compile-call ] unit-test
|
|
|
|
[ HEX: 123456 ] [ 1 "a\u123456c" [ string-nth ] compile-call ] unit-test
|
|
|
|
[ HEX: 123456 ] [ 1 [ "a\u123456c" string-nth ] compile-call ] unit-test
|
|
|
|
[ HEX: 123456 ] [ [ 1 "a\u123456c" string-nth ] compile-call ] unit-test
|
2007-12-24 21:54:45 -05:00
|
|
|
|
2010-01-13 00:08:18 -05:00
|
|
|
[ ] [ [ 0 special-object ] compile-call drop ] unit-test
|
|
|
|
[ ] [ 1 special-object [ 1 set-special-object ] compile-call ] unit-test
|
2007-12-24 21:54:45 -05:00
|
|
|
|
|
|
|
[ ] [ 1 [ drop ] compile-call ] unit-test
|
|
|
|
[ ] [ [ 1 drop ] compile-call ] unit-test
|
|
|
|
[ ] [ [ 1 2 2drop ] compile-call ] unit-test
|
|
|
|
[ ] [ 1 [ 2 2drop ] compile-call ] unit-test
|
|
|
|
[ ] [ 1 2 [ 2drop ] compile-call ] unit-test
|
|
|
|
[ 2 1 ] [ [ 1 2 swap ] compile-call ] unit-test
|
|
|
|
[ 2 1 ] [ 1 [ 2 swap ] compile-call ] unit-test
|
|
|
|
[ 2 1 ] [ 1 2 [ swap ] compile-call ] unit-test
|
|
|
|
[ 1 1 ] [ 1 [ dup ] compile-call ] unit-test
|
|
|
|
[ 1 1 ] [ [ 1 dup ] compile-call ] unit-test
|
|
|
|
[ 1 2 1 ] [ [ 1 2 over ] compile-call ] unit-test
|
|
|
|
[ 1 2 1 ] [ 1 [ 2 over ] compile-call ] unit-test
|
|
|
|
[ 1 2 1 ] [ 1 2 [ over ] compile-call ] unit-test
|
|
|
|
[ 1 2 3 1 ] [ [ 1 2 3 pick ] compile-call ] unit-test
|
|
|
|
[ 1 2 3 1 ] [ 1 [ 2 3 pick ] compile-call ] unit-test
|
|
|
|
[ 1 2 3 1 ] [ 1 2 [ 3 pick ] compile-call ] unit-test
|
|
|
|
[ 1 2 3 1 ] [ 1 2 3 [ pick ] compile-call ] unit-test
|
|
|
|
[ 1 1 2 ] [ [ 1 2 dupd ] compile-call ] unit-test
|
|
|
|
[ 1 1 2 ] [ 1 [ 2 dupd ] compile-call ] unit-test
|
|
|
|
[ 1 1 2 ] [ 1 2 [ dupd ] compile-call ] unit-test
|
|
|
|
[ 2 ] [ [ 1 2 nip ] compile-call ] unit-test
|
|
|
|
[ 2 ] [ 1 [ 2 nip ] compile-call ] unit-test
|
|
|
|
[ 2 ] [ 1 2 [ nip ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ 2 1 "hi" ] [ 1 2 [ swap "hi" ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ 4 ] [ 12 7 [ fixnum-bitand ] compile-call ] unit-test
|
|
|
|
[ 4 ] [ 12 [ 7 fixnum-bitand ] compile-call ] unit-test
|
|
|
|
[ 4 ] [ [ 12 7 fixnum-bitand ] compile-call ] unit-test
|
2009-10-19 05:58:29 -04:00
|
|
|
[ -16 ] [ -1 [ -16 fixnum-bitand ] compile-call ] unit-test
|
2007-12-24 21:54:45 -05:00
|
|
|
|
|
|
|
[ 15 ] [ 12 7 [ fixnum-bitor ] compile-call ] unit-test
|
|
|
|
[ 15 ] [ 12 [ 7 fixnum-bitor ] compile-call ] unit-test
|
|
|
|
[ 15 ] [ [ 12 7 fixnum-bitor ] compile-call ] unit-test
|
2009-10-19 05:58:29 -04:00
|
|
|
[ -1 ] [ -1 [ -16 fixnum-bitor ] compile-call ] unit-test
|
2007-12-24 21:54:45 -05:00
|
|
|
|
|
|
|
[ 11 ] [ 12 7 [ fixnum-bitxor ] compile-call ] unit-test
|
|
|
|
[ 11 ] [ 12 [ 7 fixnum-bitxor ] compile-call ] unit-test
|
|
|
|
[ 11 ] [ [ 12 7 fixnum-bitxor ] compile-call ] unit-test
|
2009-10-19 06:16:04 -04:00
|
|
|
[ 15 ] [ -1 [ -16 fixnum-bitxor ] compile-call ] unit-test
|
2007-12-24 21:54:45 -05:00
|
|
|
|
|
|
|
[ f ] [ 12 7 [ fixnum< [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ f ] [ 12 [ 7 fixnum< [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ f ] [ [ 12 7 fixnum< [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ f ] [ [ 12 12 fixnum< [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ f ] [ 12 12 [ fixnum< [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ t ] [ 12 70 [ fixnum< [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ t ] [ 12 [ 70 fixnum< [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ t ] [ [ 12 70 fixnum< [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ f ] [ 12 7 [ fixnum<= [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ f ] [ 12 [ 7 fixnum<= [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ f ] [ [ 12 7 fixnum<= [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ t ] [ [ 12 12 fixnum<= [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ t ] [ [ 12 12 fixnum<= [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ t ] [ 12 12 [ fixnum<= [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ t ] [ 12 70 [ fixnum<= [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ t ] [ 12 [ 70 fixnum<= [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ t ] [ [ 12 70 fixnum<= [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ t ] [ 12 7 [ fixnum> [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ t ] [ 12 [ 7 fixnum> [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ t ] [ [ 12 7 fixnum> [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ f ] [ [ 12 12 fixnum> [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ f ] [ [ 12 12 fixnum> [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ f ] [ 12 12 [ fixnum> [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ f ] [ 12 70 [ fixnum> [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ f ] [ 12 [ 70 fixnum> [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ f ] [ [ 12 70 fixnum> [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ t ] [ 12 7 [ fixnum>= [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ t ] [ 12 [ 7 fixnum>= [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ t ] [ [ 12 7 fixnum>= [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ t ] [ [ 12 12 fixnum>= [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ t ] [ 12 12 [ fixnum>= [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ f ] [ 12 70 [ fixnum>= [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ f ] [ 12 [ 70 fixnum>= [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ f ] [ [ 12 70 fixnum>= [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ f ] [ 1 2 [ eq? [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ f ] [ 1 [ 2 eq? [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ f ] [ [ 1 2 eq? [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ t ] [ 3 3 [ eq? [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ t ] [ 3 [ 3 eq? [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
[ t ] [ [ 3 3 eq? [ t ] [ f ] if ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ -1 ] [ 0 [ fixnum-bitnot ] compile-call ] unit-test
|
|
|
|
[ -1 ] [ [ 0 fixnum-bitnot ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ 3 ] [ 13 10 [ fixnum-mod ] compile-call ] unit-test
|
|
|
|
[ 3 ] [ 13 [ 10 fixnum-mod ] compile-call ] unit-test
|
|
|
|
[ 3 ] [ [ 13 10 fixnum-mod ] compile-call ] unit-test
|
|
|
|
[ -3 ] [ -13 10 [ fixnum-mod ] compile-call ] unit-test
|
|
|
|
[ -3 ] [ -13 [ 10 fixnum-mod ] compile-call ] unit-test
|
|
|
|
[ -3 ] [ [ -13 10 fixnum-mod ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ 2 ] [ 4 2 [ fixnum/i ] compile-call ] unit-test
|
|
|
|
[ 2 ] [ 4 [ 2 fixnum/i ] compile-call ] unit-test
|
|
|
|
[ -2 ] [ 4 [ -2 fixnum/i ] compile-call ] unit-test
|
|
|
|
[ 3 1 ] [ 10 3 [ fixnum/mod ] compile-call ] unit-test
|
|
|
|
|
2008-11-24 12:12:36 -05:00
|
|
|
[ 2 ] [ 4 2 [ fixnum/i-fast ] compile-call ] unit-test
|
|
|
|
[ 2 ] [ 4 [ 2 fixnum/i-fast ] compile-call ] unit-test
|
|
|
|
[ -2 ] [ 4 [ -2 fixnum/i-fast ] compile-call ] unit-test
|
|
|
|
[ 3 1 ] [ 10 3 [ fixnum/mod-fast ] compile-call ] unit-test
|
|
|
|
|
2007-12-24 21:54:45 -05:00
|
|
|
[ 4 ] [ 1 3 [ fixnum+ ] compile-call ] unit-test
|
|
|
|
[ 4 ] [ 1 [ 3 fixnum+ ] compile-call ] unit-test
|
|
|
|
[ 4 ] [ [ 1 3 fixnum+ ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ 4 ] [ 1 3 [ fixnum+fast ] compile-call ] unit-test
|
|
|
|
[ 4 ] [ 1 [ 3 fixnum+fast ] compile-call ] unit-test
|
|
|
|
[ 4 ] [ [ 1 3 fixnum+fast ] compile-call ] unit-test
|
|
|
|
|
2008-11-06 07:27:27 -05:00
|
|
|
[ -2 ] [ 1 3 [ fixnum-fast ] compile-call ] unit-test
|
|
|
|
[ -2 ] [ 1 [ 3 fixnum-fast ] compile-call ] unit-test
|
|
|
|
[ -2 ] [ [ 1 3 fixnum-fast ] compile-call ] unit-test
|
|
|
|
|
2007-12-24 21:54:45 -05:00
|
|
|
[ 30001 ] [ 1 [ 30000 fixnum+fast ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ 6 ] [ 2 3 [ fixnum*fast ] compile-call ] unit-test
|
|
|
|
[ 6 ] [ 2 [ 3 fixnum*fast ] compile-call ] unit-test
|
|
|
|
[ 6 ] [ [ 2 3 fixnum*fast ] compile-call ] unit-test
|
|
|
|
[ -6 ] [ 2 -3 [ fixnum*fast ] compile-call ] unit-test
|
|
|
|
[ -6 ] [ 2 [ -3 fixnum*fast ] compile-call ] unit-test
|
|
|
|
[ -6 ] [ [ 2 -3 fixnum*fast ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ 6 ] [ 2 3 [ fixnum* ] compile-call ] unit-test
|
|
|
|
[ 6 ] [ 2 [ 3 fixnum* ] compile-call ] unit-test
|
|
|
|
[ 6 ] [ [ 2 3 fixnum* ] compile-call ] unit-test
|
|
|
|
[ -6 ] [ 2 -3 [ fixnum* ] compile-call ] unit-test
|
|
|
|
[ -6 ] [ 2 [ -3 fixnum* ] compile-call ] unit-test
|
|
|
|
[ -6 ] [ [ 2 -3 fixnum* ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ 5 ] [ 1 2 [ eq? [ 3 ] [ 5 ] if ] compile-call ] unit-test
|
|
|
|
[ 3 ] [ 2 2 [ eq? [ 3 ] [ 5 ] if ] compile-call ] unit-test
|
|
|
|
[ 3 ] [ 1 2 [ fixnum< [ 3 ] [ 5 ] if ] compile-call ] unit-test
|
|
|
|
[ 5 ] [ 2 2 [ fixnum< [ 3 ] [ 5 ] if ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ 8 ] [ 1 3 [ fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ 8 ] [ 1 [ 3 fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ 8 ] [ [ 1 3 fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ -8 ] [ -1 3 [ fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ -8 ] [ -1 [ 3 fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ -8 ] [ [ -1 3 fixnum-shift ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ 2 ] [ 8 -2 [ fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ 2 ] [ 8 [ -2 fixnum-shift ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ 0 ] [ [ 123 -64 fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ 0 ] [ 123 -64 [ fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ -1 ] [ [ -123 -64 fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ -1 ] [ -123 -64 [ fixnum-shift ] compile-call ] unit-test
|
|
|
|
|
2009-07-17 00:50:48 -04:00
|
|
|
[ 4294967296 ] [ 1 32 [ fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ 4294967296 ] [ 1 [ 32 fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ 4294967296 ] [ 1 [ 16 fixnum-shift 16 fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ -4294967296 ] [ -1 32 [ fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ -4294967296 ] [ -1 [ 32 fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ -4294967296 ] [ -1 [ 16 fixnum-shift 16 fixnum-shift ] compile-call ] unit-test
|
2007-12-24 21:54:45 -05:00
|
|
|
|
2009-07-17 00:50:48 -04:00
|
|
|
[ 8 ] [ 1 3 [ fixnum-shift-fast ] compile-call ] unit-test
|
|
|
|
[ 8 ] [ 1 3 [ 15 bitand fixnum-shift-fast ] compile-call ] unit-test
|
|
|
|
[ 8 ] [ 1 [ 3 fixnum-shift-fast ] compile-call ] unit-test
|
|
|
|
[ 8 ] [ [ 1 3 fixnum-shift-fast ] compile-call ] unit-test
|
|
|
|
[ -8 ] [ -1 3 [ fixnum-shift-fast ] compile-call ] unit-test
|
|
|
|
[ -8 ] [ -1 3 [ 15 bitand fixnum-shift-fast ] compile-call ] unit-test
|
|
|
|
[ -8 ] [ -1 [ 3 fixnum-shift-fast ] compile-call ] unit-test
|
|
|
|
[ -8 ] [ [ -1 3 fixnum-shift-fast ] compile-call ] unit-test
|
|
|
|
|
|
|
|
[ 2 ] [ 8 -2 [ fixnum-shift-fast ] compile-call ] unit-test
|
|
|
|
[ 2 ] [ 8 2 [ 15 bitand neg fixnum-shift-fast ] compile-call ] unit-test
|
|
|
|
[ 2 ] [ 8 [ -2 fixnum-shift-fast ] compile-call ] unit-test
|
2007-12-24 21:54:45 -05:00
|
|
|
|
|
|
|
[ 4294967296 ] [ 1 32 [ fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ 4294967296 ] [ 1 [ 32 fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ 4294967296 ] [ 1 [ 16 fixnum-shift 16 fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ -4294967296 ] [ -1 32 [ fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ -4294967296 ] [ -1 [ 32 fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ -4294967296 ] [ -1 [ 16 fixnum-shift 16 fixnum-shift ] compile-call ] unit-test
|
|
|
|
|
2009-07-17 00:50:48 -04:00
|
|
|
[ HEX: 10000000 ] [ HEX: 1000000 HEX: 10 [ fixnum* ] compile-call ] unit-test
|
2009-11-04 19:28:46 -05:00
|
|
|
[ HEX: 8000000 ] [ HEX: -8000000 >fixnum [ 0 swap fixnum- ] compile-call ] unit-test
|
|
|
|
[ HEX: 8000000 ] [ HEX: -7ffffff >fixnum [ 1 swap fixnum- ] compile-call ] unit-test
|
2009-07-17 00:50:48 -04:00
|
|
|
|
2009-11-04 19:28:46 -05:00
|
|
|
[ t ] [ 1 26 fixnum-shift dup [ fixnum+ ] compile-call 1 27 fixnum-shift = ] unit-test
|
|
|
|
[ -134217729 ] [ 1 27 shift neg >fixnum [ -1 fixnum+ ] compile-call ] unit-test
|
2009-07-17 00:50:48 -04:00
|
|
|
|
2007-12-24 21:54:45 -05:00
|
|
|
[ t ] [ 1 20 shift 1 20 shift [ fixnum* ] compile-call 1 40 shift = ] unit-test
|
|
|
|
[ t ] [ 1 20 shift neg 1 20 shift [ fixnum* ] compile-call 1 40 shift neg = ] unit-test
|
|
|
|
[ t ] [ 1 20 shift neg 1 20 shift neg [ fixnum* ] compile-call 1 40 shift = ] unit-test
|
|
|
|
[ -351382792 ] [ -43922849 [ 3 fixnum-shift ] compile-call ] unit-test
|
|
|
|
|
2009-11-04 19:28:46 -05:00
|
|
|
[ 134217728 ] [ -134217728 >fixnum -1 [ fixnum/i ] compile-call ] unit-test
|
2007-12-24 21:54:45 -05:00
|
|
|
|
2009-11-04 19:28:46 -05:00
|
|
|
[ 134217728 0 ] [ -134217728 >fixnum -1 [ fixnum/mod ] compile-call ] unit-test
|
2007-12-24 21:54:45 -05:00
|
|
|
|
|
|
|
[ t ] [ f [ f eq? ] compile-call ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2009-07-02 18:52:53 -04:00
|
|
|
cell 8 = [
|
|
|
|
[ HEX: 40400000 ] [
|
|
|
|
HEX: 4200 [ HEX: 7fff fixnum-bitand 13 fixnum-shift-fast 112 23 fixnum-shift-fast fixnum+fast ]
|
|
|
|
compile-call
|
|
|
|
] unit-test
|
|
|
|
] when
|
|
|
|
|
2007-09-20 18:09:08 -04:00
|
|
|
! regression
|
|
|
|
[ 3 ] [
|
|
|
|
100001 f <array> 3 100000 pick set-nth
|
2007-12-24 21:54:45 -05:00
|
|
|
[ 100000 swap array-nth ] compile-call
|
2007-09-20 18:09:08 -04:00
|
|
|
] unit-test
|
|
|
|
|
2009-08-28 20:02:59 -04:00
|
|
|
[ 2 ] [ 2 4 [ fixnum-min ] compile-call ] unit-test
|
|
|
|
[ 2 ] [ 4 2 [ fixnum-min ] compile-call ] unit-test
|
|
|
|
[ 4 ] [ 2 4 [ fixnum-max ] compile-call ] unit-test
|
|
|
|
[ 4 ] [ 4 2 [ fixnum-max ] compile-call ] unit-test
|
|
|
|
[ -2 ] [ -2 -4 [ fixnum-max ] compile-call ] unit-test
|
|
|
|
[ -2 ] [ -4 -2 [ fixnum-max ] compile-call ] unit-test
|
|
|
|
[ -4 ] [ -2 -4 [ fixnum-min ] compile-call ] unit-test
|
|
|
|
[ -4 ] [ -4 -2 [ fixnum-min ] compile-call ] unit-test
|
|
|
|
|
2007-09-20 18:09:08 -04:00
|
|
|
! 64-bit overflow
|
|
|
|
cell 8 = [
|
2009-11-03 22:40:29 -05:00
|
|
|
[ t ] [ 1 58 fixnum-shift dup [ fixnum+ ] compile-call 1 59 fixnum-shift = ] unit-test
|
|
|
|
[ -576460752303423489 ] [ 1 59 shift neg >fixnum [ -1 fixnum+ ] compile-call ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2007-12-24 21:54:45 -05:00
|
|
|
[ t ] [ 1 40 shift 1 40 shift [ fixnum* ] compile-call 1 80 shift = ] unit-test
|
|
|
|
[ t ] [ 1 40 shift neg 1 40 shift [ fixnum* ] compile-call 1 80 shift neg = ] unit-test
|
|
|
|
[ t ] [ 1 40 shift neg 1 40 shift neg [ fixnum* ] compile-call 1 80 shift = ] unit-test
|
|
|
|
[ t ] [ 1 30 shift neg 1 50 shift neg [ fixnum* ] compile-call 1 80 shift = ] unit-test
|
|
|
|
[ t ] [ 1 50 shift neg 1 30 shift neg [ fixnum* ] compile-call 1 80 shift = ] unit-test
|
|
|
|
|
|
|
|
[ 18446744073709551616 ] [ 1 64 [ fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ 18446744073709551616 ] [ 1 [ 64 fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ 18446744073709551616 ] [ 1 [ 32 fixnum-shift 32 fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ -18446744073709551616 ] [ -1 64 [ fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ -18446744073709551616 ] [ -1 [ 64 fixnum-shift ] compile-call ] unit-test
|
|
|
|
[ -18446744073709551616 ] [ -1 [ 32 fixnum-shift 32 fixnum-shift ] compile-call ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2009-11-03 22:40:29 -05:00
|
|
|
[ 576460752303423488 ] [ -576460752303423488 >fixnum -1 [ fixnum/i ] compile-call ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2009-11-03 22:40:29 -05:00
|
|
|
[ 576460752303423488 0 ] [ -576460752303423488 >fixnum -1 [ fixnum/mod ] compile-call ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2007-12-24 21:54:45 -05:00
|
|
|
[ -268435457 ] [ 28 2^ [ fixnum-bitnot ] compile-call ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
] when
|
|
|
|
|
|
|
|
! Some randomized tests
|
2009-03-22 18:50:53 -04:00
|
|
|
: compiled-fixnum* ( a b -- c ) fixnum* ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2009-11-03 22:40:29 -05:00
|
|
|
ERROR: bug-in-fixnum* x y a b ;
|
|
|
|
|
2008-10-22 00:17:32 -04:00
|
|
|
[ ] [
|
|
|
|
10000 [
|
2009-11-03 22:40:29 -05:00
|
|
|
32 random-bits >fixnum
|
|
|
|
32 random-bits >fixnum
|
|
|
|
2dup [ fixnum* ] [ compiled-fixnum* ] 2bi 2dup =
|
|
|
|
[ 2drop 2drop ] [ bug-in-fixnum* ] if
|
2008-10-22 00:17:32 -04:00
|
|
|
] times
|
|
|
|
] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2009-03-22 18:50:53 -04:00
|
|
|
: compiled-fixnum>bignum ( a -- b ) fixnum>bignum ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-11-06 07:27:27 -05:00
|
|
|
[ bignum ] [ 0 compiled-fixnum>bignum class ] unit-test
|
|
|
|
|
2008-10-22 00:17:32 -04:00
|
|
|
[ ] [
|
|
|
|
10000 [
|
|
|
|
32 random-bits >fixnum
|
|
|
|
dup [ fixnum>bignum ] keep compiled-fixnum>bignum =
|
|
|
|
[ drop ] [ "Oops" throw ] if
|
|
|
|
] times
|
|
|
|
] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2009-03-22 18:50:53 -04:00
|
|
|
: compiled-bignum>fixnum ( a -- b ) bignum>fixnum ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-10-22 00:17:32 -04:00
|
|
|
[ ] [
|
|
|
|
10000 [
|
2010-01-14 13:48:57 -05:00
|
|
|
5 random iota [ drop 32 random-bits ] map product >bignum
|
2008-10-22 00:17:32 -04:00
|
|
|
dup [ bignum>fixnum ] keep compiled-bignum>fixnum =
|
|
|
|
[ drop ] [ "Oops" throw ] if
|
|
|
|
] times
|
|
|
|
] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
! Test overflow check removal
|
|
|
|
[ t ] [
|
|
|
|
most-positive-fixnum 100 - >fixnum
|
|
|
|
200
|
2007-12-24 21:54:45 -05:00
|
|
|
[ [ fixnum+ ] compile-call [ bignum>fixnum ] compile-call ] 2keep
|
|
|
|
[ fixnum+ >fixnum ] compile-call
|
2007-09-20 18:09:08 -04:00
|
|
|
=
|
|
|
|
] unit-test
|
|
|
|
|
|
|
|
[ t ] [
|
|
|
|
most-negative-fixnum 100 + >fixnum
|
|
|
|
-200
|
2007-12-24 21:54:45 -05:00
|
|
|
[ [ fixnum+ ] compile-call [ bignum>fixnum ] compile-call ] 2keep
|
|
|
|
[ fixnum+ >fixnum ] compile-call
|
2007-09-20 18:09:08 -04:00
|
|
|
=
|
|
|
|
] unit-test
|
|
|
|
|
|
|
|
[ t ] [
|
|
|
|
most-negative-fixnum 100 + >fixnum
|
|
|
|
200
|
2007-12-24 21:54:45 -05:00
|
|
|
[ [ fixnum- ] compile-call [ bignum>fixnum ] compile-call ] 2keep
|
|
|
|
[ fixnum- >fixnum ] compile-call
|
2007-09-20 18:09:08 -04:00
|
|
|
=
|
|
|
|
] unit-test
|
|
|
|
|
|
|
|
! Test inline allocators
|
|
|
|
[ { 1 1 1 } ] [
|
2007-12-24 21:54:45 -05:00
|
|
|
[ 3 1 <array> ] compile-call
|
2007-09-20 18:09:08 -04:00
|
|
|
] unit-test
|
|
|
|
|
|
|
|
[ B{ 0 0 0 } ] [
|
2007-12-24 21:54:45 -05:00
|
|
|
[ 3 <byte-array> ] compile-call
|
2007-09-20 18:09:08 -04:00
|
|
|
] unit-test
|
|
|
|
|
|
|
|
[ 500 ] [
|
2007-12-24 21:54:45 -05:00
|
|
|
[ 500 <byte-array> length ] compile-call
|
2007-09-20 18:09:08 -04:00
|
|
|
] unit-test
|
|
|
|
|
2007-10-14 21:13:42 -04:00
|
|
|
[ 1 2 ] [
|
2009-04-30 01:27:35 -04:00
|
|
|
1 2 [ complex boa ] compile-call
|
2007-12-27 17:26:39 -05:00
|
|
|
dup real-part swap imaginary-part
|
2007-10-14 21:13:42 -04:00
|
|
|
] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2007-10-14 21:13:42 -04:00
|
|
|
[ 1 2 ] [
|
2009-04-30 01:27:35 -04:00
|
|
|
1 2 [ ratio boa ] compile-call dup numerator swap denominator
|
2007-10-14 21:13:42 -04:00
|
|
|
] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2007-12-24 21:54:45 -05:00
|
|
|
[ \ + ] [ \ + [ <wrapper> ] compile-call ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
[ B{ 0 0 0 0 0 } ] [
|
2007-12-24 21:54:45 -05:00
|
|
|
[ 5 <byte-array> ] compile-call
|
2007-09-20 18:09:08 -04:00
|
|
|
] unit-test
|
|
|
|
|
|
|
|
[ V{ 1 2 } ] [
|
2008-07-01 21:19:03 -04:00
|
|
|
{ 1 2 3 } 2 [ vector boa ] compile-call
|
2007-09-20 18:09:08 -04:00
|
|
|
] unit-test
|
|
|
|
|
|
|
|
[ SBUF" hello" ] [
|
2008-07-01 21:19:03 -04:00
|
|
|
"hello world" 5 [ sbuf boa ] compile-call
|
2007-09-20 18:09:08 -04:00
|
|
|
] unit-test
|
|
|
|
|
|
|
|
[ [ 3 + ] ] [
|
2007-12-24 21:54:45 -05:00
|
|
|
3 [ + ] [ curry ] compile-call
|
2007-09-20 18:09:08 -04:00
|
|
|
] unit-test
|
|
|
|
|
|
|
|
! Alien intrinsics
|
2007-12-24 21:54:45 -05:00
|
|
|
[ 3 ] [ B{ 1 2 3 4 5 } 2 [ alien-unsigned-1 ] compile-call ] unit-test
|
|
|
|
[ 3 ] [ [ B{ 1 2 3 4 5 } 2 alien-unsigned-1 ] compile-call ] unit-test
|
|
|
|
[ 3 ] [ B{ 1 2 3 4 5 } 2 [ { byte-array fixnum } declare alien-unsigned-1 ] compile-call ] unit-test
|
|
|
|
[ 3 ] [ B{ 1 2 3 4 5 } 2 [ { c-ptr fixnum } declare alien-unsigned-1 ] compile-call ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
[ ] [ B{ 1 2 3 4 5 } malloc-byte-array "b" set ] unit-test
|
2007-09-26 13:40:32 -04:00
|
|
|
[ t ] [ "b" get >boolean ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2007-09-27 16:10:37 -04:00
|
|
|
"b" get [
|
2007-12-24 21:54:45 -05:00
|
|
|
[ 3 ] [ "b" get 2 [ alien-unsigned-1 ] compile-call ] unit-test
|
|
|
|
[ 3 ] [ "b" get [ { alien } declare 2 alien-unsigned-1 ] compile-call ] unit-test
|
2009-11-02 04:25:39 -05:00
|
|
|
[ 3 ] [ "b" get 2 [ { alien fixnum } declare alien-unsigned-1 ] compile-call ] unit-test
|
2007-12-24 21:54:45 -05:00
|
|
|
[ 3 ] [ "b" get 2 [ { c-ptr fixnum } declare alien-unsigned-1 ] compile-call ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2007-09-27 16:10:37 -04:00
|
|
|
[ ] [ "b" get free ] unit-test
|
|
|
|
] when
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-04-20 07:15:08 -04:00
|
|
|
[ ] [ "hello world" ascii malloc-string "s" set ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2007-09-27 16:10:37 -04:00
|
|
|
"s" get [
|
2008-04-20 06:15:46 -04:00
|
|
|
[ "hello world" ] [ "s" get <void*> [ { byte-array } declare *void* ] compile-call ascii alien>string ] unit-test
|
|
|
|
[ "hello world" ] [ "s" get <void*> [ { c-ptr } declare *void* ] compile-call ascii alien>string ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2007-09-27 16:10:37 -04:00
|
|
|
[ ] [ "s" get free ] unit-test
|
|
|
|
] when
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2007-12-24 21:54:45 -05:00
|
|
|
[ ALIEN: 1234 ] [ ALIEN: 1234 [ { alien } declare <void*> ] compile-call *void* ] unit-test
|
|
|
|
[ ALIEN: 1234 ] [ ALIEN: 1234 [ { c-ptr } declare <void*> ] compile-call *void* ] unit-test
|
|
|
|
[ f ] [ f [ { POSTPONE: f } declare <void*> ] compile-call *void* ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2007-12-24 21:54:45 -05:00
|
|
|
[ 252 ] [ B{ 1 2 3 -4 5 } 3 [ { byte-array fixnum } declare alien-unsigned-1 ] compile-call ] unit-test
|
|
|
|
[ -4 ] [ B{ 1 2 3 -4 5 } 3 [ { byte-array fixnum } declare alien-signed-1 ] compile-call ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2007-12-24 21:54:45 -05:00
|
|
|
[ -100 ] [ -100 <char> [ { byte-array } declare *char ] compile-call ] unit-test
|
|
|
|
[ 156 ] [ -100 <uchar> [ { byte-array } declare *uchar ] compile-call ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-10-22 00:17:32 -04:00
|
|
|
[ -100 ] [ -100 \ <char> def>> [ { fixnum } declare ] prepend compile-call *char ] unit-test
|
|
|
|
[ 156 ] [ -100 \ <uchar> def>> [ { fixnum } declare ] prepend compile-call *uchar ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2007-12-24 21:54:45 -05:00
|
|
|
[ -1000 ] [ -1000 <short> [ { byte-array } declare *short ] compile-call ] unit-test
|
|
|
|
[ 64536 ] [ -1000 <ushort> [ { byte-array } declare *ushort ] compile-call ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-10-22 00:17:32 -04:00
|
|
|
[ -1000 ] [ -1000 \ <short> def>> [ { fixnum } declare ] prepend compile-call *short ] unit-test
|
|
|
|
[ 64536 ] [ -1000 \ <ushort> def>> [ { fixnum } declare ] prepend compile-call *ushort ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2007-12-24 21:54:45 -05:00
|
|
|
[ -100000 ] [ -100000 <int> [ { byte-array } declare *int ] compile-call ] unit-test
|
|
|
|
[ 4294867296 ] [ -100000 <uint> [ { byte-array } declare *uint ] compile-call ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-10-22 00:17:32 -04:00
|
|
|
[ -100000 ] [ -100000 \ <int> def>> [ { fixnum } declare ] prepend compile-call *int ] unit-test
|
|
|
|
[ 4294867296 ] [ -100000 \ <uint> def>> [ { fixnum } declare ] prepend compile-call *uint ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
[ t ] [ pi pi <double> *double = ] unit-test
|
|
|
|
|
2007-12-24 21:54:45 -05:00
|
|
|
[ t ] [ pi <double> [ { byte-array } declare *double ] compile-call pi = ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
! Silly
|
2007-12-24 21:54:45 -05:00
|
|
|
[ t ] [ pi 4 <byte-array> [ [ { float byte-array } declare 0 set-alien-float ] compile-call ] keep *float pi - -0.001 0.001 between? ] unit-test
|
|
|
|
[ t ] [ pi <float> [ { byte-array } declare *float ] compile-call pi - -0.001 0.001 between? ] unit-test
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2007-12-24 21:54:45 -05:00
|
|
|
[ t ] [ pi 8 <byte-array> [ [ { float byte-array } declare 0 set-alien-double ] compile-call ] keep *double pi = ] unit-test
|
2007-10-01 04:20:47 -04:00
|
|
|
|
|
|
|
[ 4 ] [
|
|
|
|
2 B{ 1 2 3 4 5 6 } <displaced-alien> [
|
|
|
|
{ alien } declare 1 alien-unsigned-1
|
2007-12-24 21:54:45 -05:00
|
|
|
] compile-call
|
2007-10-01 04:20:47 -04:00
|
|
|
] unit-test
|
|
|
|
|
2009-08-27 01:06:19 -04:00
|
|
|
[ ALIEN: 123 ] [
|
2009-09-12 22:17:53 -04:00
|
|
|
HEX: 123 [ <alien> ] compile-call
|
2009-08-27 01:06:19 -04:00
|
|
|
] unit-test
|
|
|
|
|
|
|
|
[ ALIEN: 123 ] [
|
2009-09-12 22:17:53 -04:00
|
|
|
HEX: 123 [ { fixnum } declare <alien> ] compile-call
|
2009-08-27 01:06:19 -04:00
|
|
|
] unit-test
|
|
|
|
|
|
|
|
[ ALIEN: 123 ] [
|
2009-09-12 22:17:53 -04:00
|
|
|
[ HEX: 123 <alien> ] compile-call
|
2009-08-27 01:06:19 -04:00
|
|
|
] unit-test
|
|
|
|
|
|
|
|
[ f ] [
|
|
|
|
0 [ <alien> ] compile-call
|
|
|
|
] unit-test
|
|
|
|
|
|
|
|
[ f ] [
|
|
|
|
0 [ { fixnum } declare <alien> ] compile-call
|
|
|
|
] unit-test
|
|
|
|
|
|
|
|
[ f ] [
|
|
|
|
[ 0 <alien> ] compile-call
|
|
|
|
] unit-test
|
|
|
|
|
|
|
|
[ ALIEN: 321 ] [
|
|
|
|
0 ALIEN: 321 [ <displaced-alien> ] compile-call
|
|
|
|
] unit-test
|
|
|
|
|
|
|
|
[ ALIEN: 321 ] [
|
|
|
|
0 ALIEN: 321 [ { fixnum c-ptr } declare <displaced-alien> ] compile-call
|
|
|
|
] unit-test
|
|
|
|
|
|
|
|
[ ALIEN: 321 ] [
|
|
|
|
ALIEN: 321 [ 0 swap <displaced-alien> ] compile-call
|
|
|
|
] unit-test
|
|
|
|
|
|
|
|
[ B{ 0 1 2 3 4 } ] [
|
|
|
|
2 B{ 0 1 2 3 4 } <displaced-alien>
|
|
|
|
[ 1 swap <displaced-alien> ] compile-call
|
|
|
|
underlying>>
|
|
|
|
] unit-test
|
|
|
|
|
|
|
|
[ B{ 0 1 2 3 4 } ] [
|
|
|
|
2 B{ 0 1 2 3 4 } <displaced-alien>
|
|
|
|
[ 1 swap { c-ptr } declare <displaced-alien> ] compile-call
|
|
|
|
underlying>>
|
|
|
|
] unit-test
|
|
|
|
|
2009-08-30 06:11:08 -04:00
|
|
|
[ ALIEN: 1234 ALIEN: 2234 ] [
|
|
|
|
ALIEN: 234 [
|
|
|
|
{ c-ptr } declare
|
2009-09-12 22:17:53 -04:00
|
|
|
[ HEX: 1000 swap <displaced-alien> ]
|
|
|
|
[ HEX: 2000 swap <displaced-alien> ] bi
|
2009-08-30 06:11:08 -04:00
|
|
|
] compile-call
|
|
|
|
] unit-test
|
|
|
|
|
2007-10-01 04:20:47 -04:00
|
|
|
[
|
2007-12-24 21:54:45 -05:00
|
|
|
B{ 0 0 0 0 } [ { byte-array } declare <void*> ] compile-call
|
2008-02-06 14:47:19 -05:00
|
|
|
] must-fail
|
2007-10-01 04:20:47 -04:00
|
|
|
|
|
|
|
[
|
2007-12-24 21:54:45 -05:00
|
|
|
B{ 0 0 0 0 } [ { c-ptr } declare <void*> ] compile-call
|
2008-02-06 14:47:19 -05:00
|
|
|
] must-fail
|
2007-10-29 02:17:44 -04:00
|
|
|
|
|
|
|
[
|
|
|
|
4 5
|
|
|
|
] [
|
|
|
|
3 [
|
|
|
|
[
|
|
|
|
{ [ 4444 ] [ 444 ] [ 44 ] [ 4 ] } dispatch
|
|
|
|
] keep 2 fixnum+fast
|
2007-12-24 21:54:45 -05:00
|
|
|
] compile-call
|
2007-10-29 02:17:44 -04:00
|
|
|
] unit-test
|
2008-01-12 21:39:22 -05:00
|
|
|
|
|
|
|
[ 1 ] [
|
|
|
|
8 -3 [ fixnum-shift-fast ] compile-call
|
|
|
|
] unit-test
|
|
|
|
|
|
|
|
[ 2 ] [
|
|
|
|
16 -3 [ fixnum-shift-fast ] compile-call
|
|
|
|
] unit-test
|
|
|
|
|
2008-01-12 22:24:27 -05:00
|
|
|
[ 2 ] [
|
|
|
|
16 [ -3 fixnum-shift-fast ] compile-call
|
|
|
|
] unit-test
|
|
|
|
|
2008-01-12 21:39:22 -05:00
|
|
|
[ 8 ] [
|
|
|
|
1 3 [ fixnum-shift-fast ] compile-call
|
|
|
|
] unit-test
|
2008-01-12 22:24:27 -05:00
|
|
|
|
|
|
|
[ 8 ] [
|
|
|
|
1 [ 3 fixnum-shift-fast ] compile-call
|
|
|
|
] unit-test
|
2008-08-29 01:26:47 -04:00
|
|
|
|
|
|
|
TUPLE: alien-accessor-regression { b byte-array } { i fixnum } ;
|
|
|
|
|
|
|
|
[ B{ 0 1 } ] [
|
|
|
|
B{ 0 0 } 1 alien-accessor-regression boa
|
|
|
|
dup [
|
|
|
|
{ alien-accessor-regression } declare
|
|
|
|
[ i>> ] [ b>> ] bi over set-alien-unsigned-1
|
|
|
|
] compile-call
|
|
|
|
b>>
|
|
|
|
] unit-test
|
2008-10-08 04:51:44 -04:00
|
|
|
|
|
|
|
: mutable-value-bug-1 ( a b -- c )
|
|
|
|
swap [
|
|
|
|
{ tuple } declare 1 slot
|
|
|
|
] [
|
2009-11-11 03:40:24 -05:00
|
|
|
1 slot
|
2008-10-08 04:51:44 -04:00
|
|
|
] if ;
|
|
|
|
|
2009-11-11 03:40:24 -05:00
|
|
|
[ 0 ] [ f { } mutable-value-bug-1 ] unit-test
|
2008-10-08 04:51:44 -04:00
|
|
|
|
|
|
|
: mutable-value-bug-2 ( a b -- c )
|
|
|
|
swap [
|
2009-11-11 03:40:24 -05:00
|
|
|
1 slot
|
2008-10-08 04:51:44 -04:00
|
|
|
] [
|
|
|
|
{ tuple } declare 1 slot
|
|
|
|
] if ;
|
|
|
|
|
2009-11-11 03:40:24 -05:00
|
|
|
[ 0 ] [ t { } mutable-value-bug-2 ] unit-test
|