| 
									
										
										
										
											2010-01-20 10:23:20 -05:00
										 |  |  | ! Copyright (C) 2004, 2010 Slava Pestov. | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2016-03-21 13:17:29 -04:00
										 |  |  | USING: accessors assocs combinators definitions graphs kernel | 
					
						
							| 
									
										
										
										
											2011-11-22 21:49:18 -05:00
										 |  |  | make namespaces quotations sequences sets words words.symbol ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | IN: classes | 
					
						
							| 
									
										
										
										
											2008-03-24 20:52:21 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-31 06:08:18 -05:00
										 |  |  | ERROR: bad-inheritance class superclass ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | PREDICATE: class < word "class" word-prop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-22 18:58:20 -04:00
										 |  |  | PREDICATE: defining-class < word "defining-class" word-prop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-22 21:49:18 -05:00
										 |  |  | MIXIN: classoid | 
					
						
							|  |  |  | INSTANCE: class classoid | 
					
						
							| 
									
										
										
										
											2013-03-22 18:58:20 -04:00
										 |  |  | INSTANCE: defining-class classoid | 
					
						
							| 
									
										
										
										
											2011-11-22 21:49:18 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-02 03:51:38 -04:00
										 |  |  | SYMBOL: class<=-cache | 
					
						
							| 
									
										
										
										
											2008-03-24 20:52:21 -04:00
										 |  |  | SYMBOL: class-not-cache | 
					
						
							|  |  |  | SYMBOL: classes-intersect-cache | 
					
						
							|  |  |  | SYMBOL: class-and-cache | 
					
						
							|  |  |  | SYMBOL: class-or-cache | 
					
						
							| 
									
										
										
										
											2008-10-01 09:20:49 -04:00
										 |  |  | SYMBOL: next-method-quot-cache | 
					
						
							| 
									
										
										
										
											2008-03-24 20:52:21 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : init-caches ( -- )
 | 
					
						
							| 
									
										
										
										
											2016-03-29 20:14:42 -04:00
										 |  |  |     H{ } clone class<=-cache namespaces:set | 
					
						
							|  |  |  |     H{ } clone class-not-cache namespaces:set | 
					
						
							|  |  |  |     H{ } clone classes-intersect-cache namespaces:set | 
					
						
							|  |  |  |     H{ } clone class-and-cache namespaces:set | 
					
						
							|  |  |  |     H{ } clone class-or-cache namespaces:set | 
					
						
							|  |  |  |     H{ } clone next-method-quot-cache namespaces:set ;
 | 
					
						
							| 
									
										
										
										
											2008-03-24 20:52:21 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : reset-caches ( -- )
 | 
					
						
							| 
									
										
										
										
											2008-05-02 03:51:38 -04:00
										 |  |  |     class<=-cache get clear-assoc
 | 
					
						
							| 
									
										
										
										
											2008-03-24 20:52:21 -04:00
										 |  |  |     class-not-cache get clear-assoc
 | 
					
						
							|  |  |  |     classes-intersect-cache get clear-assoc
 | 
					
						
							|  |  |  |     class-and-cache get clear-assoc
 | 
					
						
							| 
									
										
										
										
											2008-10-01 09:20:49 -04:00
										 |  |  |     class-or-cache get clear-assoc
 | 
					
						
							|  |  |  |     next-method-quot-cache get clear-assoc ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: update-map | 
					
						
							| 
									
										
										
										
											2008-04-02 19:50:21 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-12 06:49:46 -04:00
										 |  |  | SYMBOL: implementors-map | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-22 17:47:52 -05:00
										 |  |  | GENERIC: class-name ( class -- string )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: class class-name name>> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | GENERIC: rank-class ( class -- n )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: reset-class ( class -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: class reset-class | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2013-03-22 18:58:20 -04:00
										 |  |  |         "defining-class" | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  |         "class" | 
					
						
							|  |  |  |         "metaclass" | 
					
						
							|  |  |  |         "superclass" | 
					
						
							|  |  |  |         "members" | 
					
						
							|  |  |  |         "participants" | 
					
						
							|  |  |  |         "predicate" | 
					
						
							| 
									
										
										
										
											2015-06-09 14:53:46 -04:00
										 |  |  |     } remove-word-props ;
 | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: word reset-class drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PRIVATE>
 | 
					
						
							| 
									
										
										
										
											2008-04-02 19:50:21 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-12 06:49:46 -04:00
										 |  |  | : classes ( -- seq ) implementors-map get keys ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-15 05:46:55 -05:00
										 |  |  | PREDICATE: predicate < word "predicating" word-prop >boolean ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-20 14:00:36 -05:00
										 |  |  | : create-predicate-word ( word -- predicate )
 | 
					
						
							| 
									
										
										
										
											2015-06-08 15:38:38 -04:00
										 |  |  |     [ name>> "?" append ] [ vocabulary>> ] bi create-word | 
					
						
							| 
									
										
										
										
											2010-02-15 05:46:55 -05:00
										 |  |  |     dup predicate? [ dup reset-generic ] unless ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-22 02:00:52 -05:00
										 |  |  | GENERIC: class-of ( object -- class )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: instance? ( object class -- ? ) flushable
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: predicate-def ( obj -- quot )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: word predicate-def | 
					
						
							|  |  |  |     "predicate" word-prop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: object predicate-def | 
					
						
							|  |  |  |     [ instance? ] curry ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-20 14:00:36 -05:00
										 |  |  | : predicate-word ( word -- predicate )
 | 
					
						
							| 
									
										
										
										
											2011-11-22 02:00:52 -05:00
										 |  |  |     predicate-def first ;
 | 
					
						
							| 
									
										
										
										
											2010-01-20 14:00:36 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-29 03:40:09 -05:00
										 |  |  | M: predicate flushable? drop t ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-13 01:40:18 -04:00
										 |  |  | M: predicate forget* | 
					
						
							|  |  |  |     [ call-next-method ] [ f "predicating" set-word-prop ] bi ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-05 19:32:02 -05:00
										 |  |  | M: predicate reset-word | 
					
						
							| 
									
										
										
										
											2009-03-13 01:40:18 -04:00
										 |  |  |     [ call-next-method ] [ f "predicating" set-word-prop ] bi ;
 | 
					
						
							| 
									
										
										
										
											2008-11-05 19:32:02 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-17 18:08:16 -05:00
										 |  |  | : define-predicate ( class quot -- )
 | 
					
						
							| 
									
										
										
										
											2011-10-18 16:18:42 -04:00
										 |  |  |     [ predicate-word ] dip ( object -- ? ) define-declared ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-20 03:46:33 -04:00
										 |  |  | : superclass-of ( class -- super )
 | 
					
						
							|  |  |  |     ! Output f for non-classes to work with algebra code | 
					
						
							| 
									
										
										
										
											2008-03-24 20:52:21 -04:00
										 |  |  |     dup class? [ "superclass" word-prop ] [ drop f ] if ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-20 03:46:33 -04:00
										 |  |  | : superclasses-of ( class -- supers )
 | 
					
						
							|  |  |  |     [ superclass-of ] follow reverse! ;
 | 
					
						
							| 
									
										
										
										
											2008-03-27 02:42:13 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | : superclass-of? ( class superclass -- ? )
 | 
					
						
							| 
									
										
										
										
											2015-07-20 03:46:33 -04:00
										 |  |  |     superclasses-of member-eq? ;
 | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-31 22:48:17 -04:00
										 |  |  | : subclass-of? ( class superclass -- ? )
 | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  |     swap superclass-of? ;
 | 
					
						
							| 
									
										
										
										
											2009-07-31 22:48:17 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-20 03:32:42 -04:00
										 |  |  | : class-members ( class -- seq )
 | 
					
						
							| 
									
										
										
										
											2015-09-08 19:15:10 -04:00
										 |  |  |     ! Output f for non-classes to work with algebra code | 
					
						
							| 
									
										
										
										
											2008-03-24 20:52:21 -04:00
										 |  |  |     dup class? [ "members" word-prop ] [ drop f ] if ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-20 03:32:42 -04:00
										 |  |  | : class-participants ( class -- seq )
 | 
					
						
							| 
									
										
										
										
											2015-09-08 19:15:10 -04:00
										 |  |  |     ! Output f for non-classes to work with algebra code | 
					
						
							| 
									
										
										
										
											2008-05-10 19:09:05 -04:00
										 |  |  |     dup class? [ "participants" word-prop ] [ drop f ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-05 11:01:39 -05:00
										 |  |  | GENERIC: contained-classes ( obj -- members )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: object contained-classes | 
					
						
							|  |  |  |     "members" word-prop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : all-contained-classes ( members -- members' )
 | 
					
						
							|  |  |  |     dup dup [ contained-classes ] map concat sift append
 | 
					
						
							|  |  |  |     2dup set= [ drop members ] [ nip all-contained-classes ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-12 06:49:46 -04:00
										 |  |  | GENERIC: implementors ( class/classes -- seq )
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | ! update-map | 
					
						
							|  |  |  | : class-uses ( class -- seq )
 | 
					
						
							| 
									
										
										
										
											2008-05-10 19:09:05 -04:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2015-07-20 03:32:42 -04:00
										 |  |  |         [ class-members % ] | 
					
						
							|  |  |  |         [ class-participants % ] | 
					
						
							| 
									
										
										
										
											2015-07-20 03:46:33 -04:00
										 |  |  |         [ superclass-of [ , ] when* ] | 
					
						
							| 
									
										
										
										
											2008-05-10 19:09:05 -04:00
										 |  |  |         tri
 | 
					
						
							|  |  |  |     ] { } make ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-09 02:23:39 -05:00
										 |  |  | : class-usage ( class -- seq )
 | 
					
						
							| 
									
										
										
										
											2015-07-20 03:46:33 -04:00
										 |  |  |     update-map get at members ;
 | 
					
						
							| 
									
										
										
										
											2008-07-04 02:32:11 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-09 02:04:31 -05:00
										 |  |  | : class-usages ( class -- seq )
 | 
					
						
							| 
									
										
										
										
											2015-07-20 03:46:33 -04:00
										 |  |  |     [ class-usage ] closure members ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-20 03:46:33 -04:00
										 |  |  | M: class implementors implementors-map get at members ;
 | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: sequence implementors [ implementors ] gather ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | : update-map+ ( class -- )
 | 
					
						
							| 
									
										
										
										
											2016-03-21 13:17:29 -04:00
										 |  |  |     dup class-uses update-map get add-vertex ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : update-map- ( class -- )
 | 
					
						
							| 
									
										
										
										
											2016-03-21 13:17:29 -04:00
										 |  |  |     dup class-uses update-map get remove-vertex ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-12 06:49:46 -04:00
										 |  |  | : implementors-map+ ( class -- )
 | 
					
						
							| 
									
										
										
										
											2013-03-08 13:29:50 -05:00
										 |  |  |     [ HS{ } clone ] dip implementors-map get set-at ;
 | 
					
						
							| 
									
										
										
										
											2008-06-12 06:49:46 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : implementors-map- ( class -- )
 | 
					
						
							|  |  |  |     implementors-map get delete-at ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-10 19:09:05 -04:00
										 |  |  | : make-class-props ( superclass members participants metaclass -- assoc )
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-05-10 19:09:05 -04:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2012-07-19 12:50:09 -04:00
										 |  |  |             [ dup [ bootstrap-word ] when "superclass" ,, ] | 
					
						
							|  |  |  |             [ [ bootstrap-word ] map "members" ,, ] | 
					
						
							|  |  |  |             [ [ bootstrap-word ] map "participants" ,, ] | 
					
						
							|  |  |  |             [ "metaclass" ,, ] | 
					
						
							| 
									
										
										
										
											2008-05-10 19:09:05 -04:00
										 |  |  |         } spread
 | 
					
						
							| 
									
										
										
										
											2012-07-19 12:50:09 -04:00
										 |  |  |     ] H{ } make ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | GENERIC: metaclass-changed ( use class -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : ?metaclass-changed ( class usages/f -- )
 | 
					
						
							| 
									
										
										
										
											2015-07-21 01:24:30 -04:00
										 |  |  |     [ [ metaclass-changed ] with each ] [ drop ] if* ;
 | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : check-metaclass ( class metaclass -- usages/f )
 | 
					
						
							|  |  |  |     over class? [ | 
					
						
							|  |  |  |         over "metaclass" word-prop eq?
 | 
					
						
							| 
									
										
										
										
											2013-03-09 02:06:16 -05:00
										 |  |  |         [ drop f ] [ class-usage ] if
 | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  |     ] [ 2drop f ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-22 21:16:31 -04:00
										 |  |  | : ?define-symbol ( word -- )
 | 
					
						
							|  |  |  |     dup deferred? [ define-symbol ] [ drop ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | : (define-class) ( word props -- )
 | 
					
						
							| 
									
										
										
										
											2010-01-20 10:23:20 -05:00
										 |  |  |     reset-caches | 
					
						
							| 
									
										
										
										
											2013-03-23 17:35:01 -04:00
										 |  |  |     2dup "metaclass" of check-metaclass | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  |     { | 
					
						
							|  |  |  |         [ 2drop update-map- ] | 
					
						
							|  |  |  |         [ 2drop dup class? [ reset-class ] [ implementors-map+ ] if ] | 
					
						
							|  |  |  |         [ 2drop ?define-symbol ] | 
					
						
							|  |  |  |         [ drop [ assoc-union ] curry change-props drop ] | 
					
						
							| 
									
										
										
										
											2010-01-20 10:23:20 -05:00
										 |  |  |         [ | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  |             2drop
 | 
					
						
							|  |  |  |             dup create-predicate-word | 
					
						
							|  |  |  |             [ 1quotation "predicate" set-word-prop ] | 
					
						
							|  |  |  |             [ swap "predicating" set-word-prop ] | 
					
						
							|  |  |  |             2bi
 | 
					
						
							|  |  |  |         ] | 
					
						
							|  |  |  |         [ 2drop t "class" set-word-prop ] | 
					
						
							| 
									
										
										
										
											2016-04-13 19:41:42 -04:00
										 |  |  |         [ 2drop f "defining-class" set-word-prop ] | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  |         [ 2drop update-map+ ] | 
					
						
							|  |  |  |         [ nip ?metaclass-changed ] | 
					
						
							|  |  |  |     } 3cleave ;
 | 
					
						
							| 
									
										
										
										
											2008-03-28 23:59:48 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-29 03:46:29 -04:00
										 |  |  | GENERIC: update-class ( class -- )
 | 
					
						
							| 
									
										
										
										
											2008-01-31 01:49:18 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-29 03:46:29 -04:00
										 |  |  | M: class update-class drop ;
 | 
					
						
							| 
									
										
										
										
											2008-01-31 01:49:18 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-11 18:40:33 -04:00
										 |  |  | GENERIC: update-methods ( class seq -- )
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-02 03:44:10 -04:00
										 |  |  | : update-classes ( class -- )
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  |     dup class-usages | 
					
						
							| 
									
										
										
										
											2008-06-11 18:40:33 -04:00
										 |  |  |     [ nip [ update-class ] each ] [ update-methods ] 2bi ;
 | 
					
						
							| 
									
										
										
										
											2008-04-02 03:44:10 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-15 13:29:06 -05:00
										 |  |  | : check-inheritance ( subclass superclass -- subclass superclass )
 | 
					
						
							|  |  |  |     2dup superclass-of? [ bad-inheritance ] when ;
 | 
					
						
							| 
									
										
										
										
											2010-01-31 06:08:18 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-10 19:09:05 -04:00
										 |  |  | : define-class ( word superclass members participants metaclass -- )
 | 
					
						
							| 
									
										
										
										
											2020-01-15 13:29:06 -05:00
										 |  |  |     [ check-inheritance ] 3dip
 | 
					
						
							| 
									
										
										
										
											2010-01-20 10:23:20 -05:00
										 |  |  |     make-class-props [ (define-class) ] [ drop changed-definition ] 2bi ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-11 21:46:53 -04:00
										 |  |  | : forget-predicate ( class -- )
 | 
					
						
							| 
									
										
										
										
											2011-11-22 02:00:52 -05:00
										 |  |  |     dup predicate-def | 
					
						
							| 
									
										
										
										
											2008-06-11 21:46:53 -04:00
										 |  |  |     dup length 1 = [ | 
					
						
							|  |  |  |         first
 | 
					
						
							| 
									
										
										
										
											2009-01-23 19:20:47 -05:00
										 |  |  |         [ nip ] [ "predicating" word-prop = ] 2bi
 | 
					
						
							| 
									
										
										
										
											2008-06-11 21:46:53 -04:00
										 |  |  |         [ forget ] [ drop ] if
 | 
					
						
							|  |  |  |     ] [ 2drop ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-06 05:16:39 -04:00
										 |  |  | GENERIC: forget-methods ( class -- )
 | 
					
						
							| 
									
										
										
										
											2008-06-12 06:49:46 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | PRIVATE>
 | 
					
						
							| 
									
										
										
										
											2008-07-04 02:32:11 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-12 06:49:46 -04:00
										 |  |  | : forget-class ( class -- )
 | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  |     dup f check-metaclass { | 
					
						
							|  |  |  |         [ drop forget-predicate ] | 
					
						
							|  |  |  |         [ drop forget-methods ] | 
					
						
							|  |  |  |         [ drop implementors-map- ] | 
					
						
							|  |  |  |         [ drop update-map- ] | 
					
						
							|  |  |  |         [ drop reset-class ] | 
					
						
							|  |  |  |         [ 2drop reset-caches ] | 
					
						
							|  |  |  |         [ ?metaclass-changed ] | 
					
						
							|  |  |  |     } 2cleave ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: class metaclass-changed | 
					
						
							|  |  |  |     swap class? [ drop ] [ forget-class ] if ;
 | 
					
						
							| 
									
										
										
										
											2008-06-12 06:49:46 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: class forget* ( class -- )
 | 
					
						
							| 
									
										
										
										
											2008-06-29 03:12:44 -04:00
										 |  |  |     [ call-next-method ] [ forget-class ] bi ;
 | 
					
						
							| 
									
										
										
										
											2020-01-15 13:29:06 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ERROR: not-an-instance obj class ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : check-instance ( obj class -- obj )
 | 
					
						
							|  |  |  |     [ dupd instance? ] keep [ not-an-instance ] curry unless ; inline
 |