32 lines
865 B
Factor
32 lines
865 B
Factor
! Copyright (C) 2004, 2005 Slava Pestov.
|
|
! See http://factor.sf.net/license.txt for BSD license.
|
|
USING: errors generic kernel kernel-internals lists math
|
|
math-internals sequences ;
|
|
|
|
IN: vectors
|
|
|
|
: empty-vector ( len -- vec ) dup <vector> [ set-length ] keep ;
|
|
|
|
: >vector ( list -- vector )
|
|
dup length <vector> [ swap nappend ] keep ;
|
|
|
|
M: repeated thaw >vector ;
|
|
|
|
M: vector clone ( vector -- vector ) >vector ;
|
|
|
|
: zero-vector ( n -- vector ) 0 <repeated> >vector ;
|
|
|
|
M: general-list thaw >vector ;
|
|
|
|
M: general-list like drop >list ;
|
|
|
|
M: vector like drop >vector ;
|
|
|
|
: (1vector) [ push ] keep ; inline
|
|
: (2vector) [ swapd push ] keep (1vector) ; inline
|
|
: (3vector) [ >r rot r> push ] keep (2vector) ; inline
|
|
|
|
: 1vector ( x -- { x } ) 1 <vector> (1vector) ;
|
|
: 2vector ( x y -- { x y } ) 2 <vector> (2vector) ;
|
|
: 3vector ( x y z -- { x y z } ) 3 <vector> (3vector) ;
|