Я написал простое приложение WAI, которое использует ReaderT, чтобы разрешить доступ к запросу следующим образом:
import qualified Network.Wai as W
handle :: (Resource a) => a -> ReaderT W.Request IO W.Response
где handle
— функция, выполняющая основную часть обработки. Затем я вызываю это в своем приложении:
app :: W.Application
app = runReaderT (handle a) -- simplified; i don't think the value of a matters
main :: IO ()
main = run 3000 app
но runhaskell main.hs
дает мне следующее:
Couldn't match expected type `Control.Monad.Trans.Resource.ResourceT
IO'
with actual type `IO'
Expected type: ReaderT
W.Request (Control.Monad.Trans.Resource.ResourceT IO) W.Response
Actual type: ServerMonad W.Response
In the return type of a call of `handle'
In the first argument of `runReaderT', namely
`(handle a)'
что смущает меня по двум причинам:
- Я понятия не имею, почему он ожидает этого типа
- Звонок
resp <- runReaderT (handle a) defaultRequest
работает в GHCI!
Почему это происходит?