Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(201)

Side by Side Diff: runtime/lib/growable_array.dart

Issue 8273004: Implement removeRange, and update some documentation on the list interface. (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: '' Created 9 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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 Array<T> {
6 Array<T> backingArray; 6 Array<T> backingArray;
7 7
8 void copyFrom(Array<Object> src, int srcStart, int dstStart, int count) { 8 void copyFrom(Array<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) throw new IllegalArgumentException(length);
13 Arrays.copy(from, startFrom, this, start, length); 14 Arrays.copy(from, startFrom, this, start, length);
14 } 15 }
15 16
16 void removeRange(int start, int length) { 17 void removeRange(int start, int length) {
17 throw const NotImplementedException(); 18 if (length == 0) {
19 return;
20 }
21 if (length < 0) {
22 throw const IllegalArgumentException();
23 }
24 if (start < 0 || start >= this.length) {
25 throw new IndexOutOfRangeException(start);
26 }
27 if (start + length > this.length) {
28 throw new IndexOutOfRangeException(start + length);
29 }
30 Arrays.copy(backingArray,
31 start + length,
32 backingArray,
33 start,
34 this.length - length - start);
35 this.length = this.length - length;
18 } 36 }
19 37
20 void insertRange(int start, int length, [T initialValue = null]) { 38 void insertRange(int start, int length, [T initialValue = null]) {
21 throw const NotImplementedException(); 39 throw const NotImplementedException();
22 } 40 }
23 41
24 List<T> getRange(int start, int length) { 42 List<T> getRange(int start, int length) {
25 throw const NotImplementedException(); 43 throw const NotImplementedException();
26 } 44 }
27 45
(...skipping 161 matching lines...) Expand 10 before | Expand all | Expand 10 after
189 if (!hasNext()) { 207 if (!hasNext()) {
190 throw const NoMoreElementsException(); 208 throw const NoMoreElementsException();
191 } 209 }
192 return _array[_pos++]; 210 return _array[_pos++];
193 } 211 }
194 212
195 final GrowableObjectArray<T> _array; 213 final GrowableObjectArray<T> _array;
196 int _pos; 214 int _pos;
197 } 215 }
198 216
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698