{-# LANGUAGE EmptyDataDecls, FlexibleContexts, FlexibleInstances,
  ForeignFunctionInterface, IncoherentInstances,
  MultiParamTypeClasses, OverlappingInstances, TemplateHaskell,
  TypeFamilies, TypeSynonymInstances #-}
module HROOT.Graf.TArc.Implementation where
import Data.Monoid
import Data.Word
import Data.Int
import Foreign.C
import Foreign.Ptr
import Language.Haskell.TH
import Language.Haskell.TH.Syntax
import System.IO.Unsafe
import FFICXX.Runtime.Cast
import FFICXX.Runtime.CodeGen.Cxx
import FFICXX.Runtime.TH
import HROOT.Graf.TArc.RawType
import HROOT.Graf.TArc.FFI
import HROOT.Graf.TArc.Interface
import HROOT.Graf.TArc.Cast
import HROOT.Graf.TArc.RawType
import HROOT.Graf.TArc.Cast
import HROOT.Graf.TArc.Interface
import HROOT.Core.TClass.RawType
import HROOT.Core.TClass.Cast
import HROOT.Core.TClass.Interface
import HROOT.Graf.TEllipse.RawType
import HROOT.Graf.TEllipse.Cast
import HROOT.Graf.TEllipse.Interface
import HROOT.Core.TObject.RawType
import HROOT.Core.TObject.Cast
import HROOT.Core.TObject.Interface
import HROOT.Core.TAttLine.RawType
import HROOT.Core.TAttLine.Cast
import HROOT.Core.TAttLine.Interface
import HROOT.Core.TAttFill.RawType
import HROOT.Core.TAttFill.Cast
import HROOT.Core.TAttFill.Interface
import STD.Deletable.RawType
import STD.Deletable.Cast
import STD.Deletable.Interface

instance () => ITArc (TArc) where

instance () => ITEllipse (TArc) where

instance () => ITObject (TArc) where
        clear :: forall c0. Castable c0 CString => TArc -> c0 -> IO ()
clear = (Ptr RawTArc -> CString -> IO ()) -> TArc -> c0 -> IO ()
forall a ca x1 cx1 y cy.
(Castable a ca, Castable x1 cx1, Castable y cy) =>
(ca -> cx1 -> IO cy) -> a -> x1 -> IO y
xform1 Ptr RawTArc -> CString -> IO ()
c_tarc_clear
        draw :: forall c0. Castable c0 CString => TArc -> c0 -> IO ()
draw = (Ptr RawTArc -> CString -> IO ()) -> TArc -> c0 -> IO ()
forall a ca x1 cx1 y cy.
(Castable a ca, Castable x1 cx1, Castable y cy) =>
(ca -> cx1 -> IO cy) -> a -> x1 -> IO y
xform1 Ptr RawTArc -> CString -> IO ()
c_tarc_draw
        findObject :: forall c0. Castable c0 CString => TArc -> c0 -> IO TObject
findObject = (Ptr RawTArc -> CString -> IO (Ptr RawTObject))
-> TArc -> c0 -> IO TObject
forall a ca x1 cx1 y cy.
(Castable a ca, Castable x1 cx1, Castable y cy) =>
(ca -> cx1 -> IO cy) -> a -> x1 -> IO y
xform1 Ptr RawTArc -> CString -> IO (Ptr RawTObject)
c_tarc_findobject
        getName :: TArc -> IO CString
getName = (Ptr RawTArc -> IO CString) -> TArc -> IO CString
forall a ca y cy.
(Castable a ca, Castable y cy) =>
(ca -> IO cy) -> a -> IO y
xform0 Ptr RawTArc -> IO CString
c_tarc_getname
        isA :: TArc -> IO TClass
isA = (Ptr RawTArc -> IO (Ptr RawTClass)) -> TArc -> IO TClass
forall a ca y cy.
(Castable a ca, Castable y cy) =>
(ca -> IO cy) -> a -> IO y
xform0 Ptr RawTArc -> IO (Ptr RawTClass)
c_tarc_isa
        paint :: forall c0. Castable c0 CString => TArc -> c0 -> IO ()
paint = (Ptr RawTArc -> CString -> IO ()) -> TArc -> c0 -> IO ()
forall a ca x1 cx1 y cy.
(Castable a ca, Castable x1 cx1, Castable y cy) =>
(ca -> cx1 -> IO cy) -> a -> x1 -> IO y
xform1 Ptr RawTArc -> CString -> IO ()
c_tarc_paint
        printObj :: forall c0. Castable c0 CString => TArc -> c0 -> IO ()
printObj = (Ptr RawTArc -> CString -> IO ()) -> TArc -> c0 -> IO ()
forall a ca x1 cx1 y cy.
(Castable a ca, Castable x1 cx1, Castable y cy) =>
(ca -> cx1 -> IO cy) -> a -> x1 -> IO y
xform1 Ptr RawTArc -> CString -> IO ()
c_tarc_printobj
        saveAs :: forall c1 c0.
(Castable c1 CString, Castable c0 CString) =>
TArc -> c0 -> c1 -> IO ()
saveAs = (Ptr RawTArc -> CString -> CString -> IO ())
-> TArc -> c0 -> c1 -> IO ()
forall a ca x1 cx1 x2 cx2 y cy.
(Castable a ca, Castable x1 cx1, Castable x2 cx2, Castable y cy) =>
(ca -> cx1 -> cx2 -> IO cy) -> a -> x1 -> x2 -> IO y
xform2 Ptr RawTArc -> CString -> CString -> IO ()
c_tarc_saveas
        write :: forall c0.
Castable c0 CString =>
TArc -> c0 -> CInt -> CInt -> IO CInt
write = (Ptr RawTArc -> CString -> CInt -> CInt -> IO CInt)
-> TArc -> c0 -> CInt -> CInt -> IO CInt
forall a ca x1 cx1 x2 cx2 x3 cx3 y cy.
(Castable a ca, Castable x1 cx1, Castable x2 cx2, Castable x3 cx3,
 Castable y cy) =>
(ca -> cx1 -> cx2 -> cx3 -> IO cy) -> a -> x1 -> x2 -> x3 -> IO y
xform3 Ptr RawTArc -> CString -> CInt -> CInt -> IO CInt
c_tarc_write
        write_ :: TArc -> IO CInt
write_ = (Ptr RawTArc -> IO CInt) -> TArc -> IO CInt
forall a ca y cy.
(Castable a ca, Castable y cy) =>
(ca -> IO cy) -> a -> IO y
xform0 Ptr RawTArc -> IO CInt
c_tarc_write_

instance () => ITAttLine (TArc) where
        getLineColor :: TArc -> IO CShort
getLineColor = (Ptr RawTArc -> IO CShort) -> TArc -> IO CShort
forall a ca y cy.
(Castable a ca, Castable y cy) =>
(ca -> IO cy) -> a -> IO y
xform0 Ptr RawTArc -> IO CShort
c_tarc_getlinecolor
        getLineStyle :: TArc -> IO CShort
getLineStyle = (Ptr RawTArc -> IO CShort) -> TArc -> IO CShort
forall a ca y cy.
(Castable a ca, Castable y cy) =>
(ca -> IO cy) -> a -> IO y
xform0 Ptr RawTArc -> IO CShort
c_tarc_getlinestyle
        getLineWidth :: TArc -> IO CShort
getLineWidth = (Ptr RawTArc -> IO CShort) -> TArc -> IO CShort
forall a ca y cy.
(Castable a ca, Castable y cy) =>
(ca -> IO cy) -> a -> IO y
xform0 Ptr RawTArc -> IO CShort
c_tarc_getlinewidth
        resetAttLine :: forall c0. Castable c0 CString => TArc -> c0 -> IO ()
resetAttLine = (Ptr RawTArc -> CString -> IO ()) -> TArc -> c0 -> IO ()
forall a ca x1 cx1 y cy.
(Castable a ca, Castable x1 cx1, Castable y cy) =>
(ca -> cx1 -> IO cy) -> a -> x1 -> IO y
xform1 Ptr RawTArc -> CString -> IO ()
c_tarc_resetattline
        setLineAttributes :: TArc -> IO ()
setLineAttributes = (Ptr RawTArc -> IO ()) -> TArc -> IO ()
forall a ca y cy.
(Castable a ca, Castable y cy) =>
(ca -> IO cy) -> a -> IO y
xform0 Ptr RawTArc -> IO ()
c_tarc_setlineattributes
        setLineColor :: TArc -> CShort -> IO ()
setLineColor = (Ptr RawTArc -> CShort -> IO ()) -> TArc -> CShort -> IO ()
forall a ca x1 cx1 y cy.
(Castable a ca, Castable x1 cx1, Castable y cy) =>
(ca -> cx1 -> IO cy) -> a -> x1 -> IO y
xform1 Ptr RawTArc -> CShort -> IO ()
c_tarc_setlinecolor
        setLineStyle :: TArc -> CShort -> IO ()
setLineStyle = (Ptr RawTArc -> CShort -> IO ()) -> TArc -> CShort -> IO ()
forall a ca x1 cx1 y cy.
(Castable a ca, Castable x1 cx1, Castable y cy) =>
(ca -> cx1 -> IO cy) -> a -> x1 -> IO y
xform1 Ptr RawTArc -> CShort -> IO ()
c_tarc_setlinestyle
        setLineWidth :: TArc -> CShort -> IO ()
setLineWidth = (Ptr RawTArc -> CShort -> IO ()) -> TArc -> CShort -> IO ()
forall a ca x1 cx1 y cy.
(Castable a ca, Castable x1 cx1, Castable y cy) =>
(ca -> cx1 -> IO cy) -> a -> x1 -> IO y
xform1 Ptr RawTArc -> CShort -> IO ()
c_tarc_setlinewidth

instance () => ITAttFill (TArc) where
        setFillColor :: TArc -> CInt -> IO ()
setFillColor = (Ptr RawTArc -> CInt -> IO ()) -> TArc -> CInt -> IO ()
forall a ca x1 cx1 y cy.
(Castable a ca, Castable x1 cx1, Castable y cy) =>
(ca -> cx1 -> IO cy) -> a -> x1 -> IO y
xform1 Ptr RawTArc -> CInt -> IO ()
c_tarc_setfillcolor
        setFillStyle :: TArc -> CInt -> IO ()
setFillStyle = (Ptr RawTArc -> CInt -> IO ()) -> TArc -> CInt -> IO ()
forall a ca x1 cx1 y cy.
(Castable a ca, Castable x1 cx1, Castable y cy) =>
(ca -> cx1 -> IO cy) -> a -> x1 -> IO y
xform1 Ptr RawTArc -> CInt -> IO ()
c_tarc_setfillstyle

instance () => IDeletable (TArc) where
        delete :: TArc -> IO ()
delete = (Ptr RawTArc -> IO ()) -> TArc -> IO ()
forall a ca y cy.
(Castable a ca, Castable y cy) =>
(ca -> IO cy) -> a -> IO y
xform0 Ptr RawTArc -> IO ()
c_tarc_delete

newTArc ::
          () =>
          CDouble -> CDouble -> CDouble -> CDouble -> CDouble -> IO TArc
newTArc :: CDouble -> CDouble -> CDouble -> CDouble -> CDouble -> IO TArc
newTArc = (CDouble
 -> CDouble -> CDouble -> CDouble -> CDouble -> IO (Ptr RawTArc))
-> CDouble -> CDouble -> CDouble -> CDouble -> CDouble -> IO TArc
forall a ca x1 cx1 x2 cx2 x3 cx3 x4 cx4 y cy.
(Castable a ca, Castable x1 cx1, Castable x2 cx2, Castable x3 cx3,
 Castable x4 cx4, Castable y cy) =>
(ca -> cx1 -> cx2 -> cx3 -> cx4 -> IO cy)
-> a -> x1 -> x2 -> x3 -> x4 -> IO y
xform4 CDouble
-> CDouble -> CDouble -> CDouble -> CDouble -> IO (Ptr RawTArc)
c_tarc_newtarc