{-# LANGUAGE CPP, ScopedTypeVariables, PatternSynonyms #-}
module Graphics.GL.Ext.APPLE.ObjectPurgeable (
gl_APPLE_object_purgeable
, glGetObjectParameterivAPPLE
, glObjectPurgeableAPPLE
, glObjectUnpurgeableAPPLE
, pattern GL_BUFFER_OBJECT_APPLE
, pattern GL_PURGEABLE_APPLE
, pattern GL_RELEASED_APPLE
, pattern GL_RETAINED_APPLE
, pattern GL_UNDEFINED_APPLE
, pattern GL_VOLATILE_APPLE
) 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_APPLE_object_purgeable :: Bool
gl_APPLE_object_purgeable :: Bool
gl_APPLE_object_purgeable = String -> Set String -> Bool
forall a. Ord a => a -> Set a -> Bool
member String
"GL_APPLE_object_purgeable" Set String
extensions
{-# NOINLINE gl_APPLE_object_purgeable #-}
glGetObjectParameterivAPPLE :: MonadIO m => GLenum -> GLuint -> GLenum -> Ptr GLint -> m ()
glGetObjectParameterivAPPLE :: forall (m :: * -> *).
MonadIO m =>
GLenum -> GLenum -> GLenum -> Ptr GLint -> m ()
glGetObjectParameterivAPPLE = FunPtr (GLenum -> GLenum -> GLenum -> Ptr GLint -> IO ())
-> GLenum -> GLenum -> GLenum -> Ptr GLint -> m ()
forall (m :: * -> *).
MonadIO m =>
FunPtr (GLenum -> GLenum -> GLenum -> Ptr GLint -> IO ())
-> GLenum -> GLenum -> GLenum -> Ptr GLint -> m ()
ffienumuintenumPtrintIOV FunPtr (GLenum -> GLenum -> GLenum -> Ptr GLint -> IO ())
glGetObjectParameterivAPPLEFunPtr
glGetObjectParameterivAPPLEFunPtr :: FunPtr (GLenum -> GLuint -> GLenum -> Ptr GLint -> IO ())
glGetObjectParameterivAPPLEFunPtr :: FunPtr (GLenum -> GLenum -> GLenum -> Ptr GLint -> IO ())
glGetObjectParameterivAPPLEFunPtr = IO (FunPtr (GLenum -> GLenum -> GLenum -> Ptr GLint -> IO ()))
-> FunPtr (GLenum -> GLenum -> GLenum -> Ptr GLint -> IO ())
forall a. IO a -> a
unsafePerformIO (String
-> IO (FunPtr (GLenum -> GLenum -> GLenum -> Ptr GLint -> IO ()))
forall a. String -> IO (FunPtr a)
getProcAddress String
"glGetObjectParameterivAPPLE")
{-# NOINLINE glGetObjectParameterivAPPLEFunPtr #-}
glObjectPurgeableAPPLE :: MonadIO m => GLenum -> GLuint -> GLenum -> m GLenum
glObjectPurgeableAPPLE :: forall (m :: * -> *).
MonadIO m =>
GLenum -> GLenum -> GLenum -> m GLenum
glObjectPurgeableAPPLE = FunPtr (GLenum -> GLenum -> GLenum -> IO GLenum)
-> GLenum -> GLenum -> GLenum -> m GLenum
forall (m :: * -> *).
MonadIO m =>
FunPtr (GLenum -> GLenum -> GLenum -> IO GLenum)
-> GLenum -> GLenum -> GLenum -> m GLenum
ffienumuintenumIOenum FunPtr (GLenum -> GLenum -> GLenum -> IO GLenum)
glObjectPurgeableAPPLEFunPtr
glObjectPurgeableAPPLEFunPtr :: FunPtr (GLenum -> GLuint -> GLenum -> IO GLenum)
glObjectPurgeableAPPLEFunPtr :: FunPtr (GLenum -> GLenum -> GLenum -> IO GLenum)
glObjectPurgeableAPPLEFunPtr = IO (FunPtr (GLenum -> GLenum -> GLenum -> IO GLenum))
-> FunPtr (GLenum -> GLenum -> GLenum -> IO GLenum)
forall a. IO a -> a
unsafePerformIO (String -> IO (FunPtr (GLenum -> GLenum -> GLenum -> IO GLenum))
forall a. String -> IO (FunPtr a)
getProcAddress String
"glObjectPurgeableAPPLE")
{-# NOINLINE glObjectPurgeableAPPLEFunPtr #-}
glObjectUnpurgeableAPPLE :: MonadIO m => GLenum -> GLuint -> GLenum -> m GLenum
glObjectUnpurgeableAPPLE :: forall (m :: * -> *).
MonadIO m =>
GLenum -> GLenum -> GLenum -> m GLenum
glObjectUnpurgeableAPPLE = FunPtr (GLenum -> GLenum -> GLenum -> IO GLenum)
-> GLenum -> GLenum -> GLenum -> m GLenum
forall (m :: * -> *).
MonadIO m =>
FunPtr (GLenum -> GLenum -> GLenum -> IO GLenum)
-> GLenum -> GLenum -> GLenum -> m GLenum
ffienumuintenumIOenum FunPtr (GLenum -> GLenum -> GLenum -> IO GLenum)
glObjectUnpurgeableAPPLEFunPtr
glObjectUnpurgeableAPPLEFunPtr :: FunPtr (GLenum -> GLuint -> GLenum -> IO GLenum)
glObjectUnpurgeableAPPLEFunPtr :: FunPtr (GLenum -> GLenum -> GLenum -> IO GLenum)
glObjectUnpurgeableAPPLEFunPtr = IO (FunPtr (GLenum -> GLenum -> GLenum -> IO GLenum))
-> FunPtr (GLenum -> GLenum -> GLenum -> IO GLenum)
forall a. IO a -> a
unsafePerformIO (String -> IO (FunPtr (GLenum -> GLenum -> GLenum -> IO GLenum))
forall a. String -> IO (FunPtr a)
getProcAddress String
"glObjectUnpurgeableAPPLE")
{-# NOINLINE glObjectUnpurgeableAPPLEFunPtr #-}
pattern GL_BUFFER_OBJECT_APPLE :: (Eq a, Num a) => a
pattern $mGL_BUFFER_OBJECT_APPLE :: forall {r} {a}.
(Eq a, Num a) =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
$bGL_BUFFER_OBJECT_APPLE :: forall a. (Eq a, Num a) => a
GL_BUFFER_OBJECT_APPLE = 0x85B3
pattern GL_PURGEABLE_APPLE :: (Eq a, Num a) => a
pattern $mGL_PURGEABLE_APPLE :: forall {r} {a}.
(Eq a, Num a) =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
$bGL_PURGEABLE_APPLE :: forall a. (Eq a, Num a) => a
GL_PURGEABLE_APPLE = 0x8A1D
pattern GL_RELEASED_APPLE :: (Eq a, Num a) => a
pattern $mGL_RELEASED_APPLE :: forall {r} {a}.
(Eq a, Num a) =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
$bGL_RELEASED_APPLE :: forall a. (Eq a, Num a) => a
GL_RELEASED_APPLE = 0x8A19
pattern GL_RETAINED_APPLE :: (Eq a, Num a) => a
pattern $mGL_RETAINED_APPLE :: forall {r} {a}.
(Eq a, Num a) =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
$bGL_RETAINED_APPLE :: forall a. (Eq a, Num a) => a
GL_RETAINED_APPLE = 0x8A1B
pattern GL_UNDEFINED_APPLE :: (Eq a, Num a) => a
pattern $mGL_UNDEFINED_APPLE :: forall {r} {a}.
(Eq a, Num a) =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
$bGL_UNDEFINED_APPLE :: forall a. (Eq a, Num a) => a
GL_UNDEFINED_APPLE = 0x8A1C
pattern GL_VOLATILE_APPLE :: (Eq a, Num a) => a
pattern $mGL_VOLATILE_APPLE :: forall {r} {a}.
(Eq a, Num a) =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
$bGL_VOLATILE_APPLE :: forall a. (Eq a, Num a) => a
GL_VOLATILE_APPLE = 0x8A1A