#define ENABLE_OVERLOADING (MIN_VERSION_haskell_gi_overloading(1,0,0) \
&& !defined(__HADDOCK_VERSION__))
module GI.Gtk.Structs.BindingSet
(
BindingSet(..) ,
newZeroBindingSet ,
noBindingSet ,
#if ENABLE_OVERLOADING
BindingSetActivateMethodInfo ,
#endif
bindingSetActivate ,
#if ENABLE_OVERLOADING
BindingSetAddPathMethodInfo ,
#endif
bindingSetAddPath ,
bindingSetFind ,
#if ENABLE_OVERLOADING
bindingSet_classBranchPspecs ,
#endif
clearBindingSetClassBranchPspecs ,
getBindingSetClassBranchPspecs ,
setBindingSetClassBranchPspecs ,
#if ENABLE_OVERLOADING
bindingSet_current ,
#endif
clearBindingSetCurrent ,
getBindingSetCurrent ,
setBindingSetCurrent ,
#if ENABLE_OVERLOADING
bindingSet_entries ,
#endif
clearBindingSetEntries ,
getBindingSetEntries ,
setBindingSetEntries ,
#if ENABLE_OVERLOADING
bindingSet_parsed ,
#endif
getBindingSetParsed ,
setBindingSetParsed ,
#if ENABLE_OVERLOADING
bindingSet_priority ,
#endif
getBindingSetPriority ,
setBindingSetPriority ,
#if ENABLE_OVERLOADING
bindingSet_setName ,
#endif
clearBindingSetSetName ,
getBindingSetSetName ,
setBindingSetSetName ,
#if ENABLE_OVERLOADING
bindingSet_widgetClassPspecs ,
#endif
clearBindingSetWidgetClassPspecs ,
getBindingSetWidgetClassPspecs ,
setBindingSetWidgetClassPspecs ,
#if ENABLE_OVERLOADING
bindingSet_widgetPathPspecs ,
#endif
clearBindingSetWidgetPathPspecs ,
getBindingSetWidgetPathPspecs ,
setBindingSetWidgetPathPspecs ,
) 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
import qualified GI.GObject.Objects.Object as GObject.Object
import qualified GI.Gdk.Flags as Gdk.Flags
import {-# SOURCE #-} qualified GI.Gtk.Enums as Gtk.Enums
import {-# SOURCE #-} qualified GI.Gtk.Structs.BindingEntry as Gtk.BindingEntry
newtype BindingSet = BindingSet (ManagedPtr BindingSet)
instance WrappedPtr BindingSet where
wrappedPtrCalloc = callocBytes 64
wrappedPtrCopy = \p -> withManagedPtr p (copyBytes 64 >=> wrapPtr BindingSet)
wrappedPtrFree = Just ptr_to_g_free
newZeroBindingSet :: MonadIO m => m BindingSet
newZeroBindingSet = liftIO $ wrappedPtrCalloc >>= wrapPtr BindingSet
instance tag ~ 'AttrSet => Constructible BindingSet tag where
new _ attrs = do
o <- newZeroBindingSet
GI.Attributes.set o attrs
return o
noBindingSet :: Maybe BindingSet
noBindingSet = Nothing
getBindingSetSetName :: MonadIO m => BindingSet -> m (Maybe T.Text)
getBindingSetSetName s = liftIO $ withManagedPtr s $ \ptr -> do
val <- peek (ptr `plusPtr` 0) :: IO CString
result <- SP.convertIfNonNull val $ \val' -> do
val'' <- cstringToText val'
return val''
return result
setBindingSetSetName :: MonadIO m => BindingSet -> CString -> m ()
setBindingSetSetName s val = liftIO $ withManagedPtr s $ \ptr -> do
poke (ptr `plusPtr` 0) (val :: CString)
clearBindingSetSetName :: MonadIO m => BindingSet -> m ()
clearBindingSetSetName s = liftIO $ withManagedPtr s $ \ptr -> do
poke (ptr `plusPtr` 0) (FP.nullPtr :: CString)
#if ENABLE_OVERLOADING
data BindingSetSetNameFieldInfo
instance AttrInfo BindingSetSetNameFieldInfo where
type AttrAllowedOps BindingSetSetNameFieldInfo = '[ 'AttrSet, 'AttrGet, 'AttrClear]
type AttrSetTypeConstraint BindingSetSetNameFieldInfo = (~) CString
type AttrBaseTypeConstraint BindingSetSetNameFieldInfo = (~) BindingSet
type AttrGetType BindingSetSetNameFieldInfo = Maybe T.Text
type AttrLabel BindingSetSetNameFieldInfo = "set_name"
type AttrOrigin BindingSetSetNameFieldInfo = BindingSet
attrGet _ = getBindingSetSetName
attrSet _ = setBindingSetSetName
attrConstruct = undefined
attrClear _ = clearBindingSetSetName
bindingSet_setName :: AttrLabelProxy "setName"
bindingSet_setName = AttrLabelProxy
#endif
getBindingSetPriority :: MonadIO m => BindingSet -> m Int32
getBindingSetPriority s = liftIO $ withManagedPtr s $ \ptr -> do
val <- peek (ptr `plusPtr` 8) :: IO Int32
return val
setBindingSetPriority :: MonadIO m => BindingSet -> Int32 -> m ()
setBindingSetPriority s val = liftIO $ withManagedPtr s $ \ptr -> do
poke (ptr `plusPtr` 8) (val :: Int32)
#if ENABLE_OVERLOADING
data BindingSetPriorityFieldInfo
instance AttrInfo BindingSetPriorityFieldInfo where
type AttrAllowedOps BindingSetPriorityFieldInfo = '[ 'AttrSet, 'AttrGet]
type AttrSetTypeConstraint BindingSetPriorityFieldInfo = (~) Int32
type AttrBaseTypeConstraint BindingSetPriorityFieldInfo = (~) BindingSet
type AttrGetType BindingSetPriorityFieldInfo = Int32
type AttrLabel BindingSetPriorityFieldInfo = "priority"
type AttrOrigin BindingSetPriorityFieldInfo = BindingSet
attrGet _ = getBindingSetPriority
attrSet _ = setBindingSetPriority
attrConstruct = undefined
attrClear _ = undefined
bindingSet_priority :: AttrLabelProxy "priority"
bindingSet_priority = AttrLabelProxy
#endif
getBindingSetWidgetPathPspecs :: MonadIO m => BindingSet -> m ([Ptr ()])
getBindingSetWidgetPathPspecs s = liftIO $ withManagedPtr s $ \ptr -> do
val <- peek (ptr `plusPtr` 16) :: IO (Ptr (GSList (Ptr ())))
val' <- unpackGSList val
return val'
setBindingSetWidgetPathPspecs :: MonadIO m => BindingSet -> Ptr (GSList (Ptr ())) -> m ()
setBindingSetWidgetPathPspecs s val = liftIO $ withManagedPtr s $ \ptr -> do
poke (ptr `plusPtr` 16) (val :: Ptr (GSList (Ptr ())))
clearBindingSetWidgetPathPspecs :: MonadIO m => BindingSet -> m ()
clearBindingSetWidgetPathPspecs s = liftIO $ withManagedPtr s $ \ptr -> do
poke (ptr `plusPtr` 16) (FP.nullPtr :: Ptr (GSList (Ptr ())))
#if ENABLE_OVERLOADING
data BindingSetWidgetPathPspecsFieldInfo
instance AttrInfo BindingSetWidgetPathPspecsFieldInfo where
type AttrAllowedOps BindingSetWidgetPathPspecsFieldInfo = '[ 'AttrSet, 'AttrGet, 'AttrClear]
type AttrSetTypeConstraint BindingSetWidgetPathPspecsFieldInfo = (~) (Ptr (GSList (Ptr ())))
type AttrBaseTypeConstraint BindingSetWidgetPathPspecsFieldInfo = (~) BindingSet
type AttrGetType BindingSetWidgetPathPspecsFieldInfo = [Ptr ()]
type AttrLabel BindingSetWidgetPathPspecsFieldInfo = "widget_path_pspecs"
type AttrOrigin BindingSetWidgetPathPspecsFieldInfo = BindingSet
attrGet _ = getBindingSetWidgetPathPspecs
attrSet _ = setBindingSetWidgetPathPspecs
attrConstruct = undefined
attrClear _ = clearBindingSetWidgetPathPspecs
bindingSet_widgetPathPspecs :: AttrLabelProxy "widgetPathPspecs"
bindingSet_widgetPathPspecs = AttrLabelProxy
#endif
getBindingSetWidgetClassPspecs :: MonadIO m => BindingSet -> m ([Ptr ()])
getBindingSetWidgetClassPspecs s = liftIO $ withManagedPtr s $ \ptr -> do
val <- peek (ptr `plusPtr` 24) :: IO (Ptr (GSList (Ptr ())))
val' <- unpackGSList val
return val'
setBindingSetWidgetClassPspecs :: MonadIO m => BindingSet -> Ptr (GSList (Ptr ())) -> m ()
setBindingSetWidgetClassPspecs s val = liftIO $ withManagedPtr s $ \ptr -> do
poke (ptr `plusPtr` 24) (val :: Ptr (GSList (Ptr ())))
clearBindingSetWidgetClassPspecs :: MonadIO m => BindingSet -> m ()
clearBindingSetWidgetClassPspecs s = liftIO $ withManagedPtr s $ \ptr -> do
poke (ptr `plusPtr` 24) (FP.nullPtr :: Ptr (GSList (Ptr ())))
#if ENABLE_OVERLOADING
data BindingSetWidgetClassPspecsFieldInfo
instance AttrInfo BindingSetWidgetClassPspecsFieldInfo where
type AttrAllowedOps BindingSetWidgetClassPspecsFieldInfo = '[ 'AttrSet, 'AttrGet, 'AttrClear]
type AttrSetTypeConstraint BindingSetWidgetClassPspecsFieldInfo = (~) (Ptr (GSList (Ptr ())))
type AttrBaseTypeConstraint BindingSetWidgetClassPspecsFieldInfo = (~) BindingSet
type AttrGetType BindingSetWidgetClassPspecsFieldInfo = [Ptr ()]
type AttrLabel BindingSetWidgetClassPspecsFieldInfo = "widget_class_pspecs"
type AttrOrigin BindingSetWidgetClassPspecsFieldInfo = BindingSet
attrGet _ = getBindingSetWidgetClassPspecs
attrSet _ = setBindingSetWidgetClassPspecs
attrConstruct = undefined
attrClear _ = clearBindingSetWidgetClassPspecs
bindingSet_widgetClassPspecs :: AttrLabelProxy "widgetClassPspecs"
bindingSet_widgetClassPspecs = AttrLabelProxy
#endif
getBindingSetClassBranchPspecs :: MonadIO m => BindingSet -> m ([Ptr ()])
getBindingSetClassBranchPspecs s = liftIO $ withManagedPtr s $ \ptr -> do
val <- peek (ptr `plusPtr` 32) :: IO (Ptr (GSList (Ptr ())))
val' <- unpackGSList val
return val'
setBindingSetClassBranchPspecs :: MonadIO m => BindingSet -> Ptr (GSList (Ptr ())) -> m ()
setBindingSetClassBranchPspecs s val = liftIO $ withManagedPtr s $ \ptr -> do
poke (ptr `plusPtr` 32) (val :: Ptr (GSList (Ptr ())))
clearBindingSetClassBranchPspecs :: MonadIO m => BindingSet -> m ()
clearBindingSetClassBranchPspecs s = liftIO $ withManagedPtr s $ \ptr -> do
poke (ptr `plusPtr` 32) (FP.nullPtr :: Ptr (GSList (Ptr ())))
#if ENABLE_OVERLOADING
data BindingSetClassBranchPspecsFieldInfo
instance AttrInfo BindingSetClassBranchPspecsFieldInfo where
type AttrAllowedOps BindingSetClassBranchPspecsFieldInfo = '[ 'AttrSet, 'AttrGet, 'AttrClear]
type AttrSetTypeConstraint BindingSetClassBranchPspecsFieldInfo = (~) (Ptr (GSList (Ptr ())))
type AttrBaseTypeConstraint BindingSetClassBranchPspecsFieldInfo = (~) BindingSet
type AttrGetType BindingSetClassBranchPspecsFieldInfo = [Ptr ()]
type AttrLabel BindingSetClassBranchPspecsFieldInfo = "class_branch_pspecs"
type AttrOrigin BindingSetClassBranchPspecsFieldInfo = BindingSet
attrGet _ = getBindingSetClassBranchPspecs
attrSet _ = setBindingSetClassBranchPspecs
attrConstruct = undefined
attrClear _ = clearBindingSetClassBranchPspecs
bindingSet_classBranchPspecs :: AttrLabelProxy "classBranchPspecs"
bindingSet_classBranchPspecs = AttrLabelProxy
#endif
getBindingSetEntries :: MonadIO m => BindingSet -> m (Maybe Gtk.BindingEntry.BindingEntry)
getBindingSetEntries s = liftIO $ withManagedPtr s $ \ptr -> do
val <- peek (ptr `plusPtr` 40) :: IO (Ptr Gtk.BindingEntry.BindingEntry)
result <- SP.convertIfNonNull val $ \val' -> do
val'' <- (newPtr Gtk.BindingEntry.BindingEntry) val'
return val''
return result
setBindingSetEntries :: MonadIO m => BindingSet -> Ptr Gtk.BindingEntry.BindingEntry -> m ()
setBindingSetEntries s val = liftIO $ withManagedPtr s $ \ptr -> do
poke (ptr `plusPtr` 40) (val :: Ptr Gtk.BindingEntry.BindingEntry)
clearBindingSetEntries :: MonadIO m => BindingSet -> m ()
clearBindingSetEntries s = liftIO $ withManagedPtr s $ \ptr -> do
poke (ptr `plusPtr` 40) (FP.nullPtr :: Ptr Gtk.BindingEntry.BindingEntry)
#if ENABLE_OVERLOADING
data BindingSetEntriesFieldInfo
instance AttrInfo BindingSetEntriesFieldInfo where
type AttrAllowedOps BindingSetEntriesFieldInfo = '[ 'AttrSet, 'AttrGet, 'AttrClear]
type AttrSetTypeConstraint BindingSetEntriesFieldInfo = (~) (Ptr Gtk.BindingEntry.BindingEntry)
type AttrBaseTypeConstraint BindingSetEntriesFieldInfo = (~) BindingSet
type AttrGetType BindingSetEntriesFieldInfo = Maybe Gtk.BindingEntry.BindingEntry
type AttrLabel BindingSetEntriesFieldInfo = "entries"
type AttrOrigin BindingSetEntriesFieldInfo = BindingSet
attrGet _ = getBindingSetEntries
attrSet _ = setBindingSetEntries
attrConstruct = undefined
attrClear _ = clearBindingSetEntries
bindingSet_entries :: AttrLabelProxy "entries"
bindingSet_entries = AttrLabelProxy
#endif
getBindingSetCurrent :: MonadIO m => BindingSet -> m (Maybe Gtk.BindingEntry.BindingEntry)
getBindingSetCurrent s = liftIO $ withManagedPtr s $ \ptr -> do
val <- peek (ptr `plusPtr` 48) :: IO (Ptr Gtk.BindingEntry.BindingEntry)
result <- SP.convertIfNonNull val $ \val' -> do
val'' <- (newPtr Gtk.BindingEntry.BindingEntry) val'
return val''
return result
setBindingSetCurrent :: MonadIO m => BindingSet -> Ptr Gtk.BindingEntry.BindingEntry -> m ()
setBindingSetCurrent s val = liftIO $ withManagedPtr s $ \ptr -> do
poke (ptr `plusPtr` 48) (val :: Ptr Gtk.BindingEntry.BindingEntry)
clearBindingSetCurrent :: MonadIO m => BindingSet -> m ()
clearBindingSetCurrent s = liftIO $ withManagedPtr s $ \ptr -> do
poke (ptr `plusPtr` 48) (FP.nullPtr :: Ptr Gtk.BindingEntry.BindingEntry)
#if ENABLE_OVERLOADING
data BindingSetCurrentFieldInfo
instance AttrInfo BindingSetCurrentFieldInfo where
type AttrAllowedOps BindingSetCurrentFieldInfo = '[ 'AttrSet, 'AttrGet, 'AttrClear]
type AttrSetTypeConstraint BindingSetCurrentFieldInfo = (~) (Ptr Gtk.BindingEntry.BindingEntry)
type AttrBaseTypeConstraint BindingSetCurrentFieldInfo = (~) BindingSet
type AttrGetType BindingSetCurrentFieldInfo = Maybe Gtk.BindingEntry.BindingEntry
type AttrLabel BindingSetCurrentFieldInfo = "current"
type AttrOrigin BindingSetCurrentFieldInfo = BindingSet
attrGet _ = getBindingSetCurrent
attrSet _ = setBindingSetCurrent
attrConstruct = undefined
attrClear _ = clearBindingSetCurrent
bindingSet_current :: AttrLabelProxy "current"
bindingSet_current = AttrLabelProxy
#endif
getBindingSetParsed :: MonadIO m => BindingSet -> m Word32
getBindingSetParsed s = liftIO $ withManagedPtr s $ \ptr -> do
val <- peek (ptr `plusPtr` 56) :: IO Word32
return val
setBindingSetParsed :: MonadIO m => BindingSet -> Word32 -> m ()
setBindingSetParsed s val = liftIO $ withManagedPtr s $ \ptr -> do
poke (ptr `plusPtr` 56) (val :: Word32)
#if ENABLE_OVERLOADING
data BindingSetParsedFieldInfo
instance AttrInfo BindingSetParsedFieldInfo where
type AttrAllowedOps BindingSetParsedFieldInfo = '[ 'AttrSet, 'AttrGet]
type AttrSetTypeConstraint BindingSetParsedFieldInfo = (~) Word32
type AttrBaseTypeConstraint BindingSetParsedFieldInfo = (~) BindingSet
type AttrGetType BindingSetParsedFieldInfo = Word32
type AttrLabel BindingSetParsedFieldInfo = "parsed"
type AttrOrigin BindingSetParsedFieldInfo = BindingSet
attrGet _ = getBindingSetParsed
attrSet _ = setBindingSetParsed
attrConstruct = undefined
attrClear _ = undefined
bindingSet_parsed :: AttrLabelProxy "parsed"
bindingSet_parsed = AttrLabelProxy
#endif
#if ENABLE_OVERLOADING
instance O.HasAttributeList BindingSet
type instance O.AttributeList BindingSet = BindingSetAttributeList
type BindingSetAttributeList = ('[ '("setName", BindingSetSetNameFieldInfo), '("priority", BindingSetPriorityFieldInfo), '("widgetPathPspecs", BindingSetWidgetPathPspecsFieldInfo), '("widgetClassPspecs", BindingSetWidgetClassPspecsFieldInfo), '("classBranchPspecs", BindingSetClassBranchPspecsFieldInfo), '("entries", BindingSetEntriesFieldInfo), '("current", BindingSetCurrentFieldInfo), '("parsed", BindingSetParsedFieldInfo)] :: [(Symbol, *)])
#endif
foreign import ccall "gtk_binding_set_activate" gtk_binding_set_activate ::
Ptr BindingSet ->
Word32 ->
CUInt ->
Ptr GObject.Object.Object ->
IO CInt
bindingSetActivate ::
(B.CallStack.HasCallStack, MonadIO m, GObject.Object.IsObject a) =>
BindingSet
-> Word32
-> [Gdk.Flags.ModifierType]
-> a
-> m Bool
bindingSetActivate bindingSet keyval modifiers object = liftIO $ do
bindingSet' <- unsafeManagedPtrGetPtr bindingSet
let modifiers' = gflagsToWord modifiers
object' <- unsafeManagedPtrCastPtr object
result <- gtk_binding_set_activate bindingSet' keyval modifiers' object'
let result' = (/= 0) result
touchManagedPtr bindingSet
touchManagedPtr object
return result'
#if ENABLE_OVERLOADING
data BindingSetActivateMethodInfo
instance (signature ~ (Word32 -> [Gdk.Flags.ModifierType] -> a -> m Bool), MonadIO m, GObject.Object.IsObject a) => O.MethodInfo BindingSetActivateMethodInfo BindingSet signature where
overloadedMethod _ = bindingSetActivate
#endif
foreign import ccall "gtk_binding_set_add_path" gtk_binding_set_add_path ::
Ptr BindingSet ->
CUInt ->
CString ->
CUInt ->
IO ()
{-# DEPRECATED bindingSetAddPath ["(Since version 3.0)"] #-}
bindingSetAddPath ::
(B.CallStack.HasCallStack, MonadIO m) =>
BindingSet
-> Gtk.Enums.PathType
-> T.Text
-> Gtk.Enums.PathPriorityType
-> m ()
bindingSetAddPath bindingSet pathType pathPattern priority = liftIO $ do
bindingSet' <- unsafeManagedPtrGetPtr bindingSet
let pathType' = (fromIntegral . fromEnum) pathType
pathPattern' <- textToCString pathPattern
let priority' = (fromIntegral . fromEnum) priority
gtk_binding_set_add_path bindingSet' pathType' pathPattern' priority'
touchManagedPtr bindingSet
freeMem pathPattern'
return ()
#if ENABLE_OVERLOADING
data BindingSetAddPathMethodInfo
instance (signature ~ (Gtk.Enums.PathType -> T.Text -> Gtk.Enums.PathPriorityType -> m ()), MonadIO m) => O.MethodInfo BindingSetAddPathMethodInfo BindingSet signature where
overloadedMethod _ = bindingSetAddPath
#endif
foreign import ccall "gtk_binding_set_find" gtk_binding_set_find ::
CString ->
IO (Ptr BindingSet)
bindingSetFind ::
(B.CallStack.HasCallStack, MonadIO m) =>
T.Text
-> m (Maybe BindingSet)
bindingSetFind setName = liftIO $ do
setName' <- textToCString setName
result <- gtk_binding_set_find setName'
maybeResult <- convertIfNonNull result $ \result' -> do
result'' <- (newPtr BindingSet) result'
return result''
freeMem setName'
return maybeResult
#if ENABLE_OVERLOADING
#endif
#if ENABLE_OVERLOADING
type family ResolveBindingSetMethod (t :: Symbol) (o :: *) :: * where
ResolveBindingSetMethod "activate" o = BindingSetActivateMethodInfo
ResolveBindingSetMethod "addPath" o = BindingSetAddPathMethodInfo
ResolveBindingSetMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveBindingSetMethod t BindingSet, O.MethodInfo info BindingSet p) => OL.IsLabel t (BindingSet -> 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