所以我有一个项目,我认为它很容易学习,但又足够复杂,很有趣,我想使用 Happstack 库来编写。在最基本的层面上,这个项目只是一个花哨的文件服务器,带有一些特定于域的 REST 方法(或者其他什么,我真的不在乎它是否真的是 RESTful)来搜索和获取所述文件和元数据。由于我现在也在尝试真正学习 monad 转换器,因此我认为这将是一个完美的学习项目。但是,我在启动它时遇到了一些困难,特别是在如何构建我的变压器堆栈方面。
现在,我只担心几件事:配置、错误报告、状态和日志记录,所以我从
newtype MyApp a = MyApp {
runMyApp :: ReaderT Config (ErrorT String (StateT AppState IO)) a
} deriving (...)
因为我总是在 IO 中,所以我可以很容易地使用 hslogger 来处理我的日志记录。但我也知道我需要使用ServerPartT
才能与 Happstack 交互,因此
runMyApp :: ReaderT Config (ErrorT String (StateT AppState (ServerPartT IO))) a
我可以让它运行,查看请求等,但我遇到的问题是,这需要FilterMonad
为它实现才能使用像dir
、path
和之类的方法ok
,但我不知道如何为这种类型实现它。我只需要它将过滤器传递给底层的 monad。有人可以给我一些关于如何实现这个明显至关重要的类型类的指示吗?或者,如果我只是在做一些非常错误的事情,请引导我朝着正确的方向前进。我只关注 Happstack 几天,变形金刚对我来说还是很陌生。我认为我对它们的了解足以使它们变得危险,但我对它们的了解还不够,以至于我可以自己实现一个。非常感谢您提供的任何帮助!
(X-从/r/haskell发布)