[ 
https://issues.apache.org/jira/browse/GROOVY-11596?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17940502#comment-17940502
 ] 

ASF GitHub Bot commented on GROOVY-11596:
-----------------------------------------

daniellansun merged PR #2170:
URL: https://github.com/apache/groovy/pull/2170




> Additional DGM lazy iterator methods
> ------------------------------------
>
>                 Key: GROOVY-11596
>                 URL: https://issues.apache.org/jira/browse/GROOVY-11596
>             Project: Groovy
>          Issue Type: Improvement
>            Reporter: Paul King
>            Assignee: Paul King
>            Priority: Major
>
> This issue is to provide a few more iterator variants in the DGM methods. 
> Some of these methods already exist but have an eager implementation. Others 
> are inspired from [groovy-stream|https://timyates.github.io/groovy-stream/].
> Instead of being executing in multiple seconds, as is, the following code 
> executes in a few 10s of ms with the iterator line uncommented, and creates 
> much fewer intermediate collections.
> {code:groovy}
> assert (1..10000)
> //  .iterator()
>   .repeat(10000)
>   .take(20000000)
>   .takeWhile{ true }
>   .drop(5)
>   .toUnique()
>   .collate(2)
>   .flatten{ it * 2 }
>   .dropRight(1)
>   .dropWhile{ it < 15 }
>   .withIndex()
>   .init()
>   .take(5)
>   .injectAll([0, 0]){ a, b -> [a.first() + b.first(), a.last() + b.last()] }
>   .collect()
>   .toString() == '[[16, 0], [34, 1], [54, 3], [76, 6], [100, 10]]'
> {code}
> In the above example, the existing methods on iterators are: drop, init, 
> take, takeWhile, withIndex, dropRight, toUnique
> Existing methods on iterables only: collate, flatten
> Existing eager iterator methods: injectAll
> New methods: repeat (this is an alias for multiply when giving a count but 
> matches the groovy-stream name and makes more sense when using the infinite 
> count)
> This is continuing Groovy's support for stream-like functionality. You can 
> think of all Iterator DGM methods that return iterators as like intermediate 
> operators. The methods on Iterator which return other things are like 
> collector operators, e.g. collect*, any, average, count, find*, inject, etc.
> Groovy-stream has much further functionality we could look at:
> * faux list comprehension variant of cross-product
> * filter/map/flatMap which we could implement just on iterators and 
> effectively provide intermediate variants for findAll/collect/collectMany



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to