| 
									
										
										
										
											2010-04-12 21:29:47 -04:00
										 |  |  | USING: tools.test alien.syntax specialized-arrays sequences | 
					
						
							|  |  |  | alien accessors kernel arrays combinators compiler | 
					
						
							|  |  |  | compiler.units classes.struct combinators.smart | 
					
						
							|  |  |  | compiler.tree.debugger math libc destructors sequences.private | 
					
						
							|  |  |  | multiline eval words vocabs namespaces assocs prettyprint | 
					
						
							|  |  |  | alien.data math.vectors definitions compiler.test ;
 | 
					
						
							|  |  |  | FROM: specialized-arrays.private => specialized-array-vocab ;
 | 
					
						
							| 
									
										
										
										
											2011-10-15 02:23:42 -04:00
										 |  |  | FROM: alien.c-types => int float bool uchar char float ulonglong ushort uint | 
					
						
							| 
									
										
										
										
											2010-12-26 01:34:12 -05:00
										 |  |  | heap-size ;
 | 
					
						
							|  |  |  | FROM: alien.data => little-endian? ;
 | 
					
						
							| 
									
										
										
										
											2010-04-12 21:29:47 -04:00
										 |  |  | IN: specialized-arrays.tests | 
					
						
							| 
									
										
										
										
											2009-09-09 23:33:34 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | SPECIALIZED-ARRAY: int | 
					
						
							| 
									
										
										
										
											2011-10-15 02:23:42 -04:00
										 |  |  | SPECIALIZED-ARRAYS: bool uchar ushort char uint float ulonglong ;
 | 
					
						
							| 
									
										
										
										
											2009-09-21 00:16:02 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { t } [ { 1 2 3 } int >c-array int-array? ] unit-test | 
					
						
							| 
									
										
										
										
											2008-11-14 21:18:16 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { t } [ int-array{ 1 2 3 } int-array? ] unit-test | 
					
						
							| 
									
										
										
										
											2008-11-14 21:18:16 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { 2 } [ int-array{ 1 2 3 } second ] unit-test | 
					
						
							| 
									
										
										
										
											2008-11-14 21:18:16 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { t } [ | 
					
						
							| 
									
										
										
										
											2011-09-25 14:49:27 -04:00
										 |  |  |     { t f t } bool >c-array underlying>> | 
					
						
							| 
									
										
										
										
											2009-11-20 02:37:24 -05:00
										 |  |  |     { 1 0 1 } bool heap-size { | 
					
						
							| 
									
										
										
										
											2011-09-25 14:49:27 -04:00
										 |  |  |         { 1 [ char >c-array ] } | 
					
						
							|  |  |  |         { 4 [ uint >c-array ] } | 
					
						
							| 
									
										
										
										
											2009-05-08 22:34:28 -04:00
										 |  |  |     } case underlying>> =
 | 
					
						
							|  |  |  | ] unit-test | 
					
						
							| 
									
										
										
										
											2008-12-02 21:35:20 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { ushort-array{ 1234 } } [ | 
					
						
							| 
									
										
										
										
											2011-09-25 14:49:27 -04:00
										 |  |  |     little-endian? B{ 210 4 } B{ 4 210 } ? ushort cast-array | 
					
						
							| 
									
										
										
										
											2008-12-02 21:35:20 -05:00
										 |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-25 14:49:27 -04:00
										 |  |  | [ B{ 210 4 1 } ushort cast-array ] must-fail | 
					
						
							| 
									
										
										
										
											2009-02-06 05:37:28 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { { 3 1 3 3 7 } } [ | 
					
						
							| 
									
										
										
										
											2012-08-26 01:53:22 -04:00
										 |  |  |     int-array{ 3 1 3 3 7 } malloc-byte-array [ &free 5 int <c-direct-array> >array ] with-destructors | 
					
						
							| 
									
										
										
										
											2009-09-03 03:24:03 -04:00
										 |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { float-array{ 0x1.222,222p0   0x1.111,112p0   } } | 
					
						
							| 
									
										
										
										
											2011-11-28 21:55:20 -05:00
										 |  |  | [ float-array{ 0x1.222,222,2p0 0x1.111,111,1p0 } ] unit-test | 
					
						
							| 
									
										
										
										
											2009-10-17 01:07:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { f } [ float-array{ 4 3 2 1 } dup clone [ underlying>> ] bi@ eq? ] unit-test | 
					
						
							| 
									
										
										
										
											2009-09-03 03:24:03 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { f } [ [ float-array{ 4 3 2 1 } dup clone [ underlying>> ] bi@ eq? ] compile-call ] unit-test | 
					
						
							| 
									
										
										
										
											2009-09-08 00:51:25 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { ushort-array{ 0 0 0 } } [ | 
					
						
							| 
									
										
										
										
											2009-09-04 23:01:55 -04:00
										 |  |  |     3 ALIEN: 123 100 <direct-ushort-array> new-sequence
 | 
					
						
							| 
									
										
										
										
											2009-10-27 23:32:56 -04:00
										 |  |  |     [ drop 0 ] map!
 | 
					
						
							| 
									
										
										
										
											2009-09-08 00:51:25 -04:00
										 |  |  | ] unit-test | 
					
						
							| 
									
										
										
										
											2009-09-09 23:33:34 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | STRUCT: test-struct | 
					
						
							|  |  |  |     { x int } | 
					
						
							|  |  |  |     { y int } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SPECIALIZED-ARRAY: test-struct | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { 1 } [ | 
					
						
							| 
									
										
										
										
											2009-09-09 23:33:34 -04:00
										 |  |  |     1 test-struct-array{ } new-sequence length
 | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { V{ test-struct } } [ | 
					
						
							| 
									
										
										
										
											2009-09-09 23:33:34 -04:00
										 |  |  |     [ [ test-struct-array <struct> ] test-struct-array{ } output>sequence first ] final-classes | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : make-point ( x y -- struct )
 | 
					
						
							|  |  |  |     test-struct <struct-boa> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { 5/4 } [ | 
					
						
							| 
									
										
										
										
											2009-09-09 23:33:34 -04:00
										 |  |  |     2 <test-struct-array> | 
					
						
							|  |  |  |     1 2 make-point over set-first
 | 
					
						
							|  |  |  |     3 4 make-point over set-second
 | 
					
						
							|  |  |  |     0 [ [ x>> ] [ y>> ] bi / + ] reduce
 | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { 5/4 } [ | 
					
						
							| 
									
										
										
										
											2009-09-09 23:33:34 -04:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2011-09-26 19:55:35 -04:00
										 |  |  |         2 \ test-struct malloc-array | 
					
						
							| 
									
										
										
										
											2009-09-09 23:33:34 -04:00
										 |  |  |         dup &free drop
 | 
					
						
							|  |  |  |         1 2 make-point over set-first
 | 
					
						
							|  |  |  |         3 4 make-point over set-second
 | 
					
						
							|  |  |  |         0 [ [ x>> ] [ y>> ] bi / + ] reduce
 | 
					
						
							|  |  |  |     ] with-destructors | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { } [ ALIEN: 123 10 <direct-test-struct-array> drop ] unit-test | 
					
						
							| 
									
										
										
										
											2009-09-09 23:33:34 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { } [ | 
					
						
							| 
									
										
										
										
											2009-09-09 23:33:34 -04:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2011-09-26 19:55:35 -04:00
										 |  |  |         10 \ test-struct malloc-array | 
					
						
							| 
									
										
										
										
											2009-09-09 23:33:34 -04:00
										 |  |  |         &free drop
 | 
					
						
							|  |  |  |     ] with-destructors | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { 15 } [ 15 10 <test-struct-array> resize length ] unit-test | 
					
						
							| 
									
										
										
										
											2009-09-09 23:33:34 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { S{ test-struct f 12 20 } } [ | 
					
						
							| 
									
										
										
										
											2009-09-09 23:33:34 -04:00
										 |  |  |     test-struct-array{ | 
					
						
							| 
									
										
										
										
											2015-07-02 13:34:01 -04:00
										 |  |  |         S{ test-struct f  4 20 } | 
					
						
							| 
									
										
										
										
											2009-09-09 23:33:34 -04:00
										 |  |  |         S{ test-struct f 12 20 } | 
					
						
							|  |  |  |         S{ test-struct f 20 20 } | 
					
						
							|  |  |  |     } second
 | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { } [ | 
					
						
							| 
									
										
										
										
											2010-04-12 21:29:47 -04:00
										 |  |  |     [ | 
					
						
							|  |  |  |         test-struct specialized-array-vocab forget-vocab | 
					
						
							|  |  |  |     ] with-compilation-unit | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-09 23:33:34 -04:00
										 |  |  | ! Regression | 
					
						
							| 
									
										
										
										
											2009-09-13 01:24:31 -04:00
										 |  |  | STRUCT: fixed-string { text char[64] } ;
 | 
					
						
							| 
									
										
										
										
											2009-09-09 23:33:34 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | SPECIALIZED-ARRAY: fixed-string | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { { ALIEN: 100 ALIEN: 140 ALIEN: 180 ALIEN: 1c0 } } [ | 
					
						
							| 
									
										
										
										
											2009-09-13 01:24:31 -04:00
										 |  |  |     ALIEN: 100 4 <direct-fixed-string-array> [ (underlying)>> ] { } map-as
 | 
					
						
							| 
									
										
										
										
											2009-09-09 23:33:34 -04:00
										 |  |  | ] unit-test | 
					
						
							| 
									
										
										
										
											2009-09-10 15:46:26 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Ensure that byte-length works with direct arrays | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { 400 } [ | 
					
						
							| 
									
										
										
										
											2009-09-10 15:46:26 -04:00
										 |  |  |     ALIEN: 123 100 <direct-int-array> byte-length | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { } [ | 
					
						
							| 
									
										
										
										
											2010-04-12 21:29:47 -04:00
										 |  |  |     [ | 
					
						
							|  |  |  |         fixed-string specialized-array-vocab forget-vocab | 
					
						
							|  |  |  |     ] with-compilation-unit | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-10 15:46:26 -04:00
										 |  |  | ! Test prettyprinting | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { "int-array{ 1 2 3 }" } [ int-array{ 1 2 3 } unparse ] unit-test | 
					
						
							|  |  |  | { "c-array@ int f 100" } [ f 100 <direct-int-array> unparse ] unit-test | 
					
						
							| 
									
										
										
										
											2009-09-10 15:46:26 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! If the C type doesn't exist, don't generate a vocab | 
					
						
							| 
									
										
										
										
											2009-10-19 05:41:53 -04:00
										 |  |  | SYMBOL: __does_not_exist__ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-10 15:46:26 -04:00
										 |  |  | [ | 
					
						
							| 
									
										
										
										
											2015-07-26 01:59:56 -04:00
										 |  |  |     " | 
					
						
							| 
									
										
										
										
											2009-09-10 15:46:26 -04:00
										 |  |  | IN: specialized-arrays.tests | 
					
						
							|  |  |  | USING: specialized-arrays ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-26 01:59:56 -04:00
										 |  |  | SPECIALIZED-ARRAY: __does_not_exist__ " eval( -- ) | 
					
						
							| 
									
										
										
										
											2009-09-10 15:46:26 -04:00
										 |  |  | ] must-fail | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { } [ | 
					
						
							| 
									
										
										
										
											2015-07-26 01:59:56 -04:00
										 |  |  |     " | 
					
						
							| 
									
										
										
										
											2009-09-10 15:46:26 -04:00
										 |  |  | IN: specialized-arrays.tests | 
					
						
							| 
									
										
										
										
											2009-09-28 09:48:39 -04:00
										 |  |  | USING: alien.c-types classes.struct specialized-arrays ;
 | 
					
						
							| 
									
										
										
										
											2009-09-10 15:46:26 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | STRUCT: __does_not_exist__ { x int } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SPECIALIZED-ARRAY: __does_not_exist__ | 
					
						
							| 
									
										
										
										
											2015-07-26 01:59:56 -04:00
										 |  |  | " eval( -- ) | 
					
						
							| 
									
										
										
										
											2009-09-10 15:46:26 -04:00
										 |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { f } [ | 
					
						
							| 
									
										
										
										
											2009-09-10 15:46:26 -04:00
										 |  |  |     "__does_not_exist__-array{" | 
					
						
							| 
									
										
										
										
											2011-11-06 18:57:24 -05:00
										 |  |  |     __does_not_exist__ specialized-array-vocab lookup-word | 
					
						
							| 
									
										
										
										
											2009-09-10 15:46:26 -04:00
										 |  |  |     deferred? | 
					
						
							|  |  |  | ] unit-test | 
					
						
							| 
									
										
										
										
											2009-10-19 05:41:53 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { } [ | 
					
						
							| 
									
										
										
										
											2009-10-20 03:18:28 -04:00
										 |  |  |     [ | 
					
						
							|  |  |  |         \ __does_not_exist__ forget | 
					
						
							|  |  |  |         __does_not_exist__ specialized-array-vocab forget-vocab | 
					
						
							|  |  |  |     ] with-compilation-unit | 
					
						
							|  |  |  | ] unit-test | 
					
						
							| 
									
										
										
										
											2009-11-15 12:26:37 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | STRUCT: struct-resize-test { x int } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SPECIALIZED-ARRAY: struct-resize-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { 40 } [ 10 <struct-resize-test-array> byte-length ] unit-test | 
					
						
							| 
									
										
										
										
											2009-11-15 12:26:37 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : struct-resize-test-usage ( seq -- seq )
 | 
					
						
							|  |  |  |     [ struct-resize-test <struct> swap >>x ] map
 | 
					
						
							| 
									
										
										
										
											2011-09-26 19:55:35 -04:00
										 |  |  |     \ struct-resize-test >c-array | 
					
						
							| 
									
										
										
										
											2009-11-15 12:26:37 -05:00
										 |  |  |     [ x>> ] { } map-as ;
 | 
					
						
							| 
									
										
										
										
											2015-07-02 13:34:01 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { { 10 20 30 } } [ { 10 20 30 } struct-resize-test-usage ] unit-test | 
					
						
							| 
									
										
										
										
											2009-11-15 12:26:37 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { } [ "IN: specialized-arrays.tests USE: classes.struct USE: alien.c-types STRUCT: struct-resize-test { x int } { y int } ;" eval( -- ) ] unit-test | 
					
						
							| 
									
										
										
										
											2009-11-15 12:26:37 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { 80 } [ 10 <struct-resize-test-array> byte-length ] unit-test | 
					
						
							| 
									
										
										
										
											2009-11-15 12:26:37 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { { 10 20 30 } } [ { 10 20 30 } struct-resize-test-usage ] unit-test | 
					
						
							| 
									
										
										
										
											2010-04-12 21:29:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { } [ | 
					
						
							| 
									
										
										
										
											2010-04-12 21:29:47 -04:00
										 |  |  |     [ | 
					
						
							|  |  |  |         struct-resize-test specialized-array-vocab forget-vocab | 
					
						
							| 
									
										
										
										
											2010-05-02 16:21:56 -04:00
										 |  |  |         \ struct-resize-test-usage forget | 
					
						
							| 
									
										
										
										
											2010-04-12 21:29:47 -04:00
										 |  |  |     ] with-compilation-unit | 
					
						
							|  |  |  | ] unit-test | 
					
						
							| 
									
										
										
										
											2010-06-08 18:00:11 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { int-array{ 4 5 6 } } [ 3 6 int-array{ 1 2 3 4 5 6 7 8 } direct-slice ] unit-test | 
					
						
							|  |  |  | { int-array{ 1 2 3 } } [ int-array{ 1 2 3 4 5 6 7 8 } 3 direct-head ] unit-test | 
					
						
							|  |  |  | { int-array{ 1 2 3 4 5 } } [ int-array{ 1 2 3 4 5 6 7 8 } 3 direct-head* ] unit-test | 
					
						
							|  |  |  | { int-array{ 4 5 6 7 8 } } [ int-array{ 1 2 3 4 5 6 7 8 } 3 direct-tail ] unit-test | 
					
						
							|  |  |  | { int-array{ 6 7 8 } } [ int-array{ 1 2 3 4 5 6 7 8 } 3 direct-tail* ] unit-test | 
					
						
							| 
									
										
										
										
											2010-06-08 18:00:11 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { uchar-array{ 0 1 255 } } [ 3 6 B{ 1 1 1 0 1 255 2 2 2 } direct-slice ] unit-test | 
					
						
							| 
									
										
										
										
											2010-06-08 18:00:11 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { int-array{ 1 2 3 4 55555 6 7 8 } } [ | 
					
						
							| 
									
										
										
										
											2010-06-08 18:00:11 -04:00
										 |  |  |     int-array{ 1 2 3 4 5 6 7 8 } | 
					
						
							|  |  |  |     3 6 pick direct-slice [ 55555 1 ] dip set-nth
 | 
					
						
							|  |  |  | ] unit-test |