| 
									
										
										
										
											2015-06-22 18:58:59 -04:00
										 |  |  | USING: accessors arrays assocs classes.tuple generic.standard | 
					
						
							|  |  |  | kernel lexer locals.types namespaces parser quotations | 
					
						
							|  |  |  | vocabs.parser words ;
 | 
					
						
							| 
									
										
										
										
											2009-08-29 22:04:19 -04:00
										 |  |  | IN: functors.backend | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | DEFER: functor-words | 
					
						
							|  |  |  | \ functor-words [ H{ } clone ] initialize
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYNTAX: FUNCTOR-SYNTAX: | 
					
						
							|  |  |  |     scan-word | 
					
						
							|  |  |  |     gensym [ parse-definition define-syntax ] keep
 | 
					
						
							|  |  |  |     swap name>> \ functor-words get-global set-at ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : functor-words ( -- assoc )
 | 
					
						
							|  |  |  |     \ functor-words get-global ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : scan-param ( -- obj ) scan-object literalize ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : >string-param ( string -- string/param )
 | 
					
						
							|  |  |  |     dup search dup lexical? [ nip ] [ drop ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : scan-string-param ( -- name/param )
 | 
					
						
							| 
									
										
										
										
											2010-07-06 16:20:08 -04:00
										 |  |  |     scan-token >string-param ;
 | 
					
						
							| 
									
										
										
										
											2009-08-29 22:04:19 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : scan-c-type-param ( -- c-type/param )
 | 
					
						
							| 
									
										
										
										
											2011-10-01 19:42:37 -04:00
										 |  |  |     scan-token dup "{" = [ drop \ } parse-until >array ] [ >string-param ] if ;
 | 
					
						
							| 
									
										
										
										
											2009-08-29 22:04:19 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-23 19:05:14 -04:00
										 |  |  | : define* ( word def -- ) over set-last-word define ;
 | 
					
						
							| 
									
										
										
										
											2009-08-29 22:04:19 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-17 09:56:41 -05:00
										 |  |  | : define-declared* ( word def effect -- )
 | 
					
						
							| 
									
										
										
										
											2013-03-23 19:05:14 -04:00
										 |  |  |     pick set-last-word define-declared ;
 | 
					
						
							| 
									
										
										
										
											2009-08-29 22:04:19 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-17 09:56:41 -05:00
										 |  |  | : define-simple-generic* ( word effect -- )
 | 
					
						
							| 
									
										
										
										
											2013-03-23 19:05:14 -04:00
										 |  |  |     over set-last-word define-simple-generic ;
 | 
					
						
							| 
									
										
										
										
											2009-08-29 22:04:19 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-17 09:56:41 -05:00
										 |  |  | : define-tuple-class* ( class superclass slots -- )
 | 
					
						
							| 
									
										
										
										
											2013-03-23 19:05:14 -04:00
										 |  |  |     pick set-last-word define-tuple-class ;
 |