From 75cf17f2eee68732a4cac4fbb6462db310b667c6 Mon Sep 17 00:00:00 2001 From: Ramakrishnan Muthukrishnan <ram@rkrishnan.org> Date: Tue, 17 Feb 2015 11:36:27 +0530 Subject: [PATCH] fix changed made during sleep deprived state --- src/Bencode.hs | 2 +- src/Tracker.hs | 6 +++--- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/src/Bencode.hs b/src/Bencode.hs index 75ae077..6b46a92 100644 --- a/src/Bencode.hs +++ b/src/Bencode.hs @@ -132,6 +132,6 @@ encode (Bstr bs) = let s = BC.unpack bs in show (length s) ++ ":" ++ s encode (Bint i) = "i" ++ show i ++ "e" encode (Blist xs) = "l" ++ encodeList xs ++ "e" - where encodeList = foldr (++ encode x) "" + where encodeList = foldr (\x -> (++ encode x)) "" encode (Bdict d) = "d" ++ encodeDict d ++ "e" where encodeDict m = concat [encode k ++ encode (m M.! k) | k <- M.keys m] diff --git a/src/Tracker.hs b/src/Tracker.hs index 5df314c..52dccdd 100644 --- a/src/Tracker.hs +++ b/src/Tracker.hs @@ -20,9 +20,9 @@ type Url = String -- "%124Vx%9a%bc%de%f1%23Eg%89%ab%cd%ef%124Vx%9a" urlEncode :: BC.ByteString -> String urlEncode bs = concatMap (encode . BC.unpack) (U.splitN 2 bs) - where encode b@[c1 : c2] = let c = chr (read ("0x" ++ b)) - in - escape c c1 c2 + where encode b@(c1 : c2 : []) = let c = chr (read ("0x" ++ b)) + in + escape c c1 c2 encode _ = "" escape i c1 c2 | i `elem` nonSpecialChars = [i] | otherwise = "%" ++ [c1] ++ [c2] -- 2.45.2