{-# 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