Safe Haskell | None |
---|---|
Language | Haskell2010 |
A Shader
is a monad in which PrimitiveStream
s and FragmentStream
s live, together with samplers and uniform values. Any computations made on the streams and values in
the Shader
monad will be performed on the GPU. A Shader
needs to be compiled before it can be used. In order to make it work over different environments after it
has been compiled, it closes over an environment value just like a Reader
monad, with the distinction that there is no ask
action, since we cannot make the
actual monad operation depend on the environment.
A Shader
is an instance of Alternative
and MonadPlus
which makes it possible to express choice with functions like guard
. The left most alternative will always be the
resulting monad.
Synopsis
- data Shader os s a
- compileShader :: (ContextHandler ctx, MonadIO m, MonadException m) => Shader os s () -> ContextT ctx os m (CompiledShader os s)
- type CompiledShader os s = s -> Render os ()
- data Render os a
- render :: (ContextHandler ctx, MonadIO m, MonadException m) => Render os () -> ContextT ctx os m ()
- guard' :: (s -> Bool) -> Shader os s ()
- mapShader :: (s -> s') -> Shader os s' a -> Shader os s a
- maybeShader :: (s -> Maybe s') -> Shader os s' () -> Shader os s ()
- chooseShader :: (s -> Either s' s'') -> Shader os s' a -> Shader os s'' a -> Shader os s a
- silenceShader :: Shader os s a -> Shader os s a
The Shader monad
The monad in which all GPU computations are done. 'Shader os s a' lives in
an object space os
and a context with format f
, closing over an
environent of type s
.
compileShader :: (ContextHandler ctx, MonadIO m, MonadException m) => Shader os s () -> ContextT ctx os m (CompiledShader os s) Source #
Compiles a shader into a CompiledShader
. This action will usually take a
second or more, so put it during a loading sequence or something.
May throw a GPipeException
if the graphics driver doesn't support something
in this shader (e.g. too many interpolated floats sent between a vertex and a
fragment shader)
type CompiledShader os s = s -> Render os () Source #
A compiled shader is just a function that takes an environment and returns
a Render
action It could have been called CompiledDrawcall
or Renderer
because it is the same thing.
The Render monad
A monad in which shaders are run.
render :: (ContextHandler ctx, MonadIO m, MonadException m) => Render os () -> ContextT ctx os m () Source #
Run a Render
monad, that may have the effect of windows or textures being drawn to.
May throw a GPipeException
if a combination of draw images (FBO) used by this render call is unsupported by the graphics driver
Shader monad combinators
guard' :: (s -> Bool) -> Shader os s () Source #
Like guard
, but dependent on the Shaders
environment value. Since this
will be evaluated at shader run time, as opposed to shader compile time for
guard
, using this to do recursion will make compileShader
diverge. You
can break that divergence by combining it with a normal guard
and a
maximum loop count.
mapShader :: (s -> s') -> Shader os s' a -> Shader os s a Source #
Map the environment to a different environment and run a Shader in that sub environment, returning it's result.