From 638033d2f29bd359448679a9dfb9e0830e3b12a7 Mon Sep 17 00:00:00 2001 From: Kamil Kloch Date: Wed, 29 Nov 2023 00:53:34 +0100 Subject: [PATCH] Update evalTapChunk. --- core/shared/src/main/scala/fs2/Stream.scala | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/core/shared/src/main/scala/fs2/Stream.scala b/core/shared/src/main/scala/fs2/Stream.scala index 9fd98ef5c4..12efb3c94a 100644 --- a/core/shared/src/main/scala/fs2/Stream.scala +++ b/core/shared/src/main/scala/fs2/Stream.scala @@ -1052,8 +1052,10 @@ final class Stream[+F[_], +O] private[fs2] (private[fs2] val underlying: Pull[F, /** Alias for `evalMapChunk(o => f(o).as(o))`. */ - def evalTapChunk[F2[x] >: F[x]: Applicative, O2](f: O => F2[O2]): Stream[F2, O] = - evalMapChunk(o => f(o).as(o)) + def evalTapChunk[F2[x] >: F[x]: Applicative, O2](f: O => F2[O2]): Stream[F2, O] = { + def tapOutChunk(o: Chunk[O]): Pull[F2, O, Unit] = Pull.eval(o.traverse_(f)) >> Pull.output(o) + underlying.unconsFlatMap(tapOutChunk).streamNoScope + } /** Emits `true` as soon as a matching element is received, else `false` if no input matches. * '''Pure''': this operation maps to `List.exists`