@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
JavaScript
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"]}