2005-01-25 19:40:57 -05:00
|
|
|
! Copyright (C) 2005 Slava Pestov.
|
2005-01-29 14:18:28 -05:00
|
|
|
! See http://factor.sf.net/license.txt for BSD license.
|
2005-01-25 19:40:57 -05:00
|
|
|
|
2005-09-11 20:46:55 -04:00
|
|
|
IN: kernel-internals
|
|
|
|
USING: kernel math math-internals sequences sequences-internals ;
|
2005-01-25 19:40:57 -05:00
|
|
|
|
2005-09-11 20:46:55 -04:00
|
|
|
: array= ( seq seq -- ? )
|
|
|
|
#! This is really only used to compare tuples.
|
|
|
|
over array-capacity over array-capacity number= [
|
|
|
|
dup array-capacity [
|
|
|
|
>r 2dup r> tuck swap array-nth >r swap array-nth r> =
|
|
|
|
] all? 2nip
|
|
|
|
] [
|
|
|
|
2drop f
|
2005-09-24 15:21:17 -04:00
|
|
|
] if ; flushable
|
2005-05-05 22:30:58 -04:00
|
|
|
|
2005-09-11 20:46:55 -04:00
|
|
|
IN: arrays
|
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-09-10 18:27:31 -04:00
|
|
|
M: array nth bounds-check array-nth ;
|
|
|
|
M: array set-nth bounds-check set-array-nth ;
|
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-06-10 17:41:41 -04:00
|
|
|
|
2005-09-11 20:46:55 -04:00
|
|
|
: >array ( seq -- array )
|
|
|
|
[ length <array> 0 over ] keep copy-into ; inline
|
|
|
|
|
|
|
|
M: array like drop dup array? [ >array ] unless ;
|
|
|
|
|
2005-09-10 18:27:31 -04:00
|
|
|
M: byte-array clone (clone) ;
|
2005-06-12 03:38:57 -04:00
|
|
|
M: byte-array length array-capacity ;
|
|
|
|
M: byte-array resize resize-array ;
|
2005-08-02 06:32:48 -04:00
|
|
|
|
2005-10-29 16:53:47 -04:00
|
|
|
: 1array ( x -- @{ x }@ )
|
2005-09-11 20:46:55 -04:00
|
|
|
1 <array> [ 0 swap set-array-nth ] keep ; flushable
|
|
|
|
|
|
|
|
: 2array ( x y -- @{ x y }@ )
|
|
|
|
2 <array>
|
|
|
|
[ 1 swap set-array-nth ] keep
|
|
|
|
[ 0 swap set-array-nth ] keep ; flushable
|
|
|
|
|
|
|
|
: 3array ( x y z -- @{ x y z }@ )
|
|
|
|
3 <array>
|
|
|
|
[ 2 swap set-array-nth ] keep
|
|
|
|
[ 1 swap set-array-nth ] keep
|
|
|
|
[ 0 swap set-array-nth ] keep ; flushable
|
2005-09-10 18:27:31 -04:00
|
|
|
|
2005-09-11 20:46:55 -04:00
|
|
|
: zero-array ( n -- array ) 0 <repeated> >array ;
|