module Graphics.Rendering.Ombra.Draw (
Draw,
DrawState,
Ctx,
refDrawCtx,
runDrawCtx,
execDrawCtx,
evalDrawCtx,
drawState,
MonadGL(gl),
MonadScreen(resizeViewport),
MonadObject,
drawInit,
clearBuffers,
drawLayer,
ResStatus(..),
preloadGeometry,
preloadTexture,
preloadProgram,
removeGeometry,
removeTexture,
removeProgram,
checkGeometry,
checkTexture,
checkProgram,
hasVertexArrayObjects,
hasFloatTextures,
hasDrawBuffers,
hasStandardDerivatives,
) where
import Data.IORef
import Graphics.Rendering.Ombra.Draw.Internal
import Graphics.Rendering.Ombra.Object.Internal
import Graphics.Rendering.Ombra.Internal.GL hiding (Buffer)
import Graphics.Rendering.Ombra.Layer
import Graphics.Rendering.Ombra.Screen
refDrawCtx :: GLES => Ctx -> Draw a -> IORef DrawState -> IO a
refDrawCtx ctx d ref = do state <- readIORef ref
(ret, state') <- runDrawCtx ctx d state
writeIORef ref state'
return ret
runDrawCtx :: Ctx
-> Draw a
-> DrawState
-> IO (a, DrawState)
runDrawCtx ctx d = flip evalGL ctx . runDraw d
execDrawCtx :: Ctx -> Draw a -> DrawState -> IO DrawState
execDrawCtx ctx d = flip evalGL ctx . execDraw d
evalDrawCtx :: Ctx -> Draw a -> DrawState -> IO a
evalDrawCtx ctx d = flip evalGL ctx . evalDraw d