{-# LANGUAGE CPP, ScopedTypeVariables, PatternSynonyms #-}
module Graphics.GL.Ext.EXT.X11SyncObject (
gl_EXT_x11_sync_object
, glImportSyncEXT
, pattern GL_SYNC_X11_FENCE_EXT
) 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_EXT_x11_sync_object :: Bool
gl_EXT_x11_sync_object :: Bool
gl_EXT_x11_sync_object = String -> Set String -> Bool
forall a. Ord a => a -> Set a -> Bool
member String
"GL_EXT_x11_sync_object" Set String
extensions
{-# NOINLINE gl_EXT_x11_sync_object #-}
glImportSyncEXT :: MonadIO m => GLenum -> GLintptr -> GLbitfield -> m GLsync
glImportSyncEXT :: forall (m :: * -> *).
MonadIO m =>
GLenum -> GLintptr -> GLenum -> m GLsync
glImportSyncEXT = FunPtr (GLenum -> GLintptr -> GLenum -> IO GLsync)
-> GLenum -> GLintptr -> GLenum -> m GLsync
forall (m :: * -> *).
MonadIO m =>
FunPtr (GLenum -> GLintptr -> GLenum -> IO GLsync)
-> GLenum -> GLintptr -> GLenum -> m GLsync
ffienumintptrbitfieldIOsync FunPtr (GLenum -> GLintptr -> GLenum -> IO GLsync)
glImportSyncEXTFunPtr
glImportSyncEXTFunPtr :: FunPtr (GLenum -> GLintptr -> GLbitfield -> IO GLsync)
glImportSyncEXTFunPtr :: FunPtr (GLenum -> GLintptr -> GLenum -> IO GLsync)
glImportSyncEXTFunPtr = IO (FunPtr (GLenum -> GLintptr -> GLenum -> IO GLsync))
-> FunPtr (GLenum -> GLintptr -> GLenum -> IO GLsync)
forall a. IO a -> a
unsafePerformIO (String -> IO (FunPtr (GLenum -> GLintptr -> GLenum -> IO GLsync))
forall a. String -> IO (FunPtr a)
getProcAddress String
"glImportSyncEXT")
{-# NOINLINE glImportSyncEXTFunPtr #-}
pattern GL_SYNC_X11_FENCE_EXT :: (Eq a, Num a) => a
pattern $mGL_SYNC_X11_FENCE_EXT :: forall {r} {a}.
(Eq a, Num a) =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
$bGL_SYNC_X11_FENCE_EXT :: forall a. (Eq a, Num a) => a
GL_SYNC_X11_FENCE_EXT = 0x90E1