我正在尝试学习如何使用管道。我有一个管道,它接收字节串并将它们分组为代表发送到服务器的操作的数据包。然后我有一个管道接收这些数据包,对它们采取行动并产生一个响应数据包。最后,我有一个管道接收响应数据包并将它们转换为字节串流。问题是包处理管道中的 yield 总是返回 Nothing。我的代码看起来像这样
processingConduit :: ServerState -> Conduit BS.ByteString IO BS.ByteString
processingConduit state = getPacketConduit
=$= processPacketConduit state
=$= putPacketConduit
processPacketConduit :: ServerState -> Conduit ClientPacket IO ServerPacket
processPacketConduit state = awaitForever $ \packet -> do
liftIO $ putStrLn "got something :)"
let function = case packet of
(LoginPacket _ _) -> login
_ -> ugh
result <- liftIO $ function state packet
yield result
getPacketConduit :: Conduit BS.ByteString IO ClientPacket
getPacketConduit = conduitGet (get :: Get ClientPacket)
putPacketConduit :: Conduit ServerPacket IO BS.ByteString
putPacketConduit = conduitPut (put :: ServerPacket -> Put)
我使用 runTCPServer 运行管道,它能够接受连接,并且 getPacketConduit 能够将字节串转换为有效的数据包,但 awaitForever 从不调用它的函数。如果我修改 processPacketConduit 以改用 await,我可以看到它总是返回 Nothing。