Commit 6cf872d
Add AsyncSeq.windowed for sliding window over async sequences
Adds AsyncSeq.windowed : int -> AsyncSeq<'T> -> AsyncSeq<'T[]>
This is a sliding-window combinator analogous to Seq.windowed and
Seq.pairwise (which is a special case with windowSize=2). Each window
is yielded as an immutable array snapshot; the window slides one
element at a time.
Implementation uses a Queue<'T> of capacity windowSize to maintain the
current window with O(1) enqueue/dequeue per element.
Includes 7 tests covering: empty source, source shorter than window,
exact-size source, sliding windows, size-1, size-2, and ArgumentException
for windowSize < 1.
All 201 tests pass.
Co-authored-by: Copilot <[email protected]>1 parent 97c0e3d commit 6cf872d
3 files changed
Lines changed: 63 additions & 0 deletions
File tree
- src/FSharp.Control.AsyncSeq
- tests/FSharp.Control.AsyncSeq.Tests
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1087 | 1087 | | |
1088 | 1088 | | |
1089 | 1089 | | |
| 1090 | + | |
| 1091 | + | |
| 1092 | + | |
| 1093 | + | |
| 1094 | + | |
| 1095 | + | |
| 1096 | + | |
| 1097 | + | |
| 1098 | + | |
| 1099 | + | |
| 1100 | + | |
| 1101 | + | |
| 1102 | + | |
| 1103 | + | |
| 1104 | + | |
1090 | 1105 | | |
1091 | 1106 | | |
1092 | 1107 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
198 | 198 | | |
199 | 199 | | |
200 | 200 | | |
| 201 | + | |
| 202 | + | |
| 203 | + | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
201 | 209 | | |
202 | 210 | | |
203 | 211 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
2553 | 2553 | | |
2554 | 2554 | | |
2555 | 2555 | | |
| 2556 | + | |
| 2557 | + | |
| 2558 | + | |
| 2559 | + | |
| 2560 | + | |
| 2561 | + | |
| 2562 | + | |
| 2563 | + | |
| 2564 | + | |
| 2565 | + | |
| 2566 | + | |
| 2567 | + | |
| 2568 | + | |
| 2569 | + | |
| 2570 | + | |
| 2571 | + | |
| 2572 | + | |
| 2573 | + | |
| 2574 | + | |
| 2575 | + | |
| 2576 | + | |
| 2577 | + | |
| 2578 | + | |
| 2579 | + | |
| 2580 | + | |
| 2581 | + | |
| 2582 | + | |
| 2583 | + | |
| 2584 | + | |
| 2585 | + | |
| 2586 | + | |
| 2587 | + | |
| 2588 | + | |
| 2589 | + | |
| 2590 | + | |
| 2591 | + | |
| 2592 | + | |
| 2593 | + | |
| 2594 | + | |
| 2595 | + | |
2556 | 2596 | | |
2557 | 2597 | | |
2558 | 2598 | | |
| |||
0 commit comments