OLD | NEW |
| (Empty) |
1 // Copyright 2014 Google Inc. All Rights Reserved. | |
2 // | |
3 // Licensed under the Apache License, Version 2.0 (the "License"); | |
4 // you may not use this file except in compliance with the License. | |
5 // You may obtain a copy of the License at | |
6 // | |
7 // http://www.apache.org/licenses/LICENSE-2.0 | |
8 // | |
9 // Unless required by applicable law or agreed to in writing, software | |
10 // distributed under the License is distributed on an "AS IS" BASIS, | |
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
12 // See the License for the specific language governing permissions and | |
13 // limitations under the License. | |
14 | |
15 part of quiver.iterables; | |
16 | |
17 /** | |
18 * Partitions the input iterable into lists of the specified size. | |
19 */ | |
20 Iterable<List> partition(Iterable iterable, int size) { | |
21 return iterable.isEmpty ? [] : new _Partition(iterable, size); | |
22 } | |
23 | |
24 class _Partition extends IterableBase<List> { | |
25 final Iterable _iterable; | |
26 final int _size; | |
27 | |
28 _Partition(this._iterable, this._size) { | |
29 if (_size <= 0) throw new ArgumentError(_size); | |
30 } | |
31 | |
32 Iterator<List> get iterator => | |
33 new _PartitionIterator(_iterable.iterator, _size); | |
34 } | |
35 | |
36 class _PartitionIterator implements Iterator<List> { | |
37 final Iterator _iterator; | |
38 final int _size; | |
39 List _current; | |
40 | |
41 _PartitionIterator(this._iterator, this._size); | |
42 | |
43 @override | |
44 List get current => _current; | |
45 | |
46 @override | |
47 bool moveNext() { | |
48 var newValue = []; | |
49 var count = 0; | |
50 for (; count < _size && _iterator.moveNext(); count++) { | |
51 newValue.add(_iterator.current); | |
52 } | |
53 _current = (count > 0) ? newValue : null; | |
54 return _current != null; | |
55 } | |
56 } | |
OLD | NEW |