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

261 lines 28.4 kB
var _a; import { ConcurrentModificationException } from "../../util/exception/ConcurrentModificationException"; import { AbstractList } from "../AbstractList"; /** * This class is denoted to work with a sub set of items in the parent collection */ export class ListView extends AbstractList { constructor(parent, fromIndex, toIndex) { super(); this._head = null; this._tail = null; this._ownerFromIndex = 0; this._ownerToIndex = 0; this._size = 0; this[_a] = "ListView"; this._parentFromIndex = Math.max(fromIndex, 0); this._parentToIndex = Math.min(toIndex, parent.size); this._ownerFromIndex = this._parentFromIndex; this._ownerToIndex = this._parentToIndex; this._parent = parent; this._owner = parent; let range; let p = parent; while (p) { this._owner = p; range = p.getParentRange(); this._ownerFromIndex += range[0]; p = p.getParent(); } this._ownerToIndex = this._ownerFromIndex + (toIndex - fromIndex); this._savedModCount = this._owner.modCount; if (this._parentFromIndex >= 0 && this._parentToIndex > 0 && this._parentFromIndex <= this._parentToIndex) { this._head = parent.getNode(this._parentFromIndex); this._tail = parent.getNode(this._parentToIndex - 1); if (this._head && this._tail) { this._size = 1; let node = this._head; while (node != this._tail) { this._size++; node = node.next; } } } } /** * @override */ get size() { return this._size; } /** * @private */ _checkModCount() { if (this._savedModCount != this._owner.modCount) { throw new ConcurrentModificationException(); } } *[Symbol.iterator]() { let nextNode; let isTail; let node = this._head; while (node) { nextNode = node.next; isTail = (node == this._tail); yield node.value; if (isTail) break; else node = nextNode; } } clone() { return new ListView(this._parent, this._parentFromIndex, this._parentToIndex); } /** * @override */ getNode(index) { return this._owner.getNode(this._ownerFromIndex + index); } /** * @override */ getParentRange() { return [this._parentFromIndex, this._parentToIndex]; } /** * @override */ getParent() { return this._parent; } /** * @override * @throws ConcurrentModificationException */ clear() { this._checkModCount(); if (this._owner.removeRange(this._ownerFromIndex, this._ownerToIndex)) { this._ownerToIndex = this._ownerFromIndex; this._head = this._tail = null; this._size = 0; this._savedModCount = this._owner.modCount; } } /** * @override * @throws ConcurrentModificationException */ get(index) { this._checkModCount(); return this._owner.get(this._ownerFromIndex + index); } /** * @override * @throws ConcurrentModificationException */ indexOf(value, fromIndex) { this._checkModCount(); return this._owner.indexOf(value, this._ownerFromIndex + (fromIndex ?? 0)); } /** * @override * @throws ConcurrentModificationException */ insert(index, value) { this._checkModCount(); if (this._owner.insert(this._ownerFromIndex + index, value)) { if (index == 0) { this._head = this._owner.getNode(this._ownerFromIndex); if (!this._tail) { this._tail = this._head; } } else if ((this._ownerFromIndex + index) > this._ownerToIndex) { this._tail = this._owner.getNode(this._ownerToIndex + 1); if (!this._head) { this._head = this._tail; } } this._size++; this._ownerToIndex++; this._savedModCount = this._owner.modCount; return true; } return false; } /** * @override * @throws ConcurrentModificationException */ lastIndexOf(value, fromIndex) { this._checkModCount(); return this._owner.lastIndexOf(value, this._ownerFromIndex + (fromIndex ?? 0)); } /** * @override */ removeRange(fromIndex, toIndex) { this._checkModCount(); return this._owner.removeRange(this._ownerFromIndex + fromIndex, this._ownerToIndex + (toIndex ?? this.size)); } /** * @override * @throws ConcurrentModificationException */ set(index, value) { this._checkModCount(); return this._owner.set(this._ownerFromIndex + index, value); } /** * @override * @throws ConcurrentModificationException */ subList(fromIndex, toIndex) { this._checkModCount(); return new ListView(this, fromIndex, toIndex); } /** * @override * @throws ConcurrentModificationException */ append(value) { this._checkModCount(); if (this._owner.insert(this._ownerToIndex, value)) { this._tail = this._owner.getNode(this._ownerToIndex); if (!this._head) this._head = this._tail; this._size++; return true; } return false; } /** * @override */ contains(value) { let node = this._head; while (node) { if (node.value === value) { return true; } if (node == this._tail) break; else node = node.next; } return false; } /** * @override */ toArray() { const vals = []; let currentNode = this._head; while (currentNode) { vals.push(currentNode.value); if (currentNode == this._tail) break; currentNode = currentNode.next; } return vals; } /** * @override * @throws ConcurrentModificationException */ remove(value) { const index = this.indexOf(value); if (index >= 0) { return (this.removeAt(index) !== undefined); } return false; } /** * @override * @throws ConcurrentModificationException */ removeAt(index) { this._checkModCount(); const node = this._owner.getNode(this._ownerFromIndex + index); let item = this._owner.removeAt(this._ownerFromIndex + index); if (!(item === undefined)) { if (this._head == this._tail && node == this._head) { this._head = this._tail = null; } else if (this._head && node == this._head) { this._head = this._head.next; } else if (this._tail && node == this._tail) { this._tail = this._tail.prev; } this._size--; this._ownerToIndex--; this._savedModCount = this._owner.modCount; return item; } return undefined; } } _a = Symbol.toStringTag; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ListView.js","sourceRoot":"","sources":["../../../../../../projects/cute-core/src/lib/collections/view/ListView.ts"],"names":[],"mappings":"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","sourcesContent":["import { ConcurrentModificationException } from \"../../util/exception/ConcurrentModificationException\";\r\nimport { Cloneable } from \"../../util/interface/Cloneable\";\r\nimport { AbstractList } from \"../AbstractList\";\r\nimport { Element } from \"../Collection\";\r\nimport { LinkedListNode } from \"../LinkedList\";\r\nimport { List } from \"../List\";\r\n/**\r\n * This class is denoted to work with a sub set of items in the parent collection\r\n */\r\nexport class ListView<T> extends AbstractList<T> implements Cloneable {\r\n  private _owner: AbstractList<T>;\r\n  private _parent: AbstractList<T>;\r\n  private _head: LinkedListNode<T> | null = null;\r\n  private _tail: LinkedListNode<T> | null = null;\r\n  private _savedModCount: number;\r\n  private _parentFromIndex: number;\r\n  private _parentToIndex: number;\r\n  private _ownerFromIndex: number = 0;\r\n  private _ownerToIndex: number = 0;\r\n  private _size: number = 0;\r\n\r\n  constructor(parent: AbstractList<T>, fromIndex: number, toIndex: number) {\r\n    super();\r\n    this._parentFromIndex = Math.max(fromIndex, 0);\r\n    this._parentToIndex = Math.min(toIndex, parent.size);\r\n    this._ownerFromIndex = this._parentFromIndex;\r\n    this._ownerToIndex = this._parentToIndex;\r\n    this._parent = parent;\r\n    this._owner = parent;\r\n\r\n    let range: [number, number];\r\n    let p: AbstractList<T> | null = parent;\r\n    while (p) {\r\n      this._owner = p;\r\n      range = p.getParentRange();\r\n      this._ownerFromIndex += range[0];\r\n      p = p.getParent();\r\n    }\r\n\r\n    this._ownerToIndex = this._ownerFromIndex + (toIndex - fromIndex);\r\n\r\n    this._savedModCount = this._owner.modCount;\r\n\r\n    if (this._parentFromIndex >= 0 && this._parentToIndex > 0 && this._parentFromIndex <= this._parentToIndex) {\r\n      this._head = parent.getNode(this._parentFromIndex);\r\n      this._tail = parent.getNode(this._parentToIndex - 1);\r\n\r\n      if (this._head && this._tail) {\r\n        this._size = 1;\r\n        let node: LinkedListNode<T>|null = this._head;\r\n        while(node != this._tail) {\r\n          this._size++;\r\n          node = node!.next;\r\n        }\r\n      }\r\n    }\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  get size(): number {return this._size}\r\n  /**\r\n   * @private\r\n   */\r\n  private _checkModCount() {\r\n    if (this._savedModCount != this._owner.modCount) {\r\n      throw new ConcurrentModificationException();\r\n    }\r\n  }\r\n\r\n  *[Symbol.iterator](): IterableIterator<Element<T>> {\r\n    let nextNode;\r\n    let isTail;\r\n    let node = this._head;\r\n    while (node) {\r\n      nextNode = node.next;\r\n      isTail = (node == this._tail);\r\n\r\n      yield node.value;\r\n\r\n      if (isTail)\r\n        break;\r\n      else\r\n        node = nextNode;\r\n    }\r\n  }\r\n\r\n  [Symbol.toStringTag] = \"ListView\";\r\n\r\n  clone(): ListView<T> {\r\n    return new ListView<T>(this._parent, this._parentFromIndex, this._parentToIndex);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  getNode(index: number): LinkedListNode<T> | null {\r\n    return this._owner.getNode(this._ownerFromIndex + index);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  getParentRange(): [number, number] {\r\n    return [this._parentFromIndex, this._parentToIndex];\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  getParent(): AbstractList<T> | null {\r\n    return this._parent;\r\n  }\r\n  /**\r\n   * @override\r\n   * @throws ConcurrentModificationException\r\n   */\r\n  clear(): void {\r\n    this._checkModCount();\r\n\r\n    if (this._owner.removeRange(this._ownerFromIndex, this._ownerToIndex)) {\r\n      this._ownerToIndex = this._ownerFromIndex;\r\n      this._head = this._tail = null;\r\n      this._size = 0;\r\n      this._savedModCount = this._owner.modCount;\r\n    }\r\n  }\r\n  /**\r\n   * @override\r\n   * @throws ConcurrentModificationException\r\n   */\r\n  get(index: number): Element<T> | undefined {\r\n    this._checkModCount();\r\n    return this._owner.get(this._ownerFromIndex + index);\r\n  }\r\n  /**\r\n   * @override\r\n   * @throws ConcurrentModificationException\r\n   */\r\n  indexOf(value: Element<T>, fromIndex?: number | undefined): number {\r\n    this._checkModCount();\r\n    return this._owner.indexOf(value, this._ownerFromIndex + (fromIndex ?? 0));\r\n  }\r\n  /**\r\n   * @override\r\n   * @throws ConcurrentModificationException\r\n   */\r\n  insert(index: number, value: Element<T>): boolean {\r\n    this._checkModCount();\r\n    if (this._owner.insert(this._ownerFromIndex + index, value)) {\r\n      if (index == 0) {\r\n        this._head = this._owner.getNode(this._ownerFromIndex);\r\n        if (!this._tail) {\r\n          this._tail = this._head;\r\n        }\r\n      } else if ((this._ownerFromIndex + index) > this._ownerToIndex) {\r\n        this._tail = this._owner.getNode(this._ownerToIndex + 1);\r\n        if (!this._head) {\r\n          this._head = this._tail;\r\n        }\r\n      }\r\n      this._size++;\r\n      this._ownerToIndex++;\r\n      this._savedModCount = this._owner.modCount;\r\n\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n  /**\r\n   * @override\r\n   * @throws ConcurrentModificationException\r\n   */\r\n  lastIndexOf(value: Element<T>, fromIndex?: number | undefined): number {\r\n    this._checkModCount();\r\n    return this._owner.lastIndexOf(value, this._ownerFromIndex + (fromIndex ?? 0));\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  removeRange(fromIndex: number, toIndex?: number | undefined): boolean {\r\n    this._checkModCount();\r\n    return this._owner.removeRange(this._ownerFromIndex+fromIndex, this._ownerToIndex+(toIndex ?? this.size) );\r\n  }\r\n  /**\r\n   * @override\r\n   * @throws ConcurrentModificationException\r\n   */\r\n  set(index: number, value: Element<T>): Element<T> | undefined {\r\n    this._checkModCount();\r\n    return this._owner.set(this._ownerFromIndex + index, value);\r\n  }\r\n  /**\r\n   * @override\r\n   * @throws ConcurrentModificationException\r\n   */\r\n  subList(fromIndex: number, toIndex: number): List<T> {\r\n    this._checkModCount();\r\n    return new ListView(this, fromIndex, toIndex);\r\n  }\r\n  /**\r\n   * @override\r\n   * @throws ConcurrentModificationException\r\n   */\r\n  append(value: Element<T>): boolean {\r\n    this._checkModCount();\r\n    if (this._owner.insert(this._ownerToIndex, value)) {\r\n      this._tail = this._owner.getNode(this._ownerToIndex);\r\n      if (!this._head)  this._head = this._tail;\r\n      this._size++;\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  contains(value: Element<T>): boolean {\r\n    let node = this._head;\r\n    while (node) {\r\n      if (node.value === value) {\r\n        return true;\r\n      }\r\n      if (node == this._tail)\r\n        break;\r\n      else\r\n        node = node.next;\r\n    }\r\n    return false;\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  toArray(): Element<T>[] {\r\n    const vals: Array<Element<T>> = [];\r\n\r\n    let currentNode = this._head;\r\n    while (currentNode) {\r\n      vals.push(currentNode.value);\r\n      if (currentNode == this._tail) break;\r\n      currentNode = currentNode.next;\r\n    }\r\n    return vals;\r\n  }\r\n  /**\r\n   * @override\r\n   * @throws ConcurrentModificationException\r\n   */\r\n  remove(value: Element<T>): boolean {\r\n    const index = this.indexOf(value);\r\n    if (index >= 0) {\r\n      return (this.removeAt(index)!==undefined);\r\n    }\r\n    return false;\r\n  }\r\n  /**\r\n   * @override\r\n   * @throws ConcurrentModificationException\r\n   */\r\n  removeAt(index: number): Element<T> | undefined {\r\n    this._checkModCount();\r\n    const node = this._owner.getNode(this._ownerFromIndex+index);\r\n    let item: Element<T>|undefined = this._owner.removeAt(this._ownerFromIndex+index);\r\n    if (!(item === undefined)) {\r\n      if (this._head==this._tail && node==this._head) {\r\n        this._head = this._tail = null;\r\n      } else if (this._head && node == this._head) {\r\n        this._head = this._head.next;\r\n      } else if (this._tail && node == this._tail) {\r\n        this._tail = this._tail.prev;\r\n      }\r\n      this._size--;\r\n      this._ownerToIndex--;\r\n      this._savedModCount = this._owner.modCount;\r\n\r\n      return item;\r\n    }\r\n    return undefined;\r\n  }\r\n\r\n}\r\n"]}