From 1e53b8533fa22640147cc4ca4ce5075c8e39b0d8 Mon Sep 17 00:00:00 2001 From: pho Date: Thu, 18 Oct 2007 19:16:26 +0900 Subject: [PATCH] Small fix darcs-hash:20071018101626-62b54-939495ea94615627610d2a08dcdc55b8c46e3c54.gz --- Lucu.cabal | 2 +- Network/HTTP/Lucu/Abortion.hs | 14 ++++++++------ Network/HTTP/Lucu/Httpd.hs | 2 +- 3 files changed, 10 insertions(+), 8 deletions(-) diff --git a/Lucu.cabal b/Lucu.cabal index 1142ea6..4a1b9ea 100644 --- a/Lucu.cabal +++ b/Lucu.cabal @@ -13,7 +13,7 @@ License: PublicDomain Author: PHO Maintainer: PHO Stability: experimental -Homepage: http://ccm.sherry.jp/lucu/ +Homepage: http://ccm.sherry.jp/Lucu/ Category: Network Tested-With: GHC == 6.6.1 Build-Depends: diff --git a/Network/HTTP/Lucu/Abortion.hs b/Network/HTTP/Lucu/Abortion.hs index bc03045..dc33eb1 100644 --- a/Network/HTTP/Lucu/Abortion.hs +++ b/Network/HTTP/Lucu/Abortion.hs @@ -17,7 +17,7 @@ import Control.Arrow.ArrowIO import Control.Concurrent.STM import Control.Exception import Control.Monad.Trans -import Data.ByteString.Base (ByteString) +import qualified Data.ByteString.Char8 as C8 import Data.Dynamic import GHC.Conc (unsafeIOToSTM) import Network.HTTP.Lucu.Config @@ -62,29 +62,31 @@ data Abortion = Abortion { -- > abort MovedPermanently -- > [("Location", "http://example.net/")] -- > (Just "It has been moved to example.net") -abort :: MonadIO m => StatusCode -> [ (ByteString, ByteString) ] -> Maybe String -> m a +abort :: MonadIO m => StatusCode -> [ (String, String) ] -> Maybe String -> m a abort status headers msg = status `seq` headers `seq` msg `seq` - let abo = Abortion status (toHeaders headers) msg + let abo = Abortion status (toHeaders $ map pack headers) msg exc = DynException (toDyn abo) in liftIO $ throwIO exc + where + pack (x, y) = (C8.pack x, C8.pack y) -- |This is similar to 'abort' but computes it with -- 'System.IO.Unsafe.unsafePerformIO'. -abortPurely :: StatusCode -> [ (ByteString, ByteString) ] -> Maybe String -> a +abortPurely :: StatusCode -> [ (String, String) ] -> Maybe String -> a abortPurely = ((unsafePerformIO .) .) . abort -- |Computation of @'abortSTM' status headers msg@ just computes -- 'abort' in a 'Control.Monad.STM.STM' monad. -abortSTM :: StatusCode -> [ (ByteString, ByteString) ] -> Maybe String -> STM a +abortSTM :: StatusCode -> [ (String, String) ] -> Maybe String -> STM a abortSTM status headers msg = status `seq` headers `seq` msg `seq` unsafeIOToSTM $! abort status headers msg -- | Computation of @'abortA' -< (status, (headers, msg))@ just -- computes 'abort' in an 'Control.Arrow.ArrowIO.ArrowIO'. -abortA :: ArrowIO a => a (StatusCode, ([ (ByteString, ByteString) ], Maybe String)) c +abortA :: ArrowIO a => a (StatusCode, ([ (String, String) ], Maybe String)) c abortA = arrIO3 abort diff --git a/Network/HTTP/Lucu/Httpd.hs b/Network/HTTP/Lucu/Httpd.hs index 2036412..9632b29 100644 --- a/Network/HTTP/Lucu/Httpd.hs +++ b/Network/HTTP/Lucu/Httpd.hs @@ -42,7 +42,7 @@ import System.Posix.Signals -- > resUsesNativeThread = False -- > , resIsGreedy = False -- > , resGet --- > = Just $ do setContentType $ "text" "plain" +-- > = Just $ do setContentType $ read "text/plain" -- > output "Hello, world!" -- > , resHead = Nothing -- > , resPost = Nothing -- 2.40.0