summaryrefslogtreecommitdiff
path: root/KikiD/GetLine.hs
diff options
context:
space:
mode:
authorJames Crayne <jim.crayne@gmail.com>2015-06-21 07:36:46 -0400
committerJames Crayne <jim.crayne@gmail.com>2015-06-21 15:35:26 -0400
commitd420aefe0b14081b00d4655f9e8317903b5b02c3 (patch)
tree7b58c8a784d1ef23be05e62aaf0c8311353d57d5 /KikiD/GetLine.hs
parent75d4b3b8bc60ff1d7ccc3990833a4439c0af02bc (diff)
kikid: The Beginnings of the Kiki Daemon
Diffstat (limited to 'KikiD/GetLine.hs')
-rw-r--r--KikiD/GetLine.hs18
1 files changed, 18 insertions, 0 deletions
diff --git a/KikiD/GetLine.hs b/KikiD/GetLine.hs
new file mode 100644
index 0000000..8af5dc6
--- /dev/null
+++ b/KikiD/GetLine.hs
@@ -0,0 +1,18 @@
1module KikiD.GetLine where
2
3import Control.Monad
4import Data.Serialize
5import qualified Data.ByteString as BS
6import qualified Data.ByteString.Lazy as L
7import Data.Monoid
8import Data.Binary.Builder
9
10getLine :: Get BS.ByteString
11getLine = getWords empty
12 where
13 getWords b = do
14 w <- getWord8
15 let x = singleton w
16 if (w == 10 || w == 0)
17 then return $ BS.concat . L.toChunks . toLazyByteString $ b <> x
18 else getWords (b <> x)