63 lines
1.6 KiB
Factor
Executable File
63 lines
1.6 KiB
Factor
Executable File
USING: kernel namespaces namespaces.private quotations sequences
|
|
assocs.lib math.parser math generalizations locals mirrors
|
|
macros ;
|
|
|
|
IN: namespaces.lib
|
|
|
|
! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
|
|
|
: save-namestack ( quot -- ) namestack >r call r> set-namestack ;
|
|
|
|
! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
|
|
|
: make* ( seq -- seq ) [ dup quotation? [ call ] [ ] if ] map ;
|
|
|
|
! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
|
|
|
: set* ( val var -- ) namestack* set-assoc-stack ;
|
|
|
|
SYMBOL: building-seq
|
|
: get-building-seq ( n -- seq )
|
|
building-seq get nth ;
|
|
|
|
: n, ( obj n -- ) get-building-seq push ;
|
|
: n% ( seq n -- ) get-building-seq push-all ;
|
|
: n# ( num n -- ) >r number>string r> n% ;
|
|
|
|
: 0, ( obj -- ) 0 n, ;
|
|
: 0% ( seq -- ) 0 n% ;
|
|
: 0# ( num -- ) 0 n# ;
|
|
: 1, ( obj -- ) 1 n, ;
|
|
: 1% ( seq -- ) 1 n% ;
|
|
: 1# ( num -- ) 1 n# ;
|
|
: 2, ( obj -- ) 2 n, ;
|
|
: 2% ( seq -- ) 2 n% ;
|
|
: 2# ( num -- ) 2 n# ;
|
|
: 3, ( obj -- ) 3 n, ;
|
|
: 3% ( seq -- ) 3 n% ;
|
|
: 3# ( num -- ) 3 n# ;
|
|
: 4, ( obj -- ) 4 n, ;
|
|
: 4% ( seq -- ) 4 n% ;
|
|
: 4# ( num -- ) 4 n# ;
|
|
|
|
MACRO: finish-nmake ( exemplars -- )
|
|
length [ firstn ] curry ;
|
|
|
|
:: nmake ( quot exemplars -- )
|
|
[
|
|
exemplars
|
|
[ 0 swap new-resizable ] map
|
|
building-seq set
|
|
|
|
quot call
|
|
|
|
building-seq get
|
|
exemplars [ [ like ] 2map ] [ finish-nmake ] bi
|
|
] with-scope ; inline
|
|
|
|
: make-object ( quot class -- object )
|
|
new [ <mirror> swap bind ] keep ; inline
|
|
|
|
: with-object ( object quot -- )
|
|
[ <mirror> ] dip bind ; inline
|