| 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 |