| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  | ! (c)2009 Joe Groff bsd license | 
					
						
							| 
									
										
										
										
											2009-09-17 23:07:21 -04:00
										 |  |  | USING: accessors alien alien.c-types alien.data alien.strings | 
					
						
							|  |  |  | arrays assocs byte-arrays classes.mixin classes.parser | 
					
						
							|  |  |  | classes.singleton classes.struct combinators combinators.short-circuit | 
					
						
							| 
									
										
										
										
											2010-02-17 14:26:32 -05:00
										 |  |  | definitions destructors fry generic.parser gpu gpu.buffers gpu.private | 
					
						
							|  |  |  | gpu.state hashtables images io.encodings.ascii io.files io.pathnames | 
					
						
							|  |  |  | kernel lexer literals locals math math.parser memoize multiline namespaces | 
					
						
							| 
									
										
										
										
											2009-09-17 23:07:21 -04:00
										 |  |  | opengl opengl.gl opengl.shaders parser quotations sequences | 
					
						
							| 
									
										
										
										
											2009-09-09 23:33:34 -04:00
										 |  |  | specialized-arrays splitting strings tr ui.gadgets.worlds | 
					
						
							|  |  |  | variants vectors vocabs vocabs.loader vocabs.parser words | 
					
						
							| 
									
										
										
										
											2010-04-28 18:48:47 -04:00
										 |  |  | words.constant math.floats.half typed ;
 | 
					
						
							| 
									
										
										
										
											2009-09-28 16:32:01 -04:00
										 |  |  | QUALIFIED-WITH: alien.c-types c | 
					
						
							| 
									
										
										
										
											2009-09-09 23:33:34 -04:00
										 |  |  | SPECIALIZED-ARRAY: int | 
					
						
							|  |  |  | SPECIALIZED-ARRAY: void* | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  | IN: gpu.shaders | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | VARIANT: shader-kind | 
					
						
							| 
									
										
										
										
											2010-03-23 05:11:57 -04:00
										 |  |  |     vertex-shader fragment-shader geometry-shader ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | VARIANT: geometry-shader-input | 
					
						
							|  |  |  |     points-input | 
					
						
							|  |  |  |     lines-input | 
					
						
							|  |  |  |     lines-with-adjacency-input | 
					
						
							|  |  |  |     triangles-input | 
					
						
							|  |  |  |     triangles-with-adjacency-input ;
 | 
					
						
							|  |  |  | VARIANT: geometry-shader-output | 
					
						
							|  |  |  |     points-output | 
					
						
							|  |  |  |     line-strips-output | 
					
						
							|  |  |  |     triangle-strips-output ;
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-25 16:50:38 -04:00
										 |  |  | ERROR: too-many-feedback-formats-error formats ;
 | 
					
						
							| 
									
										
										
										
											2009-07-25 22:19:56 -04:00
										 |  |  | ERROR: invalid-link-feedback-format-error format ;
 | 
					
						
							| 
									
										
										
										
											2009-07-27 14:16:41 -04:00
										 |  |  | ERROR: inaccurate-feedback-attribute-error attribute ;
 | 
					
						
							| 
									
										
										
										
											2009-07-25 16:50:38 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  | TUPLE: vertex-attribute | 
					
						
							| 
									
										
										
										
											2012-05-03 22:17:41 -04:00
										 |  |  |     { name            maybe{ string } read-only initial: f } | 
					
						
							|  |  |  |     { component-type  component-type  read-only initial: float-components } | 
					
						
							|  |  |  |     { dim             integer         read-only initial: 4 } | 
					
						
							|  |  |  |     { normalize?      boolean         read-only initial: f } ;
 | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | MIXIN: vertex-format | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  | TUPLE: shader | 
					
						
							|  |  |  |     { name word read-only initial: t } | 
					
						
							|  |  |  |     { kind shader-kind read-only } | 
					
						
							|  |  |  |     { filename read-only } | 
					
						
							|  |  |  |     { line integer read-only } | 
					
						
							|  |  |  |     { source string } | 
					
						
							|  |  |  |     { instances hashtable read-only } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TUPLE: program | 
					
						
							|  |  |  |     { name word read-only initial: t } | 
					
						
							|  |  |  |     { filename read-only } | 
					
						
							|  |  |  |     { line integer read-only } | 
					
						
							|  |  |  |     { shaders array read-only } | 
					
						
							| 
									
										
										
										
											2010-02-10 16:03:34 -05:00
										 |  |  |     { vertex-formats array read-only } | 
					
						
							| 
									
										
										
										
											2012-05-03 22:17:41 -04:00
										 |  |  |     { feedback-format maybe{ vertex-format } read-only } | 
					
						
							| 
									
										
										
										
											2010-03-23 05:11:57 -04:00
										 |  |  |     { geometry-shader-parameters array read-only } | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  |     { instances hashtable read-only } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TUPLE: shader-instance < gpu-object | 
					
						
							|  |  |  |     { shader shader } | 
					
						
							|  |  |  |     { world world } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TUPLE: program-instance < gpu-object | 
					
						
							|  |  |  |     { program program } | 
					
						
							|  |  |  |     { world world } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  | GENERIC: vertex-format-size ( format -- size )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | MEMO: uniform-index ( program-instance uniform-name -- index )
 | 
					
						
							|  |  |  |     [ handle>> ] dip glGetUniformLocation ;
 | 
					
						
							|  |  |  | MEMO: attribute-index ( program-instance attribute-name -- index )
 | 
					
						
							|  |  |  |     [ handle>> ] dip glGetAttribLocation ;
 | 
					
						
							|  |  |  | MEMO: output-index ( program-instance output-name -- index )
 | 
					
						
							|  |  |  |     [ handle>> ] dip glGetFragDataLocation ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-10 16:03:34 -05:00
										 |  |  | : vertex-format-attributes ( vertex-format -- attributes )
 | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  |     "vertex-format-attributes" word-prop ; inline
 | 
					
						
							| 
									
										
										
										
											2010-02-10 16:03:34 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-30 11:58:34 -04:00
										 |  |  | TR: hyphens>underscores "-" "_" ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  | : gl-vertex-type ( component-type -- gl-type )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         { ubyte-components          [ GL_UNSIGNED_BYTE  ] } | 
					
						
							|  |  |  |         { ushort-components         [ GL_UNSIGNED_SHORT ] } | 
					
						
							|  |  |  |         { uint-components           [ GL_UNSIGNED_INT   ] } | 
					
						
							|  |  |  |         { half-components           [ GL_HALF_FLOAT     ] } | 
					
						
							|  |  |  |         { float-components          [ GL_FLOAT          ] } | 
					
						
							|  |  |  |         { byte-integer-components   [ GL_BYTE           ] } | 
					
						
							|  |  |  |         { short-integer-components  [ GL_SHORT          ] } | 
					
						
							|  |  |  |         { int-integer-components    [ GL_INT            ] } | 
					
						
							|  |  |  |         { ubyte-integer-components  [ GL_UNSIGNED_BYTE  ] } | 
					
						
							|  |  |  |         { ushort-integer-components [ GL_UNSIGNED_SHORT ] } | 
					
						
							|  |  |  |         { uint-integer-components   [ GL_UNSIGNED_INT   ] } | 
					
						
							|  |  |  |     } case ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  | : vertex-type-size ( component-type -- size )
 | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  |     { | 
					
						
							|  |  |  |         { ubyte-components          [ 1 ] } | 
					
						
							|  |  |  |         { ushort-components         [ 2 ] } | 
					
						
							|  |  |  |         { uint-components           [ 4 ] } | 
					
						
							|  |  |  |         { half-components           [ 2 ] } | 
					
						
							|  |  |  |         { float-components          [ 4 ] } | 
					
						
							|  |  |  |         { byte-integer-components   [ 1 ] } | 
					
						
							|  |  |  |         { short-integer-components  [ 2 ] } | 
					
						
							|  |  |  |         { int-integer-components    [ 4 ] } | 
					
						
							|  |  |  |         { ubyte-integer-components  [ 1 ] } | 
					
						
							|  |  |  |         { ushort-integer-components [ 2 ] } | 
					
						
							|  |  |  |         { uint-integer-components   [ 4 ] } | 
					
						
							|  |  |  |     } case ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : vertex-attribute-size ( vertex-attribute -- size )
 | 
					
						
							|  |  |  |     [ component-type>> vertex-type-size ] [ dim>> ] bi * ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : vertex-attributes-size ( vertex-attributes -- size )
 | 
					
						
							|  |  |  |     [ vertex-attribute-size ] [ + ] map-reduce ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-27 14:16:41 -04:00
										 |  |  | : feedback-type= ( component-type dim gl-type -- ? )
 | 
					
						
							|  |  |  |     [ 2array ] dip { | 
					
						
							|  |  |  |         { $ GL_FLOAT             [ { float-components 1 } ] } | 
					
						
							|  |  |  |         { $ GL_FLOAT_VEC2        [ { float-components 2 } ] } | 
					
						
							|  |  |  |         { $ GL_FLOAT_VEC3        [ { float-components 3 } ] } | 
					
						
							|  |  |  |         { $ GL_FLOAT_VEC4        [ { float-components 4 } ] } | 
					
						
							|  |  |  |         { $ GL_INT               [ { int-integer-components 1 } ] } | 
					
						
							|  |  |  |         { $ GL_INT_VEC2          [ { int-integer-components 2 } ] } | 
					
						
							|  |  |  |         { $ GL_INT_VEC3          [ { int-integer-components 3 } ] } | 
					
						
							|  |  |  |         { $ GL_INT_VEC4          [ { int-integer-components 4 } ] } | 
					
						
							|  |  |  |         { $ GL_UNSIGNED_INT      [ { uint-integer-components 1 } ] } | 
					
						
							|  |  |  |         { $ GL_UNSIGNED_INT_VEC2 [ { uint-integer-components 2 } ] } | 
					
						
							|  |  |  |         { $ GL_UNSIGNED_INT_VEC3 [ { uint-integer-components 3 } ] } | 
					
						
							|  |  |  |         { $ GL_UNSIGNED_INT_VEC4 [ { uint-integer-components 4 } ] } | 
					
						
							|  |  |  |     } case = ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :: assert-feedback-attribute ( size gl-type name vertex-attribute -- )
 | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  |         [ vertex-attribute name>> name = ] | 
					
						
							| 
									
										
										
										
											2009-07-27 14:16:41 -04:00
										 |  |  |         [ size 1 = ] | 
					
						
							|  |  |  |         [ gl-type vertex-attribute [ component-type>> ] [ dim>> ] bi feedback-type= ] | 
					
						
							| 
									
										
										
										
											2015-08-13 19:13:05 -04:00
										 |  |  |     } 0&& [ vertex-attribute inaccurate-feedback-attribute-error ] unless ;
 | 
					
						
							| 
									
										
										
										
											2009-07-27 14:16:41 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-29 00:48:41 -05:00
										 |  |  | :: (bind-float-vertex-attribute) ( program-instance ptr name dim gl-type normalize? stride offset -- )
 | 
					
						
							|  |  |  |     program-instance name attribute-index :> idx | 
					
						
							|  |  |  |     idx 0 >= [ | 
					
						
							|  |  |  |         idx glEnableVertexAttribArray | 
					
						
							|  |  |  |         idx dim gl-type normalize? stride offset ptr <displaced-alien> glVertexAttribPointer | 
					
						
							|  |  |  |     ] when ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :: (bind-int-vertex-attribute) ( program-instance ptr name dim gl-type stride offset -- )
 | 
					
						
							|  |  |  |     program-instance name attribute-index :> idx | 
					
						
							|  |  |  |     idx 0 >= [ | 
					
						
							|  |  |  |         idx glEnableVertexAttribArray | 
					
						
							|  |  |  |         idx dim gl-type stride offset ptr <displaced-alien> glVertexAttribIPointer | 
					
						
							|  |  |  |     ] when ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  | :: [bind-vertex-attribute] ( stride offset vertex-attribute -- stride offset' quot )
 | 
					
						
							| 
									
										
										
										
											2009-07-30 11:58:34 -04:00
										 |  |  |     vertex-attribute name>> hyphens>underscores :> name | 
					
						
							|  |  |  |     vertex-attribute component-type>>           :> type | 
					
						
							|  |  |  |     type gl-vertex-type                         :> gl-type | 
					
						
							|  |  |  |     vertex-attribute dim>>                      :> dim | 
					
						
							|  |  |  |     vertex-attribute normalize?>> >c-bool       :> normalize? | 
					
						
							|  |  |  |     vertex-attribute vertex-attribute-size      :> size | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     stride offset size +
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         { [ name not ] [ [ 2drop ] ] } | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             [ type unnormalized-integer-components? ] | 
					
						
							| 
									
										
										
										
											2010-01-29 00:48:41 -05:00
										 |  |  |             [ { name dim gl-type stride offset (bind-int-vertex-attribute) } >quotation ] | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2010-01-29 00:48:41 -05:00
										 |  |  |         [ { name dim gl-type normalize? stride offset (bind-float-vertex-attribute) } >quotation ] | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  |     } cond ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :: [bind-vertex-format] ( vertex-attributes -- quot )
 | 
					
						
							|  |  |  |     vertex-attributes vertex-attributes-size :> stride | 
					
						
							|  |  |  |     stride 0 vertex-attributes [ [bind-vertex-attribute] ] { } map-as 2nip :> attributes-cleave | 
					
						
							|  |  |  |     { attributes-cleave 2cleave } >quotation :> with-block | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  |     { drop vertex-buffer with-block with-buffer-ptr } >quotation ;
 | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-25 22:19:56 -04:00
										 |  |  | :: [link-feedback-format] ( vertex-attributes -- quot )
 | 
					
						
							|  |  |  |     vertex-attributes [ name>> not ] any?
 | 
					
						
							| 
									
										
										
										
											2015-08-13 19:13:05 -04:00
										 |  |  |     [ [ nip invalid-link-feedback-format-error ] ] [ | 
					
						
							| 
									
										
										
										
											2009-07-25 22:19:56 -04:00
										 |  |  |         vertex-attributes | 
					
						
							|  |  |  |         [ name>> ascii malloc-string ] | 
					
						
							|  |  |  |         void*-array{ } map-as :> varying-names | 
					
						
							|  |  |  |         vertex-attributes length :> varying-count | 
					
						
							|  |  |  |         { drop varying-count varying-names GL_INTERLEAVED_ATTRIBS glTransformFeedbackVaryings } | 
					
						
							|  |  |  |         >quotation | 
					
						
							|  |  |  |     ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-27 14:16:41 -04:00
										 |  |  | :: [verify-feedback-attribute] ( vertex-attribute index -- quot )
 | 
					
						
							|  |  |  |     vertex-attribute name>> :> name | 
					
						
							|  |  |  |     name length 1 + :> name-buffer-length | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         index name-buffer-length dup
 | 
					
						
							| 
									
										
										
										
											2010-10-20 18:42:53 -04:00
										 |  |  |         [ f 0 int <ref> 0 int <ref> ] dip <byte-array> | 
					
						
							| 
									
										
										
										
											2009-07-27 14:16:41 -04:00
										 |  |  |         [ glGetTransformFeedbackVarying ] 3keep
 | 
					
						
							|  |  |  |         ascii alien>string | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  |         vertex-attribute assert-feedback-attribute | 
					
						
							| 
									
										
										
										
											2009-07-27 14:16:41 -04:00
										 |  |  |     } >quotation ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :: [verify-feedback-format] ( vertex-attributes -- quot )
 | 
					
						
							|  |  |  |     vertex-attributes [ [verify-feedback-attribute] ] map-index :> verify-cleave | 
					
						
							|  |  |  |     { drop verify-cleave cleave } >quotation ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-23 05:11:57 -04:00
										 |  |  | : gl-geometry-shader-input ( input -- input )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         { points-input [ GL_POINTS ] } | 
					
						
							|  |  |  |         { lines-input  [ GL_LINES ] } | 
					
						
							|  |  |  |         { lines-with-adjacency-input [ GL_LINES_ADJACENCY ] } | 
					
						
							|  |  |  |         { triangles-input [ GL_TRIANGLES ] } | 
					
						
							|  |  |  |         { triangles-with-adjacency-input [ GL_TRIANGLES_ADJACENCY ] } | 
					
						
							|  |  |  |     } case ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : gl-geometry-shader-output ( output -- output )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         { points-output [ GL_POINTS ] } | 
					
						
							|  |  |  |         { line-strips-output  [ GL_LINE_STRIP ] } | 
					
						
							|  |  |  |         { triangle-strips-output [ GL_TRIANGLE_STRIP ] } | 
					
						
							|  |  |  |     } case ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TUPLE: geometry-shader-vertices-out | 
					
						
							|  |  |  |     { count integer read-only } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | UNION: geometry-shader-parameter | 
					
						
							|  |  |  |     geometry-shader-input | 
					
						
							|  |  |  |     geometry-shader-output | 
					
						
							|  |  |  |     geometry-shader-vertices-out ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  | GENERIC: bind-vertex-format ( program-instance buffer-ptr format -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-25 22:19:56 -04:00
										 |  |  | GENERIC: link-feedback-format ( program-handle format -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: f link-feedback-format | 
					
						
							|  |  |  |     2drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-10 16:03:34 -05:00
										 |  |  | : link-vertex-formats ( program-handle formats -- )
 | 
					
						
							|  |  |  |     [ vertex-format-attributes [ name>> ] map sift ] map concat
 | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  |     swap '[ [ _ ] 2dip swap glBindAttribLocation ] each-index ;
 | 
					
						
							| 
									
										
										
										
											2010-02-10 16:03:34 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-23 05:11:57 -04:00
										 |  |  | GENERIC: link-geometry-shader-parameter ( program-handle parameter -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: geometry-shader-input link-geometry-shader-parameter | 
					
						
							|  |  |  |     [ GL_GEOMETRY_INPUT_TYPE ] dip gl-geometry-shader-input glProgramParameteriARB ;
 | 
					
						
							|  |  |  | M: geometry-shader-output link-geometry-shader-parameter | 
					
						
							|  |  |  |     [ GL_GEOMETRY_OUTPUT_TYPE ] dip gl-geometry-shader-output glProgramParameteriARB ;
 | 
					
						
							|  |  |  | M: geometry-shader-vertices-out link-geometry-shader-parameter | 
					
						
							|  |  |  |     [ GL_GEOMETRY_VERTICES_OUT ] dip count>> glProgramParameteriARB ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : link-geometry-shader-parameters ( program-handle parameters -- )
 | 
					
						
							|  |  |  |     [ link-geometry-shader-parameter ] with each ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-27 14:16:41 -04:00
										 |  |  | GENERIC: (verify-feedback-format) ( program-instance format -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: f (verify-feedback-format) | 
					
						
							|  |  |  |     2drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : verify-feedback-format ( program-instance -- )
 | 
					
						
							|  |  |  |     dup program>> feedback-format>> (verify-feedback-format) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  | : define-vertex-format-methods ( class vertex-attributes -- )
 | 
					
						
							| 
									
										
										
										
											2009-07-27 14:16:41 -04:00
										 |  |  |     { | 
					
						
							|  |  |  |         [ | 
					
						
							|  |  |  |             [ \ bind-vertex-format create-method-in ] dip
 | 
					
						
							|  |  |  |             [bind-vertex-format] define | 
					
						
							|  |  |  |         ] [ | 
					
						
							|  |  |  |             [ \ link-feedback-format create-method-in ] dip
 | 
					
						
							|  |  |  |             [link-feedback-format] define | 
					
						
							|  |  |  |         ] [ | 
					
						
							|  |  |  |             [ \ (verify-feedback-format) create-method-in ] dip
 | 
					
						
							|  |  |  |             [verify-feedback-format] define | 
					
						
							|  |  |  |         ] [ | 
					
						
							|  |  |  |             [ \ vertex-format-size create-method-in ] dip
 | 
					
						
							|  |  |  |             [ \ drop ] dip vertex-attributes-size [ ] 2sequence define | 
					
						
							|  |  |  |         ] | 
					
						
							|  |  |  |     } 2cleave ;
 | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : component-type>c-type ( component-type -- c-type )
 | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-09-28 16:32:01 -04:00
										 |  |  |         { ubyte-components [ c:uchar ] } | 
					
						
							|  |  |  |         { ushort-components [ c:ushort ] } | 
					
						
							|  |  |  |         { uint-components [ c:uint ] } | 
					
						
							|  |  |  |         { half-components [ half ] } | 
					
						
							|  |  |  |         { float-components [ c:float ] } | 
					
						
							|  |  |  |         { byte-integer-components [ c:char ] } | 
					
						
							|  |  |  |         { ubyte-integer-components [ c:uchar ] } | 
					
						
							|  |  |  |         { short-integer-components [ c:short ] } | 
					
						
							|  |  |  |         { ushort-integer-components [ c:ushort ] } | 
					
						
							|  |  |  |         { int-integer-components [ c:int ] } | 
					
						
							|  |  |  |         { uint-integer-components [ c:uint ] } | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  |     } case ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-31 00:06:15 -04:00
										 |  |  | : c-array-dim ( type dim -- type' )
 | 
					
						
							|  |  |  |     dup 1 = [ drop ] [ 2array ] if ;
 | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: padding-no | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : padding-name ( -- name )
 | 
					
						
							|  |  |  |     "padding-" | 
					
						
							| 
									
										
										
										
											2010-04-07 18:33:19 -04:00
										 |  |  |     padding-no counter number>string append
 | 
					
						
							|  |  |  |     "(" ")" surround ;
 | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-31 00:06:15 -04:00
										 |  |  | : vertex-attribute>struct-slot ( vertex-attribute -- struct-slot-spec )
 | 
					
						
							|  |  |  |     [ name>> [ padding-name ] unless* ] | 
					
						
							|  |  |  |     [ [ component-type>> component-type>c-type ] [ dim>> c-array-dim ] bi ] bi
 | 
					
						
							|  |  |  |     { } <struct-slot-spec> ;
 | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  | : shader-filename ( shader/program -- filename )
 | 
					
						
							|  |  |  |     dup filename>> [ nip ] [ name>> where first ] if* file-name ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : numbered-log-line? ( log-line-components -- ? )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         [ length 4 >= ] | 
					
						
							|  |  |  |         [ third string>number ] | 
					
						
							|  |  |  |     } 1&& ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : replace-log-line-number ( object log-line -- log-line' )
 | 
					
						
							|  |  |  |     ":" split dup numbered-log-line? [ | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             [ nip first ] | 
					
						
							|  |  |  |             [ drop shader-filename " " prepend ] | 
					
						
							|  |  |  |             [ [ line>> ] [ third string>number ] bi* + number>string ] | 
					
						
							|  |  |  |             [ nip 3 tail ] | 
					
						
							|  |  |  |         } 2cleave [ 3array ] dip append
 | 
					
						
							|  |  |  |     ] [ nip ] if ":" join ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : replace-log-line-numbers ( object log -- log' )
 | 
					
						
							| 
									
										
										
										
											2009-10-23 08:02:11 -04:00
										 |  |  |     "\n" split harvest
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  |     [ replace-log-line-number ] with map
 | 
					
						
							|  |  |  |     "\n" join ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : gl-shader-kind ( shader-kind -- shader-kind )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         { vertex-shader [ GL_VERTEX_SHADER ] } | 
					
						
							|  |  |  |         { fragment-shader [ GL_FRAGMENT_SHADER ] } | 
					
						
							| 
									
										
										
										
											2010-03-23 05:11:57 -04:00
										 |  |  |         { geometry-shader [ GL_GEOMETRY_SHADER ] } | 
					
						
							|  |  |  |     } case ; inline
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  | : define-vertex-format ( class vertex-attributes -- )
 | 
					
						
							|  |  |  |     [ | 
					
						
							|  |  |  |         [ | 
					
						
							|  |  |  |             [ define-singleton-class ] | 
					
						
							|  |  |  |             [ vertex-format add-mixin-instance ] | 
					
						
							|  |  |  |             [ ] tri
 | 
					
						
							|  |  |  |         ] [ define-vertex-format-methods ] bi*
 | 
					
						
							|  |  |  |     ] | 
					
						
							|  |  |  |     [ "vertex-format-attributes" set-word-prop ] 2bi ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYNTAX: VERTEX-FORMAT: | 
					
						
							| 
									
										
										
										
											2011-09-27 16:20:07 -04:00
										 |  |  |     scan-new-class parse-definition | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  |     [ first4 vertex-attribute boa ] map
 | 
					
						
							|  |  |  |     define-vertex-format ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-31 00:06:15 -04:00
										 |  |  | : define-vertex-struct ( class vertex-format -- )
 | 
					
						
							| 
									
										
										
										
											2010-02-10 16:03:34 -05:00
										 |  |  |     vertex-format-attributes [ vertex-attribute>struct-slot ] map
 | 
					
						
							| 
									
										
										
										
											2009-08-31 00:06:15 -04:00
										 |  |  |     define-struct-class ;
 | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | SYNTAX: VERTEX-STRUCT: | 
					
						
							| 
									
										
										
										
											2011-09-27 16:20:07 -04:00
										 |  |  |     scan-new-class scan-word define-vertex-struct ;
 | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-17 14:26:32 -05:00
										 |  |  | TUPLE: vertex-array-object < gpu-object | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  |     { program-instance program-instance read-only } | 
					
						
							|  |  |  |     { vertex-buffers sequence read-only } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-17 14:26:32 -05:00
										 |  |  | TUPLE: vertex-array-collection | 
					
						
							|  |  |  |     { vertex-formats sequence read-only } | 
					
						
							|  |  |  |     { program-instance program-instance read-only } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | UNION: vertex-array | 
					
						
							|  |  |  |     vertex-array-object vertex-array-collection ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: vertex-array-object dispose | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  |     [ [ delete-vertex-array ] when* f ] change-handle drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-10 18:27:57 -05:00
										 |  |  | : ?>buffer-ptr ( buffer/ptr -- buffer-ptr )
 | 
					
						
							|  |  |  |     dup buffer-ptr? [ 0 <buffer-ptr> ] unless ; inline
 | 
					
						
							|  |  |  | : ?>buffer ( buffer/ptr -- buffer )
 | 
					
						
							|  |  |  |     dup buffer? [ buffer>> ] unless ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-17 14:26:32 -05:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : normalize-vertex-formats ( vertex-formats -- vertex-formats' )
 | 
					
						
							|  |  |  |     [ first2 [ ?>buffer-ptr ] dip 2array ] map ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : (bind-vertex-array) ( vertex-formats program-instance -- )
 | 
					
						
							|  |  |  |     '[ _ swap first2 bind-vertex-format ] each ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : (reset-vertex-array) ( -- )
 | 
					
						
							|  |  |  |     GL_MAX_VERTEX_ATTRIBS get-gl-int iota [ glDisableVertexAttribArray ] each ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :: <multi-vertex-array-object> ( vertex-formats program-instance -- vertex-array )
 | 
					
						
							| 
									
										
										
										
											2010-02-10 18:27:57 -05:00
										 |  |  |     gen-vertex-array :> handle | 
					
						
							|  |  |  |     handle glBindVertexArray | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-17 14:26:32 -05:00
										 |  |  |     vertex-formats normalize-vertex-formats program-instance (bind-vertex-array) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-10 18:27:57 -05:00
										 |  |  |     handle program-instance vertex-formats [ first ?>buffer ] map
 | 
					
						
							| 
									
										
										
										
											2010-02-17 14:26:32 -05:00
										 |  |  |     vertex-array-object boa window-resource ; inline
 | 
					
						
							| 
									
										
										
										
											2010-02-10 18:27:57 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-17 14:26:32 -05:00
										 |  |  | : <multi-vertex-array-collection> ( vertex-formats program-instance -- vertex-array )
 | 
					
						
							|  |  |  |     [ normalize-vertex-formats ] dip vertex-array-collection boa ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :: <vertex-array-object> ( vertex-buffer program-instance format -- vertex-array )
 | 
					
						
							| 
									
										
										
										
											2010-02-10 18:27:57 -05:00
										 |  |  |     gen-vertex-array :> handle | 
					
						
							|  |  |  |     handle glBindVertexArray | 
					
						
							|  |  |  |     program-instance vertex-buffer ?>buffer-ptr format bind-vertex-format | 
					
						
							|  |  |  |     handle program-instance vertex-buffer ?>buffer 1array
 | 
					
						
							| 
									
										
										
										
											2010-02-17 14:26:32 -05:00
										 |  |  |     vertex-array-object boa window-resource ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : <vertex-array-collection> ( vertex-buffer program-instance format -- vertex-array )
 | 
					
						
							|  |  |  |     swap [ [ ?>buffer-ptr ] dip 2array 1array ] dip <multi-vertex-array-collection> ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: bind-vertex-array ( vertex-array -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: vertex-array-object bind-vertex-array | 
					
						
							|  |  |  |     handle>> glBindVertexArray ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: vertex-array-collection bind-vertex-array | 
					
						
							|  |  |  |     (reset-vertex-array) | 
					
						
							|  |  |  |     [ vertex-formats>> ] [ program-instance>> ] bi (bind-vertex-array) ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : <multi-vertex-array> ( vertex-formats program-instance -- vertex-array )
 | 
					
						
							|  |  |  |     has-vertex-array-objects? get
 | 
					
						
							|  |  |  |     [ <multi-vertex-array-object> ] | 
					
						
							|  |  |  |     [ <multi-vertex-array-collection> ] if ; inline
 | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-17 14:26:32 -05:00
										 |  |  | : <vertex-array*> ( vertex-buffer program-instance format -- vertex-array )
 | 
					
						
							|  |  |  |     has-vertex-array-objects? get
 | 
					
						
							|  |  |  |     [ <vertex-array-object> ] | 
					
						
							|  |  |  |     [ <vertex-array-collection> ] if ; inline
 | 
					
						
							| 
									
										
										
										
											2010-02-10 18:27:57 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : <vertex-array> ( vertex-buffer program-instance -- vertex-array )
 | 
					
						
							|  |  |  |     dup program>> vertex-formats>> first <vertex-array*> ; inline
 | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-17 14:26:32 -05:00
										 |  |  | GENERIC: vertex-array-buffers ( vertex-array -- buffers )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: vertex-array-object vertex-array-buffers | 
					
						
							|  |  |  |     vertex-buffers>> ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: vertex-array-collection vertex-array-buffers | 
					
						
							|  |  |  |     vertex-formats>> [ first buffer>> ] map ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : vertex-array-buffer ( vertex-array: vertex-array -- vertex-buffer: buffer )
 | 
					
						
							|  |  |  |     vertex-array-buffers first ; inline
 | 
					
						
							| 
									
										
										
										
											2009-07-25 12:30:59 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-13 03:24:10 -04:00
										 |  |  | TUPLE: compile-shader-error shader log ;
 | 
					
						
							|  |  |  | TUPLE: link-program-error program log ;
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-24 04:33:45 -04:00
										 |  |  | : throw-compile-shader-error ( shader instance -- * )
 | 
					
						
							| 
									
										
										
										
											2013-03-24 17:20:32 -04:00
										 |  |  |     [ dup ] dip [ gl-shader-info-log ] [ delete-gl-shader ] bi
 | 
					
						
							| 
									
										
										
										
											2015-08-13 03:24:10 -04:00
										 |  |  |     replace-log-line-numbers compile-shader-error boa throw ;
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-24 04:33:45 -04:00
										 |  |  | : throw-link-program-error ( program instance -- * )
 | 
					
						
							| 
									
										
										
										
											2013-03-24 17:20:32 -04:00
										 |  |  |     [ dup ] dip [ gl-program-info-log ] [ delete-gl-program ] bi
 | 
					
						
							| 
									
										
										
										
											2015-08-13 03:24:10 -04:00
										 |  |  |     replace-log-line-numbers link-program-error boa throw ;
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | DEFER: <shader-instance> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : valid-handle? ( handle -- ? )
 | 
					
						
							|  |  |  |     { [ ] [ zero? not ] } 1&& ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : compile-shader ( shader -- instance )
 | 
					
						
							|  |  |  |     [ ] [ source>> ] [ kind>> gl-shader-kind ] tri <gl-shader> | 
					
						
							|  |  |  |     dup gl-shader-ok? | 
					
						
							|  |  |  |     [ swap world get \ shader-instance boa window-resource ] | 
					
						
							| 
									
										
										
										
											2015-08-13 22:07:50 -04:00
										 |  |  |     [ throw-compile-shader-error ] if ;
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : (link-program) ( program shader-instances -- program-instance )
 | 
					
						
							| 
									
										
										
										
											2010-02-10 16:03:34 -05:00
										 |  |  |     '[ _ [ handle>> ] map ] | 
					
						
							|  |  |  |     [ | 
					
						
							| 
									
										
										
										
											2010-03-23 05:11:57 -04:00
										 |  |  |         [ vertex-formats>> ] [ feedback-format>> ] [ geometry-shader-parameters>> ] tri
 | 
					
						
							|  |  |  |         '[ | 
					
						
							|  |  |  |             [ _ link-vertex-formats ] | 
					
						
							|  |  |  |             [ _ link-feedback-format ] | 
					
						
							|  |  |  |             [ _ link-geometry-shader-parameters ] tri
 | 
					
						
							|  |  |  |         ] | 
					
						
							| 
									
										
										
										
											2010-02-10 16:03:34 -05:00
										 |  |  |     ] bi (gl-program) | 
					
						
							| 
									
										
										
										
											2009-07-27 14:16:41 -04:00
										 |  |  |     dup gl-program-ok?  [ | 
					
						
							|  |  |  |         [ swap world get \ program-instance boa |dispose dup verify-feedback-format ] | 
					
						
							|  |  |  |         with-destructors window-resource | 
					
						
							| 
									
										
										
										
											2015-08-13 22:07:50 -04:00
										 |  |  |     ] [ throw-link-program-error ] if ;
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : link-program ( program -- program-instance )
 | 
					
						
							|  |  |  |     dup shaders>> [ <shader-instance> ] map (link-program) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : in-word's-path ( word kind filename -- word kind filename' )
 | 
					
						
							|  |  |  |     [ over ] dip [ where first parent-directory ] dip append-path ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : become-shader-instance ( shader-instance new-shader-instance -- )
 | 
					
						
							|  |  |  |     handle>> [ swap delete-gl-shader ] curry change-handle drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : refresh-shader-source ( shader -- )
 | 
					
						
							|  |  |  |     dup filename>> | 
					
						
							|  |  |  |     [ ascii file-contents >>source drop ] | 
					
						
							|  |  |  |     [ drop ] if* ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : become-program-instance ( program-instance new-program-instance -- )
 | 
					
						
							|  |  |  |     handle>> [ swap delete-gl-program-only ] curry change-handle drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : reset-memos ( -- )
 | 
					
						
							|  |  |  |     \ uniform-index reset-memoized | 
					
						
							|  |  |  |     \ attribute-index reset-memoized | 
					
						
							|  |  |  |     \ output-index reset-memoized ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : ?delete-at ( key assoc value -- )
 | 
					
						
							|  |  |  |     2over at = [ delete-at ] [ 2drop ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : find-shader-instance ( shader -- instance )
 | 
					
						
							|  |  |  |     world get over instances>> at*
 | 
					
						
							|  |  |  |     [ nip ] [ drop compile-shader ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : find-program-instance ( program -- instance )
 | 
					
						
							|  |  |  |     world get over instances>> at*
 | 
					
						
							|  |  |  |     [ nip ] [ drop link-program ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-10 16:03:34 -05:00
										 |  |  | TUPLE: feedback-format | 
					
						
							| 
									
										
										
										
											2012-05-03 22:17:41 -04:00
										 |  |  |     { vertex-format maybe{ vertex-format } read-only } ;
 | 
					
						
							| 
									
										
										
										
											2010-02-10 16:03:34 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : validate-feedback-format ( sequence -- vertex-format/f )
 | 
					
						
							|  |  |  |     dup length 1 <=
 | 
					
						
							|  |  |  |     [ [ f ] [ first vertex-format>> ] if-empty ] | 
					
						
							| 
									
										
										
										
											2015-08-13 19:13:05 -04:00
										 |  |  |     [ too-many-feedback-formats-error ] if ;
 | 
					
						
							| 
									
										
										
										
											2010-02-10 16:03:34 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : ?shader ( object -- shader/f )
 | 
					
						
							|  |  |  |     dup word? [ def>> first dup shader? [ drop f ] unless ] [ drop f ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-23 05:11:57 -04:00
										 |  |  | : shaders-and-formats ( words -- shaders vertex-formats feedback-format geom-parameters )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         [ [ ?shader ] map sift ] | 
					
						
							|  |  |  |         [ [ vertex-format-attributes ] filter ] | 
					
						
							|  |  |  |         [ [ feedback-format? ] filter validate-feedback-format ] | 
					
						
							|  |  |  |         [ [ geometry-shader-parameter? ] filter ] | 
					
						
							|  |  |  |     } cleave ;
 | 
					
						
							| 
									
										
										
										
											2009-07-25 16:50:38 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-10 16:03:34 -05:00
										 |  |  | SYNTAX: feedback-format: | 
					
						
							|  |  |  |     scan-object feedback-format boa suffix! ;
 | 
					
						
							| 
									
										
										
										
											2010-03-23 05:11:57 -04:00
										 |  |  | SYNTAX: geometry-shader-vertices-out: | 
					
						
							|  |  |  |     scan-object geometry-shader-vertices-out boa suffix! ;
 | 
					
						
							| 
									
										
										
										
											2010-02-10 16:03:34 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-15 17:03:15 -05:00
										 |  |  | TYPED:: refresh-program ( program: program -- )
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  |     program shaders>> [ refresh-shader-source ] each
 | 
					
						
							|  |  |  |     program instances>> [| world old-instance | | 
					
						
							|  |  |  |         old-instance valid-handle? [ | 
					
						
							|  |  |  |             world [ | 
					
						
							|  |  |  |                 [ | 
					
						
							|  |  |  |                     program shaders>> [ compile-shader |dispose ] map :> new-shader-instances | 
					
						
							|  |  |  |                     program new-shader-instances (link-program) |dispose :> new-program-instance | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     old-instance new-program-instance become-program-instance | 
					
						
							|  |  |  |                     new-shader-instances [| new-shader-instance | | 
					
						
							|  |  |  |                         world new-shader-instance shader>> instances>> at
 | 
					
						
							|  |  |  |                             new-shader-instance become-shader-instance | 
					
						
							|  |  |  |                     ] each
 | 
					
						
							|  |  |  |                 ] with-destructors | 
					
						
							|  |  |  |             ] with-gl-context | 
					
						
							|  |  |  |         ] when
 | 
					
						
							|  |  |  |     ] assoc-each
 | 
					
						
							|  |  |  |     reset-memos ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-15 17:03:15 -05:00
										 |  |  | TYPED: <shader-instance> ( shader: shader -- instance: shader-instance )
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  |     [ find-shader-instance dup world get ] keep instances>> set-at ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-15 17:03:15 -05:00
										 |  |  | TYPED: <program-instance> ( program: program -- instance: program-instance )
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  |     [ find-program-instance dup world get ] keep instances>> set-at ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-18 14:44:24 -04:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : old-instances ( name -- instances )
 | 
					
						
							|  |  |  |     dup constant? [ | 
					
						
							|  |  |  |         execute( -- s/p ) dup { [ shader? ] [ program? ] } 1|| | 
					
						
							|  |  |  |         [ instances>> ] [ drop H{ } clone ] if
 | 
					
						
							|  |  |  |     ] [ drop H{ } clone ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  | SYNTAX: GLSL-SHADER: | 
					
						
							| 
									
										
										
										
											2011-09-27 16:20:07 -04:00
										 |  |  |     scan-new dup
 | 
					
						
							| 
									
										
										
										
											2009-10-18 14:44:24 -04:00
										 |  |  |     dup old-instances [ | 
					
						
							|  |  |  |         scan-word | 
					
						
							|  |  |  |         f
 | 
					
						
							|  |  |  |         lexer get line>> | 
					
						
							|  |  |  |         parse-here | 
					
						
							|  |  |  |     ] dip
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  |     shader boa
 | 
					
						
							| 
									
										
										
										
											2009-10-18 14:44:24 -04:00
										 |  |  |     over reset-generic | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  |     define-constant ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYNTAX: GLSL-SHADER-FILE: | 
					
						
							| 
									
										
										
										
											2011-09-27 16:20:07 -04:00
										 |  |  |     scan-new dup
 | 
					
						
							| 
									
										
										
										
											2009-10-18 14:44:24 -04:00
										 |  |  |     dup old-instances [ | 
					
						
							|  |  |  |         scan-word execute( -- kind ) | 
					
						
							|  |  |  |         scan-object in-word's-path | 
					
						
							|  |  |  |         0
 | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  |         over ascii file-contents | 
					
						
							| 
									
										
										
										
											2009-10-18 14:44:24 -04:00
										 |  |  |     ] dip
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  |     shader boa
 | 
					
						
							| 
									
										
										
										
											2009-10-18 14:44:24 -04:00
										 |  |  |     over reset-generic | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  |     define-constant ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYNTAX: GLSL-PROGRAM: | 
					
						
							| 
									
										
										
										
											2011-09-27 16:20:07 -04:00
										 |  |  |     scan-new dup
 | 
					
						
							| 
									
										
										
										
											2009-10-18 14:44:24 -04:00
										 |  |  |     dup old-instances [ | 
					
						
							|  |  |  |         f
 | 
					
						
							|  |  |  |         lexer get line>> | 
					
						
							| 
									
										
										
										
											2010-02-10 16:03:34 -05:00
										 |  |  |         \ ; parse-until >array shaders-and-formats | 
					
						
							| 
									
										
										
										
											2009-10-18 14:44:24 -04:00
										 |  |  |     ] dip
 | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  |     program boa
 | 
					
						
							| 
									
										
										
										
											2009-10-18 14:44:24 -04:00
										 |  |  |     over reset-generic | 
					
						
							| 
									
										
										
										
											2009-07-19 15:31:10 -04:00
										 |  |  |     define-constant ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: shader-instance dispose | 
					
						
							|  |  |  |     [ dup valid-handle? [ delete-gl-shader ] [ drop ] if f ] change-handle | 
					
						
							|  |  |  |     [ world>> ] [ shader>> instances>> ] [ ] tri ?delete-at ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: program-instance dispose | 
					
						
							|  |  |  |     [ dup valid-handle? [ delete-gl-program-only ] [ drop ] if f ] change-handle | 
					
						
							|  |  |  |     [ world>> ] [ program>> instances>> ] [ ] tri ?delete-at | 
					
						
							|  |  |  |     reset-memos ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-18 15:29:24 -04:00
										 |  |  | { "gpu.shaders" "prettyprint" } "gpu.shaders.prettyprint" require-when |