| 
									
										
										
										
											2009-03-23 18:12:41 -04:00
										 |  |  | ! Copyright (C) 2008, 2009 Slava Pestov. | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2008-03-26 02:30:44 -04:00
										 |  |  | USING: kernel math sequences vectors classes classes.algebra | 
					
						
							| 
									
										
										
										
											2008-09-10 23:11:40 -04:00
										 |  |  | combinators arrays words assocs parser namespaces make | 
					
						
							| 
									
										
										
										
											2008-12-08 21:06:44 -05:00
										 |  |  | definitions prettyprint prettyprint.backend prettyprint.custom | 
					
						
							|  |  |  | quotations generalizations debugger io compiler.units | 
					
						
							|  |  |  | kernel.private effects accessors hashtables sorting shuffle | 
					
						
							| 
									
										
										
										
											2009-03-23 18:12:41 -04:00
										 |  |  | math.order sets see effects.parser ;
 | 
					
						
							| 
									
										
										
										
											2010-02-26 16:28:38 -05:00
										 |  |  | FROM: namespaces => set ;
 | 
					
						
							| 
									
										
										
										
											2008-01-05 23:07:12 -05:00
										 |  |  | IN: multi-methods | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | ! PART I: Converting hook specializers | 
					
						
							|  |  |  | : canonicalize-specializer-0 ( specializer -- specializer' )
 | 
					
						
							|  |  |  |     [ \ f or ] map ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | SYMBOL: args | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | SYMBOL: hooks | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: total | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : canonicalize-specializer-1 ( specializer -- specializer' )
 | 
					
						
							|  |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-04-26 00:17:08 -04:00
										 |  |  |         [ class? ] filter
 | 
					
						
							| 
									
										
										
										
											2010-01-14 10:10:13 -05:00
										 |  |  |         [ length iota <reversed> [ 1 + neg ] map ] keep zip
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |         [ length args [ max ] change ] keep
 | 
					
						
							|  |  |  |     ] | 
					
						
							|  |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-04-26 00:17:08 -04:00
										 |  |  |         [ pair? ] filter
 | 
					
						
							| 
									
										
										
										
											2008-05-25 20:44:37 -04:00
										 |  |  |         [ keys [ hooks get adjoin ] each ] keep
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |     ] bi append ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : canonicalize-specializer-2 ( specializer -- specializer' )
 | 
					
						
							|  |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-12-18 00:36:13 -05:00
										 |  |  |         [ | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 { [ dup integer? ] [ ] } | 
					
						
							|  |  |  |                 { [ dup word? ] [ hooks get index ] } | 
					
						
							|  |  |  |             } cond args get +
 | 
					
						
							|  |  |  |         ] dip
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |     ] assoc-map ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : canonicalize-specializer-3 ( specializer -- specializer' )
 | 
					
						
							| 
									
										
										
										
											2010-02-03 09:25:53 -05:00
										 |  |  |     [ total get object <array> <enum> ] dip assoc-union! seq>> ;
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : canonicalize-specializers ( methods -- methods' hooks )
 | 
					
						
							|  |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-12-18 00:36:13 -05:00
										 |  |  |         [ [ canonicalize-specializer-0 ] dip ] assoc-map
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         0 args set
 | 
					
						
							|  |  |  |         V{ } clone hooks set
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-18 00:36:13 -05:00
										 |  |  |         [ [ canonicalize-specializer-1 ] dip ] assoc-map
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         hooks [ natural-sort ] change
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-18 00:36:13 -05:00
										 |  |  |         [ [ canonicalize-specializer-2 ] dip ] assoc-map
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         args get hooks get length + total set
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-18 00:36:13 -05:00
										 |  |  |         [ [ canonicalize-specializer-3 ] dip ] assoc-map
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         hooks get
 | 
					
						
							|  |  |  |     ] with-scope ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : drop-n-quot ( n -- quot ) \ drop <repetition> >quotation ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : prepare-method ( method n -- quot )
 | 
					
						
							|  |  |  |     [ 1quotation ] [ drop-n-quot ] bi* prepend ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : prepare-methods ( methods -- methods' prologue )
 | 
					
						
							|  |  |  |     canonicalize-specializers | 
					
						
							|  |  |  |     [ length [ prepare-method ] curry assoc-map ] keep
 | 
					
						
							|  |  |  |     [ [ get ] curry ] map concat [ ] like ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Part II: Topologically sorting specializers | 
					
						
							| 
									
										
										
										
											2008-01-05 23:07:12 -05:00
										 |  |  | : maximal-element ( seq quot -- n elt )
 | 
					
						
							|  |  |  |     dupd [ | 
					
						
							| 
									
										
										
										
											2008-04-27 23:44:42 -04:00
										 |  |  |         swapd [ call +lt+ = ] 2curry filter empty?
 | 
					
						
							| 
									
										
										
										
											2008-01-05 23:07:12 -05:00
										 |  |  |     ] 2curry find [ "Topological sort failed" throw ] unless* ;
 | 
					
						
							|  |  |  |     inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : topological-sort ( seq quot -- newseq )
 | 
					
						
							| 
									
										
										
										
											2008-12-18 00:36:13 -05:00
										 |  |  |     [ >vector [ dup empty? not ] ] dip
 | 
					
						
							| 
									
										
										
										
											2009-10-28 00:41:57 -04:00
										 |  |  |     [ dupd maximal-element [ over remove-nth! drop ] dip ] curry
 | 
					
						
							| 
									
										
										
										
											2009-02-28 16:31:34 -05:00
										 |  |  |     produce nip ; inline
 | 
					
						
							| 
									
										
										
										
											2008-01-05 23:07:12 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-27 23:44:42 -04:00
										 |  |  | : classes< ( seq1 seq2 -- lt/eq/gt )
 | 
					
						
							| 
									
										
										
										
											2008-01-05 23:07:12 -05:00
										 |  |  |     [ | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2008-04-27 23:44:42 -04:00
										 |  |  |             { [ 2dup eq? ] [ +eq+ ] } | 
					
						
							| 
									
										
										
										
											2008-05-02 03:51:38 -04:00
										 |  |  |             { [ 2dup [ class<= ] [ swap class<= ] 2bi and ] [ +eq+ ] } | 
					
						
							|  |  |  |             { [ 2dup class<= ] [ +lt+ ] } | 
					
						
							|  |  |  |             { [ 2dup swap class<= ] [ +gt+ ] } | 
					
						
							| 
									
										
										
										
											2008-04-27 23:44:42 -04:00
										 |  |  |             [ +eq+ ] | 
					
						
							| 
									
										
										
										
											2008-01-05 23:07:12 -05:00
										 |  |  |         } cond 2nip
 | 
					
						
							| 
									
										
										
										
											2008-05-02 03:51:38 -04:00
										 |  |  |     ] 2map [ +eq+ eq? not ] find nip +eq+ or ;
 | 
					
						
							| 
									
										
										
										
											2008-01-05 23:07:12 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | : sort-methods ( alist -- alist' )
 | 
					
						
							|  |  |  |     [ [ first ] bi@ classes< ] topological-sort ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! PART III: Creating dispatch quotation | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | : picker ( n -- quot )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         { 0 [ [ dup ] ] } | 
					
						
							|  |  |  |         { 1 [ [ over ] ] } | 
					
						
							|  |  |  |         { 2 [ [ pick ] ] } | 
					
						
							| 
									
										
										
										
											2009-08-17 14:52:15 -04:00
										 |  |  |         [ 1 - picker [ dip swap ] curry ] | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  |     } case ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-06 11:13:54 -05:00
										 |  |  | : (multi-predicate) ( class picker -- quot )
 | 
					
						
							|  |  |  |     swap "predicate" word-prop append ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-05 23:07:12 -05:00
										 |  |  | : multi-predicate ( classes -- quot )
 | 
					
						
							| 
									
										
										
										
											2010-01-14 10:10:13 -05:00
										 |  |  |     dup length iota <reversed>
 | 
					
						
							| 
									
										
										
										
											2008-01-06 11:13:54 -05:00
										 |  |  |     [ picker 2array ] 2map
 | 
					
						
							| 
									
										
										
										
											2008-04-26 00:17:08 -04:00
										 |  |  |     [ drop object eq? not ] assoc-filter
 | 
					
						
							| 
									
										
										
										
											2008-09-06 18:15:25 -04:00
										 |  |  |     [ [ t ] ] [ | 
					
						
							| 
									
										
										
										
											2008-01-06 11:13:54 -05:00
										 |  |  |         [ (multi-predicate) ] { } assoc>map
 | 
					
						
							|  |  |  |         unclip [ swap [ f ] \ if 3array append [ ] like ] reduce
 | 
					
						
							| 
									
										
										
										
											2008-09-06 18:15:25 -04:00
										 |  |  |     ] if-empty ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 11:13:54 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 20:12:48 -04:00
										 |  |  | : argument-count ( methods -- n )
 | 
					
						
							|  |  |  |     keys 0 [ length max ] reduce ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ERROR: no-method arguments generic ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : make-default-method ( methods generic -- quot )
 | 
					
						
							| 
									
										
										
										
											2008-12-18 00:36:13 -05:00
										 |  |  |     [ argument-count ] dip [ [ narray ] dip no-method ] 2curry ;
 | 
					
						
							| 
									
										
										
										
											2008-04-08 20:12:48 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | : multi-dispatch-quot ( methods generic -- quot )
 | 
					
						
							| 
									
										
										
										
											2008-04-08 20:12:48 -04:00
										 |  |  |     [ make-default-method ] | 
					
						
							| 
									
										
										
										
											2008-12-18 00:36:13 -05:00
										 |  |  |     [ drop [ [ multi-predicate ] dip ] assoc-map reverse ] | 
					
						
							| 
									
										
										
										
											2008-04-08 20:12:48 -04:00
										 |  |  |     2bi alist>quot ;
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Generic words | 
					
						
							|  |  |  | PREDICATE: generic < word | 
					
						
							|  |  |  |     "multi-methods" word-prop >boolean ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-06 11:13:54 -05:00
										 |  |  | : methods ( word -- alist )
 | 
					
						
							|  |  |  |     "multi-methods" word-prop >alist ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | : make-generic ( generic -- quot )
 | 
					
						
							| 
									
										
										
										
											2008-02-08 02:08:23 -05:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |         [ methods prepare-methods % sort-methods ] keep
 | 
					
						
							|  |  |  |         multi-dispatch-quot % | 
					
						
							| 
									
										
										
										
											2008-02-08 02:08:23 -05:00
										 |  |  |     ] [ ] make ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | : update-generic ( word -- )
 | 
					
						
							|  |  |  |     dup make-generic define ;
 | 
					
						
							| 
									
										
										
										
											2008-02-08 02:08:23 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | ! Methods | 
					
						
							| 
									
										
										
										
											2008-03-26 19:23:19 -04:00
										 |  |  | PREDICATE: method-body < word | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |     "multi-method-generic" word-prop >boolean ;
 | 
					
						
							| 
									
										
										
										
											2008-02-08 02:08:23 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: method-body stack-effect | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |     "multi-method-generic" word-prop stack-effect ;
 | 
					
						
							| 
									
										
										
										
											2008-02-08 02:08:23 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-06 21:09:20 -04:00
										 |  |  | M: method-body crossref? | 
					
						
							| 
									
										
										
										
											2008-06-11 03:58:38 -04:00
										 |  |  |     "forgotten" word-prop not ;
 | 
					
						
							| 
									
										
										
										
											2008-04-06 21:09:20 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | : method-word-name ( specializer generic -- string )
 | 
					
						
							| 
									
										
										
										
											2008-06-28 03:36:20 -04:00
										 |  |  |     [ name>> % "-" % unparse % ] "" make ;
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : method-word-props ( specializer generic -- assoc )
 | 
					
						
							| 
									
										
										
										
											2008-02-08 02:08:23 -05:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |         "multi-method-generic" set
 | 
					
						
							|  |  |  |         "multi-method-specializer" set
 | 
					
						
							|  |  |  |     ] H{ } make-assoc ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : <method> ( specializer generic -- word )
 | 
					
						
							|  |  |  |     [ method-word-props ] 2keep
 | 
					
						
							| 
									
										
										
										
											2008-02-08 02:08:23 -05:00
										 |  |  |     method-word-name f <word> | 
					
						
							| 
									
										
										
										
											2008-06-30 17:06:14 -04:00
										 |  |  |     swap >>props ;
 | 
					
						
							| 
									
										
										
										
											2008-02-08 02:08:23 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | : with-methods ( word quot -- )
 | 
					
						
							| 
									
										
										
										
											2008-12-18 00:36:13 -05:00
										 |  |  |     over [ | 
					
						
							|  |  |  |         [ "multi-methods" word-prop ] dip call
 | 
					
						
							|  |  |  |     ] dip update-generic ; inline
 | 
					
						
							| 
									
										
										
										
											2008-01-05 23:07:12 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | : reveal-method ( method classes generic -- )
 | 
					
						
							|  |  |  |     [ set-at ] with-methods ;
 | 
					
						
							| 
									
										
										
										
											2008-01-05 23:07:12 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | : method ( classes word -- method )
 | 
					
						
							|  |  |  |     "multi-methods" word-prop at ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 11:13:54 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | : create-method ( classes generic -- method )
 | 
					
						
							|  |  |  |     2dup method dup [ | 
					
						
							|  |  |  |         2nip
 | 
					
						
							|  |  |  |     ] [ | 
					
						
							|  |  |  |         drop [ <method> dup ] 2keep reveal-method | 
					
						
							| 
									
										
										
										
											2008-01-06 11:13:54 -05:00
										 |  |  |     ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : niceify-method ( seq -- seq )
 | 
					
						
							|  |  |  |     [ dup \ f eq? [ drop f ] when ] map ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 11:13:54 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: no-method error. | 
					
						
							|  |  |  |     "Type check error" print
 | 
					
						
							|  |  |  |     nl
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |     "Generic word " write dup generic>> pprint | 
					
						
							| 
									
										
										
										
											2008-01-06 11:13:54 -05:00
										 |  |  |     " does not have a method applicable to inputs:" print
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |     dup arguments>> short. | 
					
						
							| 
									
										
										
										
											2008-01-06 11:13:54 -05:00
										 |  |  |     nl
 | 
					
						
							|  |  |  |     "Inputs have signature:" print
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |     dup arguments>> [ class ] map niceify-method .
 | 
					
						
							| 
									
										
										
										
											2008-01-06 11:13:54 -05:00
										 |  |  |     nl
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |     "Available methods: " print
 | 
					
						
							| 
									
										
										
										
											2008-04-08 20:12:48 -04:00
										 |  |  |     generic>> methods canonicalize-specializers drop sort-methods | 
					
						
							|  |  |  |     keys [ niceify-method ] map stack. ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | : forget-method ( specializer generic -- )
 | 
					
						
							|  |  |  |     [ delete-at ] with-methods ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | : method>spec ( method -- spec )
 | 
					
						
							|  |  |  |     [ "multi-method-specializer" word-prop ] | 
					
						
							|  |  |  |     [ "multi-method-generic" word-prop ] bi prefix ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-23 18:12:41 -04:00
										 |  |  | : define-generic ( word effect -- )
 | 
					
						
							|  |  |  |     over set-stack-effect | 
					
						
							|  |  |  |     dup "multi-methods" word-prop [ drop ] [ | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |         [ H{ } clone "multi-methods" set-word-prop ] | 
					
						
							|  |  |  |         [ update-generic ] | 
					
						
							| 
									
										
										
										
											2008-04-08 20:12:48 -04:00
										 |  |  |         bi
 | 
					
						
							| 
									
										
										
										
											2008-02-08 02:08:23 -05:00
										 |  |  |     ] if ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | ! Syntax | 
					
						
							| 
									
										
										
										
											2009-03-23 18:12:41 -04:00
										 |  |  | SYNTAX: GENERIC: CREATE-WORD complete-effect define-generic ;
 | 
					
						
							| 
									
										
										
										
											2008-01-05 23:07:12 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | : parse-method ( -- quot classes generic )
 | 
					
						
							|  |  |  |     parse-definition [ 2 tail ] [ second ] [ first ] tri ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | : create-method-in ( specializer generic -- method )
 | 
					
						
							|  |  |  |     create-method dup save-location f set-word ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : CREATE-METHOD ( -- method )
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |     scan-word scan-object swap create-method-in ;
 | 
					
						
							| 
									
										
										
										
											2008-02-08 02:08:23 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : (METHOD:) ( -- method def ) CREATE-METHOD parse-definition ;
 | 
					
						
							| 
									
										
										
										
											2008-01-05 23:07:12 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-21 04:22:21 -04:00
										 |  |  | SYNTAX: METHOD: (METHOD:) define ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! For compatibility | 
					
						
							| 
									
										
										
										
											2009-03-21 04:22:21 -04:00
										 |  |  | SYNTAX: M: | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |     scan-word 1array scan-word create-method-in | 
					
						
							|  |  |  |     parse-definition | 
					
						
							| 
									
										
										
										
											2009-03-21 04:22:21 -04:00
										 |  |  |     define ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Definition protocol. We qualify core generics here | 
					
						
							|  |  |  | QUALIFIED: syntax | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | syntax:M: generic definer drop \ GENERIC: f ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  | syntax:M: generic definition drop f ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-26 19:23:19 -04:00
										 |  |  | PREDICATE: method-spec < array | 
					
						
							| 
									
										
										
										
											2008-12-18 00:36:13 -05:00
										 |  |  |     unclip generic? [ [ class? ] all? ] dip and ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | syntax:M: method-spec where | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |     dup unclip method [ ] [ first ] ?if where ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | syntax:M: method-spec set-where | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |     unclip method set-where ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | syntax:M: method-spec definer | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |     unclip method definer ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | syntax:M: method-spec definition | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |     unclip method definition ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | syntax:M: method-spec synopsis* | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |     unclip method synopsis* ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 10:22:26 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-14 19:11:32 -05:00
										 |  |  | syntax:M: method-spec forget* | 
					
						
							| 
									
										
										
										
											2008-04-08 19:51:56 -04:00
										 |  |  |     unclip method forget* ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | syntax:M: method-body definer | 
					
						
							|  |  |  |     drop \ METHOD: \ ; ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | syntax:M: method-body synopsis* | 
					
						
							|  |  |  |     dup definer. | 
					
						
							|  |  |  |     [ "multi-method-generic" word-prop pprint-word ] | 
					
						
							|  |  |  |     [ "multi-method-specializer" word-prop pprint* ] bi ;
 |