module Bindings.AudioFile.VFS where
import Foreign.Ptr (Ptr,FunPtr,plusPtr)
import Foreign.Ptr (wordPtrToPtr,castPtrToFunPtr)
import Foreign.Storable
import Foreign.C.Types
import Foreign.C.String (CString,CStringLen,CWString,CWStringLen)
import Foreign.Marshal.Alloc (alloca)
import Foreign.Marshal.Array (peekArray,pokeArray)
import Data.Int
import Data.Word
import System.Posix.Types
data C'_AFvirtualfile = C'_AFvirtualfile{
c'_AFvirtualfile'read :: FunPtr (C'AFvirtualfile -> Ptr () -> CSize -> IO CSsize),
c'_AFvirtualfile'length :: FunPtr (C'AFvirtualfile -> IO CLong),
c'_AFvirtualfile'write :: FunPtr (C'AFvirtualfile -> Ptr () -> CSize -> IO CSsize),
c'_AFvirtualfile'destroy :: FunPtr (C'AFvirtualfile -> IO ()),
c'_AFvirtualfile'seek :: FunPtr (C'AFvirtualfile -> CLong -> CInt -> IO CLong),
c'_AFvirtualfile'tell :: FunPtr (C'AFvirtualfile -> IO CLong),
c'_AFvirtualfile'closure :: Ptr ()
} deriving (Eq,Show)
p'_AFvirtualfile'read p = plusPtr p 0
p'_AFvirtualfile'read :: Ptr (C'_AFvirtualfile) -> Ptr (FunPtr (C'AFvirtualfile -> Ptr () -> CSize -> IO CSsize))
p'_AFvirtualfile'length p = plusPtr p 8
p'_AFvirtualfile'length :: Ptr (C'_AFvirtualfile) -> Ptr (FunPtr (C'AFvirtualfile -> IO CLong))
p'_AFvirtualfile'write p = plusPtr p 16
p'_AFvirtualfile'write :: Ptr (C'_AFvirtualfile) -> Ptr (FunPtr (C'AFvirtualfile -> Ptr () -> CSize -> IO CSsize))
p'_AFvirtualfile'destroy p = plusPtr p 24
p'_AFvirtualfile'destroy :: Ptr (C'_AFvirtualfile) -> Ptr (FunPtr (C'AFvirtualfile -> IO ()))
p'_AFvirtualfile'seek p = plusPtr p 32
p'_AFvirtualfile'seek :: Ptr (C'_AFvirtualfile) -> Ptr (FunPtr (C'AFvirtualfile -> CLong -> CInt -> IO CLong))
p'_AFvirtualfile'tell p = plusPtr p 40
p'_AFvirtualfile'tell :: Ptr (C'_AFvirtualfile) -> Ptr (FunPtr (C'AFvirtualfile -> IO CLong))
p'_AFvirtualfile'closure p = plusPtr p 48
p'_AFvirtualfile'closure :: Ptr (C'_AFvirtualfile) -> Ptr (Ptr ())
instance Storable C'_AFvirtualfile where
sizeOf _ = 56
alignment _ = 8
peek p = do
v0 <- peekByteOff p 0
v1 <- peekByteOff p 8
v2 <- peekByteOff p 16
v3 <- peekByteOff p 24
v4 <- peekByteOff p 32
v5 <- peekByteOff p 40
v6 <- peekByteOff p 48
return $ C'_AFvirtualfile v0 v1 v2 v3 v4 v5 v6
poke p (C'_AFvirtualfile v0 v1 v2 v3 v4 v5 v6) = do
pokeByteOff p 0 v0
pokeByteOff p 8 v1
pokeByteOff p 16 v2
pokeByteOff p 24 v3
pokeByteOff p 32 v4
pokeByteOff p 40 v5
pokeByteOff p 48 v6
return ()
type C'AFvirtualfile = C'_AFvirtualfile
foreign import ccall "af_virtual_file_new" c'af_virtual_file_new
:: IO (Ptr C'AFvirtualfile)
foreign import ccall "&af_virtual_file_new" p'af_virtual_file_new
:: FunPtr (IO (Ptr C'AFvirtualfile))
foreign import ccall "af_virtual_file_new_for_file" c'af_virtual_file_new_for_file
:: Ptr CFile -> IO (Ptr C'AFvirtualfile)
foreign import ccall "&af_virtual_file_new_for_file" p'af_virtual_file_new_for_file
:: FunPtr (Ptr CFile -> IO (Ptr C'AFvirtualfile))
foreign import ccall "af_virtual_file_destroy" c'af_virtual_file_destroy
:: Ptr C'AFvirtualfile -> IO ()
foreign import ccall "&af_virtual_file_destroy" p'af_virtual_file_destroy
:: FunPtr (Ptr C'AFvirtualfile -> IO ())
foreign import ccall "af_fread" c'af_fread
:: Ptr () -> CSize -> CSize -> Ptr C'AFvirtualfile -> IO CSize
foreign import ccall "&af_fread" p'af_fread
:: FunPtr (Ptr () -> CSize -> CSize -> Ptr C'AFvirtualfile -> IO CSize)
foreign import ccall "af_fwrite" c'af_fwrite
:: Ptr () -> CSize -> CSize -> Ptr C'AFvirtualfile -> IO CSize
foreign import ccall "&af_fwrite" p'af_fwrite
:: FunPtr (Ptr () -> CSize -> CSize -> Ptr C'AFvirtualfile -> IO CSize)
foreign import ccall "af_fclose" c'af_fclose
:: Ptr C'AFvirtualfile -> IO CInt
foreign import ccall "&af_fclose" p'af_fclose
:: FunPtr (Ptr C'AFvirtualfile -> IO CInt)
foreign import ccall "af_flength" c'af_flength
:: Ptr C'AFvirtualfile -> IO CLong
foreign import ccall "&af_flength" p'af_flength
:: FunPtr (Ptr C'AFvirtualfile -> IO CLong)
foreign import ccall "af_fseek" c'af_fseek
:: Ptr C'AFvirtualfile -> CLong -> CInt -> IO CInt
foreign import ccall "&af_fseek" p'af_fseek
:: FunPtr (Ptr C'AFvirtualfile -> CLong -> CInt -> IO CInt)
foreign import ccall "af_ftell" c'af_ftell
:: Ptr C'AFvirtualfile -> IO CLong
foreign import ccall "&af_ftell" p'af_ftell
:: FunPtr (Ptr C'AFvirtualfile -> IO CLong)