{-# LANGUAGE TypeApplications #-}
#if (MIN_VERSION_haskell_gi_overloading(1,0,0) && !defined(__HADDOCK_VERSION__))
#define ENABLE_OVERLOADING
#endif
module GI.NM.Objects.SettingUser
(
SettingUser(..) ,
IsSettingUser ,
toSettingUser ,
#if defined(ENABLE_OVERLOADING)
ResolveSettingUserMethod ,
#endif
settingUserCheckKey ,
settingUserCheckVal ,
#if defined(ENABLE_OVERLOADING)
SettingUserGetDataMethodInfo ,
#endif
settingUserGetData ,
#if defined(ENABLE_OVERLOADING)
SettingUserGetKeysMethodInfo ,
#endif
settingUserGetKeys ,
settingUserNew ,
#if defined(ENABLE_OVERLOADING)
SettingUserSetDataMethodInfo ,
#endif
settingUserSetData ,
#if defined(ENABLE_OVERLOADING)
SettingUserDataPropertyInfo ,
#endif
clearSettingUserData ,
constructSettingUserData ,
getSettingUserData ,
setSettingUserData ,
#if defined(ENABLE_OVERLOADING)
settingUserData ,
#endif
) 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 Data.Word as DW
import qualified Data.Int as DI
import qualified System.Posix.Types as SPT
import qualified Foreign.C.Types as FCT
#if MIN_VERSION_base(4,18,0)
import qualified GI.GLib.Structs.Bytes as GLib.Bytes
import qualified GI.GLib.Structs.VariantType as GLib.VariantType
import qualified GI.GObject.Objects.Object as GObject.Object
import qualified GI.NM.Callbacks as NM.Callbacks
import {-# SOURCE #-} qualified GI.NM.Enums as NM.Enums
import {-# SOURCE #-} qualified GI.NM.Flags as NM.Flags
import {-# SOURCE #-} qualified GI.NM.Interfaces.Connection as NM.Connection
import {-# SOURCE #-} qualified GI.NM.Objects.Setting as NM.Setting
import {-# SOURCE #-} qualified GI.NM.Objects.Setting8021x as NM.Setting8021x
import {-# SOURCE #-} qualified GI.NM.Objects.SettingAdsl as NM.SettingAdsl
import {-# SOURCE #-} qualified GI.NM.Objects.SettingBluetooth as NM.SettingBluetooth
import {-# SOURCE #-} qualified GI.NM.Objects.SettingBond as NM.SettingBond
import {-# SOURCE #-} qualified GI.NM.Objects.SettingBridge as NM.SettingBridge
import {-# SOURCE #-} qualified GI.NM.Objects.SettingBridgePort as NM.SettingBridgePort
import {-# SOURCE #-} qualified GI.NM.Objects.SettingCdma as NM.SettingCdma
import {-# SOURCE #-} qualified GI.NM.Objects.SettingConnection as NM.SettingConnection
import {-# SOURCE #-} qualified GI.NM.Objects.SettingDcb as NM.SettingDcb
import {-# SOURCE #-} qualified GI.NM.Objects.SettingDummy as NM.SettingDummy
import {-# SOURCE #-} qualified GI.NM.Objects.SettingGeneric as NM.SettingGeneric
import {-# SOURCE #-} qualified GI.NM.Objects.SettingGsm as NM.SettingGsm
import {-# SOURCE #-} qualified GI.NM.Objects.SettingIP4Config as NM.SettingIP4Config
import {-# SOURCE #-} qualified GI.NM.Objects.SettingIP6Config as NM.SettingIP6Config
import {-# SOURCE #-} qualified GI.NM.Objects.SettingIPConfig as NM.SettingIPConfig
import {-# SOURCE #-} qualified GI.NM.Objects.SettingIPTunnel as NM.SettingIPTunnel
import {-# SOURCE #-} qualified GI.NM.Objects.SettingInfiniband as NM.SettingInfiniband
import {-# SOURCE #-} qualified GI.NM.Objects.SettingMacsec as NM.SettingMacsec
import {-# SOURCE #-} qualified GI.NM.Objects.SettingMacvlan as NM.SettingMacvlan
import {-# SOURCE #-} qualified GI.NM.Objects.SettingOlpcMesh as NM.SettingOlpcMesh
import {-# SOURCE #-} qualified GI.NM.Objects.SettingOvsBridge as NM.SettingOvsBridge
import {-# SOURCE #-} qualified GI.NM.Objects.SettingOvsInterface as NM.SettingOvsInterface
import {-# SOURCE #-} qualified GI.NM.Objects.SettingOvsPatch as NM.SettingOvsPatch
import {-# SOURCE #-} qualified GI.NM.Objects.SettingOvsPort as NM.SettingOvsPort
import {-# SOURCE #-} qualified GI.NM.Objects.SettingPpp as NM.SettingPpp
import {-# SOURCE #-} qualified GI.NM.Objects.SettingPppoe as NM.SettingPppoe
import {-# SOURCE #-} qualified GI.NM.Objects.SettingProxy as NM.SettingProxy
import {-# SOURCE #-} qualified GI.NM.Objects.SettingSerial as NM.SettingSerial
import {-# SOURCE #-} qualified GI.NM.Objects.SettingTCConfig as NM.SettingTCConfig
import {-# SOURCE #-} qualified GI.NM.Objects.SettingTeam as NM.SettingTeam
import {-# SOURCE #-} qualified GI.NM.Objects.SettingTeamPort as NM.SettingTeamPort
import {-# SOURCE #-} qualified GI.NM.Objects.SettingTun as NM.SettingTun
import {-# SOURCE #-} qualified GI.NM.Objects.SettingVlan as NM.SettingVlan
import {-# SOURCE #-} qualified GI.NM.Objects.SettingVpn as NM.SettingVpn
import {-# SOURCE #-} qualified GI.NM.Objects.SettingVxlan as NM.SettingVxlan
import {-# SOURCE #-} qualified GI.NM.Objects.SettingWimax as NM.SettingWimax
import {-# SOURCE #-} qualified GI.NM.Objects.SettingWired as NM.SettingWired
import {-# SOURCE #-} qualified GI.NM.Objects.SettingWireless as NM.SettingWireless
import {-# SOURCE #-} qualified GI.NM.Objects.SettingWirelessSecurity as NM.SettingWirelessSecurity
import {-# SOURCE #-} qualified GI.NM.Structs.BridgeVlan as NM.BridgeVlan
import {-# SOURCE #-} qualified GI.NM.Structs.IPAddress as NM.IPAddress
import {-# SOURCE #-} qualified GI.NM.Structs.IPRoute as NM.IPRoute
import {-# SOURCE #-} qualified GI.NM.Structs.IPRoutingRule as NM.IPRoutingRule
import {-# SOURCE #-} qualified GI.NM.Structs.Range as NM.Range
import {-# SOURCE #-} qualified GI.NM.Structs.TCAction as NM.TCAction
import {-# SOURCE #-} qualified GI.NM.Structs.TCQdisc as NM.TCQdisc
import {-# SOURCE #-} qualified GI.NM.Structs.TCTfilter as NM.TCTfilter
import {-# SOURCE #-} qualified GI.NM.Structs.TeamLinkWatcher as NM.TeamLinkWatcher
import {-# SOURCE #-} qualified GI.NM.Structs.VariantAttributeSpec as NM.VariantAttributeSpec
#else
import qualified GI.GObject.Objects.Object as GObject.Object
import {-# SOURCE #-} qualified GI.NM.Objects.Setting as NM.Setting
#endif
newtype SettingUser = SettingUser (SP.ManagedPtr SettingUser)
deriving (SettingUser -> SettingUser -> Bool
(SettingUser -> SettingUser -> Bool)
-> (SettingUser -> SettingUser -> Bool) -> Eq SettingUser
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: SettingUser -> SettingUser -> Bool
== :: SettingUser -> SettingUser -> Bool
$c/= :: SettingUser -> SettingUser -> Bool
/= :: SettingUser -> SettingUser -> Bool
Eq)
instance SP.ManagedPtrNewtype SettingUser where
toManagedPtr :: SettingUser -> ManagedPtr SettingUser
toManagedPtr (SettingUser ManagedPtr SettingUser
p) = ManagedPtr SettingUser
p
foreign import ccall "nm_setting_user_get_type"
c_nm_setting_user_get_type :: IO B.Types.GType
instance B.Types.TypedObject SettingUser where
glibType :: IO GType
glibType = IO GType
c_nm_setting_user_get_type
instance B.Types.GObject SettingUser
class (SP.GObject o, O.IsDescendantOf SettingUser o) => IsSettingUser o
instance (SP.GObject o, O.IsDescendantOf SettingUser o) => IsSettingUser o
instance O.HasParentTypes SettingUser
type instance O.ParentTypes SettingUser = '[NM.Setting.Setting, GObject.Object.Object]
toSettingUser :: (MIO.MonadIO m, IsSettingUser o) => o -> m SettingUser
toSettingUser :: forall (m :: * -> *) o.
(MonadIO m, IsSettingUser o) =>
o -> m SettingUser
toSettingUser = IO SettingUser -> m SettingUser
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO SettingUser -> m SettingUser)
-> (o -> IO SettingUser) -> o -> m SettingUser
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ManagedPtr SettingUser -> SettingUser) -> o -> IO SettingUser
forall o o'.
(HasCallStack, ManagedPtrNewtype o, TypedObject o,
ManagedPtrNewtype o', TypedObject o') =>
(ManagedPtr o' -> o') -> o -> IO o'
B.ManagedPtr.unsafeCastTo ManagedPtr SettingUser -> SettingUser
SettingUser
instance B.GValue.IsGValue (Maybe SettingUser) where
gvalueGType_ :: IO GType
gvalueGType_ = IO GType
c_nm_setting_user_get_type
gvalueSet_ :: Ptr GValue -> Maybe SettingUser -> IO ()
gvalueSet_ Ptr GValue
gv Maybe SettingUser
P.Nothing = Ptr GValue -> Ptr SettingUser -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv (Ptr SettingUser
forall a. Ptr a
FP.nullPtr :: FP.Ptr SettingUser)
gvalueSet_ Ptr GValue
gv (P.Just SettingUser
obj) = SettingUser -> (Ptr SettingUser -> IO ()) -> IO ()
forall a c.
(HasCallStack, ManagedPtrNewtype a) =>
a -> (Ptr a -> IO c) -> IO c
B.ManagedPtr.withManagedPtr SettingUser
obj (Ptr GValue -> Ptr SettingUser -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv)
gvalueGet_ :: Ptr GValue -> IO (Maybe SettingUser)
gvalueGet_ Ptr GValue
gv = do
Ptr SettingUser
ptr <- Ptr GValue -> IO (Ptr SettingUser)
forall a. GObject a => Ptr GValue -> IO (Ptr a)
B.GValue.get_object Ptr GValue
gv :: IO (FP.Ptr SettingUser)
if Ptr SettingUser
ptr Ptr SettingUser -> Ptr SettingUser -> Bool
forall a. Eq a => a -> a -> Bool
/= Ptr SettingUser
forall a. Ptr a
FP.nullPtr
then SettingUser -> Maybe SettingUser
forall a. a -> Maybe a
P.Just (SettingUser -> Maybe SettingUser)
-> IO SettingUser -> IO (Maybe SettingUser)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (ManagedPtr SettingUser -> SettingUser)
-> Ptr SettingUser -> IO SettingUser
forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
B.ManagedPtr.newObject ManagedPtr SettingUser -> SettingUser
SettingUser Ptr SettingUser
ptr
else Maybe SettingUser -> IO (Maybe SettingUser)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Maybe SettingUser
forall a. Maybe a
P.Nothing
#if defined(ENABLE_OVERLOADING)
type family ResolveSettingUserMethod (t :: Symbol) (o :: DK.Type) :: DK.Type where
ResolveSettingUserMethod "bindProperty" o = GObject.Object.ObjectBindPropertyMethodInfo
ResolveSettingUserMethod "bindPropertyFull" o = GObject.Object.ObjectBindPropertyFullMethodInfo
ResolveSettingUserMethod "compare" o = NM.Setting.SettingCompareMethodInfo
ResolveSettingUserMethod "diff" o = NM.Setting.SettingDiffMethodInfo
ResolveSettingUserMethod "duplicate" o = NM.Setting.SettingDuplicateMethodInfo
ResolveSettingUserMethod "enumerateValues" o = NM.Setting.SettingEnumerateValuesMethodInfo
ResolveSettingUserMethod "forceFloating" o = GObject.Object.ObjectForceFloatingMethodInfo
ResolveSettingUserMethod "freezeNotify" o = GObject.Object.ObjectFreezeNotifyMethodInfo
ResolveSettingUserMethod "getv" o = GObject.Object.ObjectGetvMethodInfo
ResolveSettingUserMethod "isFloating" o = GObject.Object.ObjectIsFloatingMethodInfo
ResolveSettingUserMethod "notify" o = GObject.Object.ObjectNotifyMethodInfo
ResolveSettingUserMethod "notifyByPspec" o = GObject.Object.ObjectNotifyByPspecMethodInfo
ResolveSettingUserMethod "optionClearByName" o = NM.Setting.SettingOptionClearByNameMethodInfo
ResolveSettingUserMethod "optionGet" o = NM.Setting.SettingOptionGetMethodInfo
ResolveSettingUserMethod "optionGetAllNames" o = NM.Setting.SettingOptionGetAllNamesMethodInfo
ResolveSettingUserMethod "optionGetBoolean" o = NM.Setting.SettingOptionGetBooleanMethodInfo
ResolveSettingUserMethod "optionGetUint32" o = NM.Setting.SettingOptionGetUint32MethodInfo
ResolveSettingUserMethod "optionSet" o = NM.Setting.SettingOptionSetMethodInfo
ResolveSettingUserMethod "optionSetBoolean" o = NM.Setting.SettingOptionSetBooleanMethodInfo
ResolveSettingUserMethod "optionSetUint32" o = NM.Setting.SettingOptionSetUint32MethodInfo
ResolveSettingUserMethod "ref" o = GObject.Object.ObjectRefMethodInfo
ResolveSettingUserMethod "refSink" o = GObject.Object.ObjectRefSinkMethodInfo
ResolveSettingUserMethod "runDispose" o = GObject.Object.ObjectRunDisposeMethodInfo
ResolveSettingUserMethod "stealData" o = GObject.Object.ObjectStealDataMethodInfo
ResolveSettingUserMethod "stealQdata" o = GObject.Object.ObjectStealQdataMethodInfo
ResolveSettingUserMethod "thawNotify" o = GObject.Object.ObjectThawNotifyMethodInfo
ResolveSettingUserMethod "toString" o = NM.Setting.SettingToStringMethodInfo
ResolveSettingUserMethod "unref" o = GObject.Object.ObjectUnrefMethodInfo
ResolveSettingUserMethod "verify" o = NM.Setting.SettingVerifyMethodInfo
ResolveSettingUserMethod "verifySecrets" o = NM.Setting.SettingVerifySecretsMethodInfo
ResolveSettingUserMethod "watchClosure" o = GObject.Object.ObjectWatchClosureMethodInfo
ResolveSettingUserMethod "getData" o = SettingUserGetDataMethodInfo
ResolveSettingUserMethod "getDbusPropertyType" o = NM.Setting.SettingGetDbusPropertyTypeMethodInfo
ResolveSettingUserMethod "getKeys" o = SettingUserGetKeysMethodInfo
ResolveSettingUserMethod "getName" o = NM.Setting.SettingGetNameMethodInfo
ResolveSettingUserMethod "getProperty" o = GObject.Object.ObjectGetPropertyMethodInfo
ResolveSettingUserMethod "getQdata" o = GObject.Object.ObjectGetQdataMethodInfo
ResolveSettingUserMethod "getSecretFlags" o = NM.Setting.SettingGetSecretFlagsMethodInfo
ResolveSettingUserMethod "setData" o = SettingUserSetDataMethodInfo
ResolveSettingUserMethod "setDataFull" o = GObject.Object.ObjectSetDataFullMethodInfo
ResolveSettingUserMethod "setProperty" o = GObject.Object.ObjectSetPropertyMethodInfo
ResolveSettingUserMethod "setSecretFlags" o = NM.Setting.SettingSetSecretFlagsMethodInfo
ResolveSettingUserMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveSettingUserMethod t SettingUser, O.OverloadedMethod info SettingUser p) => OL.IsLabel t (SettingUser -> 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 ~ ResolveSettingUserMethod t SettingUser, O.OverloadedMethod info SettingUser p, R.HasField t SettingUser p) => R.HasField t SettingUser p where
getField = O.overloadedMethod @info
#endif
instance (info ~ ResolveSettingUserMethod t SettingUser, O.OverloadedMethodInfo info SettingUser) => OL.IsLabel t (O.MethodProxy info SettingUser) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.MethodProxy
#else
fromLabel _ = O.MethodProxy
#endif
#endif
getSettingUserData :: (MonadIO m, IsSettingUser o) => o -> m (Maybe (Map.Map T.Text T.Text))
getSettingUserData :: forall (m :: * -> *) o.
(MonadIO m, IsSettingUser o) =>
o -> m (Maybe (Map Text Text))
getSettingUserData o
obj = IO (Maybe (Map Text Text)) -> m (Maybe (Map Text Text))
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO (Maybe (Map Text Text)) -> m (Maybe (Map Text Text)))
-> IO (Maybe (Map Text Text)) -> m (Maybe (Map Text Text))
forall a b. (a -> b) -> a -> b
$ o -> String -> IO (Maybe (Map Text Text))
forall a b. GObject a => a -> String -> IO b
B.Properties.getObjectPropertyHash o
obj String
"data"
setSettingUserData :: (MonadIO m, IsSettingUser o) => o -> Map.Map T.Text T.Text -> m ()
setSettingUserData :: forall (m :: * -> *) o.
(MonadIO m, IsSettingUser o) =>
o -> Map Text Text -> m ()
setSettingUserData o
obj Map Text Text
val = IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ do
o -> String -> Maybe (Map Text Text) -> IO ()
forall a b. GObject a => a -> String -> b -> IO ()
B.Properties.setObjectPropertyHash o
obj String
"data" (Map Text Text -> Maybe (Map Text Text)
forall a. a -> Maybe a
Just Map Text Text
val)
constructSettingUserData :: (IsSettingUser o, MIO.MonadIO m) => Map.Map T.Text T.Text -> m (GValueConstruct o)
constructSettingUserData :: forall o (m :: * -> *).
(IsSettingUser o, MonadIO m) =>
Map Text Text -> m (GValueConstruct o)
constructSettingUserData Map Text Text
val = IO (GValueConstruct o) -> m (GValueConstruct o)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO (GValueConstruct o) -> m (GValueConstruct o))
-> IO (GValueConstruct o) -> m (GValueConstruct o)
forall a b. (a -> b) -> a -> b
$ do
IO (GValueConstruct o) -> IO (GValueConstruct o)
forall a. IO a -> IO a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO (GValueConstruct o) -> IO (GValueConstruct o))
-> IO (GValueConstruct o) -> IO (GValueConstruct o)
forall a b. (a -> b) -> a -> b
$ String -> Maybe (Map Text Text) -> IO (GValueConstruct o)
forall b o. String -> b -> IO (GValueConstruct o)
B.Properties.constructObjectPropertyHash String
"data" (Map Text Text -> Maybe (Map Text Text)
forall a. a -> Maybe a
P.Just Map Text Text
val)
clearSettingUserData :: (MonadIO m, IsSettingUser o) => o -> m ()
clearSettingUserData :: forall (m :: * -> *) o. (MonadIO m, IsSettingUser o) => o -> m ()
clearSettingUserData o
obj = IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ o -> String -> Maybe (Map Text Text) -> IO ()
forall a b. GObject a => a -> String -> b -> IO ()
B.Properties.setObjectPropertyHash o
obj String
"data" (Maybe (Map Text Text)
forall a. Maybe a
Nothing :: Maybe (Map.Map T.Text T.Text))
#if defined(ENABLE_OVERLOADING)
data SettingUserDataPropertyInfo
instance AttrInfo SettingUserDataPropertyInfo where
type AttrAllowedOps SettingUserDataPropertyInfo = '[ 'AttrSet, 'AttrConstruct, 'AttrGet, 'AttrClear]
type AttrBaseTypeConstraint SettingUserDataPropertyInfo = IsSettingUser
type AttrSetTypeConstraint SettingUserDataPropertyInfo = (~) (Map.Map T.Text T.Text)
type AttrTransferTypeConstraint SettingUserDataPropertyInfo = (~) (Map.Map T.Text T.Text)
type AttrTransferType SettingUserDataPropertyInfo = Map.Map T.Text T.Text
type AttrGetType SettingUserDataPropertyInfo = (Maybe (Map.Map T.Text T.Text))
type AttrLabel SettingUserDataPropertyInfo = "data"
type AttrOrigin SettingUserDataPropertyInfo = SettingUser
attrGet = getSettingUserData
attrSet = setSettingUserData
attrTransfer _ v = do
return v
attrConstruct = constructSettingUserData
attrClear = clearSettingUserData
dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.NM.Objects.SettingUser.data"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-nm-1.0.1/docs/GI-NM-Objects-SettingUser.html#g:attr:data"
})
#endif
#if defined(ENABLE_OVERLOADING)
instance O.HasAttributeList SettingUser
type instance O.AttributeList SettingUser = SettingUserAttributeList
type SettingUserAttributeList = ('[ '("data", SettingUserDataPropertyInfo), '("name", NM.Setting.SettingNamePropertyInfo)] :: [(Symbol, DK.Type)])
#endif
#if defined(ENABLE_OVERLOADING)
settingUserData :: AttrLabelProxy "data"
settingUserData = AttrLabelProxy
#endif
#if defined(ENABLE_OVERLOADING)
type instance O.SignalList SettingUser = SettingUserSignalList
type SettingUserSignalList = ('[ '("notify", GObject.Object.ObjectNotifySignalInfo)] :: [(Symbol, DK.Type)])
#endif
foreign import ccall "nm_setting_user_new" nm_setting_user_new ::
IO (Ptr SettingUser)
settingUserNew ::
(B.CallStack.HasCallStack, MonadIO m) =>
m SettingUser
settingUserNew :: forall (m :: * -> *). (HasCallStack, MonadIO m) => m SettingUser
settingUserNew = IO SettingUser -> m SettingUser
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO SettingUser -> m SettingUser)
-> IO SettingUser -> m SettingUser
forall a b. (a -> b) -> a -> b
$ do
Ptr SettingUser
result <- IO (Ptr SettingUser)
nm_setting_user_new
Text -> Ptr SettingUser -> IO ()
forall a. HasCallStack => Text -> Ptr a -> IO ()
checkUnexpectedReturnNULL Text
"settingUserNew" Ptr SettingUser
result
SettingUser
result' <- ((ManagedPtr SettingUser -> SettingUser)
-> Ptr SettingUser -> IO SettingUser
forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
wrapObject ManagedPtr SettingUser -> SettingUser
SettingUser) Ptr SettingUser
result
SettingUser -> IO SettingUser
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return SettingUser
result'
#if defined(ENABLE_OVERLOADING)
#endif
foreign import ccall "nm_setting_user_get_data" nm_setting_user_get_data ::
Ptr SettingUser ->
CString ->
IO CString
settingUserGetData ::
(B.CallStack.HasCallStack, MonadIO m, IsSettingUser a) =>
a
-> T.Text
-> m T.Text
settingUserGetData :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsSettingUser a) =>
a -> Text -> m Text
settingUserGetData a
setting Text
key = IO Text -> m Text
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO Text -> m Text) -> IO Text -> m Text
forall a b. (a -> b) -> a -> b
$ do
Ptr SettingUser
setting' <- a -> IO (Ptr SettingUser)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
setting
CString
key' <- Text -> IO CString
textToCString Text
key
CString
result <- Ptr SettingUser -> CString -> IO CString
nm_setting_user_get_data Ptr SettingUser
setting' CString
key'
Text -> CString -> IO ()
forall a. HasCallStack => Text -> Ptr a -> IO ()
checkUnexpectedReturnNULL Text
"settingUserGetData" CString
result
Text
result' <- HasCallStack => CString -> IO Text
CString -> IO Text
cstringToText CString
result
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
setting
CString -> IO ()
forall a. Ptr a -> IO ()
freeMem CString
key'
Text -> IO Text
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Text
result'
#if defined(ENABLE_OVERLOADING)
data SettingUserGetDataMethodInfo
instance (signature ~ (T.Text -> m T.Text), MonadIO m, IsSettingUser a) => O.OverloadedMethod SettingUserGetDataMethodInfo a signature where
overloadedMethod = settingUserGetData
instance O.OverloadedMethodInfo SettingUserGetDataMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.NM.Objects.SettingUser.settingUserGetData",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-nm-1.0.1/docs/GI-NM-Objects-SettingUser.html#v:settingUserGetData"
})
#endif
foreign import ccall "nm_setting_user_get_keys" nm_setting_user_get_keys ::
Ptr SettingUser ->
Ptr Word32 ->
IO (Ptr CString)
settingUserGetKeys ::
(B.CallStack.HasCallStack, MonadIO m, IsSettingUser a) =>
a
-> m [T.Text]
settingUserGetKeys :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsSettingUser a) =>
a -> m [Text]
settingUserGetKeys a
setting = IO [Text] -> m [Text]
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO [Text] -> m [Text]) -> IO [Text] -> m [Text]
forall a b. (a -> b) -> a -> b
$ do
Ptr SettingUser
setting' <- a -> IO (Ptr SettingUser)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
setting
Ptr Word32
outLen <- IO (Ptr Word32)
forall a. Storable a => IO (Ptr a)
allocMem :: IO (Ptr Word32)
Ptr CString
result <- Ptr SettingUser -> Ptr Word32 -> IO (Ptr CString)
nm_setting_user_get_keys Ptr SettingUser
setting' Ptr Word32
outLen
Word32
outLen' <- Ptr Word32 -> IO Word32
forall a. Storable a => Ptr a -> IO a
peek Ptr Word32
outLen
Text -> Ptr CString -> IO ()
forall a. HasCallStack => Text -> Ptr a -> IO ()
checkUnexpectedReturnNULL Text
"settingUserGetKeys" Ptr CString
result
[Text]
result' <- (Word32 -> Ptr CString -> IO [Text]
forall a.
(HasCallStack, Integral a) =>
a -> Ptr CString -> IO [Text]
unpackUTF8CArrayWithLength Word32
outLen') Ptr CString
result
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
setting
Ptr Word32 -> IO ()
forall a. Ptr a -> IO ()
freeMem Ptr Word32
outLen
[Text] -> IO [Text]
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return [Text]
result'
#if defined(ENABLE_OVERLOADING)
data SettingUserGetKeysMethodInfo
instance (signature ~ (m [T.Text]), MonadIO m, IsSettingUser a) => O.OverloadedMethod SettingUserGetKeysMethodInfo a signature where
overloadedMethod = settingUserGetKeys
instance O.OverloadedMethodInfo SettingUserGetKeysMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.NM.Objects.SettingUser.settingUserGetKeys",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-nm-1.0.1/docs/GI-NM-Objects-SettingUser.html#v:settingUserGetKeys"
})
#endif
foreign import ccall "nm_setting_user_set_data" nm_setting_user_set_data ::
Ptr SettingUser ->
CString ->
CString ->
Ptr (Ptr GError) ->
IO CInt
settingUserSetData ::
(B.CallStack.HasCallStack, MonadIO m, IsSettingUser a) =>
a
-> T.Text
-> Maybe (T.Text)
-> m ()
settingUserSetData :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsSettingUser a) =>
a -> Text -> Maybe Text -> m ()
settingUserSetData a
setting Text
key Maybe Text
val = IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ do
Ptr SettingUser
setting' <- a -> IO (Ptr SettingUser)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
setting
CString
key' <- Text -> IO CString
textToCString Text
key
CString
maybeVal <- case Maybe Text
val of
Maybe Text
Nothing -> CString -> IO CString
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return CString
forall a. Ptr a
FP.nullPtr
Just Text
jVal -> do
CString
jVal' <- Text -> IO CString
textToCString Text
jVal
CString -> IO CString
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return CString
jVal'
IO () -> IO () -> IO ()
forall a b. IO a -> IO b -> IO a
onException (do
CInt
_ <- (Ptr (Ptr GError) -> IO CInt) -> IO CInt
forall a. (Ptr (Ptr GError) -> IO a) -> IO a
propagateGError ((Ptr (Ptr GError) -> IO CInt) -> IO CInt)
-> (Ptr (Ptr GError) -> IO CInt) -> IO CInt
forall a b. (a -> b) -> a -> b
$ Ptr SettingUser
-> CString -> CString -> Ptr (Ptr GError) -> IO CInt
nm_setting_user_set_data Ptr SettingUser
setting' CString
key' CString
maybeVal
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
setting
CString -> IO ()
forall a. Ptr a -> IO ()
freeMem CString
key'
CString -> IO ()
forall a. Ptr a -> IO ()
freeMem CString
maybeVal
() -> IO ()
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return ()
) (do
CString -> IO ()
forall a. Ptr a -> IO ()
freeMem CString
key'
CString -> IO ()
forall a. Ptr a -> IO ()
freeMem CString
maybeVal
)
#if defined(ENABLE_OVERLOADING)
data SettingUserSetDataMethodInfo
instance (signature ~ (T.Text -> Maybe (T.Text) -> m ()), MonadIO m, IsSettingUser a) => O.OverloadedMethod SettingUserSetDataMethodInfo a signature where
overloadedMethod = settingUserSetData
instance O.OverloadedMethodInfo SettingUserSetDataMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.NM.Objects.SettingUser.settingUserSetData",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-nm-1.0.1/docs/GI-NM-Objects-SettingUser.html#v:settingUserSetData"
})
#endif
foreign import ccall "nm_setting_user_check_key" nm_setting_user_check_key ::
CString ->
Ptr (Ptr GError) ->
IO CInt
settingUserCheckKey ::
(B.CallStack.HasCallStack, MonadIO m) =>
T.Text
-> m ()
settingUserCheckKey :: forall (m :: * -> *). (HasCallStack, MonadIO m) => Text -> m ()
settingUserCheckKey Text
key = IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ do
CString
key' <- Text -> IO CString
textToCString Text
key
IO () -> IO () -> IO ()
forall a b. IO a -> IO b -> IO a
onException (do
CInt
_ <- (Ptr (Ptr GError) -> IO CInt) -> IO CInt
forall a. (Ptr (Ptr GError) -> IO a) -> IO a
propagateGError ((Ptr (Ptr GError) -> IO CInt) -> IO CInt)
-> (Ptr (Ptr GError) -> IO CInt) -> IO CInt
forall a b. (a -> b) -> a -> b
$ CString -> Ptr (Ptr GError) -> IO CInt
nm_setting_user_check_key CString
key'
CString -> IO ()
forall a. Ptr a -> IO ()
freeMem CString
key'
() -> IO ()
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return ()
) (do
CString -> IO ()
forall a. Ptr a -> IO ()
freeMem CString
key'
)
#if defined(ENABLE_OVERLOADING)
#endif
foreign import ccall "nm_setting_user_check_val" nm_setting_user_check_val ::
CString ->
Ptr (Ptr GError) ->
IO CInt
settingUserCheckVal ::
(B.CallStack.HasCallStack, MonadIO m) =>
T.Text
-> m ()
settingUserCheckVal :: forall (m :: * -> *). (HasCallStack, MonadIO m) => Text -> m ()
settingUserCheckVal Text
val = IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ do
CString
val' <- Text -> IO CString
textToCString Text
val
IO () -> IO () -> IO ()
forall a b. IO a -> IO b -> IO a
onException (do
CInt
_ <- (Ptr (Ptr GError) -> IO CInt) -> IO CInt
forall a. (Ptr (Ptr GError) -> IO a) -> IO a
propagateGError ((Ptr (Ptr GError) -> IO CInt) -> IO CInt)
-> (Ptr (Ptr GError) -> IO CInt) -> IO CInt
forall a b. (a -> b) -> a -> b
$ CString -> Ptr (Ptr GError) -> IO CInt
nm_setting_user_check_val CString
val'
CString -> IO ()
forall a. Ptr a -> IO ()
freeMem CString
val'
() -> IO ()
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return ()
) (do
CString -> IO ()
forall a. Ptr a -> IO ()
freeMem CString
val'
)
#if defined(ENABLE_OVERLOADING)
#endif