| 
									
										
										
										
											2009-06-04 11:17:09 -04:00
										 |  |  | ! Copyright (C) 2009 Slava Pestov, Doug Coleman. | 
					
						
							| 
									
										
										
										
											2009-01-30 15:40:08 -05:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2011-10-17 01:49:10 -04:00
										 |  |  | USING: accessors assocs classes classes.tuple effects | 
					
						
							|  |  |  | effects.parser fry kernel lexer locals macros parser | 
					
						
							|  |  |  | sequences sequences.generalizations sets vocabs vocabs.parser | 
					
						
							|  |  |  | words alien.parser ;
 | 
					
						
							| 
									
										
										
										
											2009-01-30 15:40:08 -05:00
										 |  |  | IN: constructors | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-09 12:31:00 -04:00
										 |  |  | : all-slots-assoc ( class -- slots )
 | 
					
						
							| 
									
										
										
										
											2015-07-20 03:46:33 -04:00
										 |  |  |     superclasses-of [ | 
					
						
							| 
									
										
										
										
											2011-10-17 01:49:10 -04:00
										 |  |  |         [ "slots" word-prop ] keep '[ _ ] { } map>assoc
 | 
					
						
							|  |  |  |     ] map concat ;
 | 
					
						
							| 
									
										
										
										
											2009-06-09 12:31:00 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-17 01:49:10 -04:00
										 |  |  | MACRO:: slots>boa ( slots class -- quot )
 | 
					
						
							| 
									
										
										
										
											2009-06-09 12:31:00 -04:00
										 |  |  |     class all-slots-assoc slots [ '[ first name>> _ = ] find-last nip ] with map :> slot-assoc | 
					
						
							|  |  |  |     class all-slots-assoc [ [ ] [ first initial>> ] bi ] { } map>assoc :> default-params | 
					
						
							| 
									
										
										
										
											2009-06-04 15:57:10 -04:00
										 |  |  |     slots length
 | 
					
						
							| 
									
										
										
										
											2009-06-09 12:31:00 -04:00
										 |  |  |     default-params length
 | 
					
						
							| 
									
										
										
										
											2009-06-04 11:17:09 -04:00
										 |  |  |     '[ | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  |         _ narray slot-assoc swap zip
 | 
					
						
							| 
									
										
										
										
											2009-06-09 12:31:00 -04:00
										 |  |  |         default-params swap assoc-union values _ firstn class boa
 | 
					
						
							| 
									
										
										
										
											2009-06-04 11:17:09 -04:00
										 |  |  |     ] ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-23 21:12:54 -04:00
										 |  |  | ERROR: repeated-constructor-parameters class effect ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ERROR: unknown-constructor-parameters class effect unknown ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : ensure-constructor-parameters ( class effect -- class effect )
 | 
					
						
							| 
									
										
										
										
											2015-08-13 19:13:05 -04:00
										 |  |  |     dup in>> all-unique? [ repeated-constructor-parameters ] unless
 | 
					
						
							| 
									
										
										
										
											2010-04-23 21:12:54 -04:00
										 |  |  |     2dup [ all-slots [ name>> ] map ] [ in>> ] bi* swap diff | 
					
						
							| 
									
										
										
										
											2015-08-13 19:13:05 -04:00
										 |  |  |     [ unknown-constructor-parameters ] unless-empty ;
 | 
					
						
							| 
									
										
										
										
											2010-04-23 21:12:54 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-17 01:49:10 -04:00
										 |  |  | : constructor-boa-quot ( constructor-word class effect -- word quot )
 | 
					
						
							|  |  |  |     in>> swap '[ _ _ slots>boa ] ; inline
 | 
					
						
							| 
									
										
										
										
											2009-06-09 00:18:15 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-17 01:49:10 -04:00
										 |  |  | : define-constructor ( constructor-word class effect -- )
 | 
					
						
							|  |  |  |     ensure-constructor-parameters | 
					
						
							|  |  |  |     [ constructor-boa-quot ] keep define-declared ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : create-reset ( string -- word )
 | 
					
						
							| 
									
										
										
										
											2015-06-08 15:38:38 -04:00
										 |  |  |     create-word-in dup reset-generic ;
 | 
					
						
							| 
									
										
										
										
											2009-06-09 00:18:15 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-04 15:24:13 -05:00
										 |  |  | : scan-constructor ( -- word class )
 | 
					
						
							| 
									
										
										
										
											2014-11-04 18:56:23 -05:00
										 |  |  |     scan-new-word scan-class ;
 | 
					
						
							| 
									
										
										
										
											2009-01-30 15:40:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-17 01:49:10 -04:00
										 |  |  | : parse-constructor ( -- word class effect def )
 | 
					
						
							|  |  |  |     scan-constructor scan-effect ensure-constructor-parameters | 
					
						
							| 
									
										
										
										
											2010-04-23 21:12:54 -04:00
										 |  |  |     parse-definition ;
 | 
					
						
							| 
									
										
										
										
											2009-06-09 00:18:15 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-17 01:49:10 -04:00
										 |  |  | SYNTAX: CONSTRUCTOR: | 
					
						
							|  |  |  |     parse-constructor | 
					
						
							|  |  |  |     [ [ constructor-boa-quot ] dip compose ] | 
					
						
							|  |  |  |     [ drop ] 2bi define-declared ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : scan-rest-input-effect ( -- effect )
 | 
					
						
							|  |  |  |     ")" parse-effect-tokens nip
 | 
					
						
							|  |  |  |     { "obj" } <effect> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : scan-full-input-effect ( -- effect )
 | 
					
						
							|  |  |  |     "(" expect scan-rest-input-effect ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-04 18:56:23 -05:00
										 |  |  | SYNTAX: SLOT-CONSTRUCTOR: | 
					
						
							|  |  |  |     scan-new-word [ name>> "(" append create-reset ] keep
 | 
					
						
							| 
									
										
										
										
											2011-10-17 01:49:10 -04:00
										 |  |  |     '[ scan-rest-input-effect in>> _ '[ _ _ slots>boa ] append! ] define-syntax ;
 |