{-# LANGUAGE CPP, ScopedTypeVariables, PatternSynonyms #-}
module Graphics.GL.Ext.SGIX.Async (
gl_SGIX_async
, glAsyncMarkerSGIX
, glDeleteAsyncMarkersSGIX
, glFinishAsyncSGIX
, glGenAsyncMarkersSGIX
, glIsAsyncMarkerSGIX
, glPollAsyncSGIX
, pattern GL_ASYNC_MARKER_SGIX
) where
import Control.Monad.IO.Class
import Data.Set
import Foreign.Ptr
import Graphics.GL.Internal.FFI
import Graphics.GL.Internal.Proc
import Graphics.GL.Types
import System.IO.Unsafe
gl_SGIX_async :: Bool
gl_SGIX_async :: Bool
gl_SGIX_async = String -> Set String -> Bool
forall a. Ord a => a -> Set a -> Bool
member String
"GL_SGIX_async" Set String
extensions
{-# NOINLINE gl_SGIX_async #-}
glAsyncMarkerSGIX :: MonadIO m => GLuint -> m ()
glAsyncMarkerSGIX :: forall (m :: * -> *). MonadIO m => GLuint -> m ()
glAsyncMarkerSGIX = FunPtr (GLuint -> IO ()) -> GLuint -> m ()
forall (m :: * -> *).
MonadIO m =>
FunPtr (GLuint -> IO ()) -> GLuint -> m ()
ffiuintIOV FunPtr (GLuint -> IO ())
glAsyncMarkerSGIXFunPtr
glAsyncMarkerSGIXFunPtr :: FunPtr (GLuint -> IO ())
glAsyncMarkerSGIXFunPtr :: FunPtr (GLuint -> IO ())
glAsyncMarkerSGIXFunPtr = IO (FunPtr (GLuint -> IO ())) -> FunPtr (GLuint -> IO ())
forall a. IO a -> a
unsafePerformIO (String -> IO (FunPtr (GLuint -> IO ()))
forall a. String -> IO (FunPtr a)
getProcAddress String
"glAsyncMarkerSGIX")
{-# NOINLINE glAsyncMarkerSGIXFunPtr #-}
glDeleteAsyncMarkersSGIX :: MonadIO m => GLuint -> GLsizei -> m ()
= FunPtr (GLuint -> GLsizei -> IO ()) -> GLuint -> GLsizei -> m ()
forall (m :: * -> *).
MonadIO m =>
FunPtr (GLuint -> GLsizei -> IO ()) -> GLuint -> GLsizei -> m ()
ffiuintsizeiIOV FunPtr (GLuint -> GLsizei -> IO ())
glDeleteAsyncMarkersSGIXFunPtr
glDeleteAsyncMarkersSGIXFunPtr :: FunPtr (GLuint -> GLsizei -> IO ())
= IO (FunPtr (GLuint -> GLsizei -> IO ()))
-> FunPtr (GLuint -> GLsizei -> IO ())
forall a. IO a -> a
unsafePerformIO (String -> IO (FunPtr (GLuint -> GLsizei -> IO ()))
forall a. String -> IO (FunPtr a)
getProcAddress String
"glDeleteAsyncMarkersSGIX")
{-# NOINLINE glDeleteAsyncMarkersSGIXFunPtr #-}
glFinishAsyncSGIX :: MonadIO m => Ptr GLuint -> m GLint
glFinishAsyncSGIX :: forall (m :: * -> *). MonadIO m => Ptr GLuint -> m GLsizei
glFinishAsyncSGIX = FunPtr (Ptr GLuint -> IO GLsizei) -> Ptr GLuint -> m GLsizei
forall (m :: * -> *).
MonadIO m =>
FunPtr (Ptr GLuint -> IO GLsizei) -> Ptr GLuint -> m GLsizei
ffiPtruintIOint FunPtr (Ptr GLuint -> IO GLsizei)
glFinishAsyncSGIXFunPtr
glFinishAsyncSGIXFunPtr :: FunPtr (Ptr GLuint -> IO GLint)
glFinishAsyncSGIXFunPtr :: FunPtr (Ptr GLuint -> IO GLsizei)
glFinishAsyncSGIXFunPtr = IO (FunPtr (Ptr GLuint -> IO GLsizei))
-> FunPtr (Ptr GLuint -> IO GLsizei)
forall a. IO a -> a
unsafePerformIO (String -> IO (FunPtr (Ptr GLuint -> IO GLsizei))
forall a. String -> IO (FunPtr a)
getProcAddress String
"glFinishAsyncSGIX")
{-# NOINLINE glFinishAsyncSGIXFunPtr #-}
glGenAsyncMarkersSGIX :: MonadIO m => GLsizei -> m GLuint
= FunPtr (GLsizei -> IO GLuint) -> GLsizei -> m GLuint
forall (m :: * -> *).
MonadIO m =>
FunPtr (GLsizei -> IO GLuint) -> GLsizei -> m GLuint
ffisizeiIOuint FunPtr (GLsizei -> IO GLuint)
glGenAsyncMarkersSGIXFunPtr
glGenAsyncMarkersSGIXFunPtr :: FunPtr (GLsizei -> IO GLuint)
= IO (FunPtr (GLsizei -> IO GLuint)) -> FunPtr (GLsizei -> IO GLuint)
forall a. IO a -> a
unsafePerformIO (String -> IO (FunPtr (GLsizei -> IO GLuint))
forall a. String -> IO (FunPtr a)
getProcAddress String
"glGenAsyncMarkersSGIX")
{-# NOINLINE glGenAsyncMarkersSGIXFunPtr #-}
glIsAsyncMarkerSGIX :: MonadIO m => GLuint -> m GLboolean
glIsAsyncMarkerSGIX :: forall (m :: * -> *). MonadIO m => GLuint -> m GLboolean
glIsAsyncMarkerSGIX = FunPtr (GLuint -> IO GLboolean) -> GLuint -> m GLboolean
forall (m :: * -> *).
MonadIO m =>
FunPtr (GLuint -> IO GLboolean) -> GLuint -> m GLboolean
ffiuintIOboolean FunPtr (GLuint -> IO GLboolean)
glIsAsyncMarkerSGIXFunPtr
glIsAsyncMarkerSGIXFunPtr :: FunPtr (GLuint -> IO GLboolean)
glIsAsyncMarkerSGIXFunPtr :: FunPtr (GLuint -> IO GLboolean)
glIsAsyncMarkerSGIXFunPtr = IO (FunPtr (GLuint -> IO GLboolean))
-> FunPtr (GLuint -> IO GLboolean)
forall a. IO a -> a
unsafePerformIO (String -> IO (FunPtr (GLuint -> IO GLboolean))
forall a. String -> IO (FunPtr a)
getProcAddress String
"glIsAsyncMarkerSGIX")
{-# NOINLINE glIsAsyncMarkerSGIXFunPtr #-}
glPollAsyncSGIX :: MonadIO m => Ptr GLuint -> m GLint
glPollAsyncSGIX :: forall (m :: * -> *). MonadIO m => Ptr GLuint -> m GLsizei
glPollAsyncSGIX = FunPtr (Ptr GLuint -> IO GLsizei) -> Ptr GLuint -> m GLsizei
forall (m :: * -> *).
MonadIO m =>
FunPtr (Ptr GLuint -> IO GLsizei) -> Ptr GLuint -> m GLsizei
ffiPtruintIOint FunPtr (Ptr GLuint -> IO GLsizei)
glPollAsyncSGIXFunPtr
glPollAsyncSGIXFunPtr :: FunPtr (Ptr GLuint -> IO GLint)
glPollAsyncSGIXFunPtr :: FunPtr (Ptr GLuint -> IO GLsizei)
glPollAsyncSGIXFunPtr = IO (FunPtr (Ptr GLuint -> IO GLsizei))
-> FunPtr (Ptr GLuint -> IO GLsizei)
forall a. IO a -> a
unsafePerformIO (String -> IO (FunPtr (Ptr GLuint -> IO GLsizei))
forall a. String -> IO (FunPtr a)
getProcAddress String
"glPollAsyncSGIX")
{-# NOINLINE glPollAsyncSGIXFunPtr #-}
pattern GL_ASYNC_MARKER_SGIX :: (Eq a, Num a) => a
pattern $mGL_ASYNC_MARKER_SGIX :: forall {r} {a}.
(Eq a, Num a) =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
$bGL_ASYNC_MARKER_SGIX :: forall a. (Eq a, Num a) => a
GL_ASYNC_MARKER_SGIX = 0x8329