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 GrowableObjectArray<T> implements Array<T> { | 5 class GrowableObjectArray<T> implements List<T> { |
6 Array<T> backingArray; | 6 ObjectArray<T> backingArray; |
7 | 7 |
8 void copyFrom(Array<Object> src, int srcStart, int dstStart, int count) { | 8 void copyFrom(List<Object> src, int srcStart, int dstStart, int count) { |
9 Arrays.copy(src, srcStart, this, dstStart, count); | 9 Arrays.copy(src, srcStart, this, dstStart, count); |
10 } | 10 } |
11 | 11 |
12 void setRange(int start, int length, List<T> from, [int startFrom = 0]) { | 12 void setRange(int start, int length, List<T> from, [int startFrom = 0]) { |
13 if (length < 0) { | 13 if (length < 0) { |
14 throw new IllegalArgumentException("negative length $length"); | 14 throw new IllegalArgumentException("negative length $length"); |
15 } | 15 } |
16 Arrays.copy(from, startFrom, this, start, length); | 16 Arrays.copy(from, startFrom, this, start, length); |
17 } | 17 } |
18 | 18 |
(...skipping 105 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
124 } | 124 } |
125 | 125 |
126 void operator []=(int index, T value) { | 126 void operator []=(int index, T value) { |
127 if (index >= _length) { | 127 if (index >= _length) { |
128 throw new IndexOutOfRangeException(index); | 128 throw new IndexOutOfRangeException(index); |
129 } | 129 } |
130 backingArray[index] = value; | 130 backingArray[index] = value; |
131 } | 131 } |
132 | 132 |
133 void grow(int capacity) { | 133 void grow(int capacity) { |
134 Array<T> newArray = new ObjectArray<T>(capacity); | 134 ObjectArray<T> newArray = new ObjectArray<T>(capacity); |
135 int length = backingArray.length; | 135 int length = backingArray.length; |
136 for (int i = 0; i < length; i++) { | 136 for (int i = 0; i < length; i++) { |
137 newArray[i] = backingArray[i]; | 137 newArray[i] = backingArray[i]; |
138 } | 138 } |
139 backingArray = newArray; | 139 backingArray = newArray; |
140 } | 140 } |
141 | 141 |
142 int add(T value) { | 142 int add(T value) { |
143 if (_length == backingArray.length) { | 143 if (_length == backingArray.length) { |
144 grow(_length * 2); | 144 grow(_length * 2); |
(...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
233 if (!hasNext()) { | 233 if (!hasNext()) { |
234 throw const NoMoreElementsException(); | 234 throw const NoMoreElementsException(); |
235 } | 235 } |
236 return _array[_pos++]; | 236 return _array[_pos++]; |
237 } | 237 } |
238 | 238 |
239 final GrowableObjectArray<T> _array; | 239 final GrowableObjectArray<T> _array; |
240 int _pos; | 240 int _pos; |
241 } | 241 } |
242 | 242 |
OLD | NEW |