]> gitweb @ CieloNegro.org - Lucu.git/blobdiff - Network/HTTP/Lucu/ETag.hs
data/mime.types
[Lucu.git] / Network / HTTP / Lucu / ETag.hs
index 0341f5ac382b245638575477b0474ec0b1fafe40..86dd429e265100b8318716679ebfd4d0554120b0 100644 (file)
@@ -1,13 +1,17 @@
 module Network.HTTP.Lucu.ETag
     ( ETag
-    , mkETag    -- Bool -> String -> ETag
+    , mkETag     -- Bool -> String -> ETag
+    , strongETag -- String -> ETag
+    , weakETag   -- String -> ETag
     , eTagP     -- Parser ETag
     , eTagListP -- Parser [ETag]
     )
     where
 
+import           Control.Monad
 import           Network.HTTP.Lucu.Parser
 import           Network.HTTP.Lucu.Parser.Http
+import           Network.HTTP.Lucu.Utils
 
 
 data ETag = ETag {
@@ -15,24 +19,27 @@ data ETag = ETag {
     , etagToken  :: String
     } deriving (Eq)
 
-
 instance Show ETag where
     show (ETag isWeak token) = (if isWeak then
                                     "W/"
                                 else
                                     "")
                                ++
-                               foldr (++) "" (["\""] ++ map quote token ++ ["\""])
-        where
-          quote :: Char -> String
-          quote '"' = "\\\""
-          quote c   = [c]
+                               quoteStr token
 
 
 mkETag :: Bool -> String -> ETag
 mkETag = ETag
 
 
+strongETag :: String -> ETag
+strongETag = ETag False
+
+
+weakETag :: String -> ETag
+weakETag = ETag True
+
+
 eTagP :: Parser ETag
 eTagP = do isWeak <- option False (string "W/" >> return True)
            str    <- quotedStr
@@ -41,6 +48,7 @@ eTagP = do isWeak <- option False (string "W/" >> return True)
 
 eTagListP :: Parser [ETag]
 eTagListP = allowEOF
-            $ sepBy1 eTagP (do many sp
-                               char ','
-                               many sp)
+            $ do xs <- listOf eTagP
+                 when (null xs)
+                          $ fail ""
+                 return xs