OLD | NEW |
1 // Copyright (c) 2011, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2011, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 class _Lists { | 5 class _Lists { |
6 | 6 |
7 /** | 7 /** |
8 * Returns the index in the array [a] of the given [element], starting | 8 * Returns the index in the array [a] of the given [element], starting |
9 * the search at index [startIndex] to [endIndex] (exclusive). | 9 * the search at index [startIndex] to [endIndex] (exclusive). |
10 * Returns -1 if [element] is not found. | 10 * Returns -1 if [element] is not found. |
(...skipping 28 matching lines...) Expand all Loading... |
39 if (startIndex >= a.length) { | 39 if (startIndex >= a.length) { |
40 startIndex = a.length - 1; | 40 startIndex = a.length - 1; |
41 } | 41 } |
42 for (int i = startIndex; i >= 0; i--) { | 42 for (int i = startIndex; i >= 0; i--) { |
43 if (a[i] == element) { | 43 if (a[i] == element) { |
44 return i; | 44 return i; |
45 } | 45 } |
46 } | 46 } |
47 return -1; | 47 return -1; |
48 } | 48 } |
| 49 |
| 50 /** |
| 51 * Returns a sub list copy of this list, from [start] to |
| 52 * [:start + length:]. |
| 53 * Returns an empty list if [length] is 0. |
| 54 * Throws an [IllegalArgumentException] if [length] is negative. |
| 55 * Throws an [IndexOutOfRangeException] if [start] or |
| 56 * [:start + length:] are out of range. |
| 57 */ |
| 58 static List getRange(List a, int start, int length, List accumulator) { |
| 59 if (length < 0) throw new IllegalArgumentException('length'); |
| 60 if (start < 0) throw new IndexOutOfRangeException(start); |
| 61 int end = start + length; |
| 62 if (end > a.length) throw new IndexOutOfRangeException(end); |
| 63 for (int i = start; i < end; i++) { |
| 64 accumulator.add(a[i]); |
| 65 } |
| 66 return accumulator; |
| 67 } |
49 } | 68 } |
OLD | NEW |