{-# LANGUAGE TypeApplications #-}
#if (MIN_VERSION_haskell_gi_overloading(1,0,0) && !defined(__HADDOCK_VERSION__))
#define ENABLE_OVERLOADING
#endif
module GI.Gtk.Objects.ColumnViewSorter
(
ColumnViewSorter(..) ,
IsColumnViewSorter ,
toColumnViewSorter ,
#if defined(ENABLE_OVERLOADING)
ResolveColumnViewSorterMethod ,
#endif
#if defined(ENABLE_OVERLOADING)
ColumnViewSorterGetNSortColumnsMethodInfo,
#endif
columnViewSorterGetNSortColumns ,
#if defined(ENABLE_OVERLOADING)
ColumnViewSorterGetNthSortColumnMethodInfo,
#endif
columnViewSorterGetNthSortColumn ,
#if defined(ENABLE_OVERLOADING)
ColumnViewSorterGetPrimarySortColumnMethodInfo,
#endif
columnViewSorterGetPrimarySortColumn ,
#if defined(ENABLE_OVERLOADING)
ColumnViewSorterGetPrimarySortOrderMethodInfo,
#endif
columnViewSorterGetPrimarySortOrder ,
#if defined(ENABLE_OVERLOADING)
ColumnViewSorterPrimarySortColumnPropertyInfo,
#endif
#if defined(ENABLE_OVERLOADING)
columnViewSorterPrimarySortColumn ,
#endif
getColumnViewSorterPrimarySortColumn ,
#if defined(ENABLE_OVERLOADING)
ColumnViewSorterPrimarySortOrderPropertyInfo,
#endif
#if defined(ENABLE_OVERLOADING)
columnViewSorterPrimarySortOrder ,
#endif
getColumnViewSorterPrimarySortOrder ,
) 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.BasicTypes as B.Types
import qualified Data.GI.Base.ManagedPtr as B.ManagedPtr
import qualified Data.GI.Base.GArray as B.GArray
import qualified Data.GI.Base.GClosure as B.GClosure
import qualified Data.GI.Base.GError as B.GError
import qualified Data.GI.Base.GHashTable as B.GHT
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.GI.Base.Signals as B.Signals
import qualified Control.Monad.IO.Class as MIO
import qualified Data.Coerce as Coerce
import qualified Data.Text as T
import qualified Data.Kind as DK
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 GHC.Records as R
import qualified GI.GObject.Objects.Object as GObject.Object
import {-# SOURCE #-} qualified GI.Gtk.Enums as Gtk.Enums
import {-# SOURCE #-} qualified GI.Gtk.Objects.ColumnViewColumn as Gtk.ColumnViewColumn
import {-# SOURCE #-} qualified GI.Gtk.Objects.Sorter as Gtk.Sorter
newtype ColumnViewSorter = ColumnViewSorter (SP.ManagedPtr ColumnViewSorter)
deriving (ColumnViewSorter -> ColumnViewSorter -> Bool
(ColumnViewSorter -> ColumnViewSorter -> Bool)
-> (ColumnViewSorter -> ColumnViewSorter -> Bool)
-> Eq ColumnViewSorter
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: ColumnViewSorter -> ColumnViewSorter -> Bool
== :: ColumnViewSorter -> ColumnViewSorter -> Bool
$c/= :: ColumnViewSorter -> ColumnViewSorter -> Bool
/= :: ColumnViewSorter -> ColumnViewSorter -> Bool
Eq)
instance SP.ManagedPtrNewtype ColumnViewSorter where
toManagedPtr :: ColumnViewSorter -> ManagedPtr ColumnViewSorter
toManagedPtr (ColumnViewSorter ManagedPtr ColumnViewSorter
p) = ManagedPtr ColumnViewSorter
p
foreign import ccall "gtk_column_view_sorter_get_type"
c_gtk_column_view_sorter_get_type :: IO B.Types.GType
instance B.Types.TypedObject ColumnViewSorter where
glibType :: IO GType
glibType = IO GType
c_gtk_column_view_sorter_get_type
instance B.Types.GObject ColumnViewSorter
class (SP.GObject o, O.IsDescendantOf ColumnViewSorter o) => IsColumnViewSorter o
instance (SP.GObject o, O.IsDescendantOf ColumnViewSorter o) => IsColumnViewSorter o
instance O.HasParentTypes ColumnViewSorter
type instance O.ParentTypes ColumnViewSorter = '[Gtk.Sorter.Sorter, GObject.Object.Object]
toColumnViewSorter :: (MIO.MonadIO m, IsColumnViewSorter o) => o -> m ColumnViewSorter
toColumnViewSorter :: forall (m :: * -> *) o.
(MonadIO m, IsColumnViewSorter o) =>
o -> m ColumnViewSorter
toColumnViewSorter = IO ColumnViewSorter -> m ColumnViewSorter
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO ColumnViewSorter -> m ColumnViewSorter)
-> (o -> IO ColumnViewSorter) -> o -> m ColumnViewSorter
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ManagedPtr ColumnViewSorter -> ColumnViewSorter)
-> o -> IO ColumnViewSorter
forall o o'.
(HasCallStack, ManagedPtrNewtype o, TypedObject o,
ManagedPtrNewtype o', TypedObject o') =>
(ManagedPtr o' -> o') -> o -> IO o'
B.ManagedPtr.unsafeCastTo ManagedPtr ColumnViewSorter -> ColumnViewSorter
ColumnViewSorter
instance B.GValue.IsGValue (Maybe ColumnViewSorter) where
gvalueGType_ :: IO GType
gvalueGType_ = IO GType
c_gtk_column_view_sorter_get_type
gvalueSet_ :: Ptr GValue -> Maybe ColumnViewSorter -> IO ()
gvalueSet_ Ptr GValue
gv Maybe ColumnViewSorter
P.Nothing = Ptr GValue -> Ptr ColumnViewSorter -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv (Ptr ColumnViewSorter
forall a. Ptr a
FP.nullPtr :: FP.Ptr ColumnViewSorter)
gvalueSet_ Ptr GValue
gv (P.Just ColumnViewSorter
obj) = ColumnViewSorter -> (Ptr ColumnViewSorter -> IO ()) -> IO ()
forall a c.
(HasCallStack, ManagedPtrNewtype a) =>
a -> (Ptr a -> IO c) -> IO c
B.ManagedPtr.withManagedPtr ColumnViewSorter
obj (Ptr GValue -> Ptr ColumnViewSorter -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv)
gvalueGet_ :: Ptr GValue -> IO (Maybe ColumnViewSorter)
gvalueGet_ Ptr GValue
gv = do
Ptr ColumnViewSorter
ptr <- Ptr GValue -> IO (Ptr ColumnViewSorter)
forall a. GObject a => Ptr GValue -> IO (Ptr a)
B.GValue.get_object Ptr GValue
gv :: IO (FP.Ptr ColumnViewSorter)
if Ptr ColumnViewSorter
ptr Ptr ColumnViewSorter -> Ptr ColumnViewSorter -> Bool
forall a. Eq a => a -> a -> Bool
/= Ptr ColumnViewSorter
forall a. Ptr a
FP.nullPtr
then ColumnViewSorter -> Maybe ColumnViewSorter
forall a. a -> Maybe a
P.Just (ColumnViewSorter -> Maybe ColumnViewSorter)
-> IO ColumnViewSorter -> IO (Maybe ColumnViewSorter)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (ManagedPtr ColumnViewSorter -> ColumnViewSorter)
-> Ptr ColumnViewSorter -> IO ColumnViewSorter
forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
B.ManagedPtr.newObject ManagedPtr ColumnViewSorter -> ColumnViewSorter
ColumnViewSorter Ptr ColumnViewSorter
ptr
else Maybe ColumnViewSorter -> IO (Maybe ColumnViewSorter)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Maybe ColumnViewSorter
forall a. Maybe a
P.Nothing
#if defined(ENABLE_OVERLOADING)
type family ResolveColumnViewSorterMethod (t :: Symbol) (o :: DK.Type) :: DK.Type where
ResolveColumnViewSorterMethod "bindProperty" o = GObject.Object.ObjectBindPropertyMethodInfo
ResolveColumnViewSorterMethod "bindPropertyFull" o = GObject.Object.ObjectBindPropertyFullMethodInfo
ResolveColumnViewSorterMethod "changed" o = Gtk.Sorter.SorterChangedMethodInfo
ResolveColumnViewSorterMethod "compare" o = Gtk.Sorter.SorterCompareMethodInfo
ResolveColumnViewSorterMethod "forceFloating" o = GObject.Object.ObjectForceFloatingMethodInfo
ResolveColumnViewSorterMethod "freezeNotify" o = GObject.Object.ObjectFreezeNotifyMethodInfo
ResolveColumnViewSorterMethod "getv" o = GObject.Object.ObjectGetvMethodInfo
ResolveColumnViewSorterMethod "isFloating" o = GObject.Object.ObjectIsFloatingMethodInfo
ResolveColumnViewSorterMethod "notify" o = GObject.Object.ObjectNotifyMethodInfo
ResolveColumnViewSorterMethod "notifyByPspec" o = GObject.Object.ObjectNotifyByPspecMethodInfo
ResolveColumnViewSorterMethod "ref" o = GObject.Object.ObjectRefMethodInfo
ResolveColumnViewSorterMethod "refSink" o = GObject.Object.ObjectRefSinkMethodInfo
ResolveColumnViewSorterMethod "runDispose" o = GObject.Object.ObjectRunDisposeMethodInfo
ResolveColumnViewSorterMethod "stealData" o = GObject.Object.ObjectStealDataMethodInfo
ResolveColumnViewSorterMethod "stealQdata" o = GObject.Object.ObjectStealQdataMethodInfo
ResolveColumnViewSorterMethod "thawNotify" o = GObject.Object.ObjectThawNotifyMethodInfo
ResolveColumnViewSorterMethod "unref" o = GObject.Object.ObjectUnrefMethodInfo
ResolveColumnViewSorterMethod "watchClosure" o = GObject.Object.ObjectWatchClosureMethodInfo
ResolveColumnViewSorterMethod "getData" o = GObject.Object.ObjectGetDataMethodInfo
ResolveColumnViewSorterMethod "getNSortColumns" o = ColumnViewSorterGetNSortColumnsMethodInfo
ResolveColumnViewSorterMethod "getNthSortColumn" o = ColumnViewSorterGetNthSortColumnMethodInfo
ResolveColumnViewSorterMethod "getOrder" o = Gtk.Sorter.SorterGetOrderMethodInfo
ResolveColumnViewSorterMethod "getPrimarySortColumn" o = ColumnViewSorterGetPrimarySortColumnMethodInfo
ResolveColumnViewSorterMethod "getPrimarySortOrder" o = ColumnViewSorterGetPrimarySortOrderMethodInfo
ResolveColumnViewSorterMethod "getProperty" o = GObject.Object.ObjectGetPropertyMethodInfo
ResolveColumnViewSorterMethod "getQdata" o = GObject.Object.ObjectGetQdataMethodInfo
ResolveColumnViewSorterMethod "setData" o = GObject.Object.ObjectSetDataMethodInfo
ResolveColumnViewSorterMethod "setDataFull" o = GObject.Object.ObjectSetDataFullMethodInfo
ResolveColumnViewSorterMethod "setProperty" o = GObject.Object.ObjectSetPropertyMethodInfo
ResolveColumnViewSorterMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveColumnViewSorterMethod t ColumnViewSorter, O.OverloadedMethod info ColumnViewSorter p) => OL.IsLabel t (ColumnViewSorter -> p) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.overloadedMethod @info
#else
fromLabel _ = O.overloadedMethod @info
#endif
#if MIN_VERSION_base(4,13,0)
instance (info ~ ResolveColumnViewSorterMethod t ColumnViewSorter, O.OverloadedMethod info ColumnViewSorter p, R.HasField t ColumnViewSorter p) => R.HasField t ColumnViewSorter p where
getField = O.overloadedMethod @info
#endif
instance (info ~ ResolveColumnViewSorterMethod t ColumnViewSorter, O.OverloadedMethodInfo info ColumnViewSorter) => OL.IsLabel t (O.MethodProxy info ColumnViewSorter) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.MethodProxy
#else
fromLabel _ = O.MethodProxy
#endif
#endif
getColumnViewSorterPrimarySortColumn :: (MonadIO m, IsColumnViewSorter o) => o -> m (Maybe Gtk.ColumnViewColumn.ColumnViewColumn)
getColumnViewSorterPrimarySortColumn :: forall (m :: * -> *) o.
(MonadIO m, IsColumnViewSorter o) =>
o -> m (Maybe ColumnViewColumn)
getColumnViewSorterPrimarySortColumn o
obj = IO (Maybe ColumnViewColumn) -> m (Maybe ColumnViewColumn)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO (Maybe ColumnViewColumn) -> m (Maybe ColumnViewColumn))
-> IO (Maybe ColumnViewColumn) -> m (Maybe ColumnViewColumn)
forall a b. (a -> b) -> a -> b
$ o
-> String
-> (ManagedPtr ColumnViewColumn -> ColumnViewColumn)
-> IO (Maybe ColumnViewColumn)
forall a b.
(GObject a, GObject b) =>
a -> String -> (ManagedPtr b -> b) -> IO (Maybe b)
B.Properties.getObjectPropertyObject o
obj String
"primary-sort-column" ManagedPtr ColumnViewColumn -> ColumnViewColumn
Gtk.ColumnViewColumn.ColumnViewColumn
#if defined(ENABLE_OVERLOADING)
data ColumnViewSorterPrimarySortColumnPropertyInfo
instance AttrInfo ColumnViewSorterPrimarySortColumnPropertyInfo where
type AttrAllowedOps ColumnViewSorterPrimarySortColumnPropertyInfo = '[ 'AttrGet, 'AttrClear]
type AttrBaseTypeConstraint ColumnViewSorterPrimarySortColumnPropertyInfo = IsColumnViewSorter
type AttrSetTypeConstraint ColumnViewSorterPrimarySortColumnPropertyInfo = (~) ()
type AttrTransferTypeConstraint ColumnViewSorterPrimarySortColumnPropertyInfo = (~) ()
type AttrTransferType ColumnViewSorterPrimarySortColumnPropertyInfo = ()
type AttrGetType ColumnViewSorterPrimarySortColumnPropertyInfo = (Maybe Gtk.ColumnViewColumn.ColumnViewColumn)
type AttrLabel ColumnViewSorterPrimarySortColumnPropertyInfo = "primary-sort-column"
type AttrOrigin ColumnViewSorterPrimarySortColumnPropertyInfo = ColumnViewSorter
attrGet = getColumnViewSorterPrimarySortColumn
attrSet = undefined
attrTransfer _ = undefined
attrConstruct = undefined
attrClear = undefined
dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gtk.Objects.ColumnViewSorter.primarySortColumn"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gtk-4.0.8/docs/GI-Gtk-Objects-ColumnViewSorter.html#g:attr:primarySortColumn"
})
#endif
getColumnViewSorterPrimarySortOrder :: (MonadIO m, IsColumnViewSorter o) => o -> m Gtk.Enums.SortType
getColumnViewSorterPrimarySortOrder :: forall (m :: * -> *) o.
(MonadIO m, IsColumnViewSorter o) =>
o -> m SortType
getColumnViewSorterPrimarySortOrder o
obj = IO SortType -> m SortType
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO SortType -> m SortType) -> IO SortType -> m SortType
forall a b. (a -> b) -> a -> b
$ o -> String -> IO SortType
forall a b. (GObject a, Enum b, BoxedEnum b) => a -> String -> IO b
B.Properties.getObjectPropertyEnum o
obj String
"primary-sort-order"
#if defined(ENABLE_OVERLOADING)
data ColumnViewSorterPrimarySortOrderPropertyInfo
instance AttrInfo ColumnViewSorterPrimarySortOrderPropertyInfo where
type AttrAllowedOps ColumnViewSorterPrimarySortOrderPropertyInfo = '[ 'AttrGet]
type AttrBaseTypeConstraint ColumnViewSorterPrimarySortOrderPropertyInfo = IsColumnViewSorter
type AttrSetTypeConstraint ColumnViewSorterPrimarySortOrderPropertyInfo = (~) ()
type AttrTransferTypeConstraint ColumnViewSorterPrimarySortOrderPropertyInfo = (~) ()
type AttrTransferType ColumnViewSorterPrimarySortOrderPropertyInfo = ()
type AttrGetType ColumnViewSorterPrimarySortOrderPropertyInfo = Gtk.Enums.SortType
type AttrLabel ColumnViewSorterPrimarySortOrderPropertyInfo = "primary-sort-order"
type AttrOrigin ColumnViewSorterPrimarySortOrderPropertyInfo = ColumnViewSorter
attrGet = getColumnViewSorterPrimarySortOrder
attrSet = undefined
attrTransfer _ = undefined
attrConstruct = undefined
attrClear = undefined
dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gtk.Objects.ColumnViewSorter.primarySortOrder"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gtk-4.0.8/docs/GI-Gtk-Objects-ColumnViewSorter.html#g:attr:primarySortOrder"
})
#endif
#if defined(ENABLE_OVERLOADING)
instance O.HasAttributeList ColumnViewSorter
type instance O.AttributeList ColumnViewSorter = ColumnViewSorterAttributeList
type ColumnViewSorterAttributeList = ('[ '("primarySortColumn", ColumnViewSorterPrimarySortColumnPropertyInfo), '("primarySortOrder", ColumnViewSorterPrimarySortOrderPropertyInfo)] :: [(Symbol, DK.Type)])
#endif
#if defined(ENABLE_OVERLOADING)
columnViewSorterPrimarySortColumn :: AttrLabelProxy "primarySortColumn"
columnViewSorterPrimarySortColumn = AttrLabelProxy
columnViewSorterPrimarySortOrder :: AttrLabelProxy "primarySortOrder"
columnViewSorterPrimarySortOrder = AttrLabelProxy
#endif
#if defined(ENABLE_OVERLOADING)
type instance O.SignalList ColumnViewSorter = ColumnViewSorterSignalList
type ColumnViewSorterSignalList = ('[ '("changed", Gtk.Sorter.SorterChangedSignalInfo), '("notify", GObject.Object.ObjectNotifySignalInfo)] :: [(Symbol, DK.Type)])
#endif
foreign import ccall "gtk_column_view_sorter_get_n_sort_columns" gtk_column_view_sorter_get_n_sort_columns ::
Ptr ColumnViewSorter ->
IO Word32
columnViewSorterGetNSortColumns ::
(B.CallStack.HasCallStack, MonadIO m, IsColumnViewSorter a) =>
a
-> m Word32
columnViewSorterGetNSortColumns :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsColumnViewSorter a) =>
a -> m Word32
columnViewSorterGetNSortColumns a
self = IO Word32 -> m Word32
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO Word32 -> m Word32) -> IO Word32 -> m Word32
forall a b. (a -> b) -> a -> b
$ do
Ptr ColumnViewSorter
self' <- a -> IO (Ptr ColumnViewSorter)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
self
Word32
result <- Ptr ColumnViewSorter -> IO Word32
gtk_column_view_sorter_get_n_sort_columns Ptr ColumnViewSorter
self'
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
self
Word32 -> IO Word32
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Word32
result
#if defined(ENABLE_OVERLOADING)
data ColumnViewSorterGetNSortColumnsMethodInfo
instance (signature ~ (m Word32), MonadIO m, IsColumnViewSorter a) => O.OverloadedMethod ColumnViewSorterGetNSortColumnsMethodInfo a signature where
overloadedMethod = columnViewSorterGetNSortColumns
instance O.OverloadedMethodInfo ColumnViewSorterGetNSortColumnsMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gtk.Objects.ColumnViewSorter.columnViewSorterGetNSortColumns",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gtk-4.0.8/docs/GI-Gtk-Objects-ColumnViewSorter.html#v:columnViewSorterGetNSortColumns"
})
#endif
foreign import ccall "gtk_column_view_sorter_get_nth_sort_column" gtk_column_view_sorter_get_nth_sort_column ::
Ptr ColumnViewSorter ->
Word32 ->
Ptr CUInt ->
IO (Ptr Gtk.ColumnViewColumn.ColumnViewColumn)
columnViewSorterGetNthSortColumn ::
(B.CallStack.HasCallStack, MonadIO m, IsColumnViewSorter a) =>
a
-> Word32
-> m ((Maybe Gtk.ColumnViewColumn.ColumnViewColumn, Gtk.Enums.SortType))
columnViewSorterGetNthSortColumn :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsColumnViewSorter a) =>
a -> Word32 -> m (Maybe ColumnViewColumn, SortType)
columnViewSorterGetNthSortColumn a
self Word32
position = IO (Maybe ColumnViewColumn, SortType)
-> m (Maybe ColumnViewColumn, SortType)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO (Maybe ColumnViewColumn, SortType)
-> m (Maybe ColumnViewColumn, SortType))
-> IO (Maybe ColumnViewColumn, SortType)
-> m (Maybe ColumnViewColumn, SortType)
forall a b. (a -> b) -> a -> b
$ do
Ptr ColumnViewSorter
self' <- a -> IO (Ptr ColumnViewSorter)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
self
Ptr CUInt
sortOrder <- IO (Ptr CUInt)
forall a. Storable a => IO (Ptr a)
allocMem :: IO (Ptr CUInt)
Ptr ColumnViewColumn
result <- Ptr ColumnViewSorter
-> Word32 -> Ptr CUInt -> IO (Ptr ColumnViewColumn)
gtk_column_view_sorter_get_nth_sort_column Ptr ColumnViewSorter
self' Word32
position Ptr CUInt
sortOrder
Maybe ColumnViewColumn
maybeResult <- Ptr ColumnViewColumn
-> (Ptr ColumnViewColumn -> IO ColumnViewColumn)
-> IO (Maybe ColumnViewColumn)
forall a b. Ptr a -> (Ptr a -> IO b) -> IO (Maybe b)
convertIfNonNull Ptr ColumnViewColumn
result ((Ptr ColumnViewColumn -> IO ColumnViewColumn)
-> IO (Maybe ColumnViewColumn))
-> (Ptr ColumnViewColumn -> IO ColumnViewColumn)
-> IO (Maybe ColumnViewColumn)
forall a b. (a -> b) -> a -> b
$ \Ptr ColumnViewColumn
result' -> do
ColumnViewColumn
result'' <- ((ManagedPtr ColumnViewColumn -> ColumnViewColumn)
-> Ptr ColumnViewColumn -> IO ColumnViewColumn
forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
newObject ManagedPtr ColumnViewColumn -> ColumnViewColumn
Gtk.ColumnViewColumn.ColumnViewColumn) Ptr ColumnViewColumn
result'
ColumnViewColumn -> IO ColumnViewColumn
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return ColumnViewColumn
result''
CUInt
sortOrder' <- Ptr CUInt -> IO CUInt
forall a. Storable a => Ptr a -> IO a
peek Ptr CUInt
sortOrder
let sortOrder'' :: SortType
sortOrder'' = (Int -> SortType
forall a. Enum a => Int -> a
toEnum (Int -> SortType) -> (CUInt -> Int) -> CUInt -> SortType
forall b c a. (b -> c) -> (a -> b) -> a -> c
. CUInt -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral) CUInt
sortOrder'
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
self
Ptr CUInt -> IO ()
forall a. Ptr a -> IO ()
freeMem Ptr CUInt
sortOrder
(Maybe ColumnViewColumn, SortType)
-> IO (Maybe ColumnViewColumn, SortType)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (Maybe ColumnViewColumn
maybeResult, SortType
sortOrder'')
#if defined(ENABLE_OVERLOADING)
data ColumnViewSorterGetNthSortColumnMethodInfo
instance (signature ~ (Word32 -> m ((Maybe Gtk.ColumnViewColumn.ColumnViewColumn, Gtk.Enums.SortType))), MonadIO m, IsColumnViewSorter a) => O.OverloadedMethod ColumnViewSorterGetNthSortColumnMethodInfo a signature where
overloadedMethod = columnViewSorterGetNthSortColumn
instance O.OverloadedMethodInfo ColumnViewSorterGetNthSortColumnMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gtk.Objects.ColumnViewSorter.columnViewSorterGetNthSortColumn",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gtk-4.0.8/docs/GI-Gtk-Objects-ColumnViewSorter.html#v:columnViewSorterGetNthSortColumn"
})
#endif
foreign import ccall "gtk_column_view_sorter_get_primary_sort_column" gtk_column_view_sorter_get_primary_sort_column ::
Ptr ColumnViewSorter ->
IO (Ptr Gtk.ColumnViewColumn.ColumnViewColumn)
columnViewSorterGetPrimarySortColumn ::
(B.CallStack.HasCallStack, MonadIO m, IsColumnViewSorter a) =>
a
-> m (Maybe Gtk.ColumnViewColumn.ColumnViewColumn)
columnViewSorterGetPrimarySortColumn :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsColumnViewSorter a) =>
a -> m (Maybe ColumnViewColumn)
columnViewSorterGetPrimarySortColumn a
self = IO (Maybe ColumnViewColumn) -> m (Maybe ColumnViewColumn)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO (Maybe ColumnViewColumn) -> m (Maybe ColumnViewColumn))
-> IO (Maybe ColumnViewColumn) -> m (Maybe ColumnViewColumn)
forall a b. (a -> b) -> a -> b
$ do
Ptr ColumnViewSorter
self' <- a -> IO (Ptr ColumnViewSorter)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
self
Ptr ColumnViewColumn
result <- Ptr ColumnViewSorter -> IO (Ptr ColumnViewColumn)
gtk_column_view_sorter_get_primary_sort_column Ptr ColumnViewSorter
self'
Maybe ColumnViewColumn
maybeResult <- Ptr ColumnViewColumn
-> (Ptr ColumnViewColumn -> IO ColumnViewColumn)
-> IO (Maybe ColumnViewColumn)
forall a b. Ptr a -> (Ptr a -> IO b) -> IO (Maybe b)
convertIfNonNull Ptr ColumnViewColumn
result ((Ptr ColumnViewColumn -> IO ColumnViewColumn)
-> IO (Maybe ColumnViewColumn))
-> (Ptr ColumnViewColumn -> IO ColumnViewColumn)
-> IO (Maybe ColumnViewColumn)
forall a b. (a -> b) -> a -> b
$ \Ptr ColumnViewColumn
result' -> do
ColumnViewColumn
result'' <- ((ManagedPtr ColumnViewColumn -> ColumnViewColumn)
-> Ptr ColumnViewColumn -> IO ColumnViewColumn
forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
newObject ManagedPtr ColumnViewColumn -> ColumnViewColumn
Gtk.ColumnViewColumn.ColumnViewColumn) Ptr ColumnViewColumn
result'
ColumnViewColumn -> IO ColumnViewColumn
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return ColumnViewColumn
result''
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
self
Maybe ColumnViewColumn -> IO (Maybe ColumnViewColumn)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Maybe ColumnViewColumn
maybeResult
#if defined(ENABLE_OVERLOADING)
data ColumnViewSorterGetPrimarySortColumnMethodInfo
instance (signature ~ (m (Maybe Gtk.ColumnViewColumn.ColumnViewColumn)), MonadIO m, IsColumnViewSorter a) => O.OverloadedMethod ColumnViewSorterGetPrimarySortColumnMethodInfo a signature where
overloadedMethod = columnViewSorterGetPrimarySortColumn
instance O.OverloadedMethodInfo ColumnViewSorterGetPrimarySortColumnMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gtk.Objects.ColumnViewSorter.columnViewSorterGetPrimarySortColumn",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gtk-4.0.8/docs/GI-Gtk-Objects-ColumnViewSorter.html#v:columnViewSorterGetPrimarySortColumn"
})
#endif
foreign import ccall "gtk_column_view_sorter_get_primary_sort_order" gtk_column_view_sorter_get_primary_sort_order ::
Ptr ColumnViewSorter ->
IO CUInt
columnViewSorterGetPrimarySortOrder ::
(B.CallStack.HasCallStack, MonadIO m, IsColumnViewSorter a) =>
a
-> m Gtk.Enums.SortType
columnViewSorterGetPrimarySortOrder :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsColumnViewSorter a) =>
a -> m SortType
columnViewSorterGetPrimarySortOrder a
self = IO SortType -> m SortType
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO SortType -> m SortType) -> IO SortType -> m SortType
forall a b. (a -> b) -> a -> b
$ do
Ptr ColumnViewSorter
self' <- a -> IO (Ptr ColumnViewSorter)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
self
CUInt
result <- Ptr ColumnViewSorter -> IO CUInt
gtk_column_view_sorter_get_primary_sort_order Ptr ColumnViewSorter
self'
let result' :: SortType
result' = (Int -> SortType
forall a. Enum a => Int -> a
toEnum (Int -> SortType) -> (CUInt -> Int) -> CUInt -> SortType
forall b c a. (b -> c) -> (a -> b) -> a -> c
. CUInt -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral) CUInt
result
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
self
SortType -> IO SortType
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return SortType
result'
#if defined(ENABLE_OVERLOADING)
data ColumnViewSorterGetPrimarySortOrderMethodInfo
instance (signature ~ (m Gtk.Enums.SortType), MonadIO m, IsColumnViewSorter a) => O.OverloadedMethod ColumnViewSorterGetPrimarySortOrderMethodInfo a signature where
overloadedMethod = columnViewSorterGetPrimarySortOrder
instance O.OverloadedMethodInfo ColumnViewSorterGetPrimarySortOrderMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gtk.Objects.ColumnViewSorter.columnViewSorterGetPrimarySortOrder",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gtk-4.0.8/docs/GI-Gtk-Objects-ColumnViewSorter.html#v:columnViewSorterGetPrimarySortOrder"
})
#endif