| 
									
										
										
										
											2008-02-21 02:26:44 -05:00
										 |  |  | ! Copyright (C) 2007, 2008 Slava Pestov. | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							|  |  |  | USING: assocs hashtables kernel sequences generic words | 
					
						
							| 
									
										
										
										
											2008-07-01 17:33:45 -04:00
										 |  |  | arrays classes slots slots.private classes.tuple | 
					
						
							|  |  |  | classes.tuple.private math vectors quotations accessors | 
					
						
							|  |  |  | combinators ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | IN: mirrors | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-01 17:16:02 -04:00
										 |  |  | TUPLE: mirror { object read-only } ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-01 17:16:02 -04:00
										 |  |  | C: <mirror> mirror | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : object-slots ( mirror -- slots ) object>> class all-slots ; inline
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: mirror at* | 
					
						
							| 
									
										
										
										
											2008-07-01 17:16:02 -04:00
										 |  |  |     [ nip object>> ] [ object-slots slot-named ] 2bi
 | 
					
						
							| 
									
										
										
										
											2008-04-24 03:48:48 -04:00
										 |  |  |     dup [ offset>> slot t ] [ 2drop f f ] if ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-29 02:59:25 -04:00
										 |  |  | ERROR: no-such-slot slot ;
 | 
					
						
							|  |  |  | ERROR: read-only-slot slot ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-29 03:12:44 -04:00
										 |  |  | : check-set-slot ( val slot -- val offset )
 | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-08-29 02:59:25 -04:00
										 |  |  |         { [ dup not ] [ no-such-slot ] } | 
					
						
							|  |  |  |         { [ dup read-only>> ] [ read-only-slot ] } | 
					
						
							| 
									
										
										
										
											2008-06-30 02:44:58 -04:00
										 |  |  |         { [ 2dup class>> instance? not ] [ class>> bad-slot-value ] } | 
					
						
							| 
									
										
										
										
											2008-06-29 03:12:44 -04:00
										 |  |  |         [ offset>> ] | 
					
						
							|  |  |  |     } cond ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | M: mirror set-at ( val key mirror -- )
 | 
					
						
							| 
									
										
										
										
											2008-07-01 17:16:02 -04:00
										 |  |  |     [ object-slots slot-named check-set-slot ] [ object>> ] bi
 | 
					
						
							| 
									
										
										
										
											2008-06-29 03:12:44 -04:00
										 |  |  |     swap set-slot ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: mirror delete-at ( key mirror -- )
 | 
					
						
							| 
									
										
										
										
											2008-12-22 06:41:01 -05:00
										 |  |  |     [ f ] 2dip set-at ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-29 03:12:44 -04:00
										 |  |  | M: mirror clear-assoc ( mirror -- )
 | 
					
						
							| 
									
										
										
										
											2008-07-01 17:16:02 -04:00
										 |  |  |     [ object>> ] [ object-slots ] bi [ | 
					
						
							| 
									
										
										
										
											2008-06-29 03:12:44 -04:00
										 |  |  |         [ initial>> ] [ offset>> ] bi swapd set-slot | 
					
						
							|  |  |  |     ] with each ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | M: mirror >alist ( mirror -- alist )
 | 
					
						
							| 
									
										
										
										
											2008-07-01 17:16:02 -04:00
										 |  |  |     [ object-slots [ [ name>> ] map ] [ [ offset>> ] map ] bi ] | 
					
						
							|  |  |  |     [ object>> [ swap slot ] curry ] bi
 | 
					
						
							|  |  |  |     map zip ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-06 03:52:54 -05:00
										 |  |  | M: mirror assoc-size object>> layout-of second ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | INSTANCE: mirror assoc | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: make-mirror ( obj -- assoc )
 | 
					
						
							| 
									
										
										
										
											2008-06-27 01:48:05 -04:00
										 |  |  | M: hashtable make-mirror ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | M: integer make-mirror drop f ;
 | 
					
						
							|  |  |  | M: array make-mirror <enum> ;
 | 
					
						
							|  |  |  | M: vector make-mirror <enum> ;
 | 
					
						
							|  |  |  | M: quotation make-mirror <enum> ;
 | 
					
						
							|  |  |  | M: object make-mirror <mirror> ;
 |