One more pass on flatMap/mapMulti

Brian Goetz brian.goetz at oracle.com
Thu Jan 10 08:19:54 PST 2013


DownstreamCollector?

On 1/10/2013 11:01 AM, Tim Peierls wrote:
> How about Acceptor?
>
> On Thu, Jan 10, 2013 at 10:54 AM, Brian Goetz <brian.goetz at oracle.com
> <mailto:brian.goetz at oracle.com>> wrote:
>
>     Downstream:
>
>          /** A collector for values associated with a given input.
>       Values can be
>           * yielded individually, or in aggregates such as collections,
>     arrays, or
>           * streams; aggregates are flattened, so that yielding an array
>     containing
>           * [1, 2] is equivalent to yield(1); yield(2).
>           */
>          interface Downstream<U> {
>              void yield(U element);
>
>              default void yield(Collection<U> collection) {
>                  for (U u : collection)
>                      yield(u);
>              }
>
>              default void yield(U[] array) {
>                  for (U u : array)
>                      yield(u);
>              }
>
>              default void yield(Stream<U> stream) {
>                  stream.forEach(this::yield);
>              }
>          }
>
>     The basic idea is that this is a collector for values.  It was at
>     one point called "collector" but now we have something else called
>     Collector.
>
>
>


More information about the lambda-libs-spec-experts mailing list