| 
									
										
										
										
											2009-03-23 19:25:18 -04:00
										 |  |  | ! Copyright (C) 2008, 2009 Slava Pestov. | 
					
						
							| 
									
										
										
										
											2008-08-24 04:59:37 -04:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2008-10-17 17:54:07 -04:00
										 |  |  | USING: kernel sequences sequences.private namespaces make | 
					
						
							|  |  |  | quotations accessors words continuations vectors effects math | 
					
						
							| 
									
										
										
										
											2009-03-23 19:25:18 -04:00
										 |  |  | generalizations fry arrays ;
 | 
					
						
							| 
									
										
										
										
											2008-08-24 04:59:37 -04:00
										 |  |  | IN: macros.expander | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: expand-macros ( quot -- quot' )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: stack | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : begin ( -- ) V{ } clone stack set ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : end ( -- )
 | 
					
						
							|  |  |  |     stack get
 | 
					
						
							|  |  |  |     [ [ literalize , ] each ] | 
					
						
							|  |  |  |     [ delete-all ] | 
					
						
							|  |  |  |     bi ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-23 19:25:18 -04:00
										 |  |  | GENERIC: condomize? ( obj -- ? )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: array condomize? [ condomize? ] any? ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: callable condomize? [ condomize? ] any? ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: object condomize? drop f ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: condomize ( obj -- obj' )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: array condomize [ condomize ] map ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: callable condomize [ condomize ] map ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: object condomize ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : literal ( obj -- ) dup condomize? [ condomize ] when stack get push ;
 | 
					
						
							| 
									
										
										
										
											2008-08-24 04:59:37 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | GENERIC: expand-macros* ( obj -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : (expand-macros) ( quot -- )
 | 
					
						
							|  |  |  |     [ expand-macros* ] each ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: wrapper expand-macros* wrapped>> literal ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-17 17:54:07 -04:00
										 |  |  | : expand-dispatch? ( word -- ? )
 | 
					
						
							|  |  |  |     \ dispatch eq? stack get length 1 >= and ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : expand-dispatch ( -- )
 | 
					
						
							|  |  |  |     stack get pop end | 
					
						
							|  |  |  |     [ [ expand-macros ] [ ] map-as '[ _ dip ] % ] | 
					
						
							|  |  |  |     [ | 
					
						
							|  |  |  |         length [ <reversed> ] keep
 | 
					
						
							|  |  |  |         [ '[ _ ndrop _ nnip call ] [ ] like ] 2map , \ dispatch , | 
					
						
							|  |  |  |     ] bi ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-21 05:36:52 -05:00
										 |  |  | : word, ( word -- ) end , ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : expand-macro ( word quot -- )
 | 
					
						
							|  |  |  |     '[ | 
					
						
							|  |  |  |         drop
 | 
					
						
							|  |  |  |         stack [ _ with-datastack >vector ] change
 | 
					
						
							|  |  |  |         stack get pop >quotation end (expand-macros) | 
					
						
							|  |  |  |     ] [ | 
					
						
							|  |  |  |         drop
 | 
					
						
							|  |  |  |         word, | 
					
						
							|  |  |  |     ] recover ;
 | 
					
						
							| 
									
										
										
										
											2008-08-24 04:59:37 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : expand-macro? ( word -- quot ? )
 | 
					
						
							| 
									
										
										
										
											2008-09-24 21:18:03 -04:00
										 |  |  |     dup [ "transform-quot" word-prop ] [ "macro" word-prop ] bi or dup [ | 
					
						
							|  |  |  |         swap [ "transform-n" word-prop ] [ stack-effect in>> length ] bi or
 | 
					
						
							| 
									
										
										
										
											2008-08-24 04:59:37 -04:00
										 |  |  |         stack get length <=
 | 
					
						
							|  |  |  |     ] [ 2drop f f ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: word expand-macros* | 
					
						
							| 
									
										
										
										
											2008-10-17 17:54:07 -04:00
										 |  |  |     dup expand-dispatch? [ drop expand-dispatch ] [ | 
					
						
							| 
									
										
										
										
											2008-11-21 05:36:52 -05:00
										 |  |  |         dup expand-macro? [ expand-macro ] [ | 
					
						
							| 
									
										
										
										
											2008-10-17 17:54:07 -04:00
										 |  |  |             drop word, | 
					
						
							|  |  |  |         ] if
 | 
					
						
							|  |  |  |     ] if ;
 | 
					
						
							| 
									
										
										
										
											2008-08-24 04:59:37 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: object expand-macros* literal ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: callable expand-macros* | 
					
						
							|  |  |  |     expand-macros literal ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: callable expand-macros ( quot -- quot' )
 | 
					
						
							|  |  |  |     [ begin (expand-macros) end ] [ ] make ;
 |