From d2570fdf01c6b7f1453c393aa11c680d7706540a Mon Sep 17 00:00:00 2001
From: Ramakrishnan Muthukrishnan <ram@rkrishnan.org>
Date: Thu, 12 Feb 2015 12:04:55 +0530
Subject: [PATCH] WIP: impement benc encoding, needed for infohash computation

---
 src/Bencode.hs | 17 +++++++++++++++++
 1 file changed, 17 insertions(+)

diff --git a/src/Bencode.hs b/src/Bencode.hs
index 4bbfa62..62627a6 100644
--- a/src/Bencode.hs
+++ b/src/Bencode.hs
@@ -108,3 +108,20 @@ bencVal = Bstr <$> bencStr <|>
 
 decode :: BC.ByteString -> Either ParseError BVal
 decode = parse bencVal "BVal"
+
+-- given an input dict or int or string, encode
+-- it into a bencoded bytestring.
+-- | encode bencoded-values
+--
+-- >>> encode (Bstr (BC.pack ""))
+-- "0:"
+-- >>> encode (Bstr (BC.pack "spam"))
+-- "4:spam"
+-- >>> encode (Bint 0)
+-- "i0e"
+-- >>> encode (Bint 42)
+-- "i42e"
+encode :: BVal -> String
+encode (Bstr bs) = let s = BC.unpack bs
+                   in show (length s) ++ ":" ++ s
+encode (Bint i) = "i" ++ show i ++ "e"
-- 
2.45.2