{- |
Copyright  : Will Thompson, Iñaki García Etxebarria and Jonas Platte
License    : LGPL-2.1
Maintainer : Iñaki García Etxebarria (garetxe@gmail.com)

Represents options for a submodule update.
-}

module GI.Ggit.Objects.SubmoduleUpdateOptions
    ( 

-- * Exported types
    SubmoduleUpdateOptions(..)              ,
    IsSubmoduleUpdateOptions                ,
    toSubmoduleUpdateOptions                ,
    noSubmoduleUpdateOptions                ,


 -- * Methods
-- ** getCheckoutOptions #method:getCheckoutOptions#
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
    SubmoduleUpdateOptionsGetCheckoutOptionsMethodInfo,
#endif
    submoduleUpdateOptionsGetCheckoutOptions,


-- ** getCloneCheckoutStrategy #method:getCloneCheckoutStrategy#
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
    SubmoduleUpdateOptionsGetCloneCheckoutStrategyMethodInfo,
#endif
    submoduleUpdateOptionsGetCloneCheckoutStrategy,


-- ** getFetchOptions #method:getFetchOptions#
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
    SubmoduleUpdateOptionsGetFetchOptionsMethodInfo,
#endif
    submoduleUpdateOptionsGetFetchOptions   ,


-- ** new #method:new#
    submoduleUpdateOptionsNew               ,


-- ** setCheckoutOptions #method:setCheckoutOptions#
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
    SubmoduleUpdateOptionsSetCheckoutOptionsMethodInfo,
#endif
    submoduleUpdateOptionsSetCheckoutOptions,


-- ** setCloneCheckoutStrategy #method:setCloneCheckoutStrategy#
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
    SubmoduleUpdateOptionsSetCloneCheckoutStrategyMethodInfo,
#endif
    submoduleUpdateOptionsSetCloneCheckoutStrategy,


-- ** setFetchOptions #method:setFetchOptions#
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
    SubmoduleUpdateOptionsSetFetchOptionsMethodInfo,
#endif
    submoduleUpdateOptionsSetFetchOptions   ,




 -- * Properties
-- ** checkoutOptions #attr:checkoutOptions#
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
    SubmoduleUpdateOptionsCheckoutOptionsPropertyInfo,
#endif
    clearSubmoduleUpdateOptionsCheckoutOptions,
    constructSubmoduleUpdateOptionsCheckoutOptions,
    getSubmoduleUpdateOptionsCheckoutOptions,
    setSubmoduleUpdateOptionsCheckoutOptions,
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
    submoduleUpdateOptionsCheckoutOptions   ,
#endif


-- ** cloneCheckoutStrategy #attr:cloneCheckoutStrategy#
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
    SubmoduleUpdateOptionsCloneCheckoutStrategyPropertyInfo,
#endif
    constructSubmoduleUpdateOptionsCloneCheckoutStrategy,
    getSubmoduleUpdateOptionsCloneCheckoutStrategy,
    setSubmoduleUpdateOptionsCloneCheckoutStrategy,
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
    submoduleUpdateOptionsCloneCheckoutStrategy,
#endif


-- ** fetchOptions #attr:fetchOptions#
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
    SubmoduleUpdateOptionsFetchOptionsPropertyInfo,
#endif
    clearSubmoduleUpdateOptionsFetchOptions ,
    constructSubmoduleUpdateOptionsFetchOptions,
    getSubmoduleUpdateOptionsFetchOptions   ,
    setSubmoduleUpdateOptionsFetchOptions   ,
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
    submoduleUpdateOptionsFetchOptions      ,
#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.ManagedPtr as B.ManagedPtr
import qualified Data.GI.Base.GError as B.GError
import qualified Data.GI.Base.GVariant as B.GVariant
import qualified Data.GI.Base.GParamSpec as B.GParamSpec
import qualified Data.GI.Base.CallStack as B.CallStack
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 GI.GObject.Objects.Object as GObject.Object
import {-# SOURCE #-} qualified GI.Ggit.Flags as Ggit.Flags
import {-# SOURCE #-} qualified GI.Ggit.Objects.CheckoutOptions as Ggit.CheckoutOptions
import {-# SOURCE #-} qualified GI.Ggit.Structs.FetchOptions as Ggit.FetchOptions

newtype SubmoduleUpdateOptions = SubmoduleUpdateOptions (ManagedPtr SubmoduleUpdateOptions)
foreign import ccall "ggit_submodule_update_options_get_type"
    c_ggit_submodule_update_options_get_type :: IO GType

instance GObject SubmoduleUpdateOptions where
    gobjectType _ = c_ggit_submodule_update_options_get_type
    

class GObject o => IsSubmoduleUpdateOptions o
#if MIN_VERSION_base(4,9,0)
instance {-# OVERLAPPABLE #-} (GObject a, O.UnknownAncestorError SubmoduleUpdateOptions a) =>
    IsSubmoduleUpdateOptions a
#endif
instance IsSubmoduleUpdateOptions SubmoduleUpdateOptions
instance GObject.Object.IsObject SubmoduleUpdateOptions

toSubmoduleUpdateOptions :: (MonadIO m, IsSubmoduleUpdateOptions o) => o -> m SubmoduleUpdateOptions
toSubmoduleUpdateOptions = liftIO . unsafeCastTo SubmoduleUpdateOptions

noSubmoduleUpdateOptions :: Maybe SubmoduleUpdateOptions
noSubmoduleUpdateOptions = Nothing

#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
type family ResolveSubmoduleUpdateOptionsMethod (t :: Symbol) (o :: *) :: * where
    ResolveSubmoduleUpdateOptionsMethod "bindProperty" o = GObject.Object.ObjectBindPropertyMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "bindPropertyFull" o = GObject.Object.ObjectBindPropertyFullMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "forceFloating" o = GObject.Object.ObjectForceFloatingMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "freezeNotify" o = GObject.Object.ObjectFreezeNotifyMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "isFloating" o = GObject.Object.ObjectIsFloatingMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "notify" o = GObject.Object.ObjectNotifyMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "notifyByPspec" o = GObject.Object.ObjectNotifyByPspecMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "ref" o = GObject.Object.ObjectRefMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "refSink" o = GObject.Object.ObjectRefSinkMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "replaceData" o = GObject.Object.ObjectReplaceDataMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "replaceQdata" o = GObject.Object.ObjectReplaceQdataMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "runDispose" o = GObject.Object.ObjectRunDisposeMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "stealData" o = GObject.Object.ObjectStealDataMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "stealQdata" o = GObject.Object.ObjectStealQdataMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "thawNotify" o = GObject.Object.ObjectThawNotifyMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "unref" o = GObject.Object.ObjectUnrefMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "watchClosure" o = GObject.Object.ObjectWatchClosureMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "getCheckoutOptions" o = SubmoduleUpdateOptionsGetCheckoutOptionsMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "getCloneCheckoutStrategy" o = SubmoduleUpdateOptionsGetCloneCheckoutStrategyMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "getData" o = GObject.Object.ObjectGetDataMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "getFetchOptions" o = SubmoduleUpdateOptionsGetFetchOptionsMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "getProperty" o = GObject.Object.ObjectGetPropertyMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "getQdata" o = GObject.Object.ObjectGetQdataMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "setCheckoutOptions" o = SubmoduleUpdateOptionsSetCheckoutOptionsMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "setCloneCheckoutStrategy" o = SubmoduleUpdateOptionsSetCloneCheckoutStrategyMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "setData" o = GObject.Object.ObjectSetDataMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "setFetchOptions" o = SubmoduleUpdateOptionsSetFetchOptionsMethodInfo
    ResolveSubmoduleUpdateOptionsMethod "setProperty" o = GObject.Object.ObjectSetPropertyMethodInfo
    ResolveSubmoduleUpdateOptionsMethod l o = O.MethodResolutionFailed l o

instance (info ~ ResolveSubmoduleUpdateOptionsMethod t SubmoduleUpdateOptions, O.MethodInfo info SubmoduleUpdateOptions p) => O.IsLabelProxy t (SubmoduleUpdateOptions -> p) where
    fromLabelProxy _ = O.overloadedMethod (O.MethodProxy :: O.MethodProxy info)

#if MIN_VERSION_base(4,9,0)
instance (info ~ ResolveSubmoduleUpdateOptionsMethod t SubmoduleUpdateOptions, O.MethodInfo info SubmoduleUpdateOptions p) => O.IsLabel t (SubmoduleUpdateOptions -> p) where
#if MIN_VERSION_base(4,10,0)
    fromLabel = O.overloadedMethod (O.MethodProxy :: O.MethodProxy info)
#else
    fromLabel _ = O.overloadedMethod (O.MethodProxy :: O.MethodProxy info)
#endif
#endif

#endif

-- VVV Prop "checkout-options"
   -- Type: TInterface (Name {namespace = "Ggit", name = "CheckoutOptions"})
   -- Flags: [PropertyReadable,PropertyWritable]
   -- Nullable: (Just False,Just True)

getSubmoduleUpdateOptionsCheckoutOptions :: (MonadIO m, IsSubmoduleUpdateOptions o) => o -> m Ggit.CheckoutOptions.CheckoutOptions
getSubmoduleUpdateOptionsCheckoutOptions obj = liftIO $ checkUnexpectedNothing "getSubmoduleUpdateOptionsCheckoutOptions" $ getObjectPropertyObject obj "checkout-options" Ggit.CheckoutOptions.CheckoutOptions

setSubmoduleUpdateOptionsCheckoutOptions :: (MonadIO m, IsSubmoduleUpdateOptions o, Ggit.CheckoutOptions.IsCheckoutOptions a) => o -> a -> m ()
setSubmoduleUpdateOptionsCheckoutOptions obj val = liftIO $ setObjectPropertyObject obj "checkout-options" (Just val)

constructSubmoduleUpdateOptionsCheckoutOptions :: (IsSubmoduleUpdateOptions o, Ggit.CheckoutOptions.IsCheckoutOptions a) => a -> IO (GValueConstruct o)
constructSubmoduleUpdateOptionsCheckoutOptions val = constructObjectPropertyObject "checkout-options" (Just val)

clearSubmoduleUpdateOptionsCheckoutOptions :: (MonadIO m, IsSubmoduleUpdateOptions o) => o -> m ()
clearSubmoduleUpdateOptionsCheckoutOptions obj = liftIO $ setObjectPropertyObject obj "checkout-options" (Nothing :: Maybe Ggit.CheckoutOptions.CheckoutOptions)

#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
data SubmoduleUpdateOptionsCheckoutOptionsPropertyInfo
instance AttrInfo SubmoduleUpdateOptionsCheckoutOptionsPropertyInfo where
    type AttrAllowedOps SubmoduleUpdateOptionsCheckoutOptionsPropertyInfo = '[ 'AttrSet, 'AttrConstruct, 'AttrGet, 'AttrClear]
    type AttrSetTypeConstraint SubmoduleUpdateOptionsCheckoutOptionsPropertyInfo = Ggit.CheckoutOptions.IsCheckoutOptions
    type AttrBaseTypeConstraint SubmoduleUpdateOptionsCheckoutOptionsPropertyInfo = IsSubmoduleUpdateOptions
    type AttrGetType SubmoduleUpdateOptionsCheckoutOptionsPropertyInfo = Ggit.CheckoutOptions.CheckoutOptions
    type AttrLabel SubmoduleUpdateOptionsCheckoutOptionsPropertyInfo = "checkout-options"
    type AttrOrigin SubmoduleUpdateOptionsCheckoutOptionsPropertyInfo = SubmoduleUpdateOptions
    attrGet _ = getSubmoduleUpdateOptionsCheckoutOptions
    attrSet _ = setSubmoduleUpdateOptionsCheckoutOptions
    attrConstruct _ = constructSubmoduleUpdateOptionsCheckoutOptions
    attrClear _ = clearSubmoduleUpdateOptionsCheckoutOptions
#endif

-- VVV Prop "clone-checkout-strategy"
   -- Type: TInterface (Name {namespace = "Ggit", name = "CheckoutStrategy"})
   -- Flags: [PropertyReadable,PropertyWritable]
   -- Nullable: (Just False,Just False)

getSubmoduleUpdateOptionsCloneCheckoutStrategy :: (MonadIO m, IsSubmoduleUpdateOptions o) => o -> m [Ggit.Flags.CheckoutStrategy]
getSubmoduleUpdateOptionsCloneCheckoutStrategy obj = liftIO $ getObjectPropertyFlags obj "clone-checkout-strategy"

setSubmoduleUpdateOptionsCloneCheckoutStrategy :: (MonadIO m, IsSubmoduleUpdateOptions o) => o -> [Ggit.Flags.CheckoutStrategy] -> m ()
setSubmoduleUpdateOptionsCloneCheckoutStrategy obj val = liftIO $ setObjectPropertyFlags obj "clone-checkout-strategy" val

constructSubmoduleUpdateOptionsCloneCheckoutStrategy :: (IsSubmoduleUpdateOptions o) => [Ggit.Flags.CheckoutStrategy] -> IO (GValueConstruct o)
constructSubmoduleUpdateOptionsCloneCheckoutStrategy val = constructObjectPropertyFlags "clone-checkout-strategy" val

#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
data SubmoduleUpdateOptionsCloneCheckoutStrategyPropertyInfo
instance AttrInfo SubmoduleUpdateOptionsCloneCheckoutStrategyPropertyInfo where
    type AttrAllowedOps SubmoduleUpdateOptionsCloneCheckoutStrategyPropertyInfo = '[ 'AttrSet, 'AttrConstruct, 'AttrGet]
    type AttrSetTypeConstraint SubmoduleUpdateOptionsCloneCheckoutStrategyPropertyInfo = (~) [Ggit.Flags.CheckoutStrategy]
    type AttrBaseTypeConstraint SubmoduleUpdateOptionsCloneCheckoutStrategyPropertyInfo = IsSubmoduleUpdateOptions
    type AttrGetType SubmoduleUpdateOptionsCloneCheckoutStrategyPropertyInfo = [Ggit.Flags.CheckoutStrategy]
    type AttrLabel SubmoduleUpdateOptionsCloneCheckoutStrategyPropertyInfo = "clone-checkout-strategy"
    type AttrOrigin SubmoduleUpdateOptionsCloneCheckoutStrategyPropertyInfo = SubmoduleUpdateOptions
    attrGet _ = getSubmoduleUpdateOptionsCloneCheckoutStrategy
    attrSet _ = setSubmoduleUpdateOptionsCloneCheckoutStrategy
    attrConstruct _ = constructSubmoduleUpdateOptionsCloneCheckoutStrategy
    attrClear _ = undefined
#endif

-- VVV Prop "fetch-options"
   -- Type: TInterface (Name {namespace = "Ggit", name = "FetchOptions"})
   -- Flags: [PropertyReadable,PropertyWritable]
   -- Nullable: (Nothing,Just True)

getSubmoduleUpdateOptionsFetchOptions :: (MonadIO m, IsSubmoduleUpdateOptions o) => o -> m (Maybe Ggit.FetchOptions.FetchOptions)
getSubmoduleUpdateOptionsFetchOptions obj = liftIO $ getObjectPropertyBoxed obj "fetch-options" Ggit.FetchOptions.FetchOptions

setSubmoduleUpdateOptionsFetchOptions :: (MonadIO m, IsSubmoduleUpdateOptions o) => o -> Ggit.FetchOptions.FetchOptions -> m ()
setSubmoduleUpdateOptionsFetchOptions obj val = liftIO $ setObjectPropertyBoxed obj "fetch-options" (Just val)

constructSubmoduleUpdateOptionsFetchOptions :: (IsSubmoduleUpdateOptions o) => Ggit.FetchOptions.FetchOptions -> IO (GValueConstruct o)
constructSubmoduleUpdateOptionsFetchOptions val = constructObjectPropertyBoxed "fetch-options" (Just val)

clearSubmoduleUpdateOptionsFetchOptions :: (MonadIO m, IsSubmoduleUpdateOptions o) => o -> m ()
clearSubmoduleUpdateOptionsFetchOptions obj = liftIO $ setObjectPropertyBoxed obj "fetch-options" (Nothing :: Maybe Ggit.FetchOptions.FetchOptions)

#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
data SubmoduleUpdateOptionsFetchOptionsPropertyInfo
instance AttrInfo SubmoduleUpdateOptionsFetchOptionsPropertyInfo where
    type AttrAllowedOps SubmoduleUpdateOptionsFetchOptionsPropertyInfo = '[ 'AttrSet, 'AttrConstruct, 'AttrGet, 'AttrClear]
    type AttrSetTypeConstraint SubmoduleUpdateOptionsFetchOptionsPropertyInfo = (~) Ggit.FetchOptions.FetchOptions
    type AttrBaseTypeConstraint SubmoduleUpdateOptionsFetchOptionsPropertyInfo = IsSubmoduleUpdateOptions
    type AttrGetType SubmoduleUpdateOptionsFetchOptionsPropertyInfo = (Maybe Ggit.FetchOptions.FetchOptions)
    type AttrLabel SubmoduleUpdateOptionsFetchOptionsPropertyInfo = "fetch-options"
    type AttrOrigin SubmoduleUpdateOptionsFetchOptionsPropertyInfo = SubmoduleUpdateOptions
    attrGet _ = getSubmoduleUpdateOptionsFetchOptions
    attrSet _ = setSubmoduleUpdateOptionsFetchOptions
    attrConstruct _ = constructSubmoduleUpdateOptionsFetchOptions
    attrClear _ = clearSubmoduleUpdateOptionsFetchOptions
#endif

#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
instance O.HasAttributeList SubmoduleUpdateOptions
type instance O.AttributeList SubmoduleUpdateOptions = SubmoduleUpdateOptionsAttributeList
type SubmoduleUpdateOptionsAttributeList = ('[ '("checkoutOptions", SubmoduleUpdateOptionsCheckoutOptionsPropertyInfo), '("cloneCheckoutStrategy", SubmoduleUpdateOptionsCloneCheckoutStrategyPropertyInfo), '("fetchOptions", SubmoduleUpdateOptionsFetchOptionsPropertyInfo)] :: [(Symbol, *)])
#endif

#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
submoduleUpdateOptionsCheckoutOptions :: AttrLabelProxy "checkoutOptions"
submoduleUpdateOptionsCheckoutOptions = AttrLabelProxy

submoduleUpdateOptionsCloneCheckoutStrategy :: AttrLabelProxy "cloneCheckoutStrategy"
submoduleUpdateOptionsCloneCheckoutStrategy = AttrLabelProxy

submoduleUpdateOptionsFetchOptions :: AttrLabelProxy "fetchOptions"
submoduleUpdateOptionsFetchOptions = AttrLabelProxy

#endif

#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
type instance O.SignalList SubmoduleUpdateOptions = SubmoduleUpdateOptionsSignalList
type SubmoduleUpdateOptionsSignalList = ('[ '("notify", GObject.Object.ObjectNotifySignalInfo)] :: [(Symbol, *)])

#endif

-- method SubmoduleUpdateOptions::new
-- method type : Constructor
-- Args : []
-- Lengths : []
-- returnType : Just (TInterface (Name {namespace = "Ggit", name = "SubmoduleUpdateOptions"}))
-- throws : False
-- Skip return : False

foreign import ccall "ggit_submodule_update_options_new" ggit_submodule_update_options_new :: 
    IO (Ptr SubmoduleUpdateOptions)

{- |
Creates a new submodule options object.
-}
submoduleUpdateOptionsNew ::
    (B.CallStack.HasCallStack, MonadIO m) =>
    m SubmoduleUpdateOptions
    {- ^ __Returns:__ a 'GI.Ggit.Objects.SubmoduleUpdateOptions.SubmoduleUpdateOptions'. -}
submoduleUpdateOptionsNew  = liftIO $ do
    result <- ggit_submodule_update_options_new
    checkUnexpectedReturnNULL "submoduleUpdateOptionsNew" result
    result' <- (wrapObject SubmoduleUpdateOptions) result
    return result'

#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
#endif

-- method SubmoduleUpdateOptions::get_checkout_options
-- method type : OrdinaryMethod
-- Args : [Arg {argCName = "options", argType = TInterface (Name {namespace = "Ggit", name = "SubmoduleUpdateOptions"}), direction = DirectionIn, mayBeNull = False, argDoc = Documentation {rawDocText = Just "a #GgitSubmoduleUpdateOptions.", sinceVersion = Nothing}, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, argCallerAllocates = False, transfer = TransferNothing}]
-- Lengths : []
-- returnType : Just (TInterface (Name {namespace = "Ggit", name = "CheckoutOptions"}))
-- throws : False
-- Skip return : False

foreign import ccall "ggit_submodule_update_options_get_checkout_options" ggit_submodule_update_options_get_checkout_options :: 
    Ptr SubmoduleUpdateOptions ->           -- options : TInterface (Name {namespace = "Ggit", name = "SubmoduleUpdateOptions"})
    IO (Ptr Ggit.CheckoutOptions.CheckoutOptions)

{- |
Get the checkout options.
-}
submoduleUpdateOptionsGetCheckoutOptions ::
    (B.CallStack.HasCallStack, MonadIO m, IsSubmoduleUpdateOptions a) =>
    a
    {- ^ /@options@/: a 'GI.Ggit.Objects.SubmoduleUpdateOptions.SubmoduleUpdateOptions'. -}
    -> m Ggit.CheckoutOptions.CheckoutOptions
    {- ^ __Returns:__ a 'GI.Ggit.Objects.CheckoutOptions.CheckoutOptions'. -}
submoduleUpdateOptionsGetCheckoutOptions options = liftIO $ do
    options' <- unsafeManagedPtrCastPtr options
    result <- ggit_submodule_update_options_get_checkout_options options'
    checkUnexpectedReturnNULL "submoduleUpdateOptionsGetCheckoutOptions" result
    result' <- (newObject Ggit.CheckoutOptions.CheckoutOptions) result
    touchManagedPtr options
    return result'

#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
data SubmoduleUpdateOptionsGetCheckoutOptionsMethodInfo
instance (signature ~ (m Ggit.CheckoutOptions.CheckoutOptions), MonadIO m, IsSubmoduleUpdateOptions a) => O.MethodInfo SubmoduleUpdateOptionsGetCheckoutOptionsMethodInfo a signature where
    overloadedMethod _ = submoduleUpdateOptionsGetCheckoutOptions

#endif

-- method SubmoduleUpdateOptions::get_clone_checkout_strategy
-- method type : OrdinaryMethod
-- Args : [Arg {argCName = "options", argType = TInterface (Name {namespace = "Ggit", name = "SubmoduleUpdateOptions"}), direction = DirectionIn, mayBeNull = False, argDoc = Documentation {rawDocText = Just "a #GgitSubmoduleUpdateOptions.", sinceVersion = Nothing}, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, argCallerAllocates = False, transfer = TransferNothing}]
-- Lengths : []
-- returnType : Just (TInterface (Name {namespace = "Ggit", name = "CheckoutStrategy"}))
-- throws : False
-- Skip return : False

foreign import ccall "ggit_submodule_update_options_get_clone_checkout_strategy" ggit_submodule_update_options_get_clone_checkout_strategy :: 
    Ptr SubmoduleUpdateOptions ->           -- options : TInterface (Name {namespace = "Ggit", name = "SubmoduleUpdateOptions"})
    IO CUInt

{- |
Gets the clone checkout strategy.
-}
submoduleUpdateOptionsGetCloneCheckoutStrategy ::
    (B.CallStack.HasCallStack, MonadIO m, IsSubmoduleUpdateOptions a) =>
    a
    {- ^ /@options@/: a 'GI.Ggit.Objects.SubmoduleUpdateOptions.SubmoduleUpdateOptions'. -}
    -> m [Ggit.Flags.CheckoutStrategy]
    {- ^ __Returns:__ the clone checkout strategy. -}
submoduleUpdateOptionsGetCloneCheckoutStrategy options = liftIO $ do
    options' <- unsafeManagedPtrCastPtr options
    result <- ggit_submodule_update_options_get_clone_checkout_strategy options'
    let result' = wordToGFlags result
    touchManagedPtr options
    return result'

#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
data SubmoduleUpdateOptionsGetCloneCheckoutStrategyMethodInfo
instance (signature ~ (m [Ggit.Flags.CheckoutStrategy]), MonadIO m, IsSubmoduleUpdateOptions a) => O.MethodInfo SubmoduleUpdateOptionsGetCloneCheckoutStrategyMethodInfo a signature where
    overloadedMethod _ = submoduleUpdateOptionsGetCloneCheckoutStrategy

#endif

-- method SubmoduleUpdateOptions::get_fetch_options
-- method type : OrdinaryMethod
-- Args : [Arg {argCName = "options", argType = TInterface (Name {namespace = "Ggit", name = "SubmoduleUpdateOptions"}), direction = DirectionIn, mayBeNull = False, argDoc = Documentation {rawDocText = Nothing, sinceVersion = Nothing}, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, argCallerAllocates = False, transfer = TransferNothing}]
-- Lengths : []
-- returnType : Just (TInterface (Name {namespace = "Ggit", name = "FetchOptions"}))
-- throws : False
-- Skip return : False

foreign import ccall "ggit_submodule_update_options_get_fetch_options" ggit_submodule_update_options_get_fetch_options :: 
    Ptr SubmoduleUpdateOptions ->           -- options : TInterface (Name {namespace = "Ggit", name = "SubmoduleUpdateOptions"})
    IO (Ptr Ggit.FetchOptions.FetchOptions)

{- |
/No description available in the introspection data./
-}
submoduleUpdateOptionsGetFetchOptions ::
    (B.CallStack.HasCallStack, MonadIO m, IsSubmoduleUpdateOptions a) =>
    a
    -> m Ggit.FetchOptions.FetchOptions
submoduleUpdateOptionsGetFetchOptions options = liftIO $ do
    options' <- unsafeManagedPtrCastPtr options
    result <- ggit_submodule_update_options_get_fetch_options options'
    checkUnexpectedReturnNULL "submoduleUpdateOptionsGetFetchOptions" result
    result' <- (wrapBoxed Ggit.FetchOptions.FetchOptions) result
    touchManagedPtr options
    return result'

#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
data SubmoduleUpdateOptionsGetFetchOptionsMethodInfo
instance (signature ~ (m Ggit.FetchOptions.FetchOptions), MonadIO m, IsSubmoduleUpdateOptions a) => O.MethodInfo SubmoduleUpdateOptionsGetFetchOptionsMethodInfo a signature where
    overloadedMethod _ = submoduleUpdateOptionsGetFetchOptions

#endif

-- method SubmoduleUpdateOptions::set_checkout_options
-- method type : OrdinaryMethod
-- Args : [Arg {argCName = "options", argType = TInterface (Name {namespace = "Ggit", name = "SubmoduleUpdateOptions"}), direction = DirectionIn, mayBeNull = False, argDoc = Documentation {rawDocText = Just "a #GgitSubmoduleUpdateOptions.", sinceVersion = Nothing}, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, argCallerAllocates = False, transfer = TransferNothing},Arg {argCName = "checkout_options", argType = TInterface (Name {namespace = "Ggit", name = "CheckoutOptions"}), direction = DirectionIn, mayBeNull = True, argDoc = Documentation {rawDocText = Just "a #GgitCheckoutOptions.", sinceVersion = Nothing}, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, argCallerAllocates = False, transfer = TransferNothing}]
-- Lengths : []
-- returnType : Nothing
-- throws : False
-- Skip return : False

foreign import ccall "ggit_submodule_update_options_set_checkout_options" ggit_submodule_update_options_set_checkout_options :: 
    Ptr SubmoduleUpdateOptions ->           -- options : TInterface (Name {namespace = "Ggit", name = "SubmoduleUpdateOptions"})
    Ptr Ggit.CheckoutOptions.CheckoutOptions -> -- checkout_options : TInterface (Name {namespace = "Ggit", name = "CheckoutOptions"})
    IO ()

{- |
Set the checkout options.
-}
submoduleUpdateOptionsSetCheckoutOptions ::
    (B.CallStack.HasCallStack, MonadIO m, IsSubmoduleUpdateOptions a, Ggit.CheckoutOptions.IsCheckoutOptions b) =>
    a
    {- ^ /@options@/: a 'GI.Ggit.Objects.SubmoduleUpdateOptions.SubmoduleUpdateOptions'. -}
    -> Maybe (b)
    {- ^ /@checkoutOptions@/: a 'GI.Ggit.Objects.CheckoutOptions.CheckoutOptions'. -}
    -> m ()
submoduleUpdateOptionsSetCheckoutOptions options checkoutOptions = liftIO $ do
    options' <- unsafeManagedPtrCastPtr options
    maybeCheckoutOptions <- case checkoutOptions of
        Nothing -> return nullPtr
        Just jCheckoutOptions -> do
            jCheckoutOptions' <- unsafeManagedPtrCastPtr jCheckoutOptions
            return jCheckoutOptions'
    ggit_submodule_update_options_set_checkout_options options' maybeCheckoutOptions
    touchManagedPtr options
    whenJust checkoutOptions touchManagedPtr
    return ()

#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
data SubmoduleUpdateOptionsSetCheckoutOptionsMethodInfo
instance (signature ~ (Maybe (b) -> m ()), MonadIO m, IsSubmoduleUpdateOptions a, Ggit.CheckoutOptions.IsCheckoutOptions b) => O.MethodInfo SubmoduleUpdateOptionsSetCheckoutOptionsMethodInfo a signature where
    overloadedMethod _ = submoduleUpdateOptionsSetCheckoutOptions

#endif

-- method SubmoduleUpdateOptions::set_clone_checkout_strategy
-- method type : OrdinaryMethod
-- Args : [Arg {argCName = "options", argType = TInterface (Name {namespace = "Ggit", name = "SubmoduleUpdateOptions"}), direction = DirectionIn, mayBeNull = False, argDoc = Documentation {rawDocText = Just "a #GgitSubmoduleUpdateOptions.", sinceVersion = Nothing}, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, argCallerAllocates = False, transfer = TransferNothing},Arg {argCName = "checkout_strategy", argType = TInterface (Name {namespace = "Ggit", name = "CheckoutStrategy"}), direction = DirectionIn, mayBeNull = False, argDoc = Documentation {rawDocText = Just "a #GgitCheckoutStrategy.", sinceVersion = Nothing}, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, argCallerAllocates = False, transfer = TransferNothing}]
-- Lengths : []
-- returnType : Nothing
-- throws : False
-- Skip return : False

foreign import ccall "ggit_submodule_update_options_set_clone_checkout_strategy" ggit_submodule_update_options_set_clone_checkout_strategy :: 
    Ptr SubmoduleUpdateOptions ->           -- options : TInterface (Name {namespace = "Ggit", name = "SubmoduleUpdateOptions"})
    CUInt ->                                -- checkout_strategy : TInterface (Name {namespace = "Ggit", name = "CheckoutStrategy"})
    IO ()

{- |
Sets the clone checkout strategy. Use @/GGIT_CHECKOUT_SAFE_CREATE/@ to create
all files in the working directory for the newly cloned repository.
-}
submoduleUpdateOptionsSetCloneCheckoutStrategy ::
    (B.CallStack.HasCallStack, MonadIO m, IsSubmoduleUpdateOptions a) =>
    a
    {- ^ /@options@/: a 'GI.Ggit.Objects.SubmoduleUpdateOptions.SubmoduleUpdateOptions'. -}
    -> [Ggit.Flags.CheckoutStrategy]
    {- ^ /@checkoutStrategy@/: a 'GI.Ggit.Flags.CheckoutStrategy'. -}
    -> m ()
submoduleUpdateOptionsSetCloneCheckoutStrategy options checkoutStrategy = liftIO $ do
    options' <- unsafeManagedPtrCastPtr options
    let checkoutStrategy' = gflagsToWord checkoutStrategy
    ggit_submodule_update_options_set_clone_checkout_strategy options' checkoutStrategy'
    touchManagedPtr options
    return ()

#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
data SubmoduleUpdateOptionsSetCloneCheckoutStrategyMethodInfo
instance (signature ~ ([Ggit.Flags.CheckoutStrategy] -> m ()), MonadIO m, IsSubmoduleUpdateOptions a) => O.MethodInfo SubmoduleUpdateOptionsSetCloneCheckoutStrategyMethodInfo a signature where
    overloadedMethod _ = submoduleUpdateOptionsSetCloneCheckoutStrategy

#endif

-- method SubmoduleUpdateOptions::set_fetch_options
-- method type : OrdinaryMethod
-- Args : [Arg {argCName = "options", argType = TInterface (Name {namespace = "Ggit", name = "SubmoduleUpdateOptions"}), direction = DirectionIn, mayBeNull = False, argDoc = Documentation {rawDocText = Just "a #GgitSubmoduleUpdateOptions.", sinceVersion = Nothing}, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, argCallerAllocates = False, transfer = TransferNothing},Arg {argCName = "fetch_options", argType = TInterface (Name {namespace = "Ggit", name = "FetchOptions"}), direction = DirectionIn, mayBeNull = True, argDoc = Documentation {rawDocText = Just "a #GgitFetchOptions.", sinceVersion = Nothing}, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, argCallerAllocates = False, transfer = TransferNothing}]
-- Lengths : []
-- returnType : Nothing
-- throws : False
-- Skip return : False

foreign import ccall "ggit_submodule_update_options_set_fetch_options" ggit_submodule_update_options_set_fetch_options :: 
    Ptr SubmoduleUpdateOptions ->           -- options : TInterface (Name {namespace = "Ggit", name = "SubmoduleUpdateOptions"})
    Ptr Ggit.FetchOptions.FetchOptions ->   -- fetch_options : TInterface (Name {namespace = "Ggit", name = "FetchOptions"})
    IO ()

{- |
Sets the fetch options.
-}
submoduleUpdateOptionsSetFetchOptions ::
    (B.CallStack.HasCallStack, MonadIO m, IsSubmoduleUpdateOptions a) =>
    a
    {- ^ /@options@/: a 'GI.Ggit.Objects.SubmoduleUpdateOptions.SubmoduleUpdateOptions'. -}
    -> Maybe (Ggit.FetchOptions.FetchOptions)
    {- ^ /@fetchOptions@/: a 'GI.Ggit.Structs.FetchOptions.FetchOptions'. -}
    -> m ()
submoduleUpdateOptionsSetFetchOptions options fetchOptions = liftIO $ do
    options' <- unsafeManagedPtrCastPtr options
    maybeFetchOptions <- case fetchOptions of
        Nothing -> return nullPtr
        Just jFetchOptions -> do
            jFetchOptions' <- unsafeManagedPtrGetPtr jFetchOptions
            return jFetchOptions'
    ggit_submodule_update_options_set_fetch_options options' maybeFetchOptions
    touchManagedPtr options
    whenJust fetchOptions touchManagedPtr
    return ()

#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
data SubmoduleUpdateOptionsSetFetchOptionsMethodInfo
instance (signature ~ (Maybe (Ggit.FetchOptions.FetchOptions) -> m ()), MonadIO m, IsSubmoduleUpdateOptions a) => O.MethodInfo SubmoduleUpdateOptionsSetFetchOptionsMethodInfo a signature where
    overloadedMethod _ = submoduleUpdateOptionsSetFetchOptions

#endif