2007-09-20 18:09:08 -04:00
|
|
|
! Copyright (C) 2007 Slava Pestov.
|
|
|
|
! See http://factorcode.org/license.txt for BSD license.
|
|
|
|
|
|
|
|
USING: parser kernel sequences words effects inference.transforms
|
|
|
|
combinators assocs definitions quotations namespaces ;
|
|
|
|
|
|
|
|
IN: macros
|
|
|
|
|
|
|
|
: (:)
|
|
|
|
CREATE dup reset-generic parse-definition
|
|
|
|
over "declared-effect" word-prop effect-in length ;
|
|
|
|
|
|
|
|
: (MACRO:)
|
|
|
|
>r
|
|
|
|
2dup "macro" set-word-prop
|
|
|
|
2dup [ call ] append define-compound
|
|
|
|
r> define-transform ;
|
|
|
|
|
|
|
|
: MACRO:
|
|
|
|
(:) (MACRO:) ; parsing
|
|
|
|
|
2007-11-22 20:48:24 -05:00
|
|
|
PREDICATE: compound macro
|
2007-09-20 18:09:08 -04:00
|
|
|
"macro" word-prop >boolean ;
|
|
|
|
|
|
|
|
M: macro definer drop \ MACRO: \ ; ;
|
|
|
|
|
|
|
|
M: macro definition "macro" word-prop ;
|
|
|
|
|
|
|
|
: macro-expand ( ... word -- quot ) "macro" word-prop call ;
|
|
|
|
|
|
|
|
: n*quot ( n seq -- seq' ) <repetition> concat >quotation ;
|
|
|
|
|
|
|
|
: saver \ >r <repetition> >quotation ;
|
|
|
|
|
|
|
|
: restorer \ r> <repetition> >quotation ;
|