| 
									
										
										
										
											2010-12-26 03:08:57 -05:00
										 |  |  | USING: alien alien.c-types alien.data alien.accessors | 
					
						
							|  |  |  | alien.parser effects kernel windows.ole32 parser lexer splitting | 
					
						
							|  |  |  | grouping sequences namespaces assocs quotations generalizations | 
					
						
							| 
									
										
										
										
											2009-09-27 19:19:53 -04:00
										 |  |  | accessors words macros alien.syntax fry arrays layouts math | 
					
						
							| 
									
										
										
										
											2010-02-28 22:30:15 -05:00
										 |  |  | classes.struct windows.kernel32 locals ;
 | 
					
						
							|  |  |  | FROM: alien.parser.private => parse-pointers return-type-name ;
 | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  | IN: windows.com.syntax | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-19 14:42:46 -04:00
										 |  |  | MACRO: com-invoke ( n return parameters -- quot )
 | 
					
						
							| 
									
										
										
										
											2008-12-03 07:52:16 -05:00
										 |  |  |     [ 2nip length ] 3keep
 | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  |     '[ | 
					
						
							| 
									
										
										
										
											2010-10-25 14:22:50 -04:00
										 |  |  |         _ npick void* deref _ cell * alien-cell _ _ | 
					
						
							| 
									
										
										
										
											2010-03-31 22:29:04 -04:00
										 |  |  |         stdcall alien-indirect | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  |     ] ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-27 19:19:53 -04:00
										 |  |  | TUPLE: com-interface-definition word parent iid functions ;
 | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  | C: <com-interface-definition> com-interface-definition | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-28 22:30:15 -05:00
										 |  |  | TUPLE: com-function-definition return name parameter-types parameter-names ;
 | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  | C: <com-function-definition> com-function-definition | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: +com-interface-definitions+ | 
					
						
							|  |  |  | +com-interface-definitions+ get-global
 | 
					
						
							|  |  |  | [ H{ } +com-interface-definitions+ set-global ] | 
					
						
							|  |  |  | unless
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-27 19:19:53 -04:00
										 |  |  | ERROR: no-com-interface interface ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  | : find-com-interface-definition ( name -- definition )
 | 
					
						
							| 
									
										
										
										
											2009-09-27 19:19:53 -04:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  |         dup +com-interface-definitions+ get-global at*
 | 
					
						
							| 
									
										
										
										
											2009-09-27 19:19:53 -04:00
										 |  |  |         [ nip ] [ drop no-com-interface ] if
 | 
					
						
							|  |  |  |     ] [ f ] if* ;
 | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : save-com-interface-definition ( definition -- )
 | 
					
						
							| 
									
										
										
										
											2009-09-27 19:19:53 -04:00
										 |  |  |     dup word>> +com-interface-definitions+ get-global set-at ;
 | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-28 22:30:15 -05:00
										 |  |  | : (parse-com-function) ( return name -- definition )
 | 
					
						
							| 
									
										
										
										
											2015-07-19 19:24:47 -04:00
										 |  |  |     scan-c-args | 
					
						
							| 
									
										
										
										
											2010-02-28 22:30:15 -05:00
										 |  |  |     [ pointer: void prefix ] [ "this" prefix ] bi*
 | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  |     <com-function-definition> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-28 22:30:15 -05:00
										 |  |  | :: (parse-com-functions) ( functions -- )
 | 
					
						
							| 
									
										
										
										
											2011-10-01 19:42:37 -04:00
										 |  |  |     scan-token dup ";" = [ drop ] [ | 
					
						
							|  |  |  |         parse-c-type scan-token parse-pointers | 
					
						
							| 
									
										
										
										
											2010-02-28 22:30:15 -05:00
										 |  |  |         (parse-com-function) functions push
 | 
					
						
							|  |  |  |         functions (parse-com-functions) | 
					
						
							|  |  |  |     ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  | : parse-com-functions ( -- functions )
 | 
					
						
							| 
									
										
										
										
											2010-02-28 22:30:15 -05:00
										 |  |  |     V{ } clone [ (parse-com-functions) ] keep >array ;
 | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : (iid-word) ( definition -- word )
 | 
					
						
							| 
									
										
										
										
											2015-06-08 15:38:38 -04:00
										 |  |  |     word>> name>> "-iid" append create-word-in ;
 | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : (function-word) ( function interface -- word )
 | 
					
						
							| 
									
										
										
										
											2009-09-27 19:19:53 -04:00
										 |  |  |     swap [ word>> name>> "::" ] [ name>> ] bi*
 | 
					
						
							| 
									
										
										
										
											2015-06-08 15:38:38 -04:00
										 |  |  |     3append create-word-in ;
 | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : family-tree ( definition -- definitions )
 | 
					
						
							|  |  |  |     dup parent>> [ family-tree ] [ { } ] if*
 | 
					
						
							|  |  |  |     swap suffix ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : family-tree-functions ( definition -- functions )
 | 
					
						
							|  |  |  |     dup parent>> [ family-tree-functions ] [ { } ] if*
 | 
					
						
							|  |  |  |     swap functions>> append ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-28 22:30:15 -05:00
										 |  |  | :: (define-word-for-function) ( function interface n -- )
 | 
					
						
							|  |  |  |     function interface (function-word) | 
					
						
							|  |  |  |     n function [ return>> ] [ parameter-types>> ] bi '[ _ _ _ com-invoke ] | 
					
						
							|  |  |  |     function [ parameter-names>> ] [ return>> ] bi function-effect | 
					
						
							| 
									
										
										
										
											2008-06-09 23:14:18 -04:00
										 |  |  |     define-declared ;
 | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : define-words-for-com-interface ( definition -- )
 | 
					
						
							| 
									
										
										
										
											2011-10-18 16:18:42 -04:00
										 |  |  |     [ [ (iid-word) ] [ iid>> 1quotation ] bi ( -- iid ) define-declared ] | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  |     [ | 
					
						
							|  |  |  |         dup family-tree-functions | 
					
						
							|  |  |  |         [ (define-word-for-function) ] with each-index
 | 
					
						
							| 
									
										
										
										
											2010-02-25 19:39:30 -05:00
										 |  |  |     ] bi ;
 | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-21 02:27:50 -04:00
										 |  |  | SYNTAX: COM-INTERFACE: | 
					
						
							| 
									
										
										
										
											2009-09-27 19:19:53 -04:00
										 |  |  |     CREATE-C-TYPE | 
					
						
							| 
									
										
										
										
											2010-02-25 19:39:30 -05:00
										 |  |  |     void* over typedef | 
					
						
							| 
									
										
										
										
											2009-09-27 19:19:53 -04:00
										 |  |  |     scan-object find-com-interface-definition | 
					
						
							| 
									
										
										
										
											2011-09-27 16:20:07 -04:00
										 |  |  |     scan-token string>guid | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  |     parse-com-functions | 
					
						
							|  |  |  |     <com-interface-definition> | 
					
						
							|  |  |  |     dup save-com-interface-definition | 
					
						
							| 
									
										
										
										
											2009-03-21 02:27:50 -04:00
										 |  |  |     define-words-for-com-interface ;
 | 
					
						
							| 
									
										
										
										
											2008-04-28 17:30:11 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-27 16:20:07 -04:00
										 |  |  | SYNTAX: GUID: scan-token string>guid suffix! ;
 | 
					
						
							| 
									
										
										
										
											2009-08-29 20:18:39 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-18 01:13:37 -04:00
										 |  |  | USE: vocabs.loader | 
					
						
							| 
									
										
										
										
											2009-09-04 23:00:23 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-18 15:29:24 -04:00
										 |  |  | { "windows.com" "prettyprint" } "windows.com.prettyprint" require-when |