{- | Copyright : Will Thompson, Iñaki García Etxebarria and Jonas Platte License : LGPL-2.1 Maintainer : Iñaki García Etxebarria (garetxe@gmail.com) -} module GI.Gtk.Objects.ToplevelAccessible ( -- * Exported types ToplevelAccessible(..) , ToplevelAccessibleK , toToplevelAccessible , noToplevelAccessible , -- * Methods -- ** toplevelAccessibleGetChildren toplevelAccessibleGetChildren , ) where import Prelude () import Data.GI.Base.ShortPrelude import qualified Data.Text as T import qualified Data.ByteString.Char8 as B import qualified Data.Map as Map import GI.Gtk.Types import GI.Gtk.Callbacks import qualified GI.Atk as Atk import qualified GI.GObject as GObject newtype ToplevelAccessible = ToplevelAccessible (ForeignPtr ToplevelAccessible) foreign import ccall "gtk_toplevel_accessible_get_type" c_gtk_toplevel_accessible_get_type :: IO GType type instance ParentTypes ToplevelAccessible = ToplevelAccessibleParentTypes type ToplevelAccessibleParentTypes = '[Atk.Object, GObject.Object] instance GObject ToplevelAccessible where gobjectIsInitiallyUnowned _ = False gobjectType _ = c_gtk_toplevel_accessible_get_type class GObject o => ToplevelAccessibleK o instance (GObject o, IsDescendantOf ToplevelAccessible o) => ToplevelAccessibleK o toToplevelAccessible :: ToplevelAccessibleK o => o -> IO ToplevelAccessible toToplevelAccessible = unsafeCastTo ToplevelAccessible noToplevelAccessible :: Maybe ToplevelAccessible noToplevelAccessible = Nothing type instance AttributeList ToplevelAccessible = ToplevelAccessibleAttributeList type ToplevelAccessibleAttributeList = ('[ '("accessible-component-layer", Atk.ObjectAccessibleComponentLayerPropertyInfo), '("accessible-component-mdi-zorder", Atk.ObjectAccessibleComponentMdiZorderPropertyInfo), '("accessible-description", Atk.ObjectAccessibleDescriptionPropertyInfo), '("accessible-hypertext-nlinks", Atk.ObjectAccessibleHypertextNlinksPropertyInfo), '("accessible-name", Atk.ObjectAccessibleNamePropertyInfo), '("accessible-parent", Atk.ObjectAccessibleParentPropertyInfo), '("accessible-role", Atk.ObjectAccessibleRolePropertyInfo), '("accessible-table-caption", Atk.ObjectAccessibleTableCaptionPropertyInfo), '("accessible-table-caption-object", Atk.ObjectAccessibleTableCaptionObjectPropertyInfo), '("accessible-table-column-description", Atk.ObjectAccessibleTableColumnDescriptionPropertyInfo), '("accessible-table-column-header", Atk.ObjectAccessibleTableColumnHeaderPropertyInfo), '("accessible-table-row-description", Atk.ObjectAccessibleTableRowDescriptionPropertyInfo), '("accessible-table-row-header", Atk.ObjectAccessibleTableRowHeaderPropertyInfo), '("accessible-table-summary", Atk.ObjectAccessibleTableSummaryPropertyInfo), '("accessible-value", Atk.ObjectAccessibleValuePropertyInfo)] :: [(Symbol, *)]) type instance SignalList ToplevelAccessible = ToplevelAccessibleSignalList type ToplevelAccessibleSignalList = ('[ '("active-descendant-changed", Atk.ObjectActiveDescendantChangedSignalInfo), '("children-changed", Atk.ObjectChildrenChangedSignalInfo), '("focus-event", Atk.ObjectFocusEventSignalInfo), '("notify", GObject.ObjectNotifySignalInfo), '("property-change", Atk.ObjectPropertyChangeSignalInfo), '("state-change", Atk.ObjectStateChangeSignalInfo), '("visible-data-changed", Atk.ObjectVisibleDataChangedSignalInfo), '("notify::[property]", GObjectNotifySignalInfo)] :: [(Symbol, *)]) -- method ToplevelAccessible::get_children -- method type : OrdinaryMethod -- Args : [Arg {argName = "_obj", argType = TInterface "Gtk" "ToplevelAccessible", direction = DirectionIn, mayBeNull = False, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, transfer = TransferNothing}] -- Lengths : [] -- hInArgs : [Arg {argName = "_obj", argType = TInterface "Gtk" "ToplevelAccessible", direction = DirectionIn, mayBeNull = False, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, transfer = TransferNothing}] -- returnType : TGList (TInterface "Gtk" "Window") -- throws : False -- Skip return : False foreign import ccall "gtk_toplevel_accessible_get_children" gtk_toplevel_accessible_get_children :: Ptr ToplevelAccessible -> -- _obj : TInterface "Gtk" "ToplevelAccessible" IO (Ptr (GList (Ptr Window))) toplevelAccessibleGetChildren :: (MonadIO m, ToplevelAccessibleK a) => a -> -- _obj m [Window] toplevelAccessibleGetChildren _obj = liftIO $ do let _obj' = unsafeManagedPtrCastPtr _obj result <- gtk_toplevel_accessible_get_children _obj' checkUnexpectedReturnNULL "gtk_toplevel_accessible_get_children" result result' <- unpackGList result result'' <- mapM (newObject Window) result' touchManagedPtr _obj return result''