{-# LANGUAGE FlexibleContexts, FlexibleInstances, ForeignFunctionInterface, MonoLocalBinds, MultiParamTypeClasses, ScopedTypeVariables, TypeSynonymInstances, UndecidableInstances #-} ---------- GENERATED FILE, EDITS WILL BE LOST ---------- module Graphics.UI.Qtah.Generated.Gui.QActionEvent ( castQActionEventToQEvent, castQEventToQActionEvent, QActionEventValue (..), QActionEventConstPtr (..), action, before, QActionEventPtr (..), QActionEventConst (..), castQActionEventToConst, QActionEvent (..), castQActionEventToNonconst, new, newBefore, QActionEventSuper (..), QActionEventSuperConst (..), ) where import qualified Foreign as HoppyF import qualified Foreign.C as HoppyFC import qualified Foreign.Hoppy.Runtime as HoppyFHR import qualified Graphics.UI.Qtah.Generated.Core.QEvent as M34 import qualified Graphics.UI.Qtah.Generated.Widgets.QAction as M368 import Prelude (($), (.), (==), (>>=)) import qualified Prelude as HoppyP foreign import ccall "genpop__QActionEvent_new" new' :: HoppyFC.CInt -> HoppyF.Ptr M368.QAction -> HoppyP.IO (HoppyF.Ptr QActionEvent) foreign import ccall "genpop__QActionEvent_newBefore" newBefore' :: HoppyFC.CInt -> HoppyF.Ptr M368.QAction -> HoppyP.IO (HoppyF.Ptr QActionEvent) foreign import ccall "genpop__QActionEvent_action" action' :: HoppyF.Ptr QActionEventConst -> HoppyP.IO (HoppyF.Ptr M368.QAction) foreign import ccall "genpop__QActionEvent_before" before' :: HoppyF.Ptr QActionEventConst -> HoppyP.IO (HoppyF.Ptr M368.QAction) foreign import ccall "gencast__QActionEvent__QEvent" castQActionEventToQEvent :: HoppyF.Ptr QActionEventConst -> HoppyF.Ptr M34.QEventConst foreign import ccall "gencast__QEvent__QActionEvent" castQEventToQActionEvent :: HoppyF.Ptr M34.QEventConst -> HoppyF.Ptr QActionEventConst foreign import ccall "gendel__QActionEvent" delete'QActionEvent :: HoppyF.Ptr QActionEventConst -> HoppyP.IO () foreign import ccall "&gendel__QActionEvent" deletePtr'QActionEvent :: HoppyF.FunPtr (HoppyF.Ptr QActionEventConst -> HoppyP.IO ()) class QActionEventValue a where withQActionEventPtr :: a -> (QActionEventConst -> HoppyP.IO b) -> HoppyP.IO b instance {-# OVERLAPPABLE #-} QActionEventConstPtr a => QActionEventValue a where withQActionEventPtr = HoppyP.flip ($) . toQActionEventConst class (M34.QEventConstPtr this) => QActionEventConstPtr this where toQActionEventConst :: this -> QActionEventConst action :: (QActionEventValue this) => (this) {- ^ this -} -> (HoppyP.IO M368.QAction) action arg'1 = withQActionEventPtr arg'1 $ HoppyP.flip HoppyFHR.withCppPtr $ \arg'1' -> HoppyP.fmap M368.QAction (action' arg'1') before :: (QActionEventValue this) => (this) {- ^ this -} -> (HoppyP.IO M368.QAction) before arg'1 = withQActionEventPtr arg'1 $ HoppyP.flip HoppyFHR.withCppPtr $ \arg'1' -> HoppyP.fmap M368.QAction (before' arg'1') class (QActionEventConstPtr this, M34.QEventPtr this) => QActionEventPtr this where toQActionEvent :: this -> QActionEvent data QActionEventConst = QActionEventConst (HoppyF.Ptr QActionEventConst) | QActionEventConstGc (HoppyF.ForeignPtr ()) (HoppyF.Ptr QActionEventConst) deriving (HoppyP.Show) instance HoppyP.Eq QActionEventConst where x == y = HoppyFHR.toPtr x == HoppyFHR.toPtr y instance HoppyP.Ord QActionEventConst where compare x y = HoppyP.compare (HoppyFHR.toPtr x) (HoppyFHR.toPtr y) castQActionEventToConst :: QActionEvent -> QActionEventConst castQActionEventToConst (QActionEvent ptr') = QActionEventConst $ HoppyF.castPtr ptr' castQActionEventToConst (QActionEventGc fptr' ptr') = QActionEventConstGc fptr' $ HoppyF.castPtr ptr' instance HoppyFHR.CppPtr QActionEventConst where nullptr = QActionEventConst HoppyF.nullPtr withCppPtr (QActionEventConst ptr') f' = f' ptr' withCppPtr (QActionEventConstGc fptr' ptr') f' = HoppyF.withForeignPtr fptr' $ \_ -> f' ptr' toPtr (QActionEventConst ptr') = ptr' toPtr (QActionEventConstGc _ ptr') = ptr' touchCppPtr (QActionEventConst _) = HoppyP.return () touchCppPtr (QActionEventConstGc fptr' _) = HoppyF.touchForeignPtr fptr' instance HoppyFHR.Deletable QActionEventConst where delete (QActionEventConst ptr') = delete'QActionEvent ptr' delete (QActionEventConstGc _ _) = HoppyP.fail $ HoppyP.concat ["Deletable.delete: Asked to delete a GC-managed ", "QActionEventConst", " object."] toGc this'@(QActionEventConst ptr') = if ptr' == HoppyF.nullPtr then HoppyP.return this' else HoppyP.fmap (HoppyP.flip QActionEventConstGc ptr') $ HoppyF.newForeignPtr (HoppyF.castFunPtr deletePtr'QActionEvent :: HoppyF.FunPtr (HoppyF.Ptr () -> HoppyP.IO ())) (HoppyF.castPtr ptr' :: HoppyF.Ptr ()) toGc this'@(QActionEventConstGc {}) = HoppyP.return this' instance QActionEventConstPtr QActionEventConst where toQActionEventConst = HoppyP.id instance M34.QEventConstPtr QActionEventConst where toQEventConst (QActionEventConst ptr') = M34.QEventConst $ castQActionEventToQEvent ptr' toQEventConst (QActionEventConstGc fptr' ptr') = M34.QEventConstGc fptr' $ castQActionEventToQEvent ptr' data QActionEvent = QActionEvent (HoppyF.Ptr QActionEvent) | QActionEventGc (HoppyF.ForeignPtr ()) (HoppyF.Ptr QActionEvent) deriving (HoppyP.Show) instance HoppyP.Eq QActionEvent where x == y = HoppyFHR.toPtr x == HoppyFHR.toPtr y instance HoppyP.Ord QActionEvent where compare x y = HoppyP.compare (HoppyFHR.toPtr x) (HoppyFHR.toPtr y) castQActionEventToNonconst :: QActionEventConst -> QActionEvent castQActionEventToNonconst (QActionEventConst ptr') = QActionEvent $ HoppyF.castPtr ptr' castQActionEventToNonconst (QActionEventConstGc fptr' ptr') = QActionEventGc fptr' $ HoppyF.castPtr ptr' instance HoppyFHR.CppPtr QActionEvent where nullptr = QActionEvent HoppyF.nullPtr withCppPtr (QActionEvent ptr') f' = f' ptr' withCppPtr (QActionEventGc fptr' ptr') f' = HoppyF.withForeignPtr fptr' $ \_ -> f' ptr' toPtr (QActionEvent ptr') = ptr' toPtr (QActionEventGc _ ptr') = ptr' touchCppPtr (QActionEvent _) = HoppyP.return () touchCppPtr (QActionEventGc fptr' _) = HoppyF.touchForeignPtr fptr' instance HoppyFHR.Deletable QActionEvent where delete (QActionEvent ptr') = delete'QActionEvent $ (HoppyF.castPtr ptr' :: HoppyF.Ptr QActionEventConst) delete (QActionEventGc _ _) = HoppyP.fail $ HoppyP.concat ["Deletable.delete: Asked to delete a GC-managed ", "QActionEvent", " object."] toGc this'@(QActionEvent ptr') = if ptr' == HoppyF.nullPtr then HoppyP.return this' else HoppyP.fmap (HoppyP.flip QActionEventGc ptr') $ HoppyF.newForeignPtr (HoppyF.castFunPtr deletePtr'QActionEvent :: HoppyF.FunPtr (HoppyF.Ptr () -> HoppyP.IO ())) (HoppyF.castPtr ptr' :: HoppyF.Ptr ()) toGc this'@(QActionEventGc {}) = HoppyP.return this' instance QActionEventConstPtr QActionEvent where toQActionEventConst (QActionEvent ptr') = QActionEventConst $ (HoppyF.castPtr :: HoppyF.Ptr QActionEvent -> HoppyF.Ptr QActionEventConst) ptr' toQActionEventConst (QActionEventGc fptr' ptr') = QActionEventConstGc fptr' $ (HoppyF.castPtr :: HoppyF.Ptr QActionEvent -> HoppyF.Ptr QActionEventConst) ptr' instance QActionEventPtr QActionEvent where toQActionEvent = HoppyP.id instance M34.QEventConstPtr QActionEvent where toQEventConst (QActionEvent ptr') = M34.QEventConst $ castQActionEventToQEvent $ (HoppyF.castPtr :: HoppyF.Ptr QActionEvent -> HoppyF.Ptr QActionEventConst) ptr' toQEventConst (QActionEventGc fptr' ptr') = M34.QEventConstGc fptr' $ castQActionEventToQEvent $ (HoppyF.castPtr :: HoppyF.Ptr QActionEvent -> HoppyF.Ptr QActionEventConst) ptr' instance M34.QEventPtr QActionEvent where toQEvent (QActionEvent ptr') = M34.QEvent $ (HoppyF.castPtr :: HoppyF.Ptr M34.QEventConst -> HoppyF.Ptr M34.QEvent) $ castQActionEventToQEvent $ (HoppyF.castPtr :: HoppyF.Ptr QActionEvent -> HoppyF.Ptr QActionEventConst) ptr' toQEvent (QActionEventGc fptr' ptr') = M34.QEventGc fptr' $ (HoppyF.castPtr :: HoppyF.Ptr M34.QEventConst -> HoppyF.Ptr M34.QEvent) $ castQActionEventToQEvent $ (HoppyF.castPtr :: HoppyF.Ptr QActionEvent -> HoppyF.Ptr QActionEventConst) ptr' new :: (M368.QActionPtr arg'2) => (M34.QEventType) -> (arg'2) -> (HoppyP.IO QActionEvent) new arg'1 arg'2 = ( HoppyP.return . HoppyFHR.fromCppEnum ) arg'1 >>= \arg'1' -> HoppyFHR.withCppPtr (M368.toQAction arg'2) $ \arg'2' -> HoppyP.fmap QActionEvent (new' arg'1' arg'2') newBefore :: (M368.QActionPtr arg'2) => (M34.QEventType) -> (arg'2) -> (HoppyP.IO QActionEvent) newBefore arg'1 arg'2 = ( HoppyP.return . HoppyFHR.fromCppEnum ) arg'1 >>= \arg'1' -> HoppyFHR.withCppPtr (M368.toQAction arg'2) $ \arg'2' -> HoppyP.fmap QActionEvent (newBefore' arg'1' arg'2') class QActionEventSuper a where downToQActionEvent :: a -> QActionEvent instance QActionEventSuper M34.QEvent where downToQActionEvent = castQActionEventToNonconst . cast' . M34.castQEventToConst where cast' (M34.QEventConst ptr') = QActionEventConst $ castQEventToQActionEvent ptr' cast' (M34.QEventConstGc fptr' ptr') = QActionEventConstGc fptr' $ castQEventToQActionEvent ptr' class QActionEventSuperConst a where downToQActionEventConst :: a -> QActionEventConst instance QActionEventSuperConst M34.QEventConst where downToQActionEventConst = cast' where cast' (M34.QEventConst ptr') = QActionEventConst $ castQEventToQActionEvent ptr' cast' (M34.QEventConstGc fptr' ptr') = QActionEventConstGc fptr' $ castQEventToQActionEvent ptr' instance HoppyFHR.Assignable (HoppyF.Ptr (HoppyF.Ptr QActionEvent)) QActionEvent where assign ptr' value' = HoppyF.poke ptr' $ HoppyFHR.toPtr value' instance HoppyFHR.Decodable (HoppyF.Ptr (HoppyF.Ptr QActionEvent)) QActionEvent where decode = HoppyP.fmap QActionEvent . HoppyF.peek