{-# LANGUAGE EmptyDataDecls, FlexibleContexts, FlexibleInstances, ForeignFunctionInterface, IncoherentInstances, MultiParamTypeClasses, OverlappingInstances, TemplateHaskell, TypeFamilies, TypeSynonymInstances #-} module HROOT.Core.TArrayL64.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.TArrayL64.RawType import HROOT.Core.TArrayL64.FFI import HROOT.Core.TArrayL64.Interface import HROOT.Core.TArrayL64.Cast import HROOT.Core.TArrayL64.RawType import HROOT.Core.TArrayL64.Cast import HROOT.Core.TArrayL64.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 () => ITArrayL64 (TArrayL64) where instance () => ITArray (TArrayL64) where getAt :: TArrayL64 -> CInt -> IO CDouble getAt = (Ptr RawTArrayL64 -> CInt -> IO CDouble) -> TArrayL64 -> 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 RawTArrayL64 -> CInt -> IO CDouble c_tarrayl64_getat setArray :: TArrayL64 -> CInt -> IO () setArray = (Ptr RawTArrayL64 -> CInt -> IO ()) -> TArrayL64 -> 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 RawTArrayL64 -> CInt -> IO () c_tarrayl64_setarray setAt :: TArrayL64 -> CDouble -> CInt -> IO () setAt = (Ptr RawTArrayL64 -> CDouble -> CInt -> IO ()) -> TArrayL64 -> 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 RawTArrayL64 -> CDouble -> CInt -> IO () c_tarrayl64_setat instance () => IDeletable (TArrayL64) where delete :: TArrayL64 -> IO () delete = (Ptr RawTArrayL64 -> IO ()) -> TArrayL64 -> IO () forall a ca y cy. (Castable a ca, Castable y cy) => (ca -> IO cy) -> a -> IO y xform0 Ptr RawTArrayL64 -> IO () c_tarrayl64_delete