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

190 lines 14.2 kB
var _a; import { AbstractSet } from "./AbstractSet"; import { TreeMap } from "./TreeMap"; /** * A `NavigableSet` implementation based on a `TreeMap`. The elements are ordered using their natural ordering, or * by a `Comparator` provided at set creation time, depending on which constructor is used. */ export class TreeSet extends AbstractSet { constructor(comparator) { super(); /** * @override */ this[_a] = "TreeSet"; this.tMap = new TreeMap(comparator); } /** * @override */ get size() { return this.tMap.size; } /** * Gets a key comparator */ get comparator() { return this.tMap.comparator; } /** * @override */ append(key) { return (this.tMap.put(key, null) !== undefined); } /** * @override */ appendAll(collection) { let nCount = 0; if (collection) { for (let el of collection) { if (el != null && this.append(el)) { nCount++; } } } return nCount > 0; } /** * @override */ clone() { const ts = new TreeSet(this.tMap.comparator); ts.appendAll(this); return ts; } /** * @override */ clear() { this.tMap.clear(); } /** * @override */ contains(key) { return this.tMap.has(key); } /** * Deletes the key/value pair from the collection. This method is the member of the JavaScript's `Set` interface. * @param key The key value to remove mapping * @returns _true_ if the mapping for the `key` was deleted, _false_ otherwise * @see {@link remove} */ delete(key) { return this.tMap.delete(key); } /** * @override */ *entries() { for (let key of this) { yield [key, key]; } } /** * @override */ forEach(callbackfn, thisArg) { for (let key of this) { callbackfn(key, key, this); } } /** * @override */ has(key) { return this.tMap.has(key); } /** * @override */ *keys() { yield* this.tMap.keys(); } /** * @override */ *values() { yield* this.tMap.keys(); } /** * @override * @see {@link delete} */ remove(key) { return this.tMap.remove(key) !== undefined; } /** * @override */ *[(_a = Symbol.toStringTag, Symbol.iterator)]() { for (let key of this.tMap.keys()) { yield key; } } /** * @override */ first() { return this.tMap.firstKey(); } /** * @override */ last() { return this.tMap.lastKey(); } /** * @override */ ceiling(key) { return this.tMap.ceilingKey(key); } /** * @override */ floor(key) { return this.tMap.floorKey(key); } /** * @override */ higher(key) { return this.tMap.higherKey(key); } /** * @override */ lower(key) { return this.tMap.lowerKey(key); } /** * @override */ pollFirst() { const key = this.first(); if (key !== undefined) { this.delete(key); } return key; } /** * @override */ pollLast() { const key = this.last(); if (key !== undefined) { this.delete(key); } return key; } /** * @override */ toArray() { return [...this.keys()]; } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"TreeSet.js","sourceRoot":"","sources":["../../../../../projects/cute-core/src/lib/collections/TreeSet.ts"],"names":[],"mappings":"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","sourcesContent":["import { Comparator } from \"../util/Comparator\";\r\nimport { Cloneable } from \"../util/interface/Cloneable\";\r\nimport { AbstractSet } from \"./AbstractSet\";\r\nimport { Collection } from \"./Collection\";\r\nimport { NavigableSet } from \"./NavigableSet\";\r\nimport { TreeMap } from \"./TreeMap\";\r\n\r\n/**\r\n * A `NavigableSet` implementation based on a `TreeMap`. The elements are ordered using their natural ordering, or\r\n * by a `Comparator` provided at set creation time, depending on which constructor is used.\r\n */\r\nexport class TreeSet<K> extends AbstractSet<K> implements NavigableSet<K>, Cloneable {\r\n  private tMap: TreeMap<K, null>;\r\n\r\n  constructor(comparator?: Comparator<K>) {\r\n    super();\r\n    this.tMap = new TreeMap<K, null>(comparator);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  get size(): number {\r\n    return this.tMap.size;\r\n  }\r\n  /**\r\n   * Gets a key comparator\r\n   */\r\n  get comparator(): Comparator<K> {\r\n    return this.tMap.comparator;\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  append(key: K): boolean {\r\n    return (this.tMap.put(key, null) !== undefined);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  appendAll<E extends K>(collection: Collection<E>): boolean {\r\n    let nCount = 0;\r\n    if (collection) {\r\n      for (let el of collection) {\r\n        if (el != null && this.append(el)) {\r\n          nCount++;\r\n        }\r\n      }\r\n    }\r\n    return nCount > 0;\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  clone(): TreeSet<K> {\r\n    const ts = new TreeSet<K>(this.tMap.comparator);\r\n    ts.appendAll(this);\r\n    return ts;\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  clear(): void {\r\n    this.tMap.clear();\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  contains(key: K): boolean {\r\n    return this.tMap.has(key);\r\n  }\r\n  /**\r\n   * Deletes the key/value pair from the collection. This method is the member of the JavaScript's `Set` interface.\r\n   * @param key The key value to remove mapping\r\n   * @returns _true_ if the mapping for the  `key` was deleted, _false_ otherwise\r\n   * @see {@link remove}\r\n   */\r\n  delete(key: K): boolean {\r\n    return this.tMap.delete(key);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  *entries(): IterableIterator<[K, K]> {\r\n    for (let key of this) {\r\n      yield [key, key];\r\n    }\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  forEach(callbackfn: (value: K, value2: K, set: Set<K>) => void, thisArg?: any): void {\r\n    for (let key of this) {\r\n      callbackfn(key, key, this);\r\n    }\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  has(key: K): boolean {\r\n    return this.tMap.has(key);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  *keys(): IterableIterator<K> {\r\n    yield* this.tMap.keys();\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  *values(): IterableIterator<K> {\r\n    yield* this.tMap.keys();\r\n  }\r\n  /**\r\n   * @override\r\n   * @see {@link delete}\r\n   */\r\n  remove(key: K): boolean {\r\n    return this.tMap.remove(key) !== undefined;\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  [Symbol.toStringTag]: string = \"TreeSet\";\r\n  /**\r\n   * @override\r\n   */\r\n  *[Symbol.iterator](): IterableIterator<K> {\r\n    for (let key of this.tMap.keys()) {\r\n      yield key;\r\n    }\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  first(): K | undefined {\r\n    return this.tMap.firstKey();\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  last(): K | undefined {\r\n    return this.tMap.lastKey();\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  ceiling(key: K): K | undefined {\r\n    return this.tMap.ceilingKey(key);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  floor(key: K): K | undefined {\r\n    return this.tMap.floorKey(key);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  higher(key: K): K | undefined {\r\n    return this.tMap.higherKey(key);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  lower(key: K): K | undefined {\r\n    return this.tMap.lowerKey(key);\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  pollFirst(): K | undefined {\r\n    const key = this.first();\r\n    if (key !== undefined) {\r\n      this.delete(key);\r\n    }\r\n    return key;\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  pollLast(): K | undefined {\r\n    const key = this.last();\r\n    if (key !== undefined) {\r\n      this.delete(key);\r\n    }\r\n    return key;\r\n  }\r\n  /**\r\n   * @override\r\n   */\r\n  toArray(): K[] {\r\n    return [...this.keys()];\r\n  }\r\n\r\n}\r\n"]}