#define ENABLE_OVERLOADING (MIN_VERSION_haskell_gi_overloading(1,0,0) \
&& !defined(__HADDOCK_VERSION__))
module GI.Gdk.Structs.Color
(
Color(..) ,
newZeroColor ,
noColor ,
#if ENABLE_OVERLOADING
ColorCopyMethodInfo ,
#endif
colorCopy ,
#if ENABLE_OVERLOADING
ColorEqualMethodInfo ,
#endif
colorEqual ,
#if ENABLE_OVERLOADING
ColorFreeMethodInfo ,
#endif
colorFree ,
#if ENABLE_OVERLOADING
ColorHashMethodInfo ,
#endif
colorHash ,
colorParse ,
#if ENABLE_OVERLOADING
ColorToStringMethodInfo ,
#endif
colorToString ,
#if ENABLE_OVERLOADING
color_blue ,
#endif
getColorBlue ,
setColorBlue ,
#if ENABLE_OVERLOADING
color_green ,
#endif
getColorGreen ,
setColorGreen ,
#if ENABLE_OVERLOADING
color_pixel ,
#endif
getColorPixel ,
setColorPixel ,
#if ENABLE_OVERLOADING
color_red ,
#endif
getColorRed ,
setColorRed ,
) where
import Data.GI.Base.ShortPrelude
import qualified Data.GI.Base.ShortPrelude as SP
import qualified Data.GI.Base.Overloading as O
import qualified Prelude as P
import qualified Data.GI.Base.Attributes as GI.Attributes
import qualified Data.GI.Base.ManagedPtr as B.ManagedPtr
import qualified Data.GI.Base.GClosure as B.GClosure
import qualified Data.GI.Base.GError as B.GError
import qualified Data.GI.Base.GVariant as B.GVariant
import qualified Data.GI.Base.GValue as B.GValue
import qualified Data.GI.Base.GParamSpec as B.GParamSpec
import qualified Data.GI.Base.CallStack as B.CallStack
import qualified Data.GI.Base.Properties as B.Properties
import qualified Data.Text as T
import qualified Data.ByteString.Char8 as B
import qualified Data.Map as Map
import qualified Foreign.Ptr as FP
import qualified GHC.OverloadedLabels as OL
newtype Color = Color (ManagedPtr Color)
foreign import ccall "gdk_color_get_type" c_gdk_color_get_type ::
IO GType
instance BoxedObject Color where
boxedType _ = c_gdk_color_get_type
newZeroColor :: MonadIO m => m Color
newZeroColor = liftIO $ callocBoxedBytes 12 >>= wrapBoxed Color
instance tag ~ 'AttrSet => Constructible Color tag where
new _ attrs = do
o <- newZeroColor
GI.Attributes.set o attrs
return o
noColor :: Maybe Color
noColor = Nothing
getColorPixel :: MonadIO m => Color -> m Word32
getColorPixel s = liftIO $ withManagedPtr s $ \ptr -> do
val <- peek (ptr `plusPtr` 0) :: IO Word32
return val
setColorPixel :: MonadIO m => Color -> Word32 -> m ()
setColorPixel s val = liftIO $ withManagedPtr s $ \ptr -> do
poke (ptr `plusPtr` 0) (val :: Word32)
#if ENABLE_OVERLOADING
data ColorPixelFieldInfo
instance AttrInfo ColorPixelFieldInfo where
type AttrAllowedOps ColorPixelFieldInfo = '[ 'AttrSet, 'AttrGet]
type AttrSetTypeConstraint ColorPixelFieldInfo = (~) Word32
type AttrBaseTypeConstraint ColorPixelFieldInfo = (~) Color
type AttrGetType ColorPixelFieldInfo = Word32
type AttrLabel ColorPixelFieldInfo = "pixel"
type AttrOrigin ColorPixelFieldInfo = Color
attrGet _ = getColorPixel
attrSet _ = setColorPixel
attrConstruct = undefined
attrClear _ = undefined
color_pixel :: AttrLabelProxy "pixel"
color_pixel = AttrLabelProxy
#endif
getColorRed :: MonadIO m => Color -> m Word16
getColorRed s = liftIO $ withManagedPtr s $ \ptr -> do
val <- peek (ptr `plusPtr` 4) :: IO Word16
return val
setColorRed :: MonadIO m => Color -> Word16 -> m ()
setColorRed s val = liftIO $ withManagedPtr s $ \ptr -> do
poke (ptr `plusPtr` 4) (val :: Word16)
#if ENABLE_OVERLOADING
data ColorRedFieldInfo
instance AttrInfo ColorRedFieldInfo where
type AttrAllowedOps ColorRedFieldInfo = '[ 'AttrSet, 'AttrGet]
type AttrSetTypeConstraint ColorRedFieldInfo = (~) Word16
type AttrBaseTypeConstraint ColorRedFieldInfo = (~) Color
type AttrGetType ColorRedFieldInfo = Word16
type AttrLabel ColorRedFieldInfo = "red"
type AttrOrigin ColorRedFieldInfo = Color
attrGet _ = getColorRed
attrSet _ = setColorRed
attrConstruct = undefined
attrClear _ = undefined
color_red :: AttrLabelProxy "red"
color_red = AttrLabelProxy
#endif
getColorGreen :: MonadIO m => Color -> m Word16
getColorGreen s = liftIO $ withManagedPtr s $ \ptr -> do
val <- peek (ptr `plusPtr` 6) :: IO Word16
return val
setColorGreen :: MonadIO m => Color -> Word16 -> m ()
setColorGreen s val = liftIO $ withManagedPtr s $ \ptr -> do
poke (ptr `plusPtr` 6) (val :: Word16)
#if ENABLE_OVERLOADING
data ColorGreenFieldInfo
instance AttrInfo ColorGreenFieldInfo where
type AttrAllowedOps ColorGreenFieldInfo = '[ 'AttrSet, 'AttrGet]
type AttrSetTypeConstraint ColorGreenFieldInfo = (~) Word16
type AttrBaseTypeConstraint ColorGreenFieldInfo = (~) Color
type AttrGetType ColorGreenFieldInfo = Word16
type AttrLabel ColorGreenFieldInfo = "green"
type AttrOrigin ColorGreenFieldInfo = Color
attrGet _ = getColorGreen
attrSet _ = setColorGreen
attrConstruct = undefined
attrClear _ = undefined
color_green :: AttrLabelProxy "green"
color_green = AttrLabelProxy
#endif
getColorBlue :: MonadIO m => Color -> m Word16
getColorBlue s = liftIO $ withManagedPtr s $ \ptr -> do
val <- peek (ptr `plusPtr` 8) :: IO Word16
return val
setColorBlue :: MonadIO m => Color -> Word16 -> m ()
setColorBlue s val = liftIO $ withManagedPtr s $ \ptr -> do
poke (ptr `plusPtr` 8) (val :: Word16)
#if ENABLE_OVERLOADING
data ColorBlueFieldInfo
instance AttrInfo ColorBlueFieldInfo where
type AttrAllowedOps ColorBlueFieldInfo = '[ 'AttrSet, 'AttrGet]
type AttrSetTypeConstraint ColorBlueFieldInfo = (~) Word16
type AttrBaseTypeConstraint ColorBlueFieldInfo = (~) Color
type AttrGetType ColorBlueFieldInfo = Word16
type AttrLabel ColorBlueFieldInfo = "blue"
type AttrOrigin ColorBlueFieldInfo = Color
attrGet _ = getColorBlue
attrSet _ = setColorBlue
attrConstruct = undefined
attrClear _ = undefined
color_blue :: AttrLabelProxy "blue"
color_blue = AttrLabelProxy
#endif
#if ENABLE_OVERLOADING
instance O.HasAttributeList Color
type instance O.AttributeList Color = ColorAttributeList
type ColorAttributeList = ('[ '("pixel", ColorPixelFieldInfo), '("red", ColorRedFieldInfo), '("green", ColorGreenFieldInfo), '("blue", ColorBlueFieldInfo)] :: [(Symbol, *)])
#endif
foreign import ccall "gdk_color_copy" gdk_color_copy ::
Ptr Color ->
IO (Ptr Color)
{-# DEPRECATED colorCopy ["(Since version 3.14)","Use 'GI.Gdk.Structs.RGBA.RGBA'"] #-}
colorCopy ::
(B.CallStack.HasCallStack, MonadIO m) =>
Color
-> m Color
colorCopy color = liftIO $ do
color' <- unsafeManagedPtrGetPtr color
result <- gdk_color_copy color'
checkUnexpectedReturnNULL "colorCopy" result
result' <- (wrapBoxed Color) result
touchManagedPtr color
return result'
#if ENABLE_OVERLOADING
data ColorCopyMethodInfo
instance (signature ~ (m Color), MonadIO m) => O.MethodInfo ColorCopyMethodInfo Color signature where
overloadedMethod _ = colorCopy
#endif
foreign import ccall "gdk_color_equal" gdk_color_equal ::
Ptr Color ->
Ptr Color ->
IO CInt
{-# DEPRECATED colorEqual ["(Since version 3.14)","Use 'GI.Gdk.Structs.RGBA.RGBA'"] #-}
colorEqual ::
(B.CallStack.HasCallStack, MonadIO m) =>
Color
-> Color
-> m Bool
colorEqual colora colorb = liftIO $ do
colora' <- unsafeManagedPtrGetPtr colora
colorb' <- unsafeManagedPtrGetPtr colorb
result <- gdk_color_equal colora' colorb'
let result' = (/= 0) result
touchManagedPtr colora
touchManagedPtr colorb
return result'
#if ENABLE_OVERLOADING
data ColorEqualMethodInfo
instance (signature ~ (Color -> m Bool), MonadIO m) => O.MethodInfo ColorEqualMethodInfo Color signature where
overloadedMethod _ = colorEqual
#endif
foreign import ccall "gdk_color_free" gdk_color_free ::
Ptr Color ->
IO ()
{-# DEPRECATED colorFree ["(Since version 3.14)","Use 'GI.Gdk.Structs.RGBA.RGBA'"] #-}
colorFree ::
(B.CallStack.HasCallStack, MonadIO m) =>
Color
-> m ()
colorFree color = liftIO $ do
color' <- unsafeManagedPtrGetPtr color
gdk_color_free color'
touchManagedPtr color
return ()
#if ENABLE_OVERLOADING
data ColorFreeMethodInfo
instance (signature ~ (m ()), MonadIO m) => O.MethodInfo ColorFreeMethodInfo Color signature where
overloadedMethod _ = colorFree
#endif
foreign import ccall "gdk_color_hash" gdk_color_hash ::
Ptr Color ->
IO Word32
{-# DEPRECATED colorHash ["(Since version 3.14)","Use 'GI.Gdk.Structs.RGBA.RGBA'"] #-}
colorHash ::
(B.CallStack.HasCallStack, MonadIO m) =>
Color
-> m Word32
colorHash color = liftIO $ do
color' <- unsafeManagedPtrGetPtr color
result <- gdk_color_hash color'
touchManagedPtr color
return result
#if ENABLE_OVERLOADING
data ColorHashMethodInfo
instance (signature ~ (m Word32), MonadIO m) => O.MethodInfo ColorHashMethodInfo Color signature where
overloadedMethod _ = colorHash
#endif
foreign import ccall "gdk_color_to_string" gdk_color_to_string ::
Ptr Color ->
IO CString
{-# DEPRECATED colorToString ["(Since version 3.14)","Use 'GI.Gdk.Structs.RGBA.RGBA'"] #-}
colorToString ::
(B.CallStack.HasCallStack, MonadIO m) =>
Color
-> m T.Text
colorToString color = liftIO $ do
color' <- unsafeManagedPtrGetPtr color
result <- gdk_color_to_string color'
checkUnexpectedReturnNULL "colorToString" result
result' <- cstringToText result
freeMem result
touchManagedPtr color
return result'
#if ENABLE_OVERLOADING
data ColorToStringMethodInfo
instance (signature ~ (m T.Text), MonadIO m) => O.MethodInfo ColorToStringMethodInfo Color signature where
overloadedMethod _ = colorToString
#endif
foreign import ccall "gdk_color_parse" gdk_color_parse ::
CString ->
Ptr Color ->
IO CInt
{-# DEPRECATED colorParse ["(Since version 3.14)","Use 'GI.Gdk.Structs.RGBA.RGBA'"] #-}
colorParse ::
(B.CallStack.HasCallStack, MonadIO m) =>
T.Text
-> m ((Bool, Color))
colorParse spec = liftIO $ do
spec' <- textToCString spec
color <- callocBoxedBytes 12 :: IO (Ptr Color)
result <- gdk_color_parse spec' color
let result' = (/= 0) result
color' <- (wrapBoxed Color) color
freeMem spec'
return (result', color')
#if ENABLE_OVERLOADING
#endif
#if ENABLE_OVERLOADING
type family ResolveColorMethod (t :: Symbol) (o :: *) :: * where
ResolveColorMethod "copy" o = ColorCopyMethodInfo
ResolveColorMethod "equal" o = ColorEqualMethodInfo
ResolveColorMethod "free" o = ColorFreeMethodInfo
ResolveColorMethod "hash" o = ColorHashMethodInfo
ResolveColorMethod "toString" o = ColorToStringMethodInfo
ResolveColorMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveColorMethod t Color, O.MethodInfo info Color p) => OL.IsLabel t (Color -> p) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.overloadedMethod (O.MethodProxy :: O.MethodProxy info)
#else
fromLabel _ = O.overloadedMethod (O.MethodProxy :: O.MethodProxy info)
#endif
#endif