-- | Copyright  : Will Thompson and Iñaki García Etxebarria
-- License    : LGPL-2.1
-- Maintainer : Iñaki García Etxebarria

#if (MIN_VERSION_haskell_gi_overloading(1,0,0) && !defined(__HADDOCK_VERSION__))
#define ENABLE_OVERLOADING
#endif

module GI.WebKit2WebExtension.Callbacks
    ( 

 -- * Signals


-- ** WebExtensionInitializeFunction #signal:WebExtensionInitializeFunction#

    C_WebExtensionInitializeFunction        ,
    WebExtensionInitializeFunction          ,
    dynamic_WebExtensionInitializeFunction  ,
    genClosure_WebExtensionInitializeFunction,
    mk_WebExtensionInitializeFunction       ,
    noWebExtensionInitializeFunction        ,
    wrap_WebExtensionInitializeFunction     ,


-- ** WebExtensionInitializeWithUserDataFunction #signal:WebExtensionInitializeWithUserDataFunction#

    C_WebExtensionInitializeWithUserDataFunction,
    WebExtensionInitializeWithUserDataFunction,
    dynamic_WebExtensionInitializeWithUserDataFunction,
    genClosure_WebExtensionInitializeWithUserDataFunction,
    mk_WebExtensionInitializeWithUserDataFunction,
    noWebExtensionInitializeWithUserDataFunction,
    wrap_WebExtensionInitializeWithUserDataFunction,




    ) 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 {-# SOURCE #-} qualified GI.WebKit2WebExtension.Objects.WebExtension as WebKit2WebExtension.WebExtension

-- callback WebExtensionInitializeWithUserDataFunction
{- Callable
  { returnType = Nothing
  , returnMayBeNull = False
  , returnTransfer = TransferNothing
  , returnDocumentation =
      Documentation { rawDocText = Nothing , sinceVersion = Nothing }
  , args =
      [ Arg
          { argCName = "extension"
          , argType =
              TInterface
                Name { namespace = "WebKit2WebExtension" , name = "WebExtension" }
          , direction = DirectionIn
          , mayBeNull = False
          , argDoc =
              Documentation
                { rawDocText = Just "a #WebKitWebExtension"
                , sinceVersion = Nothing
                }
          , argScope = ScopeTypeInvalid
          , argClosure = -1
          , argDestroy = -1
          , argCallerAllocates = False
          , transfer = TransferNothing
          }
      , Arg
          { argCName = "user_data"
          , argType = TVariant
          , direction = DirectionIn
          , mayBeNull = False
          , argDoc =
              Documentation
                { rawDocText = Just "a #GVariant" , sinceVersion = Nothing }
          , argScope = ScopeTypeInvalid
          , argClosure = -1
          , argDestroy = -1
          , argCallerAllocates = False
          , transfer = TransferNothing
          }
      ]
  , skipReturn = False
  , callableThrows = False
  , callableDeprecated = Nothing
  , callableDocumentation =
      Documentation
        { rawDocText =
            Just
              "Type definition for a function that will be called to initialize\nthe web extensions when the web process starts, and which receives\nas additional argument the user data set with\nwebkit_web_context_set_web_extensions_initialization_user_data()."
        , sinceVersion = Just "2.4"
        }
  , callableResolvable = Nothing
  }
-}
-- | Type for the callback on the (unwrapped) C side.
type C_WebExtensionInitializeWithUserDataFunction =
    Ptr WebKit2WebExtension.WebExtension.WebExtension ->
    Ptr GVariant ->
    IO ()

-- Args: [ Arg
--           { argCName = "extension"
--           , argType =
--               TInterface
--                 Name { namespace = "WebKit2WebExtension" , name = "WebExtension" }
--           , direction = DirectionIn
--           , mayBeNull = False
--           , argDoc =
--               Documentation
--                 { rawDocText = Just "a #WebKitWebExtension"
--                 , sinceVersion = Nothing
--                 }
--           , argScope = ScopeTypeInvalid
--           , argClosure = -1
--           , argDestroy = -1
--           , argCallerAllocates = False
--           , transfer = TransferNothing
--           }
--       , Arg
--           { argCName = "user_data"
--           , argType = TVariant
--           , direction = DirectionIn
--           , mayBeNull = False
--           , argDoc =
--               Documentation
--                 { rawDocText = Just "a #GVariant" , sinceVersion = Nothing }
--           , argScope = ScopeTypeInvalid
--           , argClosure = -1
--           , argDestroy = -1
--           , argCallerAllocates = False
--           , transfer = TransferNothing
--           }
--       ]
-- Lengths: []
-- returnType: Nothing
-- throws : False
-- Skip return : False

foreign import ccall "dynamic" __dynamic_C_WebExtensionInitializeWithUserDataFunction :: FunPtr C_WebExtensionInitializeWithUserDataFunction -> C_WebExtensionInitializeWithUserDataFunction

-- | Given a pointer to a foreign C function, wrap it into a function callable from Haskell.
dynamic_WebExtensionInitializeWithUserDataFunction ::
    (B.CallStack.HasCallStack, MonadIO m, WebKit2WebExtension.WebExtension.IsWebExtension a) =>
    FunPtr C_WebExtensionInitializeWithUserDataFunction
    -> a
    -- ^ /@extension@/: a t'GI.WebKit2WebExtension.Objects.WebExtension.WebExtension'
    -> GVariant
    -- ^ /@userData@/: a t'GVariant'
    -> m ()
dynamic_WebExtensionInitializeWithUserDataFunction :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsWebExtension a) =>
FunPtr C_WebExtensionInitializeWithUserDataFunction
-> a -> GVariant -> m ()
dynamic_WebExtensionInitializeWithUserDataFunction FunPtr C_WebExtensionInitializeWithUserDataFunction
__funPtr a
extension GVariant
userData = 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 WebExtension
extension' <- a -> IO (Ptr WebExtension)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
extension
    Ptr GVariant
userData' <- GVariant -> IO (Ptr GVariant)
forall a. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr a)
unsafeManagedPtrGetPtr GVariant
userData
    (FunPtr C_WebExtensionInitializeWithUserDataFunction
-> C_WebExtensionInitializeWithUserDataFunction
__dynamic_C_WebExtensionInitializeWithUserDataFunction FunPtr C_WebExtensionInitializeWithUserDataFunction
__funPtr) Ptr WebExtension
extension' Ptr GVariant
userData'
    a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
extension
    GVariant -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr GVariant
userData
    () -> IO ()
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return ()

-- | Generate a function pointer callable from C code, from a `C_WebExtensionInitializeWithUserDataFunction`.
foreign import ccall "wrapper"
    mk_WebExtensionInitializeWithUserDataFunction :: C_WebExtensionInitializeWithUserDataFunction -> IO (FunPtr C_WebExtensionInitializeWithUserDataFunction)

-- | Type definition for a function that will be called to initialize
-- the web extensions when the web process starts, and which receives
-- as additional argument the user data set with
-- @/webkit_web_context_set_web_extensions_initialization_user_data()/@.
-- 
-- /Since: 2.4/
type WebExtensionInitializeWithUserDataFunction =
    WebKit2WebExtension.WebExtension.WebExtension
    -- ^ /@extension@/: a t'GI.WebKit2WebExtension.Objects.WebExtension.WebExtension'
    -> GVariant
    -- ^ /@userData@/: a t'GVariant'
    -> IO ()

-- | A convenience synonym for @`Nothing` :: `Maybe` `WebExtensionInitializeWithUserDataFunction`@.
noWebExtensionInitializeWithUserDataFunction :: Maybe WebExtensionInitializeWithUserDataFunction
noWebExtensionInitializeWithUserDataFunction :: Maybe WebExtensionInitializeWithUserDataFunction
noWebExtensionInitializeWithUserDataFunction = Maybe WebExtensionInitializeWithUserDataFunction
forall a. Maybe a
Nothing

-- | Wrap the callback into a `GClosure`.
genClosure_WebExtensionInitializeWithUserDataFunction :: MonadIO m => WebExtensionInitializeWithUserDataFunction -> m (GClosure C_WebExtensionInitializeWithUserDataFunction)
genClosure_WebExtensionInitializeWithUserDataFunction :: forall (m :: * -> *).
MonadIO m =>
WebExtensionInitializeWithUserDataFunction
-> m (GClosure C_WebExtensionInitializeWithUserDataFunction)
genClosure_WebExtensionInitializeWithUserDataFunction WebExtensionInitializeWithUserDataFunction
cb = IO (GClosure C_WebExtensionInitializeWithUserDataFunction)
-> m (GClosure C_WebExtensionInitializeWithUserDataFunction)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO (GClosure C_WebExtensionInitializeWithUserDataFunction)
 -> m (GClosure C_WebExtensionInitializeWithUserDataFunction))
-> IO (GClosure C_WebExtensionInitializeWithUserDataFunction)
-> m (GClosure C_WebExtensionInitializeWithUserDataFunction)
forall a b. (a -> b) -> a -> b
$ do
    let cb' :: C_WebExtensionInitializeWithUserDataFunction
cb' = Maybe (Ptr (FunPtr C_WebExtensionInitializeWithUserDataFunction))
-> WebExtensionInitializeWithUserDataFunction
-> C_WebExtensionInitializeWithUserDataFunction
wrap_WebExtensionInitializeWithUserDataFunction Maybe (Ptr (FunPtr C_WebExtensionInitializeWithUserDataFunction))
forall a. Maybe a
Nothing WebExtensionInitializeWithUserDataFunction
cb
    C_WebExtensionInitializeWithUserDataFunction
-> IO (FunPtr C_WebExtensionInitializeWithUserDataFunction)
mk_WebExtensionInitializeWithUserDataFunction C_WebExtensionInitializeWithUserDataFunction
cb' IO (FunPtr C_WebExtensionInitializeWithUserDataFunction)
-> (FunPtr C_WebExtensionInitializeWithUserDataFunction
    -> IO (GClosure C_WebExtensionInitializeWithUserDataFunction))
-> IO (GClosure C_WebExtensionInitializeWithUserDataFunction)
forall a b. IO a -> (a -> IO b) -> IO b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= FunPtr C_WebExtensionInitializeWithUserDataFunction
-> IO (GClosure C_WebExtensionInitializeWithUserDataFunction)
forall (m :: * -> *) a. MonadIO m => FunPtr a -> m (GClosure a)
B.GClosure.newGClosure


-- | Wrap a `WebExtensionInitializeWithUserDataFunction` into a `C_WebExtensionInitializeWithUserDataFunction`.
wrap_WebExtensionInitializeWithUserDataFunction :: 
    Maybe (Ptr (FunPtr C_WebExtensionInitializeWithUserDataFunction)) ->
    WebExtensionInitializeWithUserDataFunction ->
    C_WebExtensionInitializeWithUserDataFunction
wrap_WebExtensionInitializeWithUserDataFunction :: Maybe (Ptr (FunPtr C_WebExtensionInitializeWithUserDataFunction))
-> WebExtensionInitializeWithUserDataFunction
-> C_WebExtensionInitializeWithUserDataFunction
wrap_WebExtensionInitializeWithUserDataFunction Maybe (Ptr (FunPtr C_WebExtensionInitializeWithUserDataFunction))
gi'funptrptr WebExtensionInitializeWithUserDataFunction
gi'cb Ptr WebExtension
extension Ptr GVariant
userData = do
    WebExtension
extension' <- ((ManagedPtr WebExtension -> WebExtension)
-> Ptr WebExtension -> IO WebExtension
forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
newObject ManagedPtr WebExtension -> WebExtension
WebKit2WebExtension.WebExtension.WebExtension) Ptr WebExtension
extension
    GVariant
userData' <- Ptr GVariant -> IO GVariant
B.GVariant.newGVariantFromPtr Ptr GVariant
userData
    WebExtensionInitializeWithUserDataFunction
gi'cb  WebExtension
extension' GVariant
userData'
    Maybe (Ptr (FunPtr C_WebExtensionInitializeWithUserDataFunction))
-> IO ()
forall a. Maybe (Ptr (FunPtr a)) -> IO ()
maybeReleaseFunPtr Maybe (Ptr (FunPtr C_WebExtensionInitializeWithUserDataFunction))
gi'funptrptr


-- callback WebExtensionInitializeFunction
{- Callable
  { returnType = Nothing
  , returnMayBeNull = False
  , returnTransfer = TransferNothing
  , returnDocumentation =
      Documentation { rawDocText = Nothing , sinceVersion = Nothing }
  , args =
      [ Arg
          { argCName = "extension"
          , argType =
              TInterface
                Name { namespace = "WebKit2WebExtension" , name = "WebExtension" }
          , direction = DirectionIn
          , mayBeNull = False
          , argDoc =
              Documentation
                { rawDocText = Just "a #WebKitWebExtension"
                , sinceVersion = Nothing
                }
          , argScope = ScopeTypeInvalid
          , argClosure = -1
          , argDestroy = -1
          , argCallerAllocates = False
          , transfer = TransferNothing
          }
      ]
  , skipReturn = False
  , callableThrows = False
  , callableDeprecated = Nothing
  , callableDocumentation =
      Documentation
        { rawDocText =
            Just
              "Type definition for a function that will be called to initialize\nthe web extension when the web process starts."
        , sinceVersion = Nothing
        }
  , callableResolvable = Nothing
  }
-}
-- | Type for the callback on the (unwrapped) C side.
type C_WebExtensionInitializeFunction =
    Ptr WebKit2WebExtension.WebExtension.WebExtension ->
    IO ()

-- Args: [ Arg
--           { argCName = "extension"
--           , argType =
--               TInterface
--                 Name { namespace = "WebKit2WebExtension" , name = "WebExtension" }
--           , direction = DirectionIn
--           , mayBeNull = False
--           , argDoc =
--               Documentation
--                 { rawDocText = Just "a #WebKitWebExtension"
--                 , sinceVersion = Nothing
--                 }
--           , argScope = ScopeTypeInvalid
--           , argClosure = -1
--           , argDestroy = -1
--           , argCallerAllocates = False
--           , transfer = TransferNothing
--           }
--       ]
-- Lengths: []
-- returnType: Nothing
-- throws : False
-- Skip return : False

foreign import ccall "dynamic" __dynamic_C_WebExtensionInitializeFunction :: FunPtr C_WebExtensionInitializeFunction -> C_WebExtensionInitializeFunction

-- | Given a pointer to a foreign C function, wrap it into a function callable from Haskell.
dynamic_WebExtensionInitializeFunction ::
    (B.CallStack.HasCallStack, MonadIO m, WebKit2WebExtension.WebExtension.IsWebExtension a) =>
    FunPtr C_WebExtensionInitializeFunction
    -> a
    -- ^ /@extension@/: a t'GI.WebKit2WebExtension.Objects.WebExtension.WebExtension'
    -> m ()
dynamic_WebExtensionInitializeFunction :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsWebExtension a) =>
FunPtr C_WebExtensionInitializeFunction -> a -> m ()
dynamic_WebExtensionInitializeFunction FunPtr C_WebExtensionInitializeFunction
__funPtr a
extension = 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 WebExtension
extension' <- a -> IO (Ptr WebExtension)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
extension
    (FunPtr C_WebExtensionInitializeFunction
-> C_WebExtensionInitializeFunction
__dynamic_C_WebExtensionInitializeFunction FunPtr C_WebExtensionInitializeFunction
__funPtr) Ptr WebExtension
extension'
    a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
extension
    () -> IO ()
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return ()

-- | Generate a function pointer callable from C code, from a `C_WebExtensionInitializeFunction`.
foreign import ccall "wrapper"
    mk_WebExtensionInitializeFunction :: C_WebExtensionInitializeFunction -> IO (FunPtr C_WebExtensionInitializeFunction)

-- | Type definition for a function that will be called to initialize
-- the web extension when the web process starts.
type WebExtensionInitializeFunction =
    WebKit2WebExtension.WebExtension.WebExtension
    -- ^ /@extension@/: a t'GI.WebKit2WebExtension.Objects.WebExtension.WebExtension'
    -> IO ()

-- | A convenience synonym for @`Nothing` :: `Maybe` `WebExtensionInitializeFunction`@.
noWebExtensionInitializeFunction :: Maybe WebExtensionInitializeFunction
noWebExtensionInitializeFunction :: Maybe WebExtensionInitializeFunction
noWebExtensionInitializeFunction = Maybe WebExtensionInitializeFunction
forall a. Maybe a
Nothing

-- | Wrap the callback into a `GClosure`.
genClosure_WebExtensionInitializeFunction :: MonadIO m => WebExtensionInitializeFunction -> m (GClosure C_WebExtensionInitializeFunction)
genClosure_WebExtensionInitializeFunction :: forall (m :: * -> *).
MonadIO m =>
WebExtensionInitializeFunction
-> m (GClosure C_WebExtensionInitializeFunction)
genClosure_WebExtensionInitializeFunction WebExtensionInitializeFunction
cb = IO (GClosure C_WebExtensionInitializeFunction)
-> m (GClosure C_WebExtensionInitializeFunction)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO (GClosure C_WebExtensionInitializeFunction)
 -> m (GClosure C_WebExtensionInitializeFunction))
-> IO (GClosure C_WebExtensionInitializeFunction)
-> m (GClosure C_WebExtensionInitializeFunction)
forall a b. (a -> b) -> a -> b
$ do
    let cb' :: C_WebExtensionInitializeFunction
cb' = Maybe (Ptr (FunPtr C_WebExtensionInitializeFunction))
-> WebExtensionInitializeFunction
-> C_WebExtensionInitializeFunction
wrap_WebExtensionInitializeFunction Maybe (Ptr (FunPtr C_WebExtensionInitializeFunction))
forall a. Maybe a
Nothing WebExtensionInitializeFunction
cb
    C_WebExtensionInitializeFunction
-> IO (FunPtr C_WebExtensionInitializeFunction)
mk_WebExtensionInitializeFunction C_WebExtensionInitializeFunction
cb' IO (FunPtr C_WebExtensionInitializeFunction)
-> (FunPtr C_WebExtensionInitializeFunction
    -> IO (GClosure C_WebExtensionInitializeFunction))
-> IO (GClosure C_WebExtensionInitializeFunction)
forall a b. IO a -> (a -> IO b) -> IO b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= FunPtr C_WebExtensionInitializeFunction
-> IO (GClosure C_WebExtensionInitializeFunction)
forall (m :: * -> *) a. MonadIO m => FunPtr a -> m (GClosure a)
B.GClosure.newGClosure


-- | Wrap a `WebExtensionInitializeFunction` into a `C_WebExtensionInitializeFunction`.
wrap_WebExtensionInitializeFunction :: 
    Maybe (Ptr (FunPtr C_WebExtensionInitializeFunction)) ->
    WebExtensionInitializeFunction ->
    C_WebExtensionInitializeFunction
wrap_WebExtensionInitializeFunction :: Maybe (Ptr (FunPtr C_WebExtensionInitializeFunction))
-> WebExtensionInitializeFunction
-> C_WebExtensionInitializeFunction
wrap_WebExtensionInitializeFunction Maybe (Ptr (FunPtr C_WebExtensionInitializeFunction))
gi'funptrptr WebExtensionInitializeFunction
gi'cb Ptr WebExtension
extension = do
    WebExtension
extension' <- ((ManagedPtr WebExtension -> WebExtension)
-> Ptr WebExtension -> IO WebExtension
forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
newObject ManagedPtr WebExtension -> WebExtension
WebKit2WebExtension.WebExtension.WebExtension) Ptr WebExtension
extension
    WebExtensionInitializeFunction
gi'cb  WebExtension
extension'
    Maybe (Ptr (FunPtr C_WebExtensionInitializeFunction)) -> IO ()
forall a. Maybe (Ptr (FunPtr a)) -> IO ()
maybeReleaseFunPtr Maybe (Ptr (FunPtr C_WebExtensionInitializeFunction))
gi'funptrptr