From e79225f715561a48bba8a2ec8b7f73445bfcf1d8 Mon Sep 17 00:00:00 2001 From: Simon Meier Date: Thu, 11 Apr 2013 13:24:09 +0200 Subject: [PATCH] Fix #177: compatible Eq and Ord instances for Method. --- src/Snap/Internal/Http/Types.hs | 84 ++++++++++++++++++++++++--------- 1 file changed, 61 insertions(+), 23 deletions(-) diff --git a/src/Snap/Internal/Http/Types.hs b/src/Snap/Internal/Http/Types.hs index 10ed0c49..9cab36bf 100644 --- a/src/Snap/Internal/Http/Types.hs +++ b/src/Snap/Internal/Http/Types.hs @@ -133,31 +133,69 @@ deleteHeader k = updateHeaders $ H.delete k -- ). data Method = GET | HEAD | POST | PUT | DELETE | TRACE | OPTIONS | CONNECT | PATCH | Method ByteString - deriving(Show,Read,Ord) - + deriving(Show, Read) instance Eq Method where - GET == GET = True - GET == Method "GET" = True - HEAD == HEAD = True - HEAD == Method "HEAD" = True - POST == POST = True - POST == Method "POST" = True - PUT == PUT = True - PUT == Method "PUT" = True - DELETE == DELETE = True - DELETE == Method "DELETE" = True - TRACE == TRACE = True - TRACE == Method "TRACE" = True - OPTIONS == OPTIONS = True - OPTIONS == Method "OPTIONS" = True - CONNECT == CONNECT = True - CONNECT == Method "CONNECT" = True - PATCH == PATCH = True - PATCH == Method "PATCH" = True - Method a == Method b = a == b - m@(Method _) == other = other == m - _ == _ = False + a == b = + normalizeMethod a `eq` normalizeMethod b + where + GET `eq` GET = True + HEAD `eq` HEAD = True + POST `eq` POST = True + PUT `eq` PUT = True + DELETE `eq` DELETE = True + TRACE `eq` TRACE = True + OPTIONS `eq` OPTIONS = True + CONNECT `eq` CONNECT = True + PATCH `eq` PATCH = True + Method x1 `eq` Method y1 = x1 == y1 + _ `eq` _ = False + +instance Ord Method where + compare a b = + check (normalizeMethod a) (normalizeMethod b) + where + check GET GET = EQ + check HEAD HEAD = EQ + check POST POST = EQ + check PUT PUT = EQ + check DELETE DELETE = EQ + check TRACE TRACE = EQ + check OPTIONS OPTIONS = EQ + check CONNECT CONNECT = EQ + check PATCH PATCH = EQ + check (Method x1) (Method y1) = compare x1 y1 + check x y = compare (tag x) (tag y) + + tag :: Method -> Int + tag (GET{}) = 0 + tag (HEAD{}) = 1 + tag (POST{}) = 2 + tag (PUT{}) = 3 + tag (DELETE{}) = 4 + tag (TRACE{}) = 5 + tag (OPTIONS{}) = 6 + tag (CONNECT{}) = 7 + tag (PATCH{}) = 8 + tag (Method{}) = 9 + +-- | Equate the special case constructors with their corresponding +-- @Method name@ variant. +{-# INLINE normalizeMethod #-} +normalizeMethod :: Method -> Method +normalizeMethod m@(Method name) = case name of + "GET" -> GET + "HEAD" -> HEAD + "POST" -> POST + "PUT" -> PUT + "DELETE" -> DELETE + "TRACE" -> TRACE + "OPTIONS" -> OPTIONS + "CONNECT" -> CONNECT + "PATCH" -> PATCH + _ -> m +normalizeMethod m = m + ------------------------------------------------------------------------------ type HttpVersion = (Int,Int)