wip: explore removing delays(8)

This commit is contained in:
bingus 2024-05-14 11:08:46 -05:00
parent edc7d40dbc
commit f9c0e20777
Signed by: orion
GPG Key ID: 6D4165AE4C928719

View File

@ -13,6 +13,7 @@ import Data.Tuple.Nested ((/\))
import Effect.Aff.Class (class MonadAff, liftAff) import Effect.Aff.Class (class MonadAff, liftAff)
import Effect.Class (liftEffect) import Effect.Class (liftEffect)
import Effect.Exception (Error) import Effect.Exception (Error)
import Node.Stream.Object (needsDrain)
import Node.Stream.Object as O import Node.Stream.Object as O
import Pipes (await, yield) import Pipes (await, yield)
import Pipes (for) as P import Pipes (for) as P
@ -108,23 +109,25 @@ fromTransform t =
err <- liftEffect $ liftST $ STRef.read error err <- liftEffect $ liftST $ STRef.read error
for_ err throwError for_ err throwError
yieldWhileReadable needsDrain <- liftEffect $ O.needsDrain t
ma <- await if needsDrain then do
case ma of liftAff $ O.awaitReadableOrClosed t
Nothing -> cleanup cancel yieldWhileReadable
Just a' -> do pure $ Loop {error, cancel}
res <- liftEffect $ O.write t a' else do
case res of ma <- await
O.WriteClosed -> cleanup cancel case ma of
O.WriteOk -> do Nothing -> cleanup cancel
maybeYield1 Just a' -> do
pure $ Loop { error, cancel } res <- liftEffect $ O.write t a'
O.WriteWouldBlock -> do case res of
queueLen <- liftEffect $ O.readableLength t O.WriteClosed -> cleanup cancel
when (queueLen == 0) $ liftAff $ O.awaitReadableOrClosed t O.WriteOk -> do
yieldWhileReadable maybeYield1
liftAff $ O.awaitWritableOrClosed t pure $ Loop { error, cancel }
pure $ Loop { error, cancel } O.WriteWouldBlock -> do
yieldWhileReadable
pure $ Loop { error, cancel }
in in
do do
r <- liftEffect $ O.withErrorST t r <- liftEffect $ O.withErrorST t