| 
									
										
										
										
											2009-03-22 18:47:48 -04:00
										 |  |  | ! Copyright (C) 2004, 2009 Slava Pestov. | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2009-02-05 19:51:50 -05:00
										 |  |  | USING: accessors arrays assocs generic hashtables kernel kernel.private | 
					
						
							| 
									
										
										
										
											2008-11-17 14:34:37 -05:00
										 |  |  | math namespaces parser sequences strings words libc fry | 
					
						
							| 
									
										
										
										
											2009-01-28 02:58:57 -05:00
										 |  |  | alien.c-types alien.structs.fields cpu.architecture math.order | 
					
						
							| 
									
										
										
										
											2009-02-12 10:20:32 -05:00
										 |  |  | quotations byte-arrays ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | IN: alien.structs | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-28 02:58:57 -05:00
										 |  |  | TUPLE: struct-type | 
					
						
							|  |  |  | size | 
					
						
							|  |  |  | align
 | 
					
						
							|  |  |  | fields | 
					
						
							|  |  |  | { boxer-quot callable } | 
					
						
							|  |  |  | { unboxer-quot callable } | 
					
						
							|  |  |  | { getter callable } | 
					
						
							| 
									
										
										
										
											2009-02-12 07:25:07 -05:00
										 |  |  | { setter callable } | 
					
						
							| 
									
										
										
										
											2009-02-12 09:10:21 -05:00
										 |  |  | return-in-registers? ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: struct-type c-type ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-31 08:45:33 -04:00
										 |  |  | M: struct-type heap-size size>> ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-12 10:20:32 -05:00
										 |  |  | M: struct-type c-type-class drop byte-array ;
 | 
					
						
							| 
									
										
										
										
											2008-11-29 05:59:29 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-31 08:45:33 -04:00
										 |  |  | M: struct-type c-type-align align>> ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: struct-type c-type-stack-align? drop f ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-06 05:02:00 -05:00
										 |  |  | M: struct-type c-type-boxer-quot boxer-quot>> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: struct-type c-type-unboxer-quot unboxer-quot>> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-17 14:34:37 -05:00
										 |  |  | : if-value-struct ( ctype true false -- )
 | 
					
						
							|  |  |  |     [ dup value-struct? ] 2dip '[ drop "void*" @ ] if ; inline
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-17 14:34:37 -05:00
										 |  |  | M: struct-type unbox-parameter | 
					
						
							|  |  |  |     [ %unbox-large-struct ] [ unbox-parameter ] if-value-struct ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: struct-type box-parameter | 
					
						
							| 
									
										
										
										
											2008-11-17 14:34:37 -05:00
										 |  |  |     [ %box-large-struct ] [ box-parameter ] if-value-struct ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : if-small-struct ( c-type true false -- ? )
 | 
					
						
							| 
									
										
										
										
											2009-02-12 07:25:07 -05:00
										 |  |  |     [ dup return-struct-in-registers? ] 2dip '[ f swap @ ] if ; inline
 | 
					
						
							| 
									
										
										
										
											2008-11-17 14:34:37 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: struct-type unbox-return | 
					
						
							|  |  |  |     [ %unbox-small-struct ] [ %unbox-large-struct ] if-small-struct ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: struct-type box-return | 
					
						
							| 
									
										
										
										
											2008-11-17 14:34:37 -05:00
										 |  |  |     [ %box-small-struct ] [ %box-large-struct ] if-small-struct ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: struct-type stack-size | 
					
						
							| 
									
										
										
										
											2008-11-17 14:34:37 -05:00
										 |  |  |     [ heap-size ] [ stack-size ] if-value-struct ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : c-struct? ( type -- ? ) (c-type) struct-type? ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-14 21:18:16 -05:00
										 |  |  | : (define-struct) ( name size align fields -- )
 | 
					
						
							| 
									
										
										
										
											2008-11-29 14:37:38 -05:00
										 |  |  |     [ [ align ] keep ] dip
 | 
					
						
							| 
									
										
										
										
											2009-02-06 05:02:00 -05:00
										 |  |  |     struct-type new
 | 
					
						
							| 
									
										
										
										
											2009-03-22 18:47:48 -04:00
										 |  |  |         swap >>fields | 
					
						
							|  |  |  |         swap >>align | 
					
						
							|  |  |  |         swap >>size | 
					
						
							|  |  |  |         swap typedef ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-02 01:24:00 -05:00
										 |  |  | : make-fields ( name vocab fields -- fields )
 | 
					
						
							| 
									
										
										
										
											2008-11-17 14:34:37 -05:00
										 |  |  |     [ first2 <field-spec> ] with with map ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : compute-struct-align ( types -- n )
 | 
					
						
							| 
									
										
										
										
											2009-02-03 01:27:34 -05:00
										 |  |  |     [ c-type-align ] [ max ] map-reduce ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : define-struct ( name vocab fields -- )
 | 
					
						
							| 
									
										
										
										
											2009-03-22 18:47:48 -04:00
										 |  |  |     [ 2drop ] [ make-fields ] 3bi
 | 
					
						
							|  |  |  |     [ struct-offsets ] keep
 | 
					
						
							|  |  |  |     [ [ type>> ] map compute-struct-align ] keep
 | 
					
						
							|  |  |  |     [ (define-struct) ] keep
 | 
					
						
							|  |  |  |     [ define-field ] each ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-02 01:24:00 -05:00
										 |  |  | : define-union ( name members -- )
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     [ expand-constants ] map
 | 
					
						
							| 
									
										
										
										
											2009-02-03 01:27:34 -05:00
										 |  |  |     [ [ heap-size ] [ max ] map-reduce ] keep
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     compute-struct-align f (define-struct) ;
 | 
					
						
							| 
									
										
										
										
											2009-02-05 19:51:50 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : offset-of ( field struct -- offset )
 | 
					
						
							|  |  |  |     c-types get at fields>>  | 
					
						
							|  |  |  |     [ name>> = ] with find nip offset>> ;
 |