| 
									
										
										
										
											2008-06-25 04:25:08 -04:00
										 |  |  | ! Copyright (C) 2008 Slava Pestov. | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2008-07-28 23:03:13 -04:00
										 |  |  | USING: parser kernel words generic namespaces ;
 | 
					
						
							| 
									
										
										
										
											2008-06-25 04:25:08 -04:00
										 |  |  | IN: generic.parser | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ERROR: not-in-a-method-error ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : CREATE-GENERIC ( -- word ) CREATE dup reset-word ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : create-method-in ( class generic -- method )
 | 
					
						
							|  |  |  |     create-method f set-word dup save-location ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : CREATE-METHOD ( -- method )
 | 
					
						
							|  |  |  |     scan-word bootstrap-word scan-word create-method-in ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: current-class | 
					
						
							|  |  |  | SYMBOL: current-generic | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : with-method-definition ( quot -- parsed )
 | 
					
						
							|  |  |  |     [ | 
					
						
							|  |  |  |         >r | 
					
						
							|  |  |  |         [ "method-class" word-prop current-class set ] | 
					
						
							|  |  |  |         [ "method-generic" word-prop current-generic set ] | 
					
						
							|  |  |  |         [ ] tri
 | 
					
						
							|  |  |  |         r> call
 | 
					
						
							|  |  |  |     ] with-scope ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : (M:) ( method def -- )
 | 
					
						
							|  |  |  |     CREATE-METHOD [ parse-definition ] with-method-definition ;
 | 
					
						
							|  |  |  | 
 |