2005-01-25 19:40:57 -05:00
|
|
|
! Copyright (C) 2005 Slava Pestov.
|
2005-12-31 04:20:07 -05:00
|
|
|
! See http://factorcode.org/license.txt for BSD license.
|
2005-09-11 20:46:55 -04:00
|
|
|
IN: arrays
|
2005-12-31 04:20:07 -05:00
|
|
|
USING: kernel kernel-internals math math-internals sequences
|
|
|
|
sequences-internals ;
|
2005-01-27 20:06:10 -05:00
|
|
|
|
2005-09-10 18:27:31 -04:00
|
|
|
M: array clone (clone) ;
|
2005-04-11 23:05:05 -04:00
|
|
|
M: array length array-capacity ;
|
2005-11-13 22:04:14 -05:00
|
|
|
M: array nth bounds-check nth-unsafe ;
|
|
|
|
M: array set-nth bounds-check set-nth-unsafe ;
|
2005-09-24 16:34:10 -04:00
|
|
|
M: array nth-unsafe >r >fixnum r> array-nth ;
|
|
|
|
M: array set-nth-unsafe >r >fixnum r> set-array-nth ;
|
2005-06-10 16:08:00 -04:00
|
|
|
M: array resize resize-array ;
|
2005-12-31 04:20:07 -05:00
|
|
|
|
2006-07-24 00:20:08 -04:00
|
|
|
: >array ( seq -- array )
|
|
|
|
[ array? ] [ f <array> ] >sequence ; inline
|
2005-12-31 04:20:07 -05:00
|
|
|
|
2005-09-11 20:46:55 -04:00
|
|
|
M: array like drop dup array? [ >array ] unless ;
|
2005-12-31 04:20:07 -05:00
|
|
|
|
|
|
|
M: byte-array clone (clone) ;
|
|
|
|
M: byte-array length array-capacity ;
|
|
|
|
M: byte-array resize resize-array ;
|
|
|
|
|
2006-08-15 03:01:24 -04:00
|
|
|
: 1array ( x -- array ) 1 swap <array> ;
|
2005-12-31 04:20:07 -05:00
|
|
|
|
2006-08-15 03:01:24 -04:00
|
|
|
: 2array ( x y -- array )
|
2006-06-05 23:26:44 -04:00
|
|
|
2 swap <array> [ 0 swap set-array-nth ] keep ;
|
2005-12-31 04:20:07 -05:00
|
|
|
|
2006-08-15 03:01:24 -04:00
|
|
|
: 3array ( x y z -- array )
|
2005-12-24 18:29:31 -05:00
|
|
|
3 swap <array>
|
2005-09-11 20:46:55 -04:00
|
|
|
[ 1 swap set-array-nth ] keep
|
2006-06-05 23:26:44 -04:00
|
|
|
[ 0 swap set-array-nth ] keep ;
|
2006-08-28 15:54:40 -04:00
|
|
|
|
|
|
|
: 4array ( x y z t -- array )
|
|
|
|
4 swap <array>
|
|
|
|
[ 2 swap set-array-nth ] keep
|
|
|
|
[ 1 swap set-array-nth ] keep
|
|
|
|
[ 0 swap set-array-nth ] keep ;
|