@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
81 lines • 14 kB
JavaScript
import { AbstractCollection } from "./AbstractCollection";
/**
* This class provides a skeletal implementation of the `List` interface to minimize the effort required to implement this interface backed by a "random access" data store (such as an _array_).
*/
export class AbstractList extends AbstractCollection {
constructor() {
super(...arguments);
this._modCount = 0;
}
/** Modification counter. Must be overridden in the subclasses that implement `subList` method */
get modCount() { return this._modCount; }
/**
* Tests whether all elements in the list pass the test implemented by the provided function
* @param callbackFn The function is called
* @returns {boolean} _true_ if the `callbackFn` function returns a _truthy_ value for every list element. Otherwise, _false_.
*/
every(callbackFn) {
if (this.size > 0) {
let i = -1;
for (const elem of this) {
if (!callbackFn(elem, ++i, this)) {
return false;
}
}
return true;
}
return false;
}
/**
* Creates an array as a shallow copy of a portion of the current list, filtered down to just the elements from the current list that pass the test implemented by the provided function
* @param predicate A predicate function, to test each element of the list. Return a value that coerces to _true_ to keep the element, or to _false_ otherwise.
* @returns An array of a portion of the given list, filtered down to just the elements from the given list that pass the test implemented by the provided function. If no elements pass the test, an empty array will be returned.
*/
filter(predicate) {
let arr = [];
if (this.size > 0) {
for (const elem of this) {
if (predicate(elem)) {
arr.push(elem);
}
}
}
return arr;
}
/**
* Gets the parent list of the current list `view` object
*/
getParent() { return null; }
/**
* Gets the range of the `from` and `to` indexes related to the `view`'s parent list (if any)
* @returns
*/
getParentRange() { return [0, 0]; }
/**
* Tests whether all elements in the list pass the test implemented by the provided function
* @param callbackFn A function to test for each element
* @returns {boolean} _true_ if the `callbackFn` function returns a _truthy_ value for at least one element in the list. Otherwise, _false_.
*/
some(callbackFn) {
let i = -1;
for (const elem of this) {
if (callbackFn(elem, ++i, this)) {
return true;
}
}
return false;
}
/**
* Sorts this list according to the order induced by the specified `Compare` function
* @param compare The `Compare` function used to compare list elements. A _undefined_ value indicates that the elements' natural ordering should be used
*/
sort(compare) {
const arr = this.toArray();
const nLen = arr.length;
arr.sort(compare);
for (let i = 0; i < nLen; i++) {
this.set(i, arr[i]);
}
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AbstractList.js","sourceRoot":"","sources":["../../../../../projects/cute-core/src/lib/collections/AbstractList.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,kBAAkB,EAAC,MAAM,sBAAsB,CAAC;AAKzD;;GAEG;AACH,MAAM,OAAgB,YAAgB,SAAQ,kBAAqB;IAAnE;;QACY,cAAS,GAAW,CAAC,CAAC;IAiIlC,CAAC;IA/HC,iGAAiG;IACjG,IAAI,QAAQ,KAAa,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IACjD;;;;OAIG;IACH,KAAK,CAAC,UAAwE;QAC5E,IAAI,IAAI,CAAC,IAAI,GAAG,CAAC,EAAE;YACjB,IAAI,CAAC,GAAW,CAAC,CAAC,CAAC;YACnB,KAAK,MAAM,IAAI,IAAI,IAAI,EAAE;gBACvB,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE;oBAChC,OAAO,KAAK,CAAC;iBACd;aACF;YACD,OAAO,IAAI,CAAC;SACb;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IACD;;;;OAIG;IACH,MAAM,CAAC,SAAgC;QACrC,IAAI,GAAG,GAAiB,EAAE,CAAC;QAC3B,IAAI,IAAI,CAAC,IAAI,GAAG,CAAC,EAAE;YACjB,KAAK,MAAM,IAAI,IAAI,IAAI,EAAE;gBACvB,IAAI,SAAS,CAAC,IAAI,CAAC,EAAE;oBACnB,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iBAChB;aACF;SACF;QACD,OAAO,GAAG,CAAC;IACb,CAAC;IAYD;;OAEG;IACH,SAAS,KAA6B,OAAO,IAAI,CAAA,CAAC,CAAC;IACnD;;;OAGG;IACH,cAAc,KAAuB,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAuCrD;;;;OAIG;IACH,IAAI,CAAC,UAAwE;QAC3E,IAAI,CAAC,GAAW,CAAC,CAAC,CAAC;QACnB,KAAK,MAAM,IAAI,IAAI,IAAI,EAAE;YACvB,IAAI,UAAU,CAAC,IAAI,EAAE,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE;gBAC/B,OAAO,IAAI,CAAC;aACb;SACF;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IACD;;;OAGG;IACH,IAAI,CAAC,OAA6B;QAChC,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;QAC3B,MAAM,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC;QACxB,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAClB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;YAC7B,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;SACrB;IACH,CAAC;CASF","sourcesContent":["import { Compare } from \"../util/function/Compare\";\r\nimport { Predicate } from \"../util/function/Predicate\";\r\nimport { AbstractCollection} from \"./AbstractCollection\";\r\nimport { Element } from \"./Collection\";\r\nimport { LinkedListNode } from \"./LinkedList\";\r\nimport { List } from \"./List\";\r\n\r\n/**\r\n * This class provides a skeletal implementation of the `List` interface to minimize the effort required to implement this interface backed by a \"random access\" data store (such as an _array_).\r\n */\r\nexport abstract class AbstractList<T> extends AbstractCollection<T> implements List<T> {\r\n  protected _modCount: number = 0;\r\n\r\n  /** Modification counter. Must be overridden in the subclasses that implement `subList` method */\r\n  get modCount(): number { return this._modCount; }\r\n  /**\r\n   * Tests whether all elements in the list pass the test implemented by the provided function\r\n   * @param callbackFn The function is called\r\n   * @returns {boolean} _true_ if the `callbackFn` function returns a _truthy_ value for every list element. Otherwise, _false_.\r\n   */\r\n  every(callbackFn: (value: Element<T>, index: number, list: List<T>) => boolean): boolean {\r\n    if (this.size > 0) {\r\n      let i: number = -1;\r\n      for (const elem of this) {\r\n        if (!callbackFn(elem, ++i, this)) {\r\n          return false;\r\n        }\r\n      }\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n  /**\r\n   * Creates an array as a shallow copy of a portion of the current list, filtered down to just the elements from the current list that pass the test implemented by the provided function\r\n   * @param predicate A predicate function, to test each element of the list. Return a value that coerces to _true_ to keep the element, or to _false_ otherwise.\r\n   * @returns An array of a portion of the given list, filtered down to just the elements from the given list that pass the test implemented by the provided function. If no elements pass the test, an empty array will be returned.\r\n   */\r\n  filter(predicate: Predicate<Element<T>>): Array<Element<T>> {\r\n    let arr: Element<T>[] = [];\r\n    if (this.size > 0) {\r\n      for (const elem of this) {\r\n        if (predicate(elem)) {\r\n          arr.push(elem);\r\n        }\r\n      }\r\n    }\r\n    return arr;\r\n  }\r\n  /**\r\n   * Returns the element at the specified position in this list\r\n   * @param index\r\n   */\r\n  abstract get(index: number): Element<T> | undefined;\r\n  /**\r\n   * Gets read only node's object by its index\r\n   * @param index\r\n   * @private\r\n   */\r\n  abstract getNode(index: number): Readonly<LinkedListNode<T>> | null;\r\n  /**\r\n   * Gets the parent list of the current list `view` object\r\n   */\r\n  getParent(): AbstractList<T> | null { return null }\r\n  /**\r\n   * Gets the range of the `from` and `to` indexes related to the `view`'s parent list (if any)\r\n   * @returns\r\n   */\r\n  getParentRange(): [number, number] { return [0, 0]; }\r\n  /**\r\n  * Returns the index of the first occurrence of the specified element in this list, or -1 if this list does not contain the element\r\n  * @param value\r\n  * @param fromIndex\r\n  */\r\n  abstract indexOf(value: Element<T>, fromIndex?: number): number;\r\n  /**\r\n  * Inserts the specified element at the specified position in this list\r\n  * @param index\r\n  * @param value\r\n  */\r\n  abstract insert(index: number, value: Element<T>): boolean;\r\n  /**\r\n   * Returns the index of the last occurrence of the specified element in this list, or -1 if this list does not contain the element\r\n   * @param value\r\n   * @param fromIndex\r\n   */\r\n  abstract lastIndexOf(value: Element<T>, fromIndex?: number): number;\r\n  /**\r\n   * Removes the element at the specified position in this list\r\n   * @param index The index of the element to be removed\r\n   * @returns The element previously at the specified position\r\n   */\r\n  abstract removeAt(index: number): Element<T> | undefined;\r\n  /**\r\n   * Removes from this list all of the elements whose index is between `fromIndex`, inclusive, and `toIndex`, exclusive\r\n   * @param fromIndex Index of first element to be removed\r\n   * @param toIndex Index after last element to be removed\r\n   * @returns _true_ if the list is changed, else _false_\r\n   */\r\n  abstract removeRange(fromIndex: number, toIndex?: number): boolean;\r\n  /**\r\n   * Replaces the element at the specified position in this list with the specified element\r\n   * @param index Index of the element to replace\r\n   * @param value Element to be stored at the specified position\r\n   * @returns The element previously at the specified position\r\n   */\r\n  abstract set(index: number, value: Element<T>): Element<T> | undefined;\r\n  /**\r\n   * Tests whether all elements in the list pass the test implemented by the provided function\r\n   * @param callbackFn A function to test for each element\r\n   * @returns {boolean} _true_ if the `callbackFn` function returns a _truthy_ value for at least one element in the list. Otherwise, _false_.\r\n   */\r\n  some(callbackFn: (value: Element<T>, index: number, list: List<T>) => boolean): boolean {\r\n    let i: number = -1;\r\n    for (const elem of this) {\r\n      if (callbackFn(elem, ++i, this)) {\r\n        return true;\r\n      }\r\n    }\r\n    return false;\r\n  }\r\n  /**\r\n   * Sorts this list according to the order induced by the specified `Compare` function\r\n   * @param compare The `Compare` function used to compare list elements. A _undefined_ value indicates that the elements' natural ordering should be used\r\n   */\r\n  sort(compare?: Compare<Element<T>>): void {\r\n    const arr = this.toArray();\r\n    const nLen = arr.length;\r\n    arr.sort(compare);\r\n    for (let i = 0; i < nLen; i++) {\r\n      this.set(i, arr[i]);\r\n    }\r\n  }\r\n  /**\r\n  * Returns a view of the portion of this list between the specified `fromIndex`, inclusive, and `toIndex`, exclusive.\r\n  * @param fromIndex Low endpoint (inclusive) of the subList\r\n  * @param toIndex High endpoint (exclusive) of the subList\r\n  * @returns A view of the specified range within this list\r\n  */\r\n  abstract subList(fromIndex: number, toIndex: number): List<T>;\r\n\r\n}\r\n"]}