56 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Factor
		
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Factor
		
	
	
| USING: alien alien.syntax alien.parser combinators
 | |
| kernel parser sequences system words namespaces hashtables init
 | |
| math arrays assocs continuations lexer fry locals vocabs.parser ;
 | |
| IN: opengl.gl.extensions
 | |
| 
 | |
| ERROR: unknown-gl-platform ;
 | |
| << {
 | |
|     { [ os windows? ] [ "opengl.gl.windows" ] }
 | |
|     { [ os macosx? ]  [ "opengl.gl.macosx" ] }
 | |
|     { [ os unix? ] [ "opengl.gl.gtk" ] }
 | |
|     [ unknown-gl-platform ]
 | |
| } cond use-vocab >>
 | |
| 
 | |
| SYMBOL: +gl-function-counter+
 | |
| SYMBOL: +gl-function-pointers+
 | |
| 
 | |
| : reset-gl-function-number-counter ( -- )
 | |
|     0 +gl-function-counter+ set-global ;
 | |
| : reset-gl-function-pointers ( -- )
 | |
|     100 <hashtable> +gl-function-pointers+ set-global ;
 | |
|     
 | |
| [ reset-gl-function-pointers ] "opengl.gl" add-startup-hook
 | |
| reset-gl-function-pointers
 | |
| reset-gl-function-number-counter
 | |
| 
 | |
| : gl-function-counter ( -- n )
 | |
|     +gl-function-counter+ get-global
 | |
|     dup 1 + +gl-function-counter+ set-global ;
 | |
| 
 | |
| : gl-function-pointer ( names n -- funptr )
 | |
|     gl-function-context 2array dup +gl-function-pointers+ get-global at
 | |
|     [ 2nip ] [
 | |
|         [
 | |
|             [ gl-function-address ] map [ ] find nip
 | |
|             dup [ "OpenGL function not available" throw ] unless
 | |
|             dup
 | |
|         ] dip
 | |
|         +gl-function-pointers+ get-global set-at
 | |
|     ] if* ;
 | |
| 
 | |
| : indirect-quot ( function-ptr-quot return types abi -- quot )
 | |
|     '[ @  _ _ _ alien-indirect ] ;
 | |
| 
 | |
| :: define-indirect ( abi return function-name function-ptr-quot types names -- )
 | |
|     function-name create-in dup reset-generic
 | |
|     function-ptr-quot return types abi indirect-quot
 | |
|     names return function-effect
 | |
|     define-declared ;
 | |
| 
 | |
| SYNTAX: GL-FUNCTION:
 | |
|     gl-function-calling-convention
 | |
|     scan-function-name
 | |
|     "{" expect "}" parse-tokens over suffix
 | |
|     gl-function-counter '[ _ _ gl-function-pointer ]
 | |
|     ";" scan-c-args define-indirect ;
 |