2 -- Licensed to the Apache Software Foundation (ASF) under one
3 -- or more contributor license agreements. See the NOTICE file
4 -- distributed with this work for additional information
5 -- regarding copyright ownership. The ASF licenses this file
6 -- to you under the Apache License, Version 2.0 (the
7 -- "License"); you may not use this file except in compliance
8 -- with the License. You may obtain a copy of the License at
10 -- http://www.apache.org/licenses/LICENSE-2.0
12 -- Unless required by applicable law or agreed to in writing,
13 -- software distributed under the License is distributed on an
14 -- "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15 -- KIND, either express or implied. See the License for the
16 -- specific language governing permissions and limitations
20 module Thrift.Transport.IOBuffer
32 import Data.ByteString.Lazy.Builder
38 import qualified Data.ByteString.Lazy as LBS
40 type WriteBuffer = IORef Builder
41 type ReadBuffer = IORef LBS.ByteString
43 newWriteBuffer :: IO WriteBuffer
44 newWriteBuffer = newIORef mempty
46 writeBuf :: WriteBuffer -> LBS.ByteString -> IO ()
47 writeBuf w s = modifyIORef w ( <> lazyByteString s)
49 flushBuf :: WriteBuffer -> IO LBS.ByteString
53 return $ toLazyByteString buf
55 newReadBuffer :: IO ReadBuffer
56 newReadBuffer = newIORef mempty
58 fillBuf :: ReadBuffer -> LBS.ByteString -> IO ()
61 readBuf :: ReadBuffer -> Int -> IO LBS.ByteString
64 let (hd, tl) = LBS.splitAt (fromIntegral n) bs
68 peekBuf :: ReadBuffer -> IO (Maybe Word8)
69 peekBuf r = (fmap fst . LBS.uncons) <$> readIORef r