UNPKG

@cute-dw/core

Version:

This TypeScript library is the main part of a more powerfull package designed for the fast WEB software development. The cornerstone of the library is the **DataStore** class, which might be useful when you need a full control of the data, but do not need

182 lines 22.8 kB
var _a; import { UnsupportedOperationException } from "../util/exception/UnsupportedOperationException"; import { IndexOutOfBoundsException } from "../util/exception/IndexOutOfBoundsException"; import { AbstractList } from "./AbstractList"; import { ListView } from "./view/ListView"; import { Objects } from "../util/Objects"; /** * Resizable-array implementation of the List interface. Implements all optional list operations, and permits all elements, including null. * In addition to implementing the List interface, this class provides methods to manipulate the size of the array that is used internally to store the list. */ export class ArrayList extends AbstractList { /** * Constructs an empty list with the specified initial capacity (as number), or * constructs a list containing the elements of the specified collection, in the order * they are returned by the collection's iterator * @param capacityOrCollection */ constructor(capacityOrCollection) { super(); this._elems = []; this._size = 0; this[_a] = "ArrayList"; capacityOrCollection = capacityOrCollection ?? 10; if (Objects.isNumber(capacityOrCollection)) { this._elems = new Array(Math.max(capacityOrCollection, 0)).fill(null); } else { const collection = capacityOrCollection; this._elems = new Array(Math.max(collection.length, 0)).fill(null); this.appendAll(collection); this._modCount = 0; } } _checkRange(index) { if (index >= 0 && index < this.length) { // OK! } else throw new IndexOutOfBoundsException(`Index '${index}' is out of range`); } *[Symbol.iterator]() { for (const elem of this._elems) { yield elem; } } get size() { return this._size; } append(value) { this.ensureCapacity(this.length + 1); // Increments modCount!! this._elems[this._size++] = value; return true; } clear() { this._modCount++; this._elems.fill(null); this._size = 0; } clone() { const aList = new ArrayList(this.size); aList.appendAll(this); return aList; } contains(value) { return this.indexOf(value) >= 0; } /** * @throws IndexOutOfBoundsException */ get(index) { this._checkRange(index); return this._elems[index]; } /** * @throws UnsupportedOperationException */ getNode(index) { throw new UnsupportedOperationException("Unsupported operation"); } indexOf(value, fromIndex = 0) { fromIndex = Math.max(fromIndex, 0); const nLen = this.length; for (let i = 0; i < nLen; i++) { if (this._elems[i] === value) { return i; } } return -1; } insert(index, value) { this._checkRange(index); this.ensureCapacity(this.length + 1); this._size++; this._elems.splice(index, 0, value); return true; } lastIndexOf(value, fromIndex = 0) { fromIndex = Math.max(fromIndex, 0); const nLen = this.length; for (let i = nLen - 1; i >= 0; i--) { if (this._elems[i] === value) { return i; } } return -1; } remove(value) { let i = -1; let nLen = this.length; while (++i < nLen) { if (this._elems[i] === value) { this._modCount++; this._elems.splice(i, 1); this._elems[--this._size] = null; // Let gc do its work return true; } } return false; } removeAt(index) { this._checkRange(index); this._modCount++; const oldValue = this._elems[index]; this._elems.splice(index, 1); this._elems[--this._size] = null; // Let gc do its work return oldValue; } removeRange(fromIndex, toIndex) { this._checkRange(fromIndex); toIndex = toIndex ?? this.length; const lastIndex = Math.min(toIndex, this.length); if (lastIndex > fromIndex) { this._modCount++; const oldLen = this._elems.length; const delCount = lastIndex - fromIndex; this._elems.splice(fromIndex, delCount); this._size -= delCount; this._elems.length = oldLen; this._elems.fill(null, this._size); return true; } return false; } set(index, value) { this._checkRange(index); const oldValue = this._elems[index]; this._elems[index] = value; this._modCount++; return oldValue; } subList(fromIndex, toIndex) { return new ListView(this, fromIndex, toIndex); } /** * Increases the capacity of this ArrayList instance, if necessary, to ensure that it can hold at least the number of elements specified by the minimum capacity argument * @param minCapacity The desired minimum capacity */ ensureCapacity(minCapacity) { const oldCapacity = this._elems.length; if (minCapacity > oldCapacity) { let newCapacity = Math.ceil((oldCapacity * 3) / 2 + 1); if (newCapacity < minCapacity) newCapacity = minCapacity; this._elems.length = newCapacity; this._elems.fill(null, this.length); this._modCount++; } } /** * Trims the capacity of this ArrayList instance to be the list's current size */ trimToSize() { const oldCap = this._elems.length; if (this.size < oldCap) { this._elems.length = this.size; this._modCount++; } } toArray() { return this._elems.slice(0, this.size); } } _a = Symbol.toStringTag; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ArrayList.js","sourceRoot":"","sources":["../../../../../projects/cute-core/src/lib/collections/ArrayList.ts"],"names":[],"mappings":"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","sourcesContent":["import { UnsupportedOperationException } from \"../util/exception/UnsupportedOperationException\";\r\nimport { IndexOutOfBoundsException } from \"../util/exception/IndexOutOfBoundsException\";\r\nimport { AbstractList } from \"./AbstractList\";\r\nimport { LinkedListNode } from \"./LinkedList\";\r\nimport { List } from \"./List\";\r\nimport { ListView } from \"./view/ListView\";\r\nimport { Cloneable } from \"../util/interface/Cloneable\";\r\nimport { Collection, Element } from \"./Collection\";\r\nimport { Objects } from \"../util/Objects\";\r\n/**\r\n * Resizable-array implementation of the List interface. Implements all optional list operations, and permits all elements, including null.\r\n * In addition to implementing the List interface, this class provides methods to manipulate the size of the array that is used internally to store the list.\r\n */\r\nexport class ArrayList<T> extends AbstractList<T> implements Cloneable {\r\n  private readonly _elems: Element<T>[] = [];\r\n  private _size: number = 0;\r\n\r\n  /**\r\n   * Constructs an empty list with the specified initial capacity (as number), or\r\n   * constructs a list containing the elements of the specified collection, in the order\r\n   * they are returned by the collection's iterator\r\n   * @param capacityOrCollection\r\n   */\r\n  constructor(capacityOrCollection?: Collection<T>|Array<T>|number) {\r\n    super();\r\n    capacityOrCollection = capacityOrCollection ?? 10;\r\n    if (Objects.isNumber(capacityOrCollection)) {\r\n      this._elems = new Array<Element<T>>(Math.max(capacityOrCollection, 0)).fill(null);\r\n    } else {\r\n      const collection = capacityOrCollection;\r\n      this._elems = new Array<Element<T>>(Math.max(collection.length, 0)).fill(null);\r\n      this.appendAll(collection);\r\n      this._modCount = 0;\r\n    }\r\n  }\r\n\r\n  private _checkRange(index: number): void {\r\n    if (index >= 0 && index < this.length) {\r\n      // OK!\r\n    } else\r\n      throw new IndexOutOfBoundsException(`Index '${index}' is out of range`)\r\n  }\r\n\r\n  override *[Symbol.iterator](): IterableIterator<Element<T>> {\r\n    for (const elem of this._elems) {\r\n      yield elem;\r\n    }\r\n  }\r\n\r\n  override [Symbol.toStringTag] = \"ArrayList\";\r\n\r\n  override get size(): number { return this._size }\r\n\r\n  override append(value: Element<T>): boolean {\r\n    this.ensureCapacity(this.length + 1); // Increments modCount!!\r\n    this._elems[this._size++] = value;\r\n    return true;\r\n  }\r\n\r\n  override clear(): void {\r\n    this._modCount++;\r\n    this._elems.fill(null);\r\n    this._size = 0;\r\n  }\r\n\r\n  clone(): ArrayList<T> {\r\n    const aList = new ArrayList<T>(this.size);\r\n    aList.appendAll(this);\r\n    return aList;\r\n  }\r\n\r\n  override contains(value: Element<T>): boolean {\r\n    return this.indexOf(value) >= 0;\r\n  }\r\n  /**\r\n   * @throws IndexOutOfBoundsException\r\n   */\r\n  override get(index: number): Element<T> | undefined {\r\n    this._checkRange(index);\r\n    return this._elems[index];\r\n  }\r\n  /**\r\n   * @throws UnsupportedOperationException\r\n   */\r\n  override getNode(index: number): Readonly<LinkedListNode<T>> | null {\r\n    throw new UnsupportedOperationException(\"Unsupported operation\");\r\n  }\r\n\r\n  override indexOf(value: Element<T>, fromIndex: number = 0): number {\r\n    fromIndex = Math.max(fromIndex, 0);\r\n    const nLen = this.length;\r\n    for (let i = 0; i < nLen; i++) {\r\n      if (this._elems[i] === value) {\r\n        return i;\r\n      }\r\n    }\r\n    return -1;\r\n  }\r\n\r\n  override insert(index: number, value: Element<T>): boolean {\r\n    this._checkRange(index);\r\n    this.ensureCapacity(this.length + 1);\r\n    this._size++;\r\n    this._elems.splice(index, 0, value);\r\n    return true;\r\n  }\r\n\r\n  override lastIndexOf(value: Element<T>, fromIndex: number = 0): number {\r\n    fromIndex = Math.max(fromIndex, 0);\r\n    const nLen = this.length;\r\n    for (let i = nLen - 1; i >= 0; i--) {\r\n      if (this._elems[i] === value) {\r\n        return i;\r\n      }\r\n    }\r\n    return -1;\r\n  }\r\n\r\n  override remove(value: Element<T>): boolean {\r\n    let i = -1;\r\n    let nLen = this.length;\r\n    while (++i < nLen) {\r\n      if (this._elems[i] === value) {\r\n        this._modCount++;\r\n        this._elems.splice(i, 1);\r\n        this._elems[--this._size] = null; // Let gc do its work\r\n        return true;\r\n      }\r\n    }\r\n    return false;\r\n  }\r\n\r\n  override removeAt(index: number): Element<T> | undefined {\r\n    this._checkRange(index);\r\n\r\n    this._modCount++;\r\n    const oldValue = this._elems[index];\r\n    this._elems.splice(index, 1);\r\n    this._elems[--this._size] = null; // Let gc do its work\r\n\r\n    return oldValue;\r\n  }\r\n\r\n  override removeRange(fromIndex: number, toIndex?: number): boolean {\r\n    this._checkRange(fromIndex);\r\n    toIndex = toIndex ?? this.length;\r\n    const lastIndex = Math.min(toIndex, this.length);\r\n    if (lastIndex > fromIndex) {\r\n      this._modCount++;\r\n      const oldLen = this._elems.length;\r\n      const delCount = lastIndex - fromIndex;\r\n      this._elems.splice(fromIndex, delCount);\r\n      this._size -= delCount;\r\n      this._elems.length = oldLen;\r\n      this._elems.fill(null, this._size);\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  override set(index: number, value: Element<T>): Element<T> | undefined {\r\n    this._checkRange(index);\r\n    const oldValue = this._elems[index];\r\n    this._elems[index] = value;\r\n    this._modCount++;\r\n    return oldValue;\r\n  }\r\n\r\n  override subList(fromIndex: number, toIndex: number): List<T> {\r\n    return new ListView(this, fromIndex, toIndex);\r\n  }\r\n  /**\r\n   * Increases the capacity of this ArrayList instance, if necessary, to ensure that it can hold at least the number of elements specified by the minimum capacity argument\r\n   * @param minCapacity The desired minimum capacity\r\n   */\r\n  ensureCapacity(minCapacity: number): void {\r\n    const oldCapacity = this._elems.length;\r\n    if (minCapacity > oldCapacity) {\r\n      let newCapacity = Math.ceil((oldCapacity * 3) / 2 + 1);\r\n      if (newCapacity < minCapacity)\r\n        newCapacity = minCapacity;\r\n      this._elems.length = newCapacity;\r\n      this._elems.fill(null, this.length);\r\n      this._modCount++;\r\n    }\r\n  }\r\n  /**\r\n   * Trims the capacity of this ArrayList instance to be the list's current size\r\n   */\r\n  trimToSize(): void {\r\n    const oldCap = this._elems.length;\r\n    if (this.size < oldCap) {\r\n      this._elems.length = this.size;\r\n      this._modCount++;\r\n    }\r\n  }\r\n\r\n  override toArray(): Element<T>[] {\r\n    return this._elems.slice(0, this.size);\r\n  }\r\n}\r\n"]}