factor/extra/macros/macros.factor

33 lines
933 B
Factor
Raw Normal View History

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
inference.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-01-02 19:36:36 -05:00
PREDICATE: word macro "macro" word-prop >boolean ;
2007-09-20 18:09:08 -04:00
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 ;