mirror of
https://github.com/idris-lang/Idris2.git
synced 2024-12-26 13:11:30 +03:00
5c9f8e36a1
* Fix symbom mangling
* Revert "Fix symbom mangling"
This reverts commit 6481e80155
.
* Fix typo
* [RefC] Add missed prims of setBuffer* .
* [ fix ] formatting
* [ re #2609 ] Use 'UInt' instead of 'Word'
More descriptive/to the point / Less assumed knowledge.
There are no *LE suffixes for UInt8, since endianness is to do with
multiple bytes and UInt8 is a single one.
Co-authored-by: Guillaume Allais <guillaume.allais@ens-lyon.org>
Co-authored-by: Thomas E. Hansen <teh6@st-andrews.ac.uk>
61 lines
1.5 KiB
Idris
61 lines
1.5 KiB
Idris
module TestBuffer
|
|
|
|
import Data.Buffer
|
|
import System.File
|
|
|
|
put : Show a => IO a -> IO ()
|
|
put = (>>= putStrLn . show)
|
|
|
|
main : IO ()
|
|
main = do
|
|
Just buf <- newBuffer 37
|
|
| Nothing => pure ()
|
|
|
|
-- TODO: setByte is deprecated, remove once no longer in libs
|
|
setByte buf 0 1
|
|
setBits8 buf 1 2
|
|
setBits16 buf 2 3
|
|
setBits16 buf 4 4
|
|
setInt buf 8 0x1122334455667788
|
|
setDouble buf 16 (sqrt 2)
|
|
|
|
let helloWorld = "Hello, world"
|
|
|
|
Just helloWorldBuf <- newBuffer (stringByteLength helloWorld)
|
|
| Nothing => pure ()
|
|
|
|
setString helloWorldBuf 0 "Hello, world"
|
|
copyData helloWorldBuf 0 12 buf 24
|
|
|
|
put $ rawSize buf
|
|
|
|
-- TODO: getByte is deprecated, remove once no longer in libs
|
|
put $ getByte buf 0
|
|
put $ getBits8 buf 1
|
|
put $ getBits16 buf 2
|
|
put $ getBits32 buf 4
|
|
put $ getInt buf 8
|
|
put $ getDouble buf 16
|
|
put $ getString buf 24 12
|
|
|
|
put $ bufferData buf
|
|
|
|
Just readBuf <- newBuffer 8
|
|
| Nothing => pure ()
|
|
Right f <- openFile "testRead.buf" Read
|
|
| Left err => put $ pure err
|
|
Right 8 <- readBufferData f readBuf 0 8
|
|
| Right size => put $ pure "\{show size} bytes have been read, 8 expected"
|
|
| Left err => put $ pure err
|
|
put $ bufferData readBuf
|
|
|
|
Just writeBuf <- newBuffer 8
|
|
| Nothing => pure ()
|
|
setInt writeBuf 0 0x7766554433221100
|
|
Right f <- openFile "testWrite.buf" WriteTruncate
|
|
| Left err => put $ pure err
|
|
Right () <- writeBufferData f writeBuf 0 8
|
|
| Left err => put $ pure err
|
|
|
|
pure ()
|