module Text.Sundown.Buffer.Foreign
( Buffer (..)
, c_bufnew
, c_bufputs
, c_bufgrow
, c_bufrelease
) where
import Foreign
import Foreign.C.Types
import Foreign.C.String
import Data.ByteString (ByteString)
import qualified Data.ByteString as BS
data Buffer = Buffer { bufData :: ByteString
, bufSize :: Int
, bufASize :: Int
, bufUnit :: Int
, bufRef :: Int
}
instance Storable Buffer where
sizeOf _ = ((20))
alignment _ = alignment (undefined :: CInt)
peek ptr = do
d <- ((\hsc_ptr -> peekByteOff hsc_ptr 0)) ptr
dbs <- if d == nullPtr
then return $ BS.pack [0]
else BS.packCString d
s <- ((\hsc_ptr -> peekByteOff hsc_ptr 4)) ptr
as <- ((\hsc_ptr -> peekByteOff hsc_ptr 8)) ptr
u <- ((\hsc_ptr -> peekByteOff hsc_ptr 12)) ptr
r <- ((\hsc_ptr -> peekByteOff hsc_ptr 16)) ptr
return $ Buffer dbs s as u r
poke _ _ = error "Buffer.poke not implemented."
foreign import ccall "buffer.h bufnew"
c_bufnew :: CSize -> IO (Ptr Buffer)
c_bufputs :: Ptr Buffer -> ByteString -> IO ()
c_bufputs buf bs = BS.useAsCString bs $ c_bufputs' buf
foreign import ccall "buffer.h bufputs"
c_bufputs' :: Ptr Buffer -> CString -> IO ()
foreign import ccall "buffer.h bufgrow"
c_bufgrow :: Ptr Buffer -> CSize -> IO CInt
foreign import ccall "buffer.h bufrelease"
c_bufrelease :: Ptr Buffer -> IO ()