Sketch out windows.com.syntax
							parent
							
								
									6f89d7921b
								
							
						
					
					
						commit
						53ccdc3954
					
				|  | @ -1,22 +1,81 @@ | |||
| USING: alien alien.c-types kernel windows windows.ole32 | ||||
| combinators.lib parser splitting sequences.lib ; | ||||
| USING: alien alien.c-types kernel windows.ole32 | ||||
| combinators.lib parser splitting sequences.lib | ||||
| sequences namespaces new-slots combinators.cleave | ||||
| assocs quotations shuffle ; | ||||
| IN: windows.com.syntax | ||||
| 
 | ||||
| <PRIVATE | ||||
| 
 | ||||
| : vtbl ( interface -- vtbl ) | ||||
|     *void* ; inline | ||||
| : com-invoke ( ... interface n funcptr return parameters -- ) | ||||
| : com-invoke ( ... interface-ptr n return parameters -- ) | ||||
|     "stdcall" [ | ||||
|         swap vtbl swap void*-nth | ||||
|     ] 4 ndip alien-indirect ; | ||||
|         [ *void* ] dip void*-nth | ||||
|     ] 3 ndip alien-indirect ; inline | ||||
| 
 | ||||
| TUPLE: com-interface-definition name parent iid functions ; | ||||
| C: <com-interface-definition> com-interface-definition | ||||
| 
 | ||||
| TUPLE: com-function-definition name return parameters ; | ||||
| C: <com-function-definition> com-function-definition | ||||
| 
 | ||||
| SYMBOL: +com-interface-definitions+ | ||||
| H{ } +com-interface-definitions+ set-global | ||||
| 
 | ||||
| : find-com-interface-definition ( name -- definition ) | ||||
|     dup "f" = [ drop f ] [ | ||||
|         dup +com-interface-definitions+ get-global at* | ||||
|         [ nip ] | ||||
|         [ swap " COM interface hasn't been defined" append throw ] | ||||
|         if | ||||
|     ] if ; | ||||
| 
 | ||||
| : save-com-interface-definition ( definition -- ) | ||||
|     dup name>> +com-interface-definitions+ get-global set-at ; | ||||
| 
 | ||||
| : (parse-com-function) ( tokens -- definition ) | ||||
|     [ second ] | ||||
|     [ first ] | ||||
|     [ 3 tail 2 group [ first ] map "void*" add* ] | ||||
|     tri | ||||
|     <com-function-definition> ; | ||||
| 
 | ||||
| : parse-com-functions ( -- functions ) | ||||
|     ";" parse-tokens { ")" } split | ||||
|     [ (parse-com-function) ] map ; | ||||
| 
 | ||||
| : (iid-word) ( definition -- word ) | ||||
|     name>> "-iid" append create-in ; | ||||
| 
 | ||||
| : (function-word) ( function interface -- word ) | ||||
|     name>> "::" rot name>> 3append create-in ; | ||||
| 
 | ||||
| : all-functions ( definition -- functions ) | ||||
|     dup parent>> [ all-functions ] [ { } ] if* | ||||
|     swap functions>> append ; | ||||
| 
 | ||||
| : (define-word-for-function) ( function interface n -- ) | ||||
|     -rot [ (function-word) swap ] 2keep drop | ||||
|     { return>> parameters>> } get-slots | ||||
|     [ [ com-invoke ] 3curry ] keep | ||||
|     length [ npick ] curry swap compose | ||||
|     define ; | ||||
| 
 | ||||
| : define-words-for-com-interface ( definition -- ) | ||||
|     [ [ (iid-word) ] [ iid>> 1quotation ] bi define ] | ||||
|     [ | ||||
|         dup all-functions | ||||
|         [ (define-word-for-function) ] with each-index | ||||
|     ] | ||||
|     bi ; | ||||
| 
 | ||||
| PRIVATE> | ||||
| 
 | ||||
| : COM-INTERFACE: | ||||
|     scan | ||||
|     parse-inheritance | ||||
|     ";" parse-tokens { ")" } split | ||||
|     [  | ||||
|     scan find-com-interface-definition | ||||
|     scan string>guid | ||||
|     parse-com-functions | ||||
|     <com-interface-definition> | ||||
|     dup save-com-interface-definition | ||||
|     define-words-for-com-interface | ||||
|     ; parsing | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue