{-# LANGUAGE EmptyDataDecls, FlexibleContexts, FlexibleInstances,
  ForeignFunctionInterface, IncoherentInstances,
  MultiParamTypeClasses, OverlappingInstances, TemplateHaskell,
  TypeFamilies, TypeSynonymInstances #-}
module HROOT.Core.TArrayD.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.Core.TArrayD.RawType
import HROOT.Core.TArrayD.FFI
import HROOT.Core.TArrayD.Interface
import HROOT.Core.TArrayD.Cast
import HROOT.Core.TArrayD.RawType
import HROOT.Core.TArrayD.Cast
import HROOT.Core.TArrayD.Interface
import HROOT.Core.TArray.RawType
import HROOT.Core.TArray.Cast
import HROOT.Core.TArray.Interface
import STD.Deletable.RawType
import STD.Deletable.Cast
import STD.Deletable.Interface

instance () => ITArrayD (TArrayD) where

instance () => ITArray (TArrayD) where
        getAt :: TArrayD -> CInt -> IO CDouble
getAt = (Ptr RawTArrayD -> CInt -> IO CDouble)
-> TArrayD -> CInt -> IO CDouble
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 RawTArrayD -> CInt -> IO CDouble
c_tarrayd_getat
        setArray :: TArrayD -> CInt -> IO ()
setArray = (Ptr RawTArrayD -> CInt -> IO ()) -> TArrayD -> 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 RawTArrayD -> CInt -> IO ()
c_tarrayd_setarray
        setAt :: TArrayD -> CDouble -> CInt -> IO ()
setAt = (Ptr RawTArrayD -> CDouble -> CInt -> IO ())
-> TArrayD -> CDouble -> CInt -> 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 RawTArrayD -> CDouble -> CInt -> IO ()
c_tarrayd_setat

instance () => IDeletable (TArrayD) where
        delete :: TArrayD -> IO ()
delete = (Ptr RawTArrayD -> IO ()) -> TArrayD -> IO ()
forall a ca y cy.
(Castable a ca, Castable y cy) =>
(ca -> IO cy) -> a -> IO y
xform0 Ptr RawTArrayD -> IO ()
c_tarrayd_delete

tArrayD_At :: () => TArrayD -> CInt -> IO CDouble
tArrayD_At :: TArrayD -> CInt -> IO CDouble
tArrayD_At = (Ptr RawTArrayD -> CInt -> IO CDouble)
-> TArrayD -> CInt -> IO CDouble
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 RawTArrayD -> CInt -> IO CDouble
c_tarrayd_tarrayd_at

tArrayD_GetArray :: () => TArrayD -> IO (Ptr CDouble)
tArrayD_GetArray :: TArrayD -> IO (Ptr CDouble)
tArrayD_GetArray = (Ptr RawTArrayD -> IO (Ptr CDouble)) -> TArrayD -> IO (Ptr CDouble)
forall a ca y cy.
(Castable a ca, Castable y cy) =>
(ca -> IO cy) -> a -> IO y
xform0 Ptr RawTArrayD -> IO (Ptr CDouble)
c_tarrayd_tarrayd_getarray