2008-02-26 19:40:32 -05:00
|
|
|
! Copyright (C) 2007, 2008 Slava Pestov.
|
2007-09-20 18:09:08 -04:00
|
|
|
! See http://factorcode.org/license.txt for BSD license.
|
2008-02-26 19:40:32 -05:00
|
|
|
USING: parser kernel sequences words effects
|
2008-08-12 04:31:48 -04:00
|
|
|
stack-checker.transforms combinators assocs definitions
|
|
|
|
quotations namespaces memoize ;
|
2007-09-20 18:09:08 -04:00
|
|
|
IN: macros
|
|
|
|
|
2008-01-09 17:52:37 -05:00
|
|
|
: real-macro-effect ( word -- effect' )
|
|
|
|
"declared-effect" word-prop effect-in 1 <effect> ;
|
|
|
|
|
2008-02-26 19:40:32 -05:00
|
|
|
: define-macro ( word definition -- )
|
|
|
|
over "declared-effect" word-prop effect-in length >r
|
|
|
|
2dup "macro" set-word-prop
|
|
|
|
2dup over real-macro-effect memoize-quot [ call ] append define
|
2007-09-20 18:09:08 -04:00
|
|
|
r> define-transform ;
|
|
|
|
|
|
|
|
: MACRO:
|
2008-02-26 19:40:32 -05:00
|
|
|
(:) define-macro ; parsing
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-03-26 19:23:19 -04:00
|
|
|
PREDICATE: macro < word "macro" word-prop >boolean ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
M: macro definer drop \ MACRO: \ ; ;
|
|
|
|
|
|
|
|
M: macro definition "macro" word-prop ;
|
|
|
|
|
2008-05-28 19:17:58 -04:00
|
|
|
M: macro reset-word
|
2008-06-30 04:57:00 -04:00
|
|
|
[ call-next-method ] [ f "macro" set-word-prop ] bi ;
|
2008-05-28 19:17:58 -04:00
|
|
|
|
2007-09-20 18:09:08 -04:00
|
|
|
: n*quot ( n seq -- seq' ) <repetition> concat >quotation ;
|
|
|
|
|
2008-06-08 16:32:55 -04:00
|
|
|
: saver ( n -- quot ) \ >r <repetition> >quotation ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-06-08 16:32:55 -04:00
|
|
|
: restorer ( n -- quot ) \ r> <repetition> >quotation ;
|