| // Copyright (c) 2016, the Dart project authors. Please see the AUTHORS file |
| // for details. All rights reserved. Use of this source code is governed by a |
| // BSD-style license that can be found in the LICENSE file. |
| |
| /// @assertion Iterable.generate(int count, [E generator(int index)]) |
| /// Creates an Iterable that generates its elements dynamically. |
| /// An Iterator created by iterator will count from zero to count - 1, and call |
| /// generator with each index in turn to create the next value. |
| /// If generator is omitted, it defaults to an identity function on integers |
| /// (int x) => x, so it should only be omitted if the type parameter allows |
| /// integer values. |
| /// As an Iterable, new Iterable.generate(n, generator)) is equivalent to |
| /// const [0, ..., n - 1].map(generator). |
| /// @description Checks that Iterators created by the Iterable.generate() is |
| /// equivalent to const [0, ..., n - 1].map(generator). Check how many times |
| /// generator function is called |
| /// @issue 26358 |
| /// @author sgrekhov@unipro.ru |
| |
| import "../../../Utils/expect.dart"; |
| |
| int counter1 = 0; |
| int counter2 = 0; |
| |
| int generator1(int index) { |
| counter1++; |
| return index; |
| } |
| int generator2(int index) { |
| counter2++; |
| return index; |
| } |
| |
| main() { |
| const arr = const [0, 1, 2, 3, 4, 5]; |
| Iterable i1 = arr.map(generator1); |
| Iterable i2 = new Iterable.generate(arr.length, generator2); |
| |
| counter1 = 0; |
| counter2 = 0; |
| |
| i1.elementAt(2); |
| i1.elementAt(2); |
| |
| i2.elementAt(2); |
| i2.elementAt(2); |
| |
| Expect.equals(counter1, counter2); |
| } |