| 
									
										
										
										
											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 ;
 |