#define ENABLE_OVERLOADING (MIN_VERSION_haskell_gi_overloading(1,0,0) \
&& !defined(__HADDOCK_VERSION__))
module GI.Gtk.Objects.Accessible
(
Accessible(..) ,
IsAccessible ,
toAccessible ,
noAccessible ,
#if ENABLE_OVERLOADING
AccessibleConnectWidgetDestroyedMethodInfo,
#endif
accessibleConnectWidgetDestroyed ,
#if ENABLE_OVERLOADING
AccessibleGetWidgetMethodInfo ,
#endif
accessibleGetWidget ,
#if ENABLE_OVERLOADING
AccessibleSetWidgetMethodInfo ,
#endif
accessibleSetWidget ,
#if ENABLE_OVERLOADING
AccessibleWidgetPropertyInfo ,
#endif
#if ENABLE_OVERLOADING
accessibleWidget ,
#endif
clearAccessibleWidget ,
constructAccessibleWidget ,
getAccessibleWidget ,
setAccessibleWidget ,
) 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.Atk.Objects.Object as Atk.Object
import qualified GI.GObject.Objects.Object as GObject.Object
import {-# SOURCE #-} qualified GI.Gtk.Objects.Widget as Gtk.Widget
newtype Accessible = Accessible (ManagedPtr Accessible)
foreign import ccall "gtk_accessible_get_type"
c_gtk_accessible_get_type :: IO GType
instance GObject Accessible where
gobjectType = c_gtk_accessible_get_type
class (GObject o, O.IsDescendantOf Accessible o) => IsAccessible o
instance (GObject o, O.IsDescendantOf Accessible o) => IsAccessible o
instance O.HasParentTypes Accessible
type instance O.ParentTypes Accessible = '[Atk.Object.Object, GObject.Object.Object]
toAccessible :: (MonadIO m, IsAccessible o) => o -> m Accessible
toAccessible = liftIO . unsafeCastTo Accessible
noAccessible :: Maybe Accessible
noAccessible = Nothing
#if ENABLE_OVERLOADING
type family ResolveAccessibleMethod (t :: Symbol) (o :: *) :: * where
ResolveAccessibleMethod "addRelationship" o = Atk.Object.ObjectAddRelationshipMethodInfo
ResolveAccessibleMethod "bindProperty" o = GObject.Object.ObjectBindPropertyMethodInfo
ResolveAccessibleMethod "bindPropertyFull" o = GObject.Object.ObjectBindPropertyFullMethodInfo
ResolveAccessibleMethod "connectWidgetDestroyed" o = AccessibleConnectWidgetDestroyedMethodInfo
ResolveAccessibleMethod "forceFloating" o = GObject.Object.ObjectForceFloatingMethodInfo
ResolveAccessibleMethod "freezeNotify" o = GObject.Object.ObjectFreezeNotifyMethodInfo
ResolveAccessibleMethod "getv" o = GObject.Object.ObjectGetvMethodInfo
ResolveAccessibleMethod "initialize" o = Atk.Object.ObjectInitializeMethodInfo
ResolveAccessibleMethod "isFloating" o = GObject.Object.ObjectIsFloatingMethodInfo
ResolveAccessibleMethod "notify" o = GObject.Object.ObjectNotifyMethodInfo
ResolveAccessibleMethod "notifyByPspec" o = GObject.Object.ObjectNotifyByPspecMethodInfo
ResolveAccessibleMethod "notifyStateChange" o = Atk.Object.ObjectNotifyStateChangeMethodInfo
ResolveAccessibleMethod "peekParent" o = Atk.Object.ObjectPeekParentMethodInfo
ResolveAccessibleMethod "ref" o = GObject.Object.ObjectRefMethodInfo
ResolveAccessibleMethod "refAccessibleChild" o = Atk.Object.ObjectRefAccessibleChildMethodInfo
ResolveAccessibleMethod "refRelationSet" o = Atk.Object.ObjectRefRelationSetMethodInfo
ResolveAccessibleMethod "refSink" o = GObject.Object.ObjectRefSinkMethodInfo
ResolveAccessibleMethod "refStateSet" o = Atk.Object.ObjectRefStateSetMethodInfo
ResolveAccessibleMethod "removePropertyChangeHandler" o = Atk.Object.ObjectRemovePropertyChangeHandlerMethodInfo
ResolveAccessibleMethod "removeRelationship" o = Atk.Object.ObjectRemoveRelationshipMethodInfo
ResolveAccessibleMethod "runDispose" o = GObject.Object.ObjectRunDisposeMethodInfo
ResolveAccessibleMethod "stealData" o = GObject.Object.ObjectStealDataMethodInfo
ResolveAccessibleMethod "stealQdata" o = GObject.Object.ObjectStealQdataMethodInfo
ResolveAccessibleMethod "thawNotify" o = GObject.Object.ObjectThawNotifyMethodInfo
ResolveAccessibleMethod "unref" o = GObject.Object.ObjectUnrefMethodInfo
ResolveAccessibleMethod "watchClosure" o = GObject.Object.ObjectWatchClosureMethodInfo
ResolveAccessibleMethod "getAttributes" o = Atk.Object.ObjectGetAttributesMethodInfo
ResolveAccessibleMethod "getData" o = GObject.Object.ObjectGetDataMethodInfo
ResolveAccessibleMethod "getDescription" o = Atk.Object.ObjectGetDescriptionMethodInfo
ResolveAccessibleMethod "getIndexInParent" o = Atk.Object.ObjectGetIndexInParentMethodInfo
ResolveAccessibleMethod "getLayer" o = Atk.Object.ObjectGetLayerMethodInfo
ResolveAccessibleMethod "getMdiZorder" o = Atk.Object.ObjectGetMdiZorderMethodInfo
ResolveAccessibleMethod "getNAccessibleChildren" o = Atk.Object.ObjectGetNAccessibleChildrenMethodInfo
ResolveAccessibleMethod "getName" o = Atk.Object.ObjectGetNameMethodInfo
ResolveAccessibleMethod "getObjectLocale" o = Atk.Object.ObjectGetObjectLocaleMethodInfo
ResolveAccessibleMethod "getParent" o = Atk.Object.ObjectGetParentMethodInfo
ResolveAccessibleMethod "getProperty" o = GObject.Object.ObjectGetPropertyMethodInfo
ResolveAccessibleMethod "getQdata" o = GObject.Object.ObjectGetQdataMethodInfo
ResolveAccessibleMethod "getRole" o = Atk.Object.ObjectGetRoleMethodInfo
ResolveAccessibleMethod "getWidget" o = AccessibleGetWidgetMethodInfo
ResolveAccessibleMethod "setData" o = GObject.Object.ObjectSetDataMethodInfo
ResolveAccessibleMethod "setDataFull" o = GObject.Object.ObjectSetDataFullMethodInfo
ResolveAccessibleMethod "setDescription" o = Atk.Object.ObjectSetDescriptionMethodInfo
ResolveAccessibleMethod "setName" o = Atk.Object.ObjectSetNameMethodInfo
ResolveAccessibleMethod "setParent" o = Atk.Object.ObjectSetParentMethodInfo
ResolveAccessibleMethod "setProperty" o = GObject.Object.ObjectSetPropertyMethodInfo
ResolveAccessibleMethod "setRole" o = Atk.Object.ObjectSetRoleMethodInfo
ResolveAccessibleMethod "setWidget" o = AccessibleSetWidgetMethodInfo
ResolveAccessibleMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveAccessibleMethod t Accessible, O.MethodInfo info Accessible p) => OL.IsLabel t (Accessible -> 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
getAccessibleWidget :: (MonadIO m, IsAccessible o) => o -> m (Maybe Gtk.Widget.Widget)
getAccessibleWidget obj = liftIO $ B.Properties.getObjectPropertyObject obj "widget" Gtk.Widget.Widget
setAccessibleWidget :: (MonadIO m, IsAccessible o, Gtk.Widget.IsWidget a) => o -> a -> m ()
setAccessibleWidget obj val = liftIO $ B.Properties.setObjectPropertyObject obj "widget" (Just val)
constructAccessibleWidget :: (IsAccessible o, Gtk.Widget.IsWidget a) => a -> IO (GValueConstruct o)
constructAccessibleWidget val = B.Properties.constructObjectPropertyObject "widget" (Just val)
clearAccessibleWidget :: (MonadIO m, IsAccessible o) => o -> m ()
clearAccessibleWidget obj = liftIO $ B.Properties.setObjectPropertyObject obj "widget" (Nothing :: Maybe Gtk.Widget.Widget)
#if ENABLE_OVERLOADING
data AccessibleWidgetPropertyInfo
instance AttrInfo AccessibleWidgetPropertyInfo where
type AttrAllowedOps AccessibleWidgetPropertyInfo = '[ 'AttrSet, 'AttrConstruct, 'AttrGet, 'AttrClear]
type AttrSetTypeConstraint AccessibleWidgetPropertyInfo = Gtk.Widget.IsWidget
type AttrBaseTypeConstraint AccessibleWidgetPropertyInfo = IsAccessible
type AttrGetType AccessibleWidgetPropertyInfo = (Maybe Gtk.Widget.Widget)
type AttrLabel AccessibleWidgetPropertyInfo = "widget"
type AttrOrigin AccessibleWidgetPropertyInfo = Accessible
attrGet _ = getAccessibleWidget
attrSet _ = setAccessibleWidget
attrConstruct _ = constructAccessibleWidget
attrClear _ = clearAccessibleWidget
#endif
#if ENABLE_OVERLOADING
instance O.HasAttributeList Accessible
type instance O.AttributeList Accessible = AccessibleAttributeList
type AccessibleAttributeList = ('[ '("accessibleComponentLayer", Atk.Object.ObjectAccessibleComponentLayerPropertyInfo), '("accessibleComponentMdiZorder", Atk.Object.ObjectAccessibleComponentMdiZorderPropertyInfo), '("accessibleDescription", Atk.Object.ObjectAccessibleDescriptionPropertyInfo), '("accessibleHypertextNlinks", Atk.Object.ObjectAccessibleHypertextNlinksPropertyInfo), '("accessibleName", Atk.Object.ObjectAccessibleNamePropertyInfo), '("accessibleParent", Atk.Object.ObjectAccessibleParentPropertyInfo), '("accessibleRole", Atk.Object.ObjectAccessibleRolePropertyInfo), '("accessibleTableCaption", Atk.Object.ObjectAccessibleTableCaptionPropertyInfo), '("accessibleTableCaptionObject", Atk.Object.ObjectAccessibleTableCaptionObjectPropertyInfo), '("accessibleTableColumnDescription", Atk.Object.ObjectAccessibleTableColumnDescriptionPropertyInfo), '("accessibleTableColumnHeader", Atk.Object.ObjectAccessibleTableColumnHeaderPropertyInfo), '("accessibleTableRowDescription", Atk.Object.ObjectAccessibleTableRowDescriptionPropertyInfo), '("accessibleTableRowHeader", Atk.Object.ObjectAccessibleTableRowHeaderPropertyInfo), '("accessibleTableSummary", Atk.Object.ObjectAccessibleTableSummaryPropertyInfo), '("accessibleValue", Atk.Object.ObjectAccessibleValuePropertyInfo), '("widget", AccessibleWidgetPropertyInfo)] :: [(Symbol, *)])
#endif
#if ENABLE_OVERLOADING
accessibleWidget :: AttrLabelProxy "widget"
accessibleWidget = AttrLabelProxy
#endif
#if ENABLE_OVERLOADING
type instance O.SignalList Accessible = AccessibleSignalList
type AccessibleSignalList = ('[ '("activeDescendantChanged", Atk.Object.ObjectActiveDescendantChangedSignalInfo), '("childrenChanged", Atk.Object.ObjectChildrenChangedSignalInfo), '("focusEvent", Atk.Object.ObjectFocusEventSignalInfo), '("notify", GObject.Object.ObjectNotifySignalInfo), '("propertyChange", Atk.Object.ObjectPropertyChangeSignalInfo), '("stateChange", Atk.Object.ObjectStateChangeSignalInfo), '("visibleDataChanged", Atk.Object.ObjectVisibleDataChangedSignalInfo)] :: [(Symbol, *)])
#endif
foreign import ccall "gtk_accessible_connect_widget_destroyed" gtk_accessible_connect_widget_destroyed ::
Ptr Accessible ->
IO ()
{-# DEPRECATED accessibleConnectWidgetDestroyed ["(Since version 3.4)","Use 'GI.Gtk.Objects.Accessible.accessibleSetWidget' and its vfuncs."] #-}
accessibleConnectWidgetDestroyed ::
(B.CallStack.HasCallStack, MonadIO m, IsAccessible a) =>
a
-> m ()
accessibleConnectWidgetDestroyed accessible = liftIO $ do
accessible' <- unsafeManagedPtrCastPtr accessible
gtk_accessible_connect_widget_destroyed accessible'
touchManagedPtr accessible
return ()
#if ENABLE_OVERLOADING
data AccessibleConnectWidgetDestroyedMethodInfo
instance (signature ~ (m ()), MonadIO m, IsAccessible a) => O.MethodInfo AccessibleConnectWidgetDestroyedMethodInfo a signature where
overloadedMethod _ = accessibleConnectWidgetDestroyed
#endif
foreign import ccall "gtk_accessible_get_widget" gtk_accessible_get_widget ::
Ptr Accessible ->
IO (Ptr Gtk.Widget.Widget)
accessibleGetWidget ::
(B.CallStack.HasCallStack, MonadIO m, IsAccessible a) =>
a
-> m (Maybe Gtk.Widget.Widget)
accessibleGetWidget accessible = liftIO $ do
accessible' <- unsafeManagedPtrCastPtr accessible
result <- gtk_accessible_get_widget accessible'
maybeResult <- convertIfNonNull result $ \result' -> do
result'' <- (newObject Gtk.Widget.Widget) result'
return result''
touchManagedPtr accessible
return maybeResult
#if ENABLE_OVERLOADING
data AccessibleGetWidgetMethodInfo
instance (signature ~ (m (Maybe Gtk.Widget.Widget)), MonadIO m, IsAccessible a) => O.MethodInfo AccessibleGetWidgetMethodInfo a signature where
overloadedMethod _ = accessibleGetWidget
#endif
foreign import ccall "gtk_accessible_set_widget" gtk_accessible_set_widget ::
Ptr Accessible ->
Ptr Gtk.Widget.Widget ->
IO ()
accessibleSetWidget ::
(B.CallStack.HasCallStack, MonadIO m, IsAccessible a, Gtk.Widget.IsWidget b) =>
a
-> Maybe (b)
-> m ()
accessibleSetWidget accessible widget = liftIO $ do
accessible' <- unsafeManagedPtrCastPtr accessible
maybeWidget <- case widget of
Nothing -> return nullPtr
Just jWidget -> do
jWidget' <- unsafeManagedPtrCastPtr jWidget
return jWidget'
gtk_accessible_set_widget accessible' maybeWidget
touchManagedPtr accessible
whenJust widget touchManagedPtr
return ()
#if ENABLE_OVERLOADING
data AccessibleSetWidgetMethodInfo
instance (signature ~ (Maybe (b) -> m ()), MonadIO m, IsAccessible a, Gtk.Widget.IsWidget b) => O.MethodInfo AccessibleSetWidgetMethodInfo a signature where
overloadedMethod _ = accessibleSetWidget
#endif