{-# LANGUAGE TypeApplications #-}
#if (MIN_VERSION_haskell_gi_overloading(1,0,0) && !defined(__HADDOCK_VERSION__))
#define ENABLE_OVERLOADING
#endif
module GI.Soup.Objects.RequestData
(
RequestData(..) ,
IsRequestData ,
toRequestData ,
#if defined(ENABLE_OVERLOADING)
ResolveRequestDataMethod ,
#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.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 qualified GI.Gio.Interfaces.Initable as Gio.Initable
import {-# SOURCE #-} qualified GI.Soup.Objects.Request as Soup.Request
newtype RequestData = RequestData (SP.ManagedPtr RequestData)
deriving (RequestData -> RequestData -> Bool
(RequestData -> RequestData -> Bool)
-> (RequestData -> RequestData -> Bool) -> Eq RequestData
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: RequestData -> RequestData -> Bool
== :: RequestData -> RequestData -> Bool
$c/= :: RequestData -> RequestData -> Bool
/= :: RequestData -> RequestData -> Bool
Eq)
instance SP.ManagedPtrNewtype RequestData where
toManagedPtr :: RequestData -> ManagedPtr RequestData
toManagedPtr (RequestData ManagedPtr RequestData
p) = ManagedPtr RequestData
p
foreign import ccall "soup_request_data_get_type"
c_soup_request_data_get_type :: IO B.Types.GType
instance B.Types.TypedObject RequestData where
glibType :: IO GType
glibType = IO GType
c_soup_request_data_get_type
instance B.Types.GObject RequestData
class (SP.GObject o, O.IsDescendantOf RequestData o) => IsRequestData o
instance (SP.GObject o, O.IsDescendantOf RequestData o) => IsRequestData o
instance O.HasParentTypes RequestData
type instance O.ParentTypes RequestData = '[Soup.Request.Request, GObject.Object.Object, Gio.Initable.Initable]
toRequestData :: (MIO.MonadIO m, IsRequestData o) => o -> m RequestData
toRequestData :: forall (m :: * -> *) o.
(MonadIO m, IsRequestData o) =>
o -> m RequestData
toRequestData = IO RequestData -> m RequestData
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO RequestData -> m RequestData)
-> (o -> IO RequestData) -> o -> m RequestData
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ManagedPtr RequestData -> RequestData) -> o -> IO RequestData
forall o o'.
(HasCallStack, ManagedPtrNewtype o, TypedObject o,
ManagedPtrNewtype o', TypedObject o') =>
(ManagedPtr o' -> o') -> o -> IO o'
B.ManagedPtr.unsafeCastTo ManagedPtr RequestData -> RequestData
RequestData
instance B.GValue.IsGValue (Maybe RequestData) where
gvalueGType_ :: IO GType
gvalueGType_ = IO GType
c_soup_request_data_get_type
gvalueSet_ :: Ptr GValue -> Maybe RequestData -> IO ()
gvalueSet_ Ptr GValue
gv Maybe RequestData
P.Nothing = Ptr GValue -> Ptr RequestData -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv (Ptr RequestData
forall a. Ptr a
FP.nullPtr :: FP.Ptr RequestData)
gvalueSet_ Ptr GValue
gv (P.Just RequestData
obj) = RequestData -> (Ptr RequestData -> IO ()) -> IO ()
forall a c.
(HasCallStack, ManagedPtrNewtype a) =>
a -> (Ptr a -> IO c) -> IO c
B.ManagedPtr.withManagedPtr RequestData
obj (Ptr GValue -> Ptr RequestData -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv)
gvalueGet_ :: Ptr GValue -> IO (Maybe RequestData)
gvalueGet_ Ptr GValue
gv = do
Ptr RequestData
ptr <- Ptr GValue -> IO (Ptr RequestData)
forall a. GObject a => Ptr GValue -> IO (Ptr a)
B.GValue.get_object Ptr GValue
gv :: IO (FP.Ptr RequestData)
if Ptr RequestData
ptr Ptr RequestData -> Ptr RequestData -> Bool
forall a. Eq a => a -> a -> Bool
/= Ptr RequestData
forall a. Ptr a
FP.nullPtr
then RequestData -> Maybe RequestData
forall a. a -> Maybe a
P.Just (RequestData -> Maybe RequestData)
-> IO RequestData -> IO (Maybe RequestData)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (ManagedPtr RequestData -> RequestData)
-> Ptr RequestData -> IO RequestData
forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
B.ManagedPtr.newObject ManagedPtr RequestData -> RequestData
RequestData Ptr RequestData
ptr
else Maybe RequestData -> IO (Maybe RequestData)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Maybe RequestData
forall a. Maybe a
P.Nothing
#if defined(ENABLE_OVERLOADING)
type family ResolveRequestDataMethod (t :: Symbol) (o :: *) :: * where
ResolveRequestDataMethod "bindProperty" o = GObject.Object.ObjectBindPropertyMethodInfo
ResolveRequestDataMethod "bindPropertyFull" o = GObject.Object.ObjectBindPropertyFullMethodInfo
ResolveRequestDataMethod "forceFloating" o = GObject.Object.ObjectForceFloatingMethodInfo
ResolveRequestDataMethod "freezeNotify" o = GObject.Object.ObjectFreezeNotifyMethodInfo
ResolveRequestDataMethod "getv" o = GObject.Object.ObjectGetvMethodInfo
ResolveRequestDataMethod "init" o = Gio.Initable.InitableInitMethodInfo
ResolveRequestDataMethod "isFloating" o = GObject.Object.ObjectIsFloatingMethodInfo
ResolveRequestDataMethod "notify" o = GObject.Object.ObjectNotifyMethodInfo
ResolveRequestDataMethod "notifyByPspec" o = GObject.Object.ObjectNotifyByPspecMethodInfo
ResolveRequestDataMethod "ref" o = GObject.Object.ObjectRefMethodInfo
ResolveRequestDataMethod "refSink" o = GObject.Object.ObjectRefSinkMethodInfo
ResolveRequestDataMethod "runDispose" o = GObject.Object.ObjectRunDisposeMethodInfo
ResolveRequestDataMethod "send" o = Soup.Request.RequestSendMethodInfo
ResolveRequestDataMethod "sendAsync" o = Soup.Request.RequestSendAsyncMethodInfo
ResolveRequestDataMethod "sendFinish" o = Soup.Request.RequestSendFinishMethodInfo
ResolveRequestDataMethod "stealData" o = GObject.Object.ObjectStealDataMethodInfo
ResolveRequestDataMethod "stealQdata" o = GObject.Object.ObjectStealQdataMethodInfo
ResolveRequestDataMethod "thawNotify" o = GObject.Object.ObjectThawNotifyMethodInfo
ResolveRequestDataMethod "unref" o = GObject.Object.ObjectUnrefMethodInfo
ResolveRequestDataMethod "watchClosure" o = GObject.Object.ObjectWatchClosureMethodInfo
ResolveRequestDataMethod "getContentLength" o = Soup.Request.RequestGetContentLengthMethodInfo
ResolveRequestDataMethod "getContentType" o = Soup.Request.RequestGetContentTypeMethodInfo
ResolveRequestDataMethod "getData" o = GObject.Object.ObjectGetDataMethodInfo
ResolveRequestDataMethod "getProperty" o = GObject.Object.ObjectGetPropertyMethodInfo
ResolveRequestDataMethod "getQdata" o = GObject.Object.ObjectGetQdataMethodInfo
ResolveRequestDataMethod "getSession" o = Soup.Request.RequestGetSessionMethodInfo
ResolveRequestDataMethod "getUri" o = Soup.Request.RequestGetUriMethodInfo
ResolveRequestDataMethod "setData" o = GObject.Object.ObjectSetDataMethodInfo
ResolveRequestDataMethod "setDataFull" o = GObject.Object.ObjectSetDataFullMethodInfo
ResolveRequestDataMethod "setProperty" o = GObject.Object.ObjectSetPropertyMethodInfo
ResolveRequestDataMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveRequestDataMethod t RequestData, O.OverloadedMethod info RequestData p) => OL.IsLabel t (RequestData -> 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 ~ ResolveRequestDataMethod t RequestData, O.OverloadedMethod info RequestData p, R.HasField t RequestData p) => R.HasField t RequestData p where
getField = O.overloadedMethod @info
#endif
instance (info ~ ResolveRequestDataMethod t RequestData, O.OverloadedMethodInfo info RequestData) => OL.IsLabel t (O.MethodProxy info RequestData) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.MethodProxy
#else
fromLabel _ = O.MethodProxy
#endif
#endif
#if defined(ENABLE_OVERLOADING)
instance O.HasAttributeList RequestData
type instance O.AttributeList RequestData = RequestDataAttributeList
type RequestDataAttributeList = ('[ '("session", Soup.Request.RequestSessionPropertyInfo), '("uri", Soup.Request.RequestUriPropertyInfo)] :: [(Symbol, *)])
#endif
#if defined(ENABLE_OVERLOADING)
#endif
#if defined(ENABLE_OVERLOADING)
type instance O.SignalList RequestData = RequestDataSignalList
type RequestDataSignalList = ('[ '("notify", GObject.Object.ObjectNotifySignalInfo)] :: [(Symbol, *)])
#endif