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

145 lines 12.6 kB
var _a; import { AbstractList } from "./AbstractList"; import { LinkedList } from "./LinkedList"; /** * The Vector class implements a growable array of objects. Like an array, it contains components that can be accessed using an integer index. */ export class Vector extends AbstractList { /* //++ Iterator implemetation protected get iteratorFirstItem$(): LinkedListNode<T> | null { return this._list.getHead() }; protected iteratorValue$(node: LinkedListNode<T>): T | null { return node.value; } protected iteratorIterate$(node: LinkedListNode<T>): LinkedListNode<T> | null { if (node && node != this._list.getTail()) { return node.next; } return null; } //-- */ *[Symbol.iterator]() { yield* this._list[Symbol.iterator](); } constructor(capacity = 0) { super(); this._list = new LinkedList(); this[_a] = "Vector"; if (capacity > 0) { this.loadArray(Array(capacity).fill(null)); } } /** * Returns the number of components in this vector */ get size() { return this._list.size; } clone() { const aVector = new Vector(this.size); aVector.appendAll(this); return aVector; } getNode(index) { return this._list.getNode(index); } /** * @override */ append(value) { return this._list.append(value); } /** * @override */ appendAll(collection) { return this._list.appendAll(collection); } /** * @override */ clear() { this._list.clear(); } /** * @override */ contains(value) { return this._list.contains(value); } /** * @override */ get(index) { return this._list.get(index); } /** * @override */ indexOf(value, fromIndex) { return this._list.indexOf(value, fromIndex); } /** * @override */ insert(index, value) { return this._list.insert(index, value); } /** * @override */ lastIndexOf(value, fromIndex) { return this._list.lastIndexOf(value, fromIndex); } /** * @override */ remove(value) { return this._list.remove(value); } /** * @override */ removeAll(collection) { return this._list.removeAll(collection); } /** * @override */ removeAt(index) { return this._list.removeAt(index); } /** * @override */ removeRange(fromIndex, toIndex) { return this._list.removeRange(fromIndex, toIndex); } /** * @override */ retainAll(collection) { return this._list.retainAll(collection); } /** * @override */ set(index, value) { return this._list.set(index, value); } /** * @override */ subList(fromIndex, toIndex) { return this._list.subList(fromIndex, toIndex); } /** * @override */ loadArray(values) { this._list.loadArray(values); } /** * @override */ toArray() { return this._list.toArray(); } } _a = Symbol.toStringTag; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Vector.js","sourceRoot":"","sources":["../../../../../projects/cute-core/src/lib/collections/Vector.ts"],"names":[],"mappings":"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","sourcesContent":["import { Cloneable } from \"../util/interface/Cloneable\";\r\nimport { AbstractList } from \"./AbstractList\";\r\nimport { Collection, Element } from \"./Collection\";\r\nimport { LinkedList, LinkedListNode } from \"./LinkedList\";\r\nimport { List } from \"./List\";\r\n\r\n/**\r\n * The Vector class implements a growable array of objects. Like an array, it contains components that can be accessed using an integer index.\r\n */\r\nexport class Vector<T> extends AbstractList<T> implements Cloneable {\r\n  protected _list: LinkedList<T> = new LinkedList();\r\n\r\n  /*\r\n  //++ Iterator implemetation\r\n  protected get iteratorFirstItem$(): LinkedListNode<T> | null { return this._list.getHead() };\r\n  protected iteratorValue$(node: LinkedListNode<T>): T | null { return node.value; }\r\n  protected iteratorIterate$(node: LinkedListNode<T>): LinkedListNode<T> | null {\r\n    if (node && node != this._list.getTail()) {\r\n      return node.next;\r\n    }\r\n    return null;\r\n  }\r\n  //--\r\n  */\r\n\r\n  *[Symbol.iterator](): IterableIterator<Element<T>> {\r\n    yield* this._list[Symbol.iterator]();\r\n  }\r\n\r\n  constructor(capacity: number = 0) {\r\n    super();\r\n    if (capacity > 0) {\r\n      this.loadArray(Array(capacity).fill(null));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Returns the number of components in this vector\r\n   */\r\n  get size(): number { return this._list.size; }\r\n\r\n  clone(): Vector<T> {\r\n    const aVector = new Vector<T>(this.size);\r\n    aVector.appendAll(this);\r\n    return aVector;\r\n  }\r\n\r\n  getNode(index: number): Readonly<LinkedListNode<T> | null> {\r\n    return this._list.getNode(index);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  append(value: Element<T>): boolean {\r\n    return this._list.append(value);\r\n  }\r\n  /**\r\n   *  @override\r\n   */\r\n  appendAll<E extends T>(collection: Collection<E>): boolean {\r\n    return this._list.appendAll(collection);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  clear(): void { this._list.clear(); }\r\n  /**\r\n   * @override\r\n   */\r\n  contains(value: Element<T>): boolean {\r\n    return this._list.contains(value);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  get(index: number): Element<T> | undefined {\r\n    return this._list.get(index);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  indexOf(value: Element<T>, fromIndex?: number | undefined): number {\r\n    return this._list.indexOf(value, fromIndex);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  insert(index: number, value: Element<T>): boolean {\r\n    return this._list.insert(index, value);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  lastIndexOf(value: Element<T>, fromIndex?: number | undefined): number {\r\n    return this._list.lastIndexOf(value, fromIndex);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  remove(value: Element<T>): boolean {\r\n    return this._list.remove(value);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  removeAll<E extends T>(collection: Collection<E>): boolean {\r\n    return this._list.removeAll(collection);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  removeAt(index: number): Element<T> | undefined {\r\n    return this._list.removeAt(index);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  removeRange(fromIndex: number, toIndex: number): boolean {\r\n    return this._list.removeRange(fromIndex, toIndex);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  retainAll<E extends T>(collection: Collection<E>): boolean {\r\n    return this._list.retainAll(collection);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  set(index: number, value: Element<T>): Element<T> | undefined {\r\n    return this._list.set(index, value);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  subList(fromIndex: number, toIndex: number): List<T> {\r\n    return this._list.subList(fromIndex, toIndex);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  loadArray<E extends T>(values: Array<Element<T>>): void {\r\n    this._list.loadArray(values);\r\n  }\r\n\r\n  /**\r\n   * @override\r\n   */\r\n  toArray(): Array<Element<T>> {\r\n    return this._list.toArray();\r\n  }\r\n\r\n  [Symbol.toStringTag] = \"Vector\";\r\n\r\n}\r\n"]}