{-# LANGUAGE CPP, ScopedTypeVariables, PatternSynonyms #-}
module Graphics.GL.Ext.EXT.TexturePerturbNormal (
gl_EXT_texture_perturb_normal
, glTextureNormalEXT
, pattern GL_PERTURB_EXT
, pattern GL_TEXTURE_NORMAL_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_texture_perturb_normal :: Bool
gl_EXT_texture_perturb_normal :: Bool
gl_EXT_texture_perturb_normal = String -> Set String -> Bool
forall a. Ord a => a -> Set a -> Bool
member String
"GL_EXT_texture_perturb_normal" Set String
extensions
{-# NOINLINE gl_EXT_texture_perturb_normal #-}
glTextureNormalEXT :: MonadIO m => GLenum -> m ()
glTextureNormalEXT :: forall (m :: * -> *). MonadIO m => GLenum -> m ()
glTextureNormalEXT = FunPtr (GLenum -> IO ()) -> GLenum -> m ()
forall (m :: * -> *).
MonadIO m =>
FunPtr (GLenum -> IO ()) -> GLenum -> m ()
ffienumIOV FunPtr (GLenum -> IO ())
glTextureNormalEXTFunPtr
glTextureNormalEXTFunPtr :: FunPtr (GLenum -> IO ())
glTextureNormalEXTFunPtr :: FunPtr (GLenum -> IO ())
glTextureNormalEXTFunPtr = IO (FunPtr (GLenum -> IO ())) -> FunPtr (GLenum -> IO ())
forall a. IO a -> a
unsafePerformIO (String -> IO (FunPtr (GLenum -> IO ()))
forall a. String -> IO (FunPtr a)
getProcAddress String
"glTextureNormalEXT")
{-# NOINLINE glTextureNormalEXTFunPtr #-}
pattern GL_PERTURB_EXT :: (Eq a, Num a) => a
pattern $mGL_PERTURB_EXT :: forall {r} {a}.
(Eq a, Num a) =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
$bGL_PERTURB_EXT :: forall a. (Eq a, Num a) => a
GL_PERTURB_EXT = 0x85AE
pattern GL_TEXTURE_NORMAL_EXT :: (Eq a, Num a) => a
pattern $mGL_TEXTURE_NORMAL_EXT :: forall {r} {a}.
(Eq a, Num a) =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
$bGL_TEXTURE_NORMAL_EXT :: forall a. (Eq a, Num a) => a
GL_TEXTURE_NORMAL_EXT = 0x85AF