blob: df03cf655023d69cf88ed7b130d3ae7360b7ba46 [file] [log] [blame]
// Copyright (c) 2012, 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.
// part of "core_patch.dart";
@patch
class List<E> {
@patch
factory List.empty({bool growable = false}) {
return growable ? <E>[] : _List<E>(0);
}
@patch
@pragma("vm:recognized", "other")
factory List([int? length]) native "List_new";
@patch
factory List.filled(int length, E fill, {bool growable: false}) {
// All error handling on the length parameter is done at the implementation
// of new _List.
var result = growable ? new _GrowableList<E>(length) : new _List<E>(length);
if (fill != null) {
for (int i = 0; i < length; i++) {
result[i] = fill;
}
}
return result;
}
@patch
factory List.from(Iterable elements, {bool growable: true}) {
// If elements is an Iterable<E>, we won't need a type-test for each
// element.
if (elements is Iterable<E>) {
return List.of(elements, growable: growable);
}
List<E> list = new _GrowableList<E>(0);
for (E e in elements) {
list.add(e);
}
if (growable) return list;
return makeListFixedLength(list);
}
@patch
factory List.of(Iterable<E> elements, {bool growable: true}) {
final cid = ClassID.getID(elements);
final isVMList = (cid == ClassID.cidArray) ||
(cid == ClassID.cidGrowableObjectArray) ||
(cid == ClassID.cidImmutableArray);
if (isVMList) {
final ListBase<E> elementsAsList = elements as ListBase<E>;
final int length = elementsAsList.length;
final list =
growable ? new _GrowableList<E>(length) : new _List<E>(length);
if (length > 0) {
for (int i = 0; i < length; i++) {
list[i] = elementsAsList[i];
}
}
return list;
}
if (elements is EfficientLengthIterable) {
final int length = elements.length;
final list =
growable ? new _GrowableList<E>(length) : new _List<E>(length);
if (length > 0) {
int i = 0;
for (var element in elements) {
list[i++] = element;
}
if (i != length) throw ConcurrentModificationError(elements);
}
return list;
}
final list = <E>[];
for (var elements in elements) {
list.add(elements);
}
if (growable) return list;
return makeListFixedLength(list);
}
@patch
@pragma("vm:prefer-inline")
factory List.generate(int length, E generator(int index),
{bool growable = true}) {
final List<E> result =
growable ? new _GrowableList<E>(length) : new _List<E>(length);
for (int i = 0; i < result.length; ++i) {
result[i] = generator(i);
}
return result;
}
@patch
factory List.unmodifiable(Iterable elements) {
final result = new List<E>.from(elements, growable: false);
return makeFixedListUnmodifiable(result);
}
// Factory constructing a mutable List from a parser generated List literal.
// [elements] contains elements that are already type checked.
@pragma("vm:entry-point", "call")
factory List._fromLiteral(List elements) {
if (elements.isEmpty) {
return new _GrowableList<E>(0);
}
final result = new _GrowableList<E>._withData(unsafeCast<_List>(elements));
result._setLength(elements.length);
return result;
}
}