gpt4 book ai didi

haskell - 将功能提升到 Conduit Sink

转载 作者:行者123 更新时间:2023-12-04 18:14:24 26 4
gpt4 key购买 nike

我有一个函数f :: ByteString -> String ,并且需要一个 Sink ByteString (ResourceT IO) .
我怎么得到这个?

不幸的是,这些文档不是很有帮助......

最佳答案

这是该问题的一般解决方案:让我们采用任何函数i -> r , 其中 iMonoid ,然后通过折叠所有 await 将其变成水槽支持 mappend .

import Data.Conduit
import Data.Conduit.List as CL
import Data.Monoid

monoidFold :: (Monoid i, Monad m) => (i -> r) -> Sink i m r
monoidFold f = f `fmap` CL.fold mappend mempty

由于 ByteStringMonoid , 你的函数类型为 ByteString -> String可以作为 monoidFold的参数.
myMD5 :: ByteString -> String
monoidFold myMD5 :: Monad m => Sink ByteString m String

关于haskell - 将功能提升到 Conduit Sink,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11987606/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com