structurae
Advanced tools
Comparing version 4.0.0-pre.10 to 4.0.0-pre.11
@@ -1,32 +0,10 @@ | ||
/** | ||
* Creates an Adjacency List class extending a given TypedArray class. | ||
* | ||
* @param Base a TypedArray class to extend | ||
*/ | ||
export function AdjacencyListMixin(Base) { | ||
/** | ||
* Implements the Adjacency List data structure for weighted directed graphs. | ||
*/ | ||
class AdjacencyList extends Base { | ||
// deno-lint-ignore no-explicit-any | ||
static directed = true; | ||
static weighted = true; | ||
vertices = 2; | ||
edges = 4; | ||
empty = undefined; | ||
constructor(...args) { | ||
super(...args); | ||
Object.defineProperty(this, "vertices", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: 2 | ||
}); | ||
Object.defineProperty(this, "edges", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: 4 | ||
}); | ||
Object.defineProperty(this, "empty", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: undefined | ||
}); | ||
[this.vertices, this.edges] = AdjacencyList.getDimensions(this); | ||
@@ -45,5 +23,2 @@ } | ||
} | ||
/* | ||
* Returns the dimensions, vertices and maximum edge count, of an existing AdjacencyList | ||
*/ | ||
static getDimensions(list) { | ||
@@ -60,11 +35,8 @@ let vertices = 0; | ||
} | ||
// TODO document RangeError | ||
addEdge(x, y, weight) { | ||
if (this.hasEdge(x, y)) | ||
return this; | ||
// the list is full | ||
if (this.isFull()) | ||
throw new RangeError("The list is full."); | ||
const { vertices } = this; | ||
// shift values | ||
for (let i = this[vertices]; i > this[x]; i -= 2) { | ||
@@ -78,6 +50,4 @@ [this[i], this[i + 1], this[i - 1], this[i - 2]] = [ | ||
} | ||
// set edge | ||
this[this[x]] = y; | ||
this[this[x] + 1] = weight; | ||
// update offsets | ||
for (let i = x + 1; i <= vertices; i++) { | ||
@@ -91,3 +61,2 @@ this[i] += 2; | ||
const nextOffset = this[x + 1]; | ||
// no out edges from x | ||
if (offset === nextOffset) | ||
@@ -132,3 +101,2 @@ return NaN; | ||
const nextOffset = this[x + 1]; | ||
// no out edges from x | ||
if (offset === nextOffset) | ||
@@ -143,6 +111,4 @@ return this; | ||
} | ||
// there is no such edge | ||
if (!edgeIndex) | ||
return this; | ||
// shift value | ||
for (let i = edgeIndex; i < this[this.vertices]; i += 2) { | ||
@@ -152,3 +118,2 @@ this[i] = this[i + 2]; | ||
} | ||
// update offsets | ||
for (let i = x + 1; i <= this.vertices; i++) { | ||
@@ -166,17 +131,5 @@ this[i] -= 2; | ||
} | ||
Object.defineProperty(AdjacencyList, "directed", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: true | ||
}); | ||
Object.defineProperty(AdjacencyList, "weighted", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: true | ||
}); | ||
return AdjacencyList; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRqYWNlbmN5LWxpc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJhZGphY2VuY3ktbGlzdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFZQSxNQUFNLFVBQVUsa0JBQWtCLENBQ2hDLElBQU87SUFRUCxNQUFNLGFBQWMsU0FBUSxJQUFJO1FBQzlCLE1BQU0sQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1FBQ3ZCLE1BQU0sQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1FBQ3ZCLFFBQVEsR0FBRyxDQUFDLENBQUM7UUFDYixLQUFLLEdBQUcsQ0FBQyxDQUFDO1FBQ1YsS0FBSyxHQUFHLFNBQVMsQ0FBQztRQUdsQixZQUFZLEdBQUcsSUFBVztZQUN4QixLQUFLLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQztZQUNmLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsYUFBYSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNsRSxDQUFDO1FBRUQsTUFBTSxLQUFLLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQztZQUN6QixPQUFPLElBQUksQ0FBQztRQUNkLENBQUM7UUFFRCxNQUFNLENBQUMsTUFBTSxDQUFDLFFBQWdCLEVBQUUsS0FBYTtZQUMzQyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsRUFBRSxLQUFLLENBQUMsQ0FBQztZQUMvQyxNQUFNLElBQUksR0FBRyxJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUM5QixJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztZQUN6QixJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztZQUNuQixJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDbEIsT0FBTyxJQUF1QyxDQUFDO1FBQ2pELENBQUM7UUFLRCxNQUFNLENBQUMsYUFBYSxDQUNsQixJQUF1QjtZQUV2QixJQUFJLFFBQVEsR0FBRyxDQUFDLENB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QUFDO0FBQ3ZCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIEFkamFjZW5jeVN0cnVjdHVyZSxcbiAgQWRqYWNlbmN5U3RydWN0dXJlQ29uc3RydWN0b3IsXG4gIEluZGV4ZWRDb2xsZWN0aW9uLFxuICBUeXBlZEFycmF5Q29uc3RydWN0b3JzLFxufSBmcm9tIFwiLi91dGlsaXR5LXR5cGVzLnRzXCI7XG5cbi8qKlxuICogQ3JlYXRlcyBhbiBBZGphY2VuY3kgTGlzdCBjbGFzcyBleHRlbmRpbmcgYSBnaXZlbiBUeXBlZEFycmF5IGNsYXNzLlxuICpcbiAqIEBwYXJhbSBCYXNlIGEgVHlwZWRBcnJheSBjbGFzcyB0byBleHRlbmRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIEFkamFjZW5jeUxpc3RNaXhpbjxVIGV4dGVuZHMgVHlwZWRBcnJheUNvbnN0cnVjdG9ycz4oXG4gIEJhc2U6IFUsXG4pOiBBZGphY2VuY3lTdHJ1Y3R1cmVDb25zdHJ1Y3RvcjxVPiB7XG4gIC8vIGRlbm8tbGludC1pZ25vcmUgbm8tZW1wdHktaW50ZXJmYWNlXG4gIGludGVyZmFjZSBBZGphY2VuY3lMaXN0IGV4dGVuZHMgSW5kZXhlZENvbGxlY3Rpb24ge31cblxuICAvKipcbiAgICogSW1wbGVtZW50cyB0aGUgQWRqYWNlbmN5IExpc3QgZGF0YSBzdHJ1Y3R1cmUgZm9yIHdlaWdodGVkIGRpcmVjdGVkIGdyYXBocy5cbiAgICovXG4gIGNsYXNzIEFkamFjZW5jeUxpc3QgZXh0ZW5kcyBCYXNlIGltcGxlbWVudHMgQWRqYWNlbmN5U3RydWN0dXJlIHtcbiAgICBzdGF0aWMgZGlyZWN0ZWQgPSB0cnVlO1xuICAgIHN0YXRpYyB3ZWlnaHRlZCA9IHRydWU7XG4gICAgdmVydGljZXMgPSAyO1xuICAgIGVkZ2VzID0gNDtcbiAgICBlbXB0eSA9IHVuZGVmaW5lZDtcblxuICAgIC8vIGRlbm8tbGludC1pZ25vcmUgbm8tZXhwbGljaXQtYW55XG4gICAgY29uc3RydWN0b3IoLi4uYXJnczogYW55W10pIHtcbiAgICAgIHN1cGVyKC4uLmFyZ3MpO1xuICAgICAgW3RoaXMudmVydGljZXMsIHRoaXMuZWRnZXNdID0gQWRqYWNlbmN5TGlzdC5nZXREaW1lbnNpb25zKHRoaXMpO1xuICAgIH1cblxuICAgIHN0YXRpYyBnZXQgW1N5bWJvbC5zcGVjaWVzXSgpOiBVIHtcbiAgICAgIHJldHVybiBCYXNlO1xuICAgIH1cblxuICAgIHN0YXRpYyBjcmVhdGUodmVydGljZXM6IG51bWJlciwgZWRnZXM6IG51bWJlcikge1xuICAgICAgY29uc3QgbGVuZ3RoID0gdGhpcy5nZXRMZW5ndGgodmVydGljZXMsIGVkZ2VzKTtcbiAgICAgIGNvbnN0IGxpc3QgPSBuZXcgdGhpcyhsZW5ndGgpO1xuICAgICAgbGlzdC52ZXJ0aWNlcyA9IHZlcnRpY2VzO1xuICAgICAgbGlzdC5lZGdlcyA9IGVkZ2VzO1xuICAgICAgbGlzdC5zZXRPZmZzZXRzKCk7XG4gICAgICByZXR1cm4gbGlzdCBhcyBBZGphY2VuY3lMaXN0ICYgSW5zdGFuY2VUeXBlPFU+O1xuICAgIH1cblxuICAgIC8qXG4gICAgKiBSZXR1cm5zIHRoZSBkaW1lbnNpb25zLCB2ZXJ0aWNlcyBhbmQgbWF4aW11bSBlZGdlIGNvdW50LCBvZiBhbiBleGlzdGluZyBBZGphY2VuY3lMaXN0XG4gICAgKi9cbiAgICBzdGF0aWMgZ2V0RGltZW5zaW9ucyhcbiAgICAgIGxpc3Q6IEluZGV4ZWRDb2xsZWN0aW9uLFxuICAgICk6IFt2ZXJ0aWNlczogbnVtYmVyLCBlZGdlczogbnVtYmVyXSB7XG4gICAgICBsZXQgdmVydGljZXMgPSAwO1xuICAgICAgd2hpbGUgKGxpc3RbdmVydGljZXNdIDw9IGxpc3RbdmVydGljZXMgKyAxXSkge1xuICAgICAgICB2ZXJ0aWNlcysrO1xuICAgICAgfVxuICAgICAgY29uc3QgZWRnZXMgPSAobGlzdC5sZW5ndGggLSB2ZXJ0aWNlcyAtIDEpID4+IDE7XG4gICAgICByZXR1cm4gW3ZlcnRpY2VzLCBlZGdlc107XG4gICAgfVxuXG4gICAgc3RhdGljIGdldExlbmd0aCh2ZXJ0aWNlczogbnVtYmVyLCBlZGdlczogbnVtYmVyKTogbnVtYmVyIHtcbiAgICAgIHJldHVybiB2ZXJ0aWNlcyArIChlZGdlcyA8PCAxKSArIDE7XG4gICAgfVxuXG4gICAgLy8gVE9ETyBkb2N1bWVudCBSYW5nZUVycm9yXG4gICAgYWRkRWRnZSh4OiBudW1iZXIsIHk6IG51bWJlciwgd2VpZ2h0OiBudW1iZXIpOiB0aGlzIHtcbiAgICAgIGlmICh0aGlzLmhhc0VkZ2UoeCwgeSkpIHJldHVybiB0aGlzO1xuICAgICAgLy8gdGhlIGxpc3QgaXMgZnVsbFxuICAgICAgaWYgKHRoaXMuaXNGdWxsKCkpIHRocm93IG5ldyBSYW5nZUVycm9yKFwiVGhlIGxpc3QgaXMgZnVsbC5cIik7XG4gICAgICBjb25zdCB7IHZlcnRpY2VzIH0gPSB0aGlzO1xuXG4gICAgICAvLyBzaGlmdCB2YWx1ZXNcbiAgICAgIGZvciAobGV0IGkgPSB0aGlzW3ZlcnRpY2VzXTsgaSA+IHRoaXNbeF07IGkgLT0gMikge1xuICAgICAgICBbdGhpc1tpXSwgdGhpc1tpICsgMV0sIHRoaXNbaSAtIDFdLCB0aGlzW2kgLSAyXV0gPSBbXG4gICAgICAgICAgdGhpc1tpIC0gMl0sXG4gICAgICAgICAgdGhpc1tpIC0gMV0sXG4gICAgICAgICAgdGhpc1tpXSxcbiAgICAgICAgICB0aGlzW2kgKyAxXSxcbiAgICAgICAgXTtcbiAgICAgIH1cbiAgICAgIC8vIHNldCBlZGdlXG4gICAgICB0aGlzW3RoaXNbeF1dID0geTtcbiAgICAgIHRoaXNbdGhpc1t4XSArIDFdID0gd2VpZ2h0O1xuXG4gICAgICAvLyB1cGRhdGUgb2Zmc2V0c1xuICAgICAgZm9yIChsZXQgaSA9IHggKyAxOyBpIDw9IHZlcnRpY2VzOyBpKyspIHtcbiAgICAgICAgdGhpc1tpXSArPSAyO1xuICAgICAgfVxuICAgICAgcmV0dXJuIHRoaXM7XG4gICAgfVxuXG4gICAgZ2V0RWRnZSh4OiBudW1iZXIsIHk6IG51bWJlcik6IG51bWJlciB7XG4gICAgICBjb25zdCBvZmZzZXQgPSB0aGlzW3hdO1xuICAgICAgY29uc3QgbmV4dE9mZnNldCA9IHRoaXNbeCArIDFdO1xuICAgICAgLy8gbm8gb3V0IGVkZ2VzIGZyb20geFxuICAgICAgaWYgKG9mZnNldCA9PT0gbmV4dE9mZnNldCkgcmV0dXJuIE5hTjtcbiAgICAgIGZvciAobGV0IGkgPSBvZmZzZXQ7IGkgPCBuZXh0T2Zmc2V0OyBpICs9IDIpIHtcbiAgICAgICAgaWYgKHRoaXNbaV0gPT09IHkpIHJldHVybiB0aGlzW2kgKyAxXTtcbiAgICAgIH1cbiAgICAgIHJldHVybiBOYU47XG4gICAgfVxuXG4gICAgaGFzRWRnZSh4OiBudW1iZXIsIHk6IG51bWJlcik6IGJvb2xlYW4ge1xuICAgICAgcmV0dXJuICFOdW1iZXIuaXNOYU4odGhpcy5nZXRFZGdlKHgsIHkpKTtcbiAgICB9XG5cbiAgICAqaW5FZGdlcyh2ZXJ0ZXg6IG51bWJlcikge1xuICAgICAgY29uc3QgeyB2ZXJ0aWNlcyB9ID0gdGhpcztcbiAgICAgIGxldCBlZGdlID0gMDtcbiAgICAgIGxldCBuZXh0VmVydGV4ID0gMTtcbiAgICAgIGZvciAobGV0IGkgPSB2ZXJ0aWNlcyArIDE7IGkgPCB0aGlzW3ZlcnRpY2VzXTsgaSArPSAyKSB7XG4gICAgICAgIHdoaWxlIChpID49IHRoaXNbbmV4dFZlcnRleF0pIHtcbiAgICAgICAgICBlZGdlKys7XG4gICAgICAgICAgbmV4dFZlcnRleCsrO1xuICAgICAgICB9XG4gICAgICAgIGlmICh0aGlzW2ldID09PSB2ZXJ0ZXgpIHlpZWxkIGVkZ2U7XG4gICAgICB9XG4gICAgfVxuXG4gICAgaXNGdWxsKCk6IGJvb2xlYW4ge1xuICAgICAgcmV0dXJuIHRoaXNbdGhpcy52ZXJ0aWNlc10gPj0gdGhpcy5sZW5ndGg7XG4gICAgfVxuXG4gICAgKm91dEVkZ2VzKHZlcnRleDogbnVtYmVyKSB7XG4gICAgICBjb25zdCBvZmZzZXQgPSB0aGlzW3ZlcnRleF07XG4gICAgICBjb25zdCBuZXh0T2Zmc2V0ID0gdGhpc1t2ZXJ0ZXggKyAxXTtcbiAgICAgIGlmIChvZmZzZXQgIT09IG5leHRPZmZzZXQpIHtcbiAgICAgICAgZm9yIChsZXQgaSA9IG5leHRPZmZzZXQgLSAyOyBpID49IG9mZnNldDsgaSAtPSAyKSB7XG4gICAgICAgICAgeWllbGQgdGhpc1tpXTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIHJlbW92ZUVkZ2UoeDogbnVtYmVyLCB5OiBudW1iZXIpOiB0aGlzIHtcbiAgICAgIGNvbnN0IG9mZnNldCA9IHRoaXNbeF07XG4gICAgICBjb25zdCBuZXh0T2Zmc2V0ID0gdGhpc1t4ICsgMV07XG4gICAgICAvLyBubyBvdXQgZWRnZXMgZnJvbSB4XG4gICAgICBpZiAob2Zmc2V0ID09PSBuZXh0T2Zmc2V0KSByZXR1cm4gdGhpcztcbiAgICAgIGxldCBlZGdlSW5kZXggPSAwO1xuICAgICAgZm9yIChsZXQgaSA9IG9mZnNldDsgaSA8IG5leHRPZmZzZXQ7IGkgKz0gMikge1xuICAgICAgICBpZiAodGhpc1tpXSA9PT0geSkge1xuICAgICAgICAgIGVkZ2VJbmRleCA9IGk7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIC8vIHRoZXJlIGlzIG5vIHN1Y2ggZWRnZVxuICAgICAgaWYgKCFlZGdlSW5kZXgpIHJldHVybiB0aGlzO1xuICAgICAgLy8gc2hpZnQgdmFsdWVcbiAgICAgIGZvciAobGV0IGkgPSBlZGdlSW5kZXg7IGkgPCB0aGlzW3RoaXMudmVydGljZXNdOyBpICs9IDIpIHtcbiAgICAgICAgdGhpc1tpXSA9IHRoaXNbaSArIDJdO1xuICAgICAgICB0aGlzW2kgKyAxXSA9IHRoaXNbaSArIDNdO1xuICAgICAgfVxuXG4gICAgICAvLyB1cGRhdGUgb2Zmc2V0c1xuICAgICAgZm9yIChsZXQgaSA9IHggKyAxOyBpIDw9IHRoaXMudmVydGljZXM7IGkrKykge1xuICAgICAgICB0aGlzW2ldIC09IDI7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB0aGlzO1xuICAgIH1cblxuICAgIHNldE9mZnNldHMoKTogdm9pZCB7XG4gICAgICBjb25zdCBsYXN0RWxlbWVudCA9IHRoaXMudmVydGljZXMgKyAxO1xuICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCBsYXN0RWxlbWVudDsgaSsrKSB7XG4gICAgICAgIHRoaXNbaV0gPSBsYXN0RWxlbWVudDtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICByZXR1cm4gQWRqYWNlbmN5TGlzdDtcbn1cbiJdfQ== | ||
//# sourceMappingURL=adjacency-list.js.map |
import { getLog2 } from "./utilities.js"; | ||
/** | ||
* Implements the Adjacency Matrix structure for unweighted directed graphs. | ||
*/ | ||
export class AdjacencyMatrixUnweightedDirected extends Uint32Array { | ||
constructor() { | ||
super(...arguments); | ||
Object.defineProperty(this, "empty", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: 0 | ||
}); | ||
Object.defineProperty(this, "_size", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: 0 | ||
}); | ||
} | ||
static directed = true; | ||
static weighted = false; | ||
empty = 0; | ||
static get [Symbol.species]() { | ||
return Uint32Array; | ||
} | ||
_size = 0; | ||
get size() { | ||
@@ -97,15 +83,3 @@ return this._size || ((this._size = getLog2(this.vertices)), this._size); | ||
} | ||
Object.defineProperty(AdjacencyMatrixUnweightedDirected, "directed", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: true | ||
}); | ||
Object.defineProperty(AdjacencyMatrixUnweightedDirected, "weighted", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: false | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRqYWNlbmN5LW1hdHJpeC11bndlaWdodGVkLWRpcmVjdGVkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYWRqYWNlbmN5LW1hdHJpeC11bndlaWdodGVkLWRpcmVjdGVkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU1BLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUt6QyxNQUFNLE9BQU8saUNBQWtDLFNBQVEsV0FBVztJQUVoRSxNQUFNLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztJQUN2QixNQUFNLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQztJQUN4QixLQUFLLEdBQUcsQ0FBQyxDQUFDO0lBRVYsTUFBTSxLQUFLLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQztRQUN6QixPQUFPLFdBQVcsQ0FBQztJQUNyQixDQUFDO0lBRUQsS0FBSyxHQUFHLENBQUMsQ0FBQztJQUVWLElBQUksSUFBSTtRQUNOLE9BQU8sSUFBSSxDQUFDLEtBQUssSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzNFLENBQUM7SUFFRCxJQUFJLFFBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFRCxJQUFJLFFBQVEsQ0FBQyxLQUFhO1FBQ3hCLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQztRQUM5QixJQUFJLENBQUMsS0FBSyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM5QixDQUFDO0lBRUQsSUFBSSxLQUFLO1FBQ1AsT0FBTyxJQUFJLENBQUMsUUFBUSxJQUFJLENBQUMsQ0FBQztJQUM1QixDQUFDO0lBRUQsTUFBTSxDQUFDLE1BQU0sQ0FFRixRQUFn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Q0FBQyxHQUFHLFFBQVEsRUFBRSxDQUFDLEVBQUUsRUFBRTtZQUNqQyxJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztnQkFBRSxNQUFNLENBQUMsQ0FBQztTQUN0QztJQUNILENBQUM7SUFFRCxVQUFVLENBQUMsQ0FBUyxFQUFFLENBQVM7UUFDN0IsTUFBTSxDQUFDLE1BQU0sRUFBRSxRQUFRLENBQUMsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNyRCxJQUFJLE1BQU0sQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDO1lBQUUsT0FBTyxJQUFJLENBQUM7UUFDdEMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxJQUFJLFFBQVEsQ0FBQyxDQUFDO1FBQy9DLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHtcbiAgQWRqYWNlbmN5U3RydWN0dXJlLFxuICBBZGphY2VuY3lTdHJ1Y3R1cmVDb25zdHJ1Y3RvcixcbiAgQml0LFxuICBUeXBlZEFycmF5Q29uc3RydWN0b3JzLFxufSBmcm9tIFwiLi91dGlsaXR5LXR5cGVzLnRzXCI7XG5pbXBvcnQgeyBnZXRMb2cyIH0gZnJvbSBcIi4vdXRpbGl0aWVzLnRzXCI7XG5cbi8qKlxuICogSW1wbGVtZW50cyB0aGUgQWRqYWNlbmN5IE1hdHJpeCBzdHJ1Y3R1cmUgZm9yIHVud2VpZ2h0ZWQgZGlyZWN0ZWQgZ3JhcGhzLlxuICovXG5leHBvcnQgY2xhc3MgQWRqYWNlbmN5TWF0cml4VW53ZWlnaHRlZERpcmVjdGVkIGV4dGVuZHMgVWludDMyQXJyYXlcbiAgaW1wbGVtZW50cyBBZGphY2VuY3lTdHJ1Y3R1cmUge1xuICBzdGF0aWMgZGlyZWN0ZWQgPSB0cnVlO1xuICBzdGF0aWMgd2VpZ2h0ZWQgPSBmYWxzZTtcbiAgZW1wdHkgPSAwO1xuXG4gIHN0YXRpYyBnZXQgW1N5bWJvbC5zcGVjaWVzXSgpOiBVaW50MzJBcnJheUNvbnN0cnVjdG9yIHtcbiAgICByZXR1cm4gVWludDMyQXJyYXk7XG4gIH1cblxuICBfc2l6ZSA9IDA7XG5cbiAgZ2V0IHNpemUoKSB7XG4gICAgcmV0dXJuIHRoaXMuX3NpemUgfHwgKCh0aGlzLl9zaXplID0gZ2V0TG9nMih0aGlzLnZlcnRpY2VzKSksIHRoaXMuX3NpemUpO1xuICB9XG5cbiAgZ2V0IHZlcnRpY2VzKCkge1xuICAgIHJldHVybiB0aGlzW3RoaXMubGVuZ3RoIC0gMV07XG4gIH1cblxuICBzZXQgdmVydGljZXModmFsdWU6IG51bWJlcikge1xuICAgIHRoaXNbdGhpcy5sZW5ndGggLSAxXSA9IHZhbHVlO1xuICAgIHRoaXMuX3NpemUgPSBnZXRMb2cyKHZhbHVlKTtcbiAgfVxuXG4gIGdldCBlZGdlcygpIHtcbiAgICByZXR1cm4gdGhpcy52ZXJ0aWNlcyAqKiAyO1xuICB9XG5cbiAgc3RhdGljIGNyZWF0ZTxcbiAgICBUIGV4dGVuZHMgQWRqYWNlbmN5U3RydWN0dXJlQ29uc3RydWN0b3I8VHlwZWRBcnJheUNvbnN0cnVjdG9ycz4sXG4gID4odGhpczogVCwgdmVydGljZXM6IG51bWJlcik6IEluc3RhbmNlVHlwZTxUPiB7XG4gICAgY29uc3QgbGVuZ3RoID0gdGhpcy5nZXRMZW5ndGgodmVydGljZXMpO1xuICAgIGNvbnN0IG1hdHJpeCA9IG5ldyB0aGlzKGxlbmd0aCk7XG4gICAgbWF0cml4LnZlcnRpY2VzID0gdmVydGljZXM7XG4gICAgcmV0dXJuIG1hdHJpeCBhcyBJbnN0YW5jZVR5cGU8VD47XG4gIH1cblxuICBzdGF0aWMgZ2V0TGVuZ3RoKHZlcnRpY2VzOiBudW1iZXIpIHtcbiAgICByZXR1cm4gKCh2ZXJ0aWNlcyA8PCBnZXRMb2cyKHZlcnRpY2VzKSkgPj4gNSkgKyAyO1xuICB9XG5cbiAgYWRkRWRnZSh4OiBudW1iZXIsIHk6IG51bWJlcik6IHRoaXMge1xuICAgIGNvbnN0IFtidWNrZXQsIHBvc2l0aW9uXSA9IHRoaXMuZ2V0Q29vcmRpbmF0ZXMoeCwgeSk7XG4gICAgaWYgKE51bWJlci5pc05hTihidWNrZXQpKSByZXR1cm4gdGhpcztcbiAgICB0aGlzW2J1Y2tldF0gPSAodGhpc1tidWNrZXRdICYgfigxIDw8IHBvc2l0aW9uKSkgfCAoMSA8PCBwb3NpdGlvbik7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICBnZXRDb29yZGluYXRlcyh4OiBudW1iZXIsIHkgPSAxKTogW2J1Y2tldDogbnVtYmVyLCBwb3NpdGlvbjogbnVtYmVyXSB7XG4gICAgY29uc3QgaW5kZXggPSB0aGlzLmdldEluZGV4KHgsIHkpO1xuICAgIGNvbnN0IGJ1Y2tldCA9IGluZGV4ID4+IDU7XG4gICAgaWYgKGJ1Y2tldCA+PSB0aGlzLmxlbmd0aCAtIDEpIHJldHVybiBbTmFOLCBOYU5dO1xuICAgIHJldHVybiBbYnVja2V0LCBpbmRleCAtIChidWNrZXQgPDwgNSldO1xuICB9XG5cbiAgZ2V0RWRnZSh4OiBudW1iZXIsIHk6IG51bWJlcik6IG51bWJlciB7XG4gICAgY29uc3QgW2J1Y2tldCwgcG9zaXRpb25dID0gdGhpcy5nZXRDb29yZGluYXRlcyh4LCB5KTtcbiAgICBpZiAoTnVtYmVyLmlzTmFOKGJ1Y2tldCkpIHJldHVybiAwO1xuICAgIHJldHVybiAoKHRoaXNbYnVja2V0XSA+PiBwb3NpdGlvbikgJiAxKSBhcyBCaXQ7XG4gIH1cblxuICBnZXRJbmRleCh4OiBudW1iZXIsIHk6IG51bWJlcik6IG51bWJlciB7XG4gICAgcmV0dXJuICh4IDw8IHRoaXMuc2l6ZSkgKyB5O1xuICB9XG5cbiAgaGFzRWRnZSh4OiBudW1iZXIsIHk6IG51bWJlcik6IGJvb2xlYW4ge1xuICAgIHJldHVybiAhIXRoaXMuZ2V0RWRnZSh4LCB5KTtcbiAgfVxuXG4gICppbkVkZ2VzKHZlcnRleDogbnVtYmVyKSB7XG4gICAgY29uc3QgeyB2ZXJ0aWNlcyB9ID0gdGhpcztcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHZlcnRpY2VzOyBpKyspIHtcbiAgICAgIGlmICh0aGlzLmdldEVkZ2UoaSwgdmVydGV4KSkgeWllbGQgaTtcbiAgICB9XG4gIH1cblxuICBpc0Z1bGwoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgKm91dEVkZ2VzKHZlcnRleDogbnVtYmVyKSB7XG4gICAgY29uc3QgeyB2ZXJ0aWNlcyB9ID0gdGhpcztcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHZlcnRpY2VzOyBpKyspIHtcbiAgICAgIGlmICh0aGlzLmdldEVkZ2UodmVydGV4LCBpKSkgeWllbGQgaTtcbiAgICB9XG4gIH1cblxuICByZW1vdmVFZGdlKHg6IG51bWJlciwgeTogbnVtYmVyKTogdGhpcyB7XG4gICAgY29uc3QgW2J1Y2tldCwgcG9zaXRpb25dID0gdGhpcy5nZXRDb29yZGluYXRlcyh4LCB5KTtcbiAgICBpZiAoTnVtYmVyLmlzTmFOKGJ1Y2tldCkpIHJldHVybiB0aGlzO1xuICAgIHRoaXNbYnVja2V0XSA9IHRoaXNbYnVja2V0XSAmIH4oMSA8PCBwb3NpdGlvbik7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=adjacency-matrix-unweighted-directed.js.map |
import { AdjacencyMatrixUnweightedDirected } from "./adjacency-matrix-unweighted-directed.js"; | ||
/** | ||
* Implements the Adjacency Matrix data structure for unweighted undirected graphs. | ||
*/ | ||
export class AdjacencyMatrixUnweightedUndirected extends AdjacencyMatrixUnweightedDirected { | ||
static directed = false; | ||
static getLength(vertices) { | ||
@@ -13,9 +11,3 @@ return (((vertices + 1) * vertices) >> 6) + 2; | ||
} | ||
Object.defineProperty(AdjacencyMatrixUnweightedUndirected, "directed", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: false | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRqYWNlbmN5LW1hdHJpeC11bndlaWdodGVkLXVuZGlyZWN0ZWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJhZGphY2VuY3ktbWF0cml4LXVud2VpZ2h0ZWQtdW5kaXJlY3RlZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUs5RixNQUFNLE9BQU8sbUNBQ1gsU0FBUSxpQ0FBaUM7SUFDekMsTUFBTSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7SUFDeEIsTUFBTSxDQUFDLFNBQVMsQ0FBQyxRQUFnQjtRQUMvQixPQUFPLENBQUMsQ0FBQyxDQUFDLFFBQVEsR0FBRyxDQUFDLENBQUMsR0FBRyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDaEQsQ0FBQztJQUNELFFBQVEsQ0FBQyxDQUFTLEVBQUUsQ0FBUztRQUMzQixPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7SUFDdEUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFkamFjZW5jeU1hdHJpeFVud2VpZ2h0ZWREaXJlY3RlZCB9IGZyb20gXCIuL2FkamFjZW5jeS1tYXRyaXgtdW53ZWlnaHRlZC1kaXJlY3RlZC50c1wiO1xuXG4vKipcbiAqIEltcGxlbWVudHMgdGhlIEFkamFjZW5jeSBNYXRyaXggZGF0YSBzdHJ1Y3R1cmUgZm9yIHVud2VpZ2h0ZWQgdW5kaXJlY3RlZCBncmFwaHMuXG4gKi9cbmV4cG9ydCBjbGFzcyBBZGphY2VuY3lNYXRyaXhVbndlaWdodGVkVW5kaXJlY3RlZFxuICBleHRlbmRzIEFkamFjZW5jeU1hdHJpeFVud2VpZ2h0ZWREaXJlY3RlZCB7XG4gIHN0YXRpYyBkaXJlY3RlZCA9IGZhbHNlO1xuICBzdGF0aWMgZ2V0TGVuZ3RoKHZlcnRpY2VzOiBudW1iZXIpOiBudW1iZXIge1xuICAgIHJldHVybiAoKCh2ZXJ0aWNlcyArIDEpICogdmVydGljZXMpID4+IDYpICsgMjtcbiAgfVxuICBnZXRJbmRleCh4OiBudW1iZXIsIHk6IG51bWJlcik6IG51bWJlciB7XG4gICAgcmV0dXJuIHggPj0geSA/IHkgKyAoKCh4ICsgMSkgKiB4KSA+PiAxKSA6IHggKyAoKCh5ICsgMSkgKiB5KSA+PiAxKTtcbiAgfVxufVxuIl19 | ||
//# sourceMappingURL=adjacency-matrix-unweighted-undirected.js.map |
@@ -1,29 +0,10 @@ | ||
/** | ||
* Creates an Adjacency Matrix class extending a given TypedArray class. | ||
* | ||
* @param Base a TypedArray class to extend | ||
*/ | ||
export function AdjacencyMatrixWeightedDirectedMixin(Base) { | ||
/** | ||
* Implements Adjacency Matrix for weighted directed graphs. | ||
*/ | ||
class AdjacencyMatrixWeightedDirected extends Base { | ||
constructor() { | ||
super(...arguments); | ||
Object.defineProperty(this, "empty", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: 0 | ||
}); | ||
Object.defineProperty(this, "_vertices", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: 0 | ||
}); | ||
} | ||
static directed = true; | ||
static weighted = true; | ||
empty = 0; | ||
static get [Symbol.species]() { | ||
return Base; | ||
} | ||
_vertices = 0; | ||
get vertices() { | ||
@@ -85,17 +66,5 @@ return (this._vertices || | ||
} | ||
Object.defineProperty(AdjacencyMatrixWeightedDirected, "directed", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: true | ||
}); | ||
Object.defineProperty(AdjacencyMatrixWeightedDirected, "weighted", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: true | ||
}); | ||
return AdjacencyMatrixWeightedDirected; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRqYWNlbmN5LW1hdHJpeC13ZWlnaHRlZC1kaXJlY3RlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImFkamFjZW5jeS1tYXRyaXgtd2VpZ2h0ZWQtZGlyZWN0ZWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWUEsTUFBTSxVQUFVLG9DQUFvQyxDQUVsRCxJQUFPO0lBTVAsTUFBTSwrQkFBZ0MsU0FBUSxJQUFJO1FBRWhELE1BQU0sQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1FBQ3ZCLE1BQU0sQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1FBQ3ZCLEtBQUssR0FBRyxDQUFDLENBQUM7UUFFVixNQUFNLEtBQUssQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDO1lBQ3pCLE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQztRQUVELFNBQVMsR0FBRyxDQUFDLENBQUM7UUFFZCxJQUFJLFFBQVE7WUFDVixPQUFPLENBQ0wsSUFBSSxDQUFDLFNBQVM7Z0JBQ2QsQ0FBQyxJQUFJLENBQUMsU0FBUyxHQUFJLElBQUk7cUJBQ3BCLFdBQXNELENBQUMsV0FBVyxDQUNqRSxJQUFJLENBQUMsTUFBTSxDQUNaLENBQUMsRUFBRSxJQUFJLENBQUMsU0FBUyxDQUNyQixDQUFDO1FBQ0osQ0FBQztRQUVELElBQUksS0FBSztZQUNQLE9BQU8sSUFBSSxDQUFDLFFBQVEsSUFBSSxDQUFDLENBQUM7UUFDNUIsQ0FBQztRQUVELE1BQU0sQ0FBQyxNQUFNLENBRVgsUUFBZ0I7WUFDaEIsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUN4QyxPQUFPLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBb0IsQ0FBQztRQUM3QyxDQUFDO1FBRUQsTUFBTSxDQUFDLFNBQVMsQ0FBQyxRQUFnQjtZQUMvQixPQUFPLFFBQVEsR0FBRyxRQUFRLENBQUM7UUFDN0IsQ0FBQztRQUVTLE1BQU0sQ0FBQyxXQUFXLENBQUMsTUFBYztZQUN6QyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDM0IsQ0FBQztRQUVELE9BQU8sQ0FBQyxDQUFTLEVBQUUsQ0FBUyxFQUFFLE1BQWM7WUFDMUMsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUcsTUFBTSxDQUFDO1lBQ25DLE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQztRQUVELE9BQU8sQ0FBQyxDQUFTLEVBQUUsQ0FBUztZQUMxQixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ25DLENBQUM7UUFFRCxRQUFRLENBQUMsQ0FBUyxFQUFFLENBQVM7WUFDM0IsT0FBTyxDQUFDLEdBQUcsSUFBSSxDQUFDLFFBQVEsR0FBRyxDQUFDLENBQUM7UUFDL0IsQ0FBQztRQUVELE9BQU8sQ0FBQyxDQUFTLEVBQUUsQ0FBUztZQUMxQixNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztZQUNoQyxPQUFPLElBQUksS0FBSyxTQUFTLElBQUksSUFBSSxLQUFLLElBQUksQ0FBQyxLQUFLLENBQUM7UUFDbkQsQ0FBQztRQUVELENBQUMsT0FBTyxDQUFDLE1BQWM7WUFDckIsTUFBTSxFQUFFLFFBQVEsRUFBRSxHQUFHLElBQUksQ0FBQztZQUMxQixLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsUUFBUSxFQUFFLENBQUMsRUFBRSxFQUFFO2dCQUNqQyxJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxFQUFFLE1BQU0sQ0FBQztvQkFBRSxNQUFNLENBQUMsQ0FBQzthQUN0QztRQUNILENBQUM7UUFFRCxNQUFNO1lBQ0osT0FBTyxLQUFLLENBQUM7UUFDZixDQUFDO1FBRUQsQ0FBQyxRQUFRLENBQUMsTUFBYztZQUN0QixNQUFNLEVBQUUsUUFBUSxFQUFFLEdBQUcsSUFBSSxDQUFDO1lBQzFCLE1BQU0sTUFBTSxHQUFHLE1BQU0sR0FBRyxRQUFRLENBQUM7WUFDakMsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLFFBQVEsRUFBRSxDQUFDLEVBQUUsRUFBRTtnQkFDakMsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQztnQkFDOUIsSUFBSSxJQUFJLEtBQUssU0FBUyxJQUFJLElBQUksS0FBSyxJQUFJLENBQUMsS0FBSztvQkFBRSxNQUFNLENBQUMsQ0FBQzthQUN4RDtRQUNILENBQUM7UUFFRCxVQUFVLENBQUMsQ0FBUyxFQUFFLENBQVM7WUFDN0IsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQztZQUN2QyxPQUFPLElBQUksQ0FBQztRQUNkLENBQUM7O0lBR0gsT0FBTywrQkFBK0IsQ0FBQztBQUN6QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1xuICBBZGphY2VuY3lTdHJ1Y3R1cmUsXG4gIEFkamFjZW5jeVN0cnVjdHVyZUNvbnN0cnVjdG9yLFxuICBJbmRleGVkQ29sbGVjdGlvbixcbiAgVHlwZWRBcnJheUNvbnN0cnVjdG9ycyxcbn0gZnJvbSBcIi4vdXRpbGl0eS10eXBlcy50c1wiO1xuXG4vKipcbiAqIENyZWF0ZXMgYW4gQWRqYWNlbmN5IE1hdHJpeCBjbGFzcyBleHRlbmRpbmcgYSBnaXZlbiBUeXBlZEFycmF5IGNsYXNzLlxuICpcbiAqIEBwYXJhbSBCYXNlIGEgVHlwZWRBcnJheSBjbGFzcyB0byBleHRlbmRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIEFkamFjZW5jeU1hdHJpeFdlaWdodGVkRGlyZWN0ZWRNaXhpbjxcbiAgVSBleHRlbmRzIFR5cGVkQXJyYXlDb25zdHJ1Y3RvcnMsXG4+KEJhc2U6IFUpOiBBZGphY2VuY3lTdHJ1Y3R1cmVDb25zdHJ1Y3RvcjxVPiB7XG4gIC8vIGRlbm8tbGludC1pZ25vcmUgbm8tZW1wdHktaW50ZXJmYWNlXG4gIGludGVyZmFjZSBBZGphY2VuY3lNYXRyaXhXZWlnaHRlZERpcmVjdGVkIGV4dGVuZHMgSW5kZXhlZENvbGxlY3Rpb24ge31cbiAgLyoqXG4gICAqIEltcGxlbWVudHMgQWRqYWNlbmN5IE1hdHJpeCBmb3Igd2VpZ2h0ZWQgZGlyZWN0ZWQgZ3JhcGhzLlxuICAgKi9cbiAgY2xhc3MgQWRqYWNlbmN5TWF0cml4V2VpZ2h0ZWREaXJlY3RlZCBleHRlbmRzIEJhc2VcbiAgICBpbXBsZW1lbnRzIEFkamFjZW5jeVN0cnVjdHVyZSB7XG4gICAgc3RhdGljIGRpcmVjdGVkID0gdHJ1ZTtcbiAgICBzdGF0aWMgd2VpZ2h0ZWQgPSB0cnVlO1xuICAgIGVtcHR5ID0gMDtcblxuICAgIHN0YXRpYyBnZXQgW1N5bWJvbC5zcGVjaWVzXSgpOiBVIHtcbiAgICAgIHJldHVybiBCYXNlO1xuICAgIH1cblxuICAgIF92ZXJ0aWNlcyA9IDA7XG5cbiAgICBnZXQgdmVydGljZXMoKSB7XG4gICAgICByZXR1cm4gKFxuICAgICAgICB0aGlzLl92ZXJ0aWNlcyB8fFxuICAgICAgICAodGhpcy5fdmVydGljZXMgPSAodGhpc1xuICAgICAgICAgIC5jb25zdHJ1Y3RvciBhcyB0eXBlb2YgQWRqYWNlbmN5TWF0cml4V2VpZ2h0ZWREaXJlY3RlZCkuZ2V0VmVydGljZXMoXG4gICAgICAgICAgICB0aGlzLmxlbmd0aCxcbiAgICAgICAgICApKSwgdGhpcy5fdmVydGljZXNcbiAgICAgICk7XG4gICAgfVxuXG4gICAgZ2V0IGVkZ2VzKCkge1xuICAgICAgcmV0dXJuIHRoaXMudmVydGljZXMgKiogMjtcbiAgICB9XG5cbiAgICBzdGF0aWMgY3JlYXRlPFxuICAgICAgVCBleHRlbmRzIEFkamFjZW5jeVN0cnVjdHVyZUNvbnN0cnVjdG9yPFR5cGVkQXJyYXlDb25zdHJ1Y3RvcnM+LFxuICAgID4odmVydGljZXM6IG51bWJlcik6IEluc3RhbmNlVHlwZTxUPiB7XG4gICAgICBjb25zdCBsZW5ndGggPSB0aGlzLmdldExlbmd0aCh2ZXJ0aWNlcyk7XG4gICAgICByZXR1cm4gbmV3IHRoaXMobGVuZ3RoKSBhcyBJbnN0YW5jZVR5cGU8VD47XG4gICAgfVxuXG4gICAgc3RhdGljIGdldExlbmd0aCh2ZXJ0aWNlczogbnVtYmVyKTogbnVtYmVyIHtcbiAgICAgIHJldHVybiB2ZXJ0aWNlcyAqIHZlcnRpY2VzO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBzdGF0aWMgZ2V0VmVydGljZXMobGVuZ3RoOiBudW1iZXIpOiBudW1iZXIge1xuICAgICAgcmV0dXJuIE1hdGguc3FydChsZW5ndGgpO1xuICAgIH1cblxuICAgIGFkZEVkZ2UoeDogbnVtYmVyLCB5OiBudW1iZXIsIHdlaWdodDogbnVtYmVyKTogdGhpcyB7XG4gICAgICB0aGlzW3RoaXMuZ2V0SW5kZXgoeCwgeSldID0gd2VpZ2h0O1xuICAgICAgcmV0dXJuIHRoaXM7XG4gICAgfVxuXG4gICAgZ2V0RWRnZSh4OiBudW1iZXIsIHk6IG51bWJlcikge1xuICAgICAgcmV0dXJuIHRoaXNbdGhpcy5nZXRJbmRleCh4LCB5KV07XG4gICAgfVxuXG4gICAgZ2V0SW5kZXgoeDogbnVtYmVyLCB5OiBudW1iZXIpOiBudW1iZXIge1xuICAgICAgcmV0dXJuIHggKiB0aGlzLnZlcnRpY2VzICsgeTtcbiAgICB9XG5cbiAgICBoYXNFZGdlKHg6IG51bWJlciwgeTogbnVtYmVyKSB7XG4gICAgICBjb25zdCBlZGdlID0gdGhpcy5nZXRFZGdlKHgsIHkpO1xuICAgICAgcmV0dXJuIGVkZ2UgIT09IHVuZGVmaW5lZCAmJiBlZGdlICE9PSB0aGlzLmVtcHR5O1xuICAgIH1cblxuICAgICppbkVkZ2VzKHZlcnRleDogbnVtYmVyKSB7XG4gICAgICBjb25zdCB7IHZlcnRpY2VzIH0gPSB0aGlzO1xuICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCB2ZXJ0aWNlczsgaSsrKSB7XG4gICAgICAgIGlmICh0aGlzLmhhc0VkZ2UoaSwgdmVydGV4KSkgeWllbGQgaTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBpc0Z1bGwoKTogYm9vbGVhbiB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuXG4gICAgKm91dEVkZ2VzKHZlcnRleDogbnVtYmVyKSB7XG4gICAgICBjb25zdCB7IHZlcnRpY2VzIH0gPSB0aGlzO1xuICAgICAgY29uc3Qgb2Zmc2V0ID0gdmVydGV4ICogdmVydGljZXM7XG4gICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHZlcnRpY2VzOyBpKyspIHtcbiAgICAgICAgY29uc3QgZWRnZSA9IHRoaXNbb2Zmc2V0ICsgaV07XG4gICAgICAgIGlmIChlZGdlICE9PSB1bmRlZmluZWQgJiYgZWRnZSAhPT0gdGhpcy5lbXB0eSkgeWllbGQgaTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICByZW1vdmVFZGdlKHg6IG51bWJlciwgeTogbnVtYmVyKTogdGhpcyB7XG4gICAgICB0aGlzW3RoaXMuZ2V0SW5kZXgoeCwgeSldID0gdGhpcy5lbXB0eTtcbiAgICAgIHJldHVybiB0aGlzO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBBZGphY2VuY3lNYXRyaXhXZWlnaHRlZERpcmVjdGVkO1xufVxuIl19 | ||
//# sourceMappingURL=adjacency-matrix-weighted-directed.js.map |
import { AdjacencyMatrixWeightedDirectedMixin } from "./adjacency-matrix-weighted-directed.js"; | ||
/** | ||
* Creates an Adjacency Matrix class extending a given TypedArray class. | ||
* | ||
* @param Base a TypedArray class to extend | ||
*/ | ||
export function AdjacencyMatrixWeightedUndirectedMixin(Base) { | ||
/** | ||
* Implements the Adjacency Matrix for weighted undirected graphs. | ||
*/ | ||
class AdjacencyMatrixWeightedUndirected extends AdjacencyMatrixWeightedDirectedMixin(Base) { | ||
static directed = false; | ||
static getLength(vertices, _) { | ||
@@ -22,16 +15,8 @@ return ((vertices + 1) * vertices) >> 1; | ||
outEdges(vertex) { | ||
// TODO: fix type casting | ||
return this.inEdges(vertex); | ||
} | ||
} | ||
Object.defineProperty(AdjacencyMatrixWeightedUndirected, "directed", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: false | ||
}); | ||
// TODO: fix type casting | ||
return AdjacencyMatrixWeightedUndirected; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRqYWNlbmN5LW1hdHJpeC13ZWlnaHRlZC11bmRpcmVjdGVkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYWRqYWNlbmN5LW1hdHJpeC13ZWlnaHRlZC11bmRpcmVjdGVkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUtBLE9BQU8sRUFBRSxvQ0FBb0MsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBTy9GLE1BQU0sVUFBVSxzQ0FBc0MsQ0FFcEQsSUFBTztJQUlQLE1BQU0saUNBQ0osU0FBUSxvQ0FBb0MsQ0FBQyxJQUFJLENBQUM7UUFDbEQsTUFBTSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7UUFFeEIsTUFBTSxDQUFDLFNBQVMsQ0FBQyxRQUFnQixFQUFFLENBQVU7WUFDM0MsT0FBTyxDQUFDLENBQUMsUUFBUSxHQUFHLENBQUMsQ0FBQyxHQUFHLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMxQyxDQUFDO1FBRVMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxNQUFjO1lBQ3pDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsTUFBTSxJQUFJLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNqRCxDQUFDO1FBRUQsUUFBUSxDQUFDLENBQVMsRUFBRSxDQUFTO1lBQzNCLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUN0RSxDQUFDO1FBRUQsUUFBUSxDQUFDLE1BQWM7WUFFckIsT0FBUSxJQUFzQyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNqRSxDQUFDOztJQUlILE9BQU8saUNBRU4sQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIEFkamFjZW5jeVN0cnVjdHVyZSxcbiAgQWRqYWNlbmN5U3RydWN0dXJlQ29uc3RydWN0b3IsXG4gIFR5cGVkQXJyYXlDb25zdHJ1Y3RvcnMsXG59IGZyb20gXCIuL3V0aWxpdHktdHlwZXMudHNcIjtcbmltcG9ydCB7IEFkamFjZW5jeU1hdHJpeFdlaWdodGVkRGlyZWN0ZWRNaXhpbiB9IGZyb20gXCIuL2FkamFjZW5jeS1tYXRyaXgtd2VpZ2h0ZWQtZGlyZWN0ZWQudHNcIjtcblxuLyoqXG4gKiBDcmVhdGVzIGFuIEFkamFjZW5jeSBNYXRyaXggY2xhc3MgZXh0ZW5kaW5nIGEgZ2l2ZW4gVHlwZWRBcnJheSBjbGFzcy5cbiAqXG4gKiBAcGFyYW0gQmFzZSBhIFR5cGVkQXJyYXkgY2xhc3MgdG8gZXh0ZW5kXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBBZGphY2VuY3lNYXRyaXhXZWlnaHRlZFVuZGlyZWN0ZWRNaXhpbjxcbiAgVSBleHRlbmRzIFR5cGVkQXJyYXlDb25zdHJ1Y3RvcnMsXG4+KEJhc2U6IFUpOiBBZGphY2VuY3lTdHJ1Y3R1cmVDb25zdHJ1Y3RvcjxVPiB7XG4gIC8qKlxuICAgKiBJbXBsZW1lbnRzIHRoZSBBZGphY2VuY3kgTWF0cml4IGZvciB3ZWlnaHRlZCB1bmRpcmVjdGVkIGdyYXBocy5cbiAgICovXG4gIGNsYXNzIEFkamFjZW5jeU1hdHJpeFdlaWdodGVkVW5kaXJlY3RlZFxuICAgIGV4dGVuZHMgQWRqYWNlbmN5TWF0cml4V2VpZ2h0ZWREaXJlY3RlZE1peGluKEJhc2UpIHtcbiAgICBzdGF0aWMgZGlyZWN0ZWQgPSBmYWxzZTtcblxuICAgIHN0YXRpYyBnZXRMZW5ndGgodmVydGljZXM6IG51bWJlciwgXz86IG51bWJlcik6IG51bWJlciB7XG4gICAgICByZXR1cm4gKCh2ZXJ0aWNlcyArIDEpICogdmVydGljZXMpID4+IDE7XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIHN0YXRpYyBnZXRWZXJ0aWNlcyhsZW5ndGg6IG51bWJlcik6IG51bWJlciB7XG4gICAgICByZXR1cm4gKE1hdGguc3FydCgobGVuZ3RoIDw8IDMpICsgMSkgLSAxKSA+PiAxO1xuICAgIH1cblxuICAgIGdldEluZGV4KHg6IG51bWJlciwgeTogbnVtYmVyKTogbnVtYmVyIHtcbiAgICAgIHJldHVybiB4ID49IHkgPyB5ICsgKCgoeCArIDEpICogeCkgPj4gMSkgOiB4ICsgKCgoeSArIDEpICogeSkgPj4gMSk7XG4gICAgfVxuXG4gICAgb3V0RWRnZXModmVydGV4OiBudW1iZXIpIHtcbiAgICAgIC8vIFRPRE86IGZpeCB0eXBlIGNhc3RpbmdcbiAgICAgIHJldHVybiAodGhpcyBhcyB1bmtub3duIGFzIEFkamFjZW5jeVN0cnVjdHVyZSkuaW5FZGdlcyh2ZXJ0ZXgpO1xuICAgIH1cbiAgfVxuXG4gIC8vIFRPRE86IGZpeCB0eXBlIGNhc3RpbmdcbiAgcmV0dXJuIEFkamFjZW5jeU1hdHJpeFdlaWdodGVkVW5kaXJlY3RlZCBhcyB1bmtub3duIGFzIEFkamFjZW5jeVN0cnVjdHVyZUNvbnN0cnVjdG9yPFxuICAgIFVcbiAgPjtcbn1cbiJdfQ== | ||
//# sourceMappingURL=adjacency-matrix-weighted-undirected.js.map |
@@ -13,2 +13,3 @@ import type { ComplexView, ContainerView, PrimitiveView, ViewConstructor, ViewInstance } from "./view-types"; | ||
static getSize(length: number): number; | ||
static indexOf<T>(value: T, view: DataView, startIndex?: number, startOffset?: number, length?: number): number; | ||
[Symbol.iterator](): Generator<ViewInstance<T>>; | ||
@@ -19,2 +20,3 @@ at(index: number): T; | ||
getView(index: number): ViewInstance<T>; | ||
indexOf(value: T, start?: number): number; | ||
set(index: number, value: T): void; | ||
@@ -21,0 +23,0 @@ setView(index: number, value: DataView): void; |
export class ArrayView extends DataView { | ||
static View; | ||
static viewLength = 0; | ||
static itemLength; | ||
get size() { | ||
@@ -27,2 +24,3 @@ return this.constructor.getSize(this.byteLength); | ||
const written = max * itemLength; | ||
// zero-out remaining bytes | ||
let caret = written; | ||
@@ -47,2 +45,15 @@ while (caret < length) | ||
} | ||
static indexOf(value, view, startIndex = 0, startOffset = 0, length = view.byteLength) { | ||
const size = this.getSize(length); | ||
const valueView = this.View.from(value); | ||
outer: for (let i = startIndex; i < size; i++) { | ||
const offset = startOffset + this.getOffset(i); | ||
for (let j = 0; j < valueView.byteLength; j++) { | ||
if (valueView.getUint8(j) !== view.getUint8(offset + j)) | ||
continue outer; | ||
} | ||
return i; | ||
} | ||
return -1; | ||
} | ||
*[Symbol.iterator]() { | ||
@@ -72,2 +83,5 @@ const { size } = this; | ||
} | ||
indexOf(value, start = 0) { | ||
return this.constructor.indexOf(value, this, start, 0, this.byteLength); | ||
} | ||
set(index, value) { | ||
@@ -86,3 +100,9 @@ const constructor = this.constructor; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJyYXktdmlldy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImFycmF5LXZpZXcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUUEsTUFBTSxPQUFPLFNBQWEsU0FBUSxRQUFRO0lBQ3hDLE1BQU0sQ0FBQyxJQUFJLENBR1Q7SUFDRixNQUFNLENBQUMsVUFBVSxHQUFHLENBQUMsQ0FBQztJQUN0QixNQUFNLENBQUMsVUFBVSxDQUFTO0lBRTFCLElBQUksSUFBSTtRQUNOLE9BQVEsSUFBSSxDQUFDLFdBQWdDLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUN6RSxDQUFDO0lBRUQsTUFBTSxDQUFDLE1BQU0sQ0FDWCxJQUFjLEVBQ2QsS0FBSyxHQUFHLENBQUMsRUFDVCxNQUFNLEdBQUcsSUFBSSxDQUFDLFVBQVU7UUFFeEIsTUFBTSxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUUsR0FBRyxJQUFJLENBQUM7UUFDbEMsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNsQyxNQUFNLEtBQUssR0FBRyxJQUFJLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUM5QixLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsSUFBSSxFQUFFLENBQUMsRUFBRSxFQUFFO1lBQzdCLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDakMsS0FBSyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLEtBQUssR0FBRyxNQUFNLEVBQUUsVUFBVSxDQUFDLENBQUM7U0FDMUQ7UUFDRCxPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7SUFFRCxNQUFNLENBQUMsTUFBTSxDQUNYLEtBQWUsRUFDZixJQUFjLEVBQ2QsS0FBSyxHQUFHLENBQUMsRUFDVCxNQUFNLEdBQUcsSUFBSSxDQUFDLFVBQVU7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Q2hCLENBQUM7SUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1xuICBDb21wbGV4VmlldyxcbiAgQ29udGFpbmVyVmlldyxcbiAgUHJpbWl0aXZlVmlldyxcbiAgVmlld0NvbnN0cnVjdG9yLFxuICBWaWV3SW5zdGFuY2UsXG59IGZyb20gXCIuL3ZpZXctdHlwZXMudHNcIjtcblxuZXhwb3J0IGNsYXNzIEFycmF5VmlldzxUPiBleHRlbmRzIERhdGFWaWV3IGltcGxlbWVudHMgQ29udGFpbmVyVmlldzxUPiB7XG4gIHN0YXRpYyBWaWV3OiBWaWV3Q29uc3RydWN0b3I8XG4gICAgdW5rbm93bixcbiAgICBQcmltaXRpdmVWaWV3PHVua25vd24+IHwgQ29udGFpbmVyVmlldzx1bmtub3duPiB8IENvbXBsZXhWaWV3PHVua25vd24+XG4gID47XG4gIHN0YXRpYyB2aWV3TGVuZ3RoID0gMDtcbiAgc3RhdGljIGl0ZW1MZW5ndGg6IG51bWJlcjtcblxuICBnZXQgc2l6ZSgpIHtcbiAgICByZXR1cm4gKHRoaXMuY29uc3RydWN0b3IgYXMgdHlwZW9mIEFycmF5VmlldykuZ2V0U2l6ZSh0aGlzLmJ5dGVMZW5ndGgpO1xuICB9XG5cbiAgc3RhdGljIGRlY29kZTxUPihcbiAgICB2aWV3OiBEYXRhVmlldyxcbiAgICBzdGFydCA9IDAsXG4gICAgbGVuZ3RoID0gdmlldy5ieXRlTGVuZ3RoLFxuICApOiBBcnJheTxUPiB7XG4gICAgY29uc3QgeyBWaWV3LCBpdGVtTGVuZ3RoIH0gPSB0aGlzO1xuICAgIGNvbnN0IHNpemUgPSB0aGlzLmdldFNpemUobGVuZ3RoKTtcbiAgICBjb25zdCBhcnJheSA9IG5ldyBBcnJheShzaXplKTtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHNpemU7IGkrKykge1xuICAgICAgY29uc3Qgb2Zmc2V0ID0gdGhpcy5nZXRPZmZzZXQoaSk7XG4gICAgICBhcnJheVtpXSA9IFZpZXcuZGVjb2RlKHZpZXcsIHN0YXJ0ICsgb2Zmc2V0LCBpdGVtTGVuZ3RoKTtcbiAgICB9XG4gICAgcmV0dXJuIGFycmF5O1xuICB9XG5cbiAgc3RhdGljIGVuY29kZTxUPihcbiAgICB2YWx1ZTogQXJyYXk8VD4sXG4gICAgdmlldzogRGF0YVZpZXcsXG4gICAgc3RhcnQgPSAwLFxuICAgIGxlbmd0aCA9IHZpZXcuYnl0ZUxlbmd0aCxcbiAgKTogbnVtYmVyIHtcbiAgICBjb25zdCB7IFZpZXcsIGl0ZW1MZW5ndGggfSA9IHRoaXM7XG4gICAgY29uc3Qgc2l6ZSA9IHRoaXMuZ2V0U2l6ZShsZW5ndGgpO1xuICAgIGNvbnN0IG1heCA9IHNpemUgPCB2YWx1ZS5sZW5ndGggPyBzaXplIDogdmFsdWUubGVuZ3RoO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgbWF4OyBpKyspIHtcbiAgICAgIGNvbnN0IG9mZnNldCA9IHRoaXMuZ2V0T2Zmc2V0KGkpO1xuICAgICAgVmlldy5lbmNvZGUodmFsdWVbaV0sIHZpZXcsIHN0YXJ0ICsgb2Zmc2V0LCBpdGVtTGVuZ3RoKTtcbiAgICB9XG4gICAgY29uc3Qgd3JpdHRlbiA9IG1heCAqIGl0ZW1MZW5ndGg7XG4gICAgLy8gemVyby1vdXQgcmVtYWluaW5nIGJ5dGVzXG4gICAgbGV0IGNhcmV0ID0gd3JpdHRlbjtcbiAgICB3aGlsZSAoY2FyZXQgPCBsZW5ndGgpIHZpZXcuc2V0VWludDgoc3RhcnQgKyBjYXJldCsrLCAwKTtcbiAgICByZXR1cm4gd3JpdHRlbjtcbiAgfVxuXG4gIHN0YXRpYyBmcm9tPFQsIFUgZXh0ZW5kcyBBcnJheVZpZXc8VD4+KHZhbHVlOiBBcnJheTxUPik6IFUge1xuICAgIGNvbnN0IHZpZXcgPSBuZXcgdGhpczxUPihuZXcgQXJyYXlCdWZmZXIodGhpcy5nZXRPZmZzZXQodmFsdWUubGVuZ3RoKSkpO1xuICAgIHRoaXMuZW5jb2RlPFQ+KHZhbHVlLCB2aWV3LCAwLCB2aWV3LmJ5dGVMZW5ndGgpO1xuICAgIHJldHVybiB2aWV3IGFzIFU7XG4gIH1cblxuICBzdGF0aWMgZ2V0TGVuZ3RoKHNpemU6IG51bWJlcik6IG51bWJlciB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0T2Zmc2V0KHNpemUpO1xuICB9XG5cbiAgc3RhdGljIGdldE9mZnNldChpbmRleDogbnVtYmVyKTogbnVtYmVyIHtcbiAgICByZXR1cm4gKGluZGV4ICogdGhpcy5pdGVtTGVuZ3RoKSB8IDA7XG4gIH1cblxuICBzdGF0aWMgZ2V0U2l6ZShsZW5ndGg6IG51bWJlcik6IG51bWJlciB7XG4gICAgcmV0dXJuIChsZW5ndGggLyB0aGlzLml0ZW1MZW5ndGgpIHwgMDtcbiAgfVxuXG4gICpbU3ltYm9sLml0ZXJhdG9yXSgpOiBHZW5lcmF0b3I8Vmlld0luc3RhbmNlPFQ+PiB7XG4gICAgY29uc3QgeyBzaXplIH0gPSB0aGlzO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgc2l6ZTsgaSsrKSB7XG4gICAgICB5aWVsZCB0aGlzLmdldFZpZXcoaSk7XG4gICAgfVxuICB9XG5cbiAgYXQoaW5kZXg6IG51bWJlcik6IFQge1xuICAgIGlmIChpbmRleCA8IDApIHJldHVybiB0aGlzLmdldCh0aGlzLnNpemUgKyBpbmRleCk7XG4gICAgcmV0dXJuIHRoaXMuZ2V0KGluZGV4KTtcbiAgfVxuXG4gIGdldChpbmRleDogbnVtYmVyKTogVCB7XG4gICAgY29uc3QgY29uc3RydWN0b3IgPSB0aGlzLmNvbnN0cnVjdG9yIGFzIHR5cGVvZiBBcnJheVZpZXc7XG4gICAgY29uc3QgVmlldyA9IGNvbnN0cnVjdG9yLlZpZXcgYXMgVmlld0NvbnN0cnVjdG9yPFQ+O1xuICAgIHJldHVybiBWaWV3LmRlY29kZSh0aGlzLCBjb25zdHJ1Y3Rvci5nZXRPZmZzZXQoaW5kZXgpKTtcbiAgfVxuXG4gIGdldExlbmd0aChfOiBudW1iZXIpOiBudW1iZXIge1xuICAgIHJldHVybiAodGhpcy5jb25zdHJ1Y3RvciBhcyB0eXBlb2YgQXJyYXlWaWV3KS5pdGVtTGVuZ3RoO1xuICB9XG5cbiAgZ2V0VmlldyhpbmRleDogbnVtYmVyKTogVmlld0luc3RhbmNlPFQ+IHtcbiAgICBjb25zdCBjb25zdHJ1Y3RvciA9IHRoaXMuY29uc3RydWN0b3IgYXMgdHlwZW9mIEFycmF5VmlldztcbiAgICBjb25zdCBWaWV3ID0gY29uc3RydWN0b3IuVmlldyBhcyBWaWV3Q29uc3RydWN0b3I8VD47XG4gICAgcmV0dXJuIG5ldyBWaWV3KFxuICAgICAgdGhpcy5idWZmZXIsXG4gICAgICB0aGlzLmJ5dGVPZmZzZXQgKyBjb25zdHJ1Y3Rvci5nZXRPZmZzZXQoaW5kZXgpLFxuICAgICAgY29uc3RydWN0b3IuaXRlbUxlbmd0aCxcbiAgICApO1xuICB9XG5cbiAgc2V0KGluZGV4OiBudW1iZXIsIHZhbHVlOiBUKTogdm9pZCB7XG4gICAgY29uc3QgY29uc3RydWN0b3IgPSB0aGlzLmNvbnN0cnVjdG9yIGFzIHR5cGVvZiBBcnJheVZpZXc7XG4gICAgY29uc3QgVmlldyA9IGNvbnN0cnVjdG9yLlZpZXcgYXMgVmlld0NvbnN0cnVjdG9yPFQ+O1xuICAgIFZpZXcuZW5jb2RlKFxuICAgICAgdmFsdWUsXG4gICAgICB0aGlzLFxuICAgICAgdGhpcy5ieXRlT2Zmc2V0ICsgY29uc3RydWN0b3IuZ2V0T2Zmc2V0KGluZGV4KSxcbiAgICAgIGNvbnN0cnVjdG9yLml0ZW1MZW5ndGgsXG4gICAgKTtcbiAgfVxuXG4gIHNldFZpZXcoaW5kZXg6IG51bWJlciwgdmFsdWU6IERhdGFWaWV3KTogdm9pZCB7XG4gICAgY29uc3QgY29uc3RydWN0b3IgPSB0aGlzLmNvbnN0cnVjdG9yIGFzIHR5cGVvZiBBcnJheVZpZXc7XG4gICAgbmV3IFVpbnQ4QXJyYXkoXG4gICAgICB0aGlzLmJ1ZmZlcixcbiAgICAgIHRoaXMuYnl0ZU9mZnNldCArIGNvbnN0cnVjdG9yLmdldE9mZnNldChpbmRleCksXG4gICAgICBjb25zdHJ1Y3Rvci5pdGVtTGVuZ3RoLFxuICAgICkuc2V0KG5ldyBVaW50OEFycmF5KHZhbHVlLmJ1ZmZlciwgdmFsdWUuYnl0ZU9mZnNldCwgdmFsdWUuYnl0ZUxlbmd0aCkpO1xuICB9XG5cbiAgdG9KU09OKCk6IEFycmF5PFQ+IHtcbiAgICByZXR1cm4gKHRoaXMuY29uc3RydWN0b3IgYXMgdHlwZW9mIEFycmF5VmlldykuZGVjb2RlPFQ+KFxuICAgICAgdGhpcyxcbiAgICAgIDAsXG4gICAgICB0aGlzLmJ5dGVMZW5ndGgsXG4gICAgKTtcbiAgfVxufVxuIl19 | ||
Object.defineProperty(ArrayView, "viewLength", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: 0 | ||
}); | ||
//# sourceMappingURL=array-view.js.map |
@@ -7,9 +7,10 @@ import { getBitSize } from "./utilities.js"; | ||
class BigBitField { | ||
static schema; | ||
static fields; | ||
static masks; | ||
static offsets; | ||
static mask; | ||
static size; | ||
value = ZERO; | ||
constructor(data = ZERO) { | ||
Object.defineProperty(this, "value", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: ZERO | ||
}); | ||
this.value = data instanceof BigBitField | ||
@@ -126,21 +127,3 @@ ? data.valueOf() | ||
} | ||
/** | ||
* Creates a BigBitField class with a given schema. BigBitField uses bigints as bitfields | ||
* to store and operate on data using bitwise operations. | ||
* | ||
* @param schema the schema | ||
* @returns the BigBitFieldClass | ||
* | ||
* @example | ||
* const LargeField = BitFieldMixin({ width: 20, height: 20 }); | ||
* const largeField = new LargeField({ width: 1048576, height: 1048576 }); | ||
* largeField.value | ||
* //=> 1099512676352n | ||
* largeField.set('width', 1000).get('width') | ||
* //=> 1000 | ||
* largeField.toObject() | ||
* //=> { width: 1000, height: 1048576 } | ||
*/ | ||
export function BigBitFieldMixin(schema) { | ||
var _a; | ||
const fields = Object.keys(schema); | ||
@@ -159,43 +142,12 @@ const _schema = {}; | ||
} | ||
return _a = class extends BigBitField { | ||
}, | ||
Object.defineProperty(_a, "schema", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: _schema | ||
}), | ||
Object.defineProperty(_a, "fields", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: fields | ||
}), | ||
Object.defineProperty(_a, "masks", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: masks | ||
}), | ||
Object.defineProperty(_a, "offsets", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: offsets | ||
}), | ||
Object.defineProperty(_a, "size", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: lastOffset | ||
}), | ||
Object.defineProperty(_a, "mask", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: TWO << (BigInt(lastOffset) - ONE) | ||
}), | ||
_a; | ||
return class extends BigBitField { | ||
static schema = _schema; | ||
static fields = fields; | ||
static masks = masks; | ||
static offsets = offsets; | ||
static size = lastOffset; | ||
static mask = TWO << (BigInt(lastOffset) - ONE); | ||
}; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmlnLWJpdC1maWVsZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImJpZy1iaXQtZmllbGQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBTTVDLE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztBQUNwQyxNQUFNLElBQUksR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDdkIsTUFBTSxHQUFHLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ3RCLE1BQU0sR0FBRyxHQUFHLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUV0QixNQUFNLFdBQVc7SUFFZixNQUFNLENBQUMsTUFBTSxDQUE4QjtJQUMzQyxNQUFNLENBQUMsTUFBTSxDQUFxQjtJQUNsQyxNQUFNLENBQUMsS0FBSyxDQUE4QjtJQUMxQyxNQUFNLENBQUMsT0FBTyxDQUE4QjtJQUM1QyxNQUFNLENBQUMsSUFBSSxDQUFTO0lBQ3BCLE1BQU0sQ0FBQyxJQUFJLENBQVM7SUFDcEIsS0FBSyxHQUFHLElBQUksQ0FBQztJQUViLFlBQ0UsT0FBb0UsSUFBSTtRQUV4RSxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksWUFBWSxXQUFXO1lBQ3RDLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ2hCLENBQUMsQ0FBQyxPQUFPLElBQUksS0FBSyxRQUFRO2dCQUMxQixDQUFDLENBQUUsSUFBSSxDQUFDLFdBQWtDLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQztnQkFDdkQsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNuQixDQUFDO0lBRUQsTUFBTSxDQUFDLE1BQU0sQ0FBd0IsSUFBWTtRQUMvQyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBMkIsQ0FBQztRQUNoRCxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBa0IsQ0FBQztRQUN2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R0FBRyxHQUFHLENBQUMsQ0FBQyxHQUFHLEdBQUcsQ0FBQztRQUMzQyxPQUFPLENBQUMsS0FBSyxDQUFDLEdBQUcsVUFBVSxDQUFDO1FBQzVCLFVBQVUsSUFBSSxJQUFJLENBQUM7S0FDcEI7SUFFRCxPQUFPLEtBQU0sU0FBUSxXQUFjO1FBQ2pDLE1BQU0sQ0FBQyxNQUFNLEdBQUcsT0FBTyxDQUFDO1FBQ3hCLE1BQU0sQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3ZCLE1BQU0sQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ3JCLE1BQU0sQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO1FBQ3pCLE1BQU0sQ0FBQyxJQUFJLEdBQUcsVUFBVSxDQUFDO1FBQ3pCLE1BQU0sQ0FBQyxJQUFJLEdBQUcsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxDQUFDO0tBQ2pELENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0Qml0U2l6ZSB9IGZyb20gXCIuL3V0aWxpdGllcy50c1wiO1xuaW1wb3J0IHR5cGUge1xuICBCaXRGaWVsZENvbnN0cnVjdG9yLFxuICBCaXRGaWVsZFN0cnVjdHVyZSxcbn0gZnJvbSBcIi4vYml0LWZpZWxkLXR5cGVzLnRzXCI7XG5cbmNvbnN0IFNJR05fQklUID0gQmlnSW50KDIxNDc0ODM2NDcpO1xuY29uc3QgWkVSTyA9IEJpZ0ludCgwKTtcbmNvbnN0IE9ORSA9IEJpZ0ludCgxKTtcbmNvbnN0IFRXTyA9IEJpZ0ludCgyKTtcblxuY2xhc3MgQmlnQml0RmllbGQ8SyBleHRlbmRzIFByb3BlcnR5S2V5PlxuICBpbXBsZW1lbnRzIEJpdEZpZWxkU3RydWN0dXJlPEssIGJpZ2ludD4ge1xuICBzdGF0aWMgc2NoZW1hOiBSZWNvcmQ8UHJvcGVydHlLZXksIGJpZ2ludD47XG4gIHN0YXRpYyBmaWVsZHM6IEFycmF5PFByb3BlcnR5S2V5PjtcbiAgc3RhdGljIG1hc2tzOiBSZWNvcmQ8UHJvcGVydHlLZXksIGJpZ2ludD47XG4gIHN0YXRpYyBvZmZzZXRzOiBSZWNvcmQ8UHJvcGVydHlLZXksIGJpZ2ludD47XG4gIHN0YXRpYyBtYXNrOiBiaWdpbnQ7XG4gIHN0YXRpYyBzaXplOiBiaWdpbnQ7XG4gIHZhbHVlID0gWkVSTztcblxuICBjb25zdHJ1Y3RvcihcbiAgICBkYXRhOiBiaWdpbnQgfCBCaWdCaXRGaWVsZDxLPiB8IEFycmF5PG51bWJlcj4gfCBSZWNvcmQ8SywgbnVtYmVyPiA9IFpFUk8sXG4gICkge1xuICAgIHRoaXMudmFsdWUgPSBkYXRhIGluc3RhbmNlb2YgQmlnQml0RmllbGRcbiAgICAgID8gZGF0YS52YWx1ZU9mKClcbiAgICAgIDogdHlwZW9mIGRhdGEgPT09IFwib2JqZWN0XCJcbiAgICAgID8gKHRoaXMuY29uc3RydWN0b3IgYXMgdHlwZW9mIEJpZ0JpdEZpZWxkKS5lbmNvZGUoZGF0YSlcbiAgICAgIDogQmlnSW50KGRhdGEpO1xuICB9XG5cbiAgc3RhdGljIGRlY29kZTxLIGV4dGVuZHMgUHJvcGVydHlLZXk+KGRhdGE6IGJpZ2ludCk6IFJlY29yZDxLLCBudW1iZXI+IHtcbiAgICBjb25zdCBzY2hlbWEgPSB0aGlzLnNjaGVtYSBhcyBSZWNvcmQ8SywgYmlnaW50PjtcbiAgICBjb25zdCBmaWVsZHMgPSB0aGlzLmZpZWxkcyBhcyBBcnJheTxLPjtcbiAgICBjb25zdCBtYXNrcyA9IHRoaXMubWFza3MgYXMgUmVjb3JkPEssIGJpZ2ludD47XG4gICAgY29uc3QgcmVzdWx0ID0ge30gYXMgUmVjb3JkPEssIG51bWJlcj47XG4gICAgbGV0IHZhbHVlID0gZGF0YTtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IGZpZWxkcy5sZW5ndGg7IGkrKykge1xuICAgICAgY29uc3QgZmllbGQgPSBmaWVsZHNbaV07XG4gICAgICByZXN1bHRbZmllbGRdID0gTnVtYmVyKHZhbHVlICYgbWFza3NbZmllbGRdKTtcbiAgICAgIHZhbHVlID4+PSBzY2hlbWFbZmllbGRdO1xuICAgIH1cbiAgICByZXR1cm4gcmVzdWx0O1xuICB9XG5cbiAgc3RhdGljIGVuY29kZTxLIGV4dGVuZHMgUHJvcGVydHlLZXk+KFxuICAgIGRhdGE6IEFycmF5PG51bWJlcj4gfCBSZWNvcmQ8SywgbnVtYmVyPixcbiAgKTogYmlnaW50IHtcbiAgICBjb25zdCBzY2hlbWEgPSB0aGlzLnNjaGVtYSBhcyBSZWNvcmQ8SywgYmlnaW50PjtcbiAgICBjb25zdCBmaWVsZHMgPSB0aGlzLmZpZWxkcyBhcyBBcnJheTxLPjtcbiAgICBjb25zdCBhcnJheSA9IEFycmF5LmlzQXJyYXkoZGF0YSlcbiAgICAgID8gZGF0YVxuICAgICAgOiBmaWVsZHMubWFwKChuYW1lKSA9PiBkYXRhW25hbWVdIHx8IDApO1xuICAgIGxldCByZXN1bHQgPSBaRVJPO1xuICAgIGZvciAobGV0IGkgPSBmaWVsZHMubGVuZ3RoIC0gMTsgaSA+PSAwOyBpLS0pIHtcbiAgICAgIGNvbnN0IGZpZWxkID0gZmllbGRzW2ldO1xuICAgICAgY29uc3QgY3VycmVudCA9IGFycmF5W2ldO1xuICAgICAgcmVzdWx0IDw8PSBzY2hlbWFbZmllbGRdO1xuICAgICAgcmVzdWx0IHw9IEJpZ0ludChjdXJyZW50KTtcbiAgICB9XG4gICAgcmV0dXJuIHJlc3VsdDtcbiAgfVxuXG4gIHN0YXRpYyBnZXRNYXRjaGVyPEsgZXh0ZW5kcyBQcm9wZXJ0eUtleT4oXG4gICAgbWF0Y2hlcjogUGFydGlhbDxSZWNvcmQ8SywgbnVtYmVyPj4sXG4gICk6IFtiaWdpbnQsIGJpZ2ludF0ge1xuICAgIGNvbnN0IHsgbWFza3MsIG9mZnNldHMgfSA9IHRoaXM7XG4gICAgY29uc3QgZmllbGRzID0gT2JqZWN0LmtleXMobWF0Y2hlcikgYXMgQXJyYXk8Sz47XG4gICAgbGV0IG1hc2sgPSBaRVJPO1xuICAgIGxldCB2YWx1ZSA9IFpFUk87XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBmaWVsZHMubGVuZ3RoOyBpKyspIHtcbiAgICAgIGNvbnN0IGZpZWxkTmFtZSA9IGZpZWxkc1tpXTtcbiAgICAgIGNvbnN0IG9mZnNldDogYmlnaW50ID0gb2Zmc2V0c1tmaWVsZE5hbWVdO1xuICAgICAgY29uc3QgZmllbGRNYXNrID0gbWFza3NbZmllbGROYW1lXSA8PCBvZmZzZXQ7XG4gICAgICBjb25zdCBmaWVsZFZhbHVlID0gQmlnSW50KG1hdGNoZXJbZmllbGROYW1lXSEpO1xuICAgICAgdmFsdWUgPSAodmFsdWUgJiB+ZmllbGRNYXNrKSB8IChmaWVsZFZhbHVlIDw8IG9mZnNldHNbZmllbGROYW1lXSk7XG4gICAgICBtYXNrIHw9IGZpZWxkTWFzaztcbiAgICB9XG4gICAgcmV0dXJuIFt2YWx1ZSwgdGhpcy5tYXNrIF4gbWFza107XG4gIH1cblxuICBzdGF0aWMgZ2V0TWluU2l6ZShudW1iZXI6IG51bWJlcik6IG51bWJlciB7XG4gICAgcmV0dXJuIGdldEJpdFNpemUobnVtYmVyKTtcbiAgfVxuXG4gIHN0YXRpYyBpc1ZhbGlkPEsgZXh0ZW5kcyBQcm9wZXJ0eUtleT4oXG4gICAgZGF0YTogUGFydGlhbDxSZWNvcmQ8SywgbnVtYmVyPj4sXG4gICk6IGJvb2xlYW4ge1xuICAgIGNvbnN0IHsgbWFza3MgfSA9IHRoaXM7XG4gICAgY29uc3QgZmllbGRzID0gT2JqZWN0LmtleXMoZGF0YSkgYXMgQXJyYXk8Sz47XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBmaWVsZHMubGVuZ3RoOyBpKyspIHtcbiAgICAgIGNvbnN0IGZpZWxkID0gZmllbGRzW2ldO1xuICAgICAgY29uc3QgdmFsdWUgPSBCaWdJbnQoZGF0YVtmaWVsZF0hKTtcbiAgICAgIGlmICgodmFsdWUgJiBTSUdOX0JJVCkgIT09IHZhbHVlIHx8IHZhbHVlID4gbWFza3NbZmllbGRdKSByZXR1cm4gZmFsc2U7XG4gICAgfVxuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgc3RhdGljIG1hdGNoKHZhbHVlOiBiaWdpbnQsIG1hdGNoZXI6IFtiaWdpbnQsIGJpZ2ludF0pIHtcbiAgICByZXR1cm4gKHZhbHVlICYgbWF0Y2hlclsxXSkgPT09IG1hdGNoZXJbMF07XG4gIH1cblxuICAqW1N5bWJvbC5pdGVyYXRvcl0oKTogR2VuZXJhdG9yPG51bWJlcj4ge1xuICAgIGNvbnN0IHsgZmllbGRzIH0gPSB0aGlzLmNvbnN0cnVjdG9yIGFzIEJpdEZpZWxkQ29uc3RydWN0b3I8SywgYmlnaW50PjtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IGZpZWxkcy5sZW5ndGg7IGkrKykge1xuICAgICAgeWllbGQgdGhpcy5nZXQoZmllbGRzW2ldKTtcbiAgICB9XG4gIH1cblxuICBnZXQoZmllbGQ6IEspOiBudW1iZXIge1xuICAgIGNvbnN0IHsgb2Zmc2V0cywgbWFza3MgfSA9IHRoaXMuY29uc3RydWN0b3IgYXMgQml0RmllbGRDb25zdHJ1Y3RvcjxcbiAgICAgIEssXG4gICAgICBiaWdpbnRcbiAgICA+O1xuICAgIGNvbnN0IHZhbHVlID0gKHRoaXMudmFsdWUgPj4gb2Zmc2V0c1tmaWVsZF0pICYgbWFza3NbZmllbGRdO1xuICAgIHJldHVybiBOdW1iZXIodmFsdWUpO1xuICB9XG5cbiAgaGFzKC4uLmZpZWxkczogQXJyYXk8Sz4pOiBib29sZWFuIHtcbiAgICBjb25zdCB7IG9mZnNldHMgfSA9IHRoaXMuY29uc3RydWN0b3IgYXMgQml0RmllbGRDb25zdHJ1Y3RvcjxLLCBiaWdpbnQ+O1xuICAgIGxldCBtYXNrID0gWkVSTztcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IGZpZWxkcy5sZW5ndGg7IGkrKykge1xuICAgICAgbWFzayB8PSBPTkUgPDwgb2Zmc2V0c1tmaWVsZHNbaV1dO1xuICAgIH1cbiAgICBtYXNrIHw9IHRoaXMudmFsdWU7XG4gICAgcmV0dXJuIHRoaXMudmFsdWUgPT09IG1hc2s7XG4gIH1cblxuICBtYXRjaChtYXRjaGVyOiBQYXJ0aWFsPFJlY29yZDxLLCBudW1iZXI+PiB8IFtiaWdpbnQsIGJpZ2ludF0pOiBib29sZWFuIHtcbiAgICByZXR1cm4gKHRoaXMuY29uc3RydWN0b3IgYXMgQml0RmllbGRDb25zdHJ1Y3RvcjxLLCBiaWdpbnQ+KS5tYXRjaChcbiAgICAgIHRoaXMudmFsdWUsXG4gICAgICBBcnJheS5pc0FycmF5KG1hdGNoZXIpXG4gICAgICAgID8gbWF0Y2hlclxuICAgICAgICA6ICh0aGlzLmNvbnN0cnVjdG9yIGFzIEJpdEZpZWxkQ29uc3RydWN0b3I8SywgYmlnaW50PikuZ2V0TWF0Y2hlcihcbiAgICAgICAgICBtYXRjaGVyLFxuICAgICAgICApLFxuICAgICk7XG4gIH1cblxuICBzZXQoZmllbGQ6IEssIHZhbHVlID0gMSkge1xuICAgIGNvbnN0IHsgb2Zmc2V0cywgbWFza3MgfSA9IHRoaXMuY29uc3RydWN0b3IgYXMgQml0RmllbGRDb25zdHJ1Y3RvcjxcbiAgICAgIEssXG4gICAgICBiaWdpbnRcbiAgICA+O1xuICAgIGNvbnN0IG9mZnNldDogYmlnaW50ID0gb2Zmc2V0c1tmaWVsZF07XG4gICAgdGhpcy52YWx1ZSA9ICh0aGlzLnZhbHVlICYgfihtYXNrc1tmaWVsZF0gPDwgb2Zmc2V0KSkgfFxuICAgICAgKEJpZ0ludCh2YWx1ZSkgPDwgb2Zmc2V0c1tmaWVsZF0pO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgdG9KU09OKCkge1xuICAgIHJldHVybiB0aGlzLnZhbHVlO1xuICB9XG5cbiAgdG9PYmplY3QoKTogUmVjb3JkPEssIG51bWJlcj4ge1xuICAgIHJldHVybiAodGhpcy5jb25zdHJ1Y3RvciBhcyBCaXRGaWVsZENvbnN0cnVjdG9yPEssIGJpZ2ludD4pLmRlY29kZShcbiAgICAgIHRoaXMudmFsdWUsXG4gICAgKTtcbiAgfVxuXG4gIHRvU3RyaW5nKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMudmFsdWUudG9TdHJpbmcoKTtcbiAgfVxuXG4gIHZhbHVlT2YoKTogYmlnaW50IHtcbiAgICByZXR1cm4gdGhpcy52YWx1ZTtcbiAgfVxufVxuXG4vKipcbiAqIENyZWF0ZXMgYSBCaWdCaXRGaWVsZCBjbGFzcyB3aXRoIGEgZ2l2ZW4gc2NoZW1hLiBCaWdCaXRGaWVsZCB1c2VzIGJpZ2ludHMgYXMgYml0ZmllbGRzXG4gKiB0byBzdG9yZSBhbmQgb3BlcmF0ZSBvbiBkYXRhIHVzaW5nIGJpdHdpc2Ugb3BlcmF0aW9ucy5cbiAqXG4gKiBAcGFyYW0gc2NoZW1hIHRoZSBzY2hlbWFcbiAqIEByZXR1cm5zIHRoZSBCaWdCaXRGaWVsZENsYXNzXG4gKlxuICogQGV4YW1wbGVcbiAqIGNvbnN0IExhcmdlRmllbGQgPSBCaXRGaWVsZE1peGluKHsgd2lkdGg6IDIwLCBoZWlnaHQ6IDIwIH0pO1xuICogY29uc3QgbGFyZ2VGaWVsZCA9IG5ldyBMYXJnZUZpZWxkKHsgd2lkdGg6IDEwNDg1NzYsIGhlaWdodDogMTA0ODU3NiB9KTtcbiAqIGxhcmdlRmllbGQudmFsdWVcbiAqIC8vPT4gMTA5OTUxMjY3NjM1Mm5cbiAqIGxhcmdlRmllbGQuc2V0KCd3aWR0aCcsIDEwMDApLmdldCgnd2lkdGgnKVxuICogLy89PiAxMDAwXG4gKiBsYXJnZUZpZWxkLnRvT2JqZWN0KClcbiAqIC8vPT4geyB3aWR0aDogMTAwMCwgaGVpZ2h0OiAxMDQ4NTc2IH1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIEJpZ0JpdEZpZWxkTWl4aW48XG4gIFQgZXh0ZW5kcyBSZWNvcmQ8SywgbnVtYmVyPixcbiAgSyBleHRlbmRzIGtleW9mIFQsXG4+KHNjaGVtYTogVCk6IEJpdEZpZWxkQ29uc3RydWN0b3I8SywgYmlnaW50PiB7XG4gIGNvbnN0IGZpZWxkcyA9IE9iamVjdC5rZXlzKHNjaGVtYSkgYXMgQXJyYXk8Sz47XG4gIGNvbnN0IF9zY2hlbWEgPSB7fSBhcyBSZWNvcmQ8SywgYmlnaW50PjtcbiAgY29uc3QgbWFza3MgPSB7fSBhcyBSZWNvcmQ8SywgYmlnaW50PjtcbiAgY29uc3Qgb2Zmc2V0cyA9IHt9IGFzIFJlY29yZDxLLCBiaWdpbnQ+O1xuICBsZXQgbGFzdE9mZnNldCA9IFpFUk87XG4gIGZvciAobGV0IGkgPSAwOyBpIDwgZmllbGRzLmxlbmd0aDsgaSsrKSB7XG4gICAgY29uc3QgZmllbGQgPSBmaWVsZHNbaV07XG4gICAgY29uc3Qgc2l6ZSA9IEJpZ0ludChzY2hlbWFbZmllbGRdKTtcbiAgICBfc2NoZW1hW2ZpZWxkXSA9IHNpemU7XG4gICAgbWFza3NbZmllbGRdID0gKFRXTyA8PCAoc2l6ZSAtIE9ORSkpIC0gT05FO1xuICAgIG9mZnNldHNbZmllbGRdID0gbGFzdE9mZnNldDtcbiAgICBsYXN0T2Zmc2V0ICs9IHNpemU7XG4gIH1cblxuICByZXR1cm4gY2xhc3MgZXh0ZW5kcyBCaWdCaXRGaWVsZDxLPiB7XG4gICAgc3RhdGljIHNjaGVtYSA9IF9zY2hlbWE7XG4gICAgc3RhdGljIGZpZWxkcyA9IGZpZWxkcztcbiAgICBzdGF0aWMgbWFza3MgPSBtYXNrcztcbiAgICBzdGF0aWMgb2Zmc2V0cyA9IG9mZnNldHM7XG4gICAgc3RhdGljIHNpemUgPSBsYXN0T2Zmc2V0O1xuICAgIHN0YXRpYyBtYXNrID0gVFdPIDw8IChCaWdJbnQobGFzdE9mZnNldCkgLSBPTkUpO1xuICB9O1xufVxuIl19 | ||
//# sourceMappingURL=big-bit-field.js.map |
import { getLog2 } from "./utilities.js"; | ||
/** | ||
* Implements a grid or 2D matrix of bits. | ||
*/ | ||
export class BinaryGrid extends Uint32Array { | ||
constructor() { | ||
super(...arguments); | ||
Object.defineProperty(this, "size", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: 0 | ||
}); | ||
} | ||
size = 0; | ||
static get [Symbol.species]() { | ||
return Uint32Array; | ||
} | ||
/** | ||
* Number of columns in the grid. | ||
*/ | ||
get columns() { | ||
return 1 << this.size; | ||
} | ||
/** | ||
* Specifies the number of columns of the grid. | ||
*/ | ||
set columns(columns) { | ||
this.size = getLog2(columns); | ||
} | ||
/** | ||
* Number of rows in the grid. | ||
*/ | ||
get rows() { | ||
return (this.length << 5) >> this.size; | ||
} | ||
/** | ||
* Creates a binary grid of specified dimensions. | ||
* | ||
* @param rows the amount of rows | ||
* @param columns the amount of columns | ||
* @return a new binary grid | ||
*/ | ||
static create(rows, columns = 1) { | ||
@@ -50,12 +23,5 @@ const offset = getLog2(columns); | ||
} | ||
/** | ||
* Creates a new binary grid from an array of arrays representing rows and item value of the grid. | ||
* | ||
* @param arrays the array of arrays | ||
* @return a new binary grid | ||
*/ | ||
static fromArrays(arrays) { | ||
const rows = arrays.length; | ||
// find longest array to get the column size | ||
let columns = arrays[0].length; // if !arrays[0].length | ||
let columns = arrays[0].length; | ||
for (let i = 0; i < rows; i++) { | ||
@@ -65,6 +31,4 @@ if (arrays[i].length > columns) | ||
} | ||
// create grid of the required length | ||
const grid = this.create(rows, columns); | ||
grid.size = getLog2(columns); | ||
// fill the grid with values from arrays | ||
for (let i = 0; i < rows; i++) { | ||
@@ -77,9 +41,2 @@ for (let j = 0; j < arrays[i].length; j++) { | ||
} | ||
/** | ||
* Returns the length of the underlying TypedArray required to hold a grid of specified dimensions. | ||
* | ||
* @param rows the amount of rows | ||
* @param columns the amount of columns | ||
* @return the required length | ||
*/ | ||
static getLength(rows, columns = 1) { | ||
@@ -93,9 +50,2 @@ return (rows << getLog2(columns)) >> 5; | ||
} | ||
/** | ||
* Returns the index of an item holding the bit at given coordinates. | ||
* | ||
* @param rows the row index | ||
* @param columns the column index | ||
* @return the item index | ||
*/ | ||
getIndex(row, column = 1) { | ||
@@ -105,9 +55,2 @@ const index = (row << this.size) + column; | ||
} | ||
/** | ||
* Returns the bit at given coordinates. | ||
* | ||
* @param rows the row index | ||
* @param columns the column index | ||
* @return the bit | ||
*/ | ||
getValue(row, column) { | ||
@@ -117,10 +60,2 @@ const [bucket, position] = this.getCoordinates(row, column); | ||
} | ||
/** | ||
* Sets the bit at given coordinates. | ||
* | ||
* @param rows the row index | ||
* @param columns the column index | ||
* @param value the bit | ||
* @return the grid | ||
*/ | ||
setValue(row, column, value = 1) { | ||
@@ -131,7 +66,2 @@ const [bucket, position] = this.getCoordinates(row, column || 0); | ||
} | ||
/** | ||
* Creates an array of arrays representing rows of the grid. | ||
* | ||
* @return an array of arrays | ||
*/ | ||
toArrays() { | ||
@@ -149,3 +79,3 @@ const { rows, columns } = this; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmluYXJ5LWdyaWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJiaW5hcnktZ3JpZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFLekMsTUFBTSxPQUFPLFVBQVcsU0FBUSxXQUFXO0lBQ3pDLElBQUksR0FBRyxDQUFDLENBQUM7SUFFVCxNQUFNLEtBQUssQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDO1FBQ3pCLE9BQU8sV0FBVyxDQUFDO0lBQ3JCLENBQUM7SUFLRCxJQUFJLE9BQU87UUFDVCxPQUFPLENBQUMsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQ3hCLENBQUM7SUFLRCxJQUFJLE9BQU8sQ0FBQyxPQUFlO1FBQ3pCLElBQUksQ0FBQyxJQUFJLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFLRCxJQUFJLElBQUk7UUFDTixPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUMsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQ3pDLENBQUM7SUFTRCxNQUFNLENBQUMsTUFBTSxDQUFDLElBQVksRUFBRSxPQUFPLEdBQUcsQ0FBQztRQUNyQyxNQUFNLE1BQU0sR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDaEMsTUFBTSxNQUFNLEdBQUcsQ0FBQyxJQUFJLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JDLE1BQU0sSUFBSSxHQUFHLElBQUksSUFBSSxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUMsQ0FBQztRQUNuQyxJQUFJLENBQUMsSUFBSSxHQUFHLE1BQU0sQ0FBQztRQUNuQixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFRRCxNQUFNLENBQUMsVUFBVSxDQUFDLE1BQXlCO1FBQ3pDLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUM7UUFHM0IsSUFBSSxPQUFPLEdB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LENBQUMsR0FBRyxJQUFJLEVBQUUsQ0FBQyxFQUFFLEVBQUU7WUFDN0IsTUFBTSxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQy9CLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxPQUFPLEVBQUUsQ0FBQyxFQUFFLEVBQUU7Z0JBQ2hDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQzthQUNwQztTQUNGO1FBQ0QsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBCaXQgfSBmcm9tIFwiLi91dGlsaXR5LXR5cGVzLnRzXCI7XG5pbXBvcnQgeyBnZXRMb2cyIH0gZnJvbSBcIi4vdXRpbGl0aWVzLnRzXCI7XG5cbi8qKlxuICogSW1wbGVtZW50cyBhIGdyaWQgb3IgMkQgbWF0cml4IG9mIGJpdHMuXG4gKi9cbmV4cG9ydCBjbGFzcyBCaW5hcnlHcmlkIGV4dGVuZHMgVWludDMyQXJyYXkge1xuICBzaXplID0gMDtcblxuICBzdGF0aWMgZ2V0IFtTeW1ib2wuc3BlY2llc10oKTogVWludDMyQXJyYXlDb25zdHJ1Y3RvciB7XG4gICAgcmV0dXJuIFVpbnQzMkFycmF5O1xuICB9XG5cbiAgLyoqXG4gICAqIE51bWJlciBvZiBjb2x1bW5zIGluIHRoZSBncmlkLlxuICAgKi9cbiAgZ2V0IGNvbHVtbnMoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gMSA8PCB0aGlzLnNpemU7XG4gIH1cblxuICAvKipcbiAgICogU3BlY2lmaWVzIHRoZSBudW1iZXIgb2YgY29sdW1ucyBvZiB0aGUgZ3JpZC5cbiAgICovXG4gIHNldCBjb2x1bW5zKGNvbHVtbnM6IG51bWJlcikge1xuICAgIHRoaXMuc2l6ZSA9IGdldExvZzIoY29sdW1ucyk7XG4gIH1cblxuICAvKipcbiAgICogTnVtYmVyIG9mIHJvd3MgaW4gdGhlIGdyaWQuXG4gICAqL1xuICBnZXQgcm93cygpOiBudW1iZXIge1xuICAgIHJldHVybiAodGhpcy5sZW5ndGggPDwgNSkgPj4gdGhpcy5zaXplO1xuICB9XG5cbiAgLyoqXG4gICAqIENyZWF0ZXMgYSBiaW5hcnkgZ3JpZCBvZiBzcGVjaWZpZWQgZGltZW5zaW9ucy5cbiAgICpcbiAgICogQHBhcmFtIHJvd3MgdGhlIGFtb3VudCBvZiByb3dzXG4gICAqIEBwYXJhbSBjb2x1bW5zIHRoZSBhbW91bnQgb2YgY29sdW1uc1xuICAgKiBAcmV0dXJuIGEgbmV3IGJpbmFyeSBncmlkXG4gICAqL1xuICBzdGF0aWMgY3JlYXRlKHJvd3M6IG51bWJlciwgY29sdW1ucyA9IDEpOiBCaW5hcnlHcmlkIHtcbiAgICBjb25zdCBvZmZzZXQgPSBnZXRMb2cyKGNvbHVtbnMpO1xuICAgIGNvbnN0IGxlbmd0aCA9IChyb3dzIDw8IG9mZnNldCkgPj4gNTtcbiAgICBjb25zdCBncmlkID0gbmV3IHRoaXMobGVuZ3RoIHx8IDEpO1xuICAgIGdyaWQuc2l6ZSA9IG9mZnNldDtcbiAgICByZXR1cm4gZ3JpZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgbmV3IGJpbmFyeSBncmlkIGZyb20gYW4gYXJyYXkgb2YgYXJyYXlzIHJlcHJlc2VudGluZyByb3dzIGFuZCBpdGVtIHZhbHVlIG9mIHRoZSBncmlkLlxuICAgKlxuICAgKiBAcGFyYW0gYXJyYXlzIHRoZSBhcnJheSBvZiBhcnJheXNcbiAgICogQHJldHVybiBhIG5ldyBiaW5hcnkgZ3JpZFxuICAgKi9cbiAgc3RhdGljIGZyb21BcnJheXMoYXJyYXlzOiBBcnJheTxBcnJheTxCaXQ+Pik6IEJpbmFyeUdyaWQge1xuICAgIGNvbnN0IHJvd3MgPSBhcnJheXMubGVuZ3RoO1xuXG4gICAgLy8gZmluZCBsb25nZXN0IGFycmF5IHRvIGdldCB0aGUgY29sdW1uIHNpemVcbiAgICBsZXQgY29sdW1ucyA9IGFycmF5c1swXS5sZW5ndGg7IC8vIGlmICFhcnJheXNbMF0ubGVuZ3RoXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCByb3dzOyBpKyspIHtcbiAgICAgIGlmIChhcnJheXNbaV0ubGVuZ3RoID4gY29sdW1ucykgY29sdW1ucyA9IGFycmF5c1tpXS5sZW5ndGg7XG4gICAgfVxuICAgIC8vIGNyZWF0ZSBncmlkIG9mIHRoZSByZXF1aXJlZCBsZW5ndGhcbiAgICBjb25zdCBncmlkID0gdGhpcy5jcmVhdGUocm93cywgY29sdW1ucyk7XG4gICAgZ3JpZC5zaXplID0gZ2V0TG9nMihjb2x1bW5zKTtcblxuICAgIC8vIGZpbGwgdGhlIGdyaWQgd2l0aCB2YWx1ZXMgZnJvbSBhcnJheXNcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHJvd3M7IGkrKykge1xuICAgICAgZm9yIChsZXQgaiA9IDA7IGogPCBhcnJheXNbaV0ubGVuZ3RoOyBqKyspIHtcbiAgICAgICAgZ3JpZC5zZXRWYWx1ZShpLCBqLCBhcnJheXNbaV1bal0pO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBncmlkO1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIGxlbmd0aCBvZiB0aGUgdW5kZXJseWluZyBUeXBlZEFycmF5IHJlcXVpcmVkIHRvIGhvbGQgYSBncmlkIG9mIHNwZWNpZmllZCBkaW1lbnNpb25zLlxuICAgKlxuICAgKiBAcGFyYW0gcm93cyB0aGUgYW1vdW50IG9mIHJvd3NcbiAgICogQHBhcmFtIGNvbHVtbnMgdGhlIGFtb3VudCBvZiBjb2x1bW5zXG4gICAqIEByZXR1cm4gdGhlIHJlcXVpcmVkIGxlbmd0aFxuICAgKi9cbiAgc3RhdGljIGdldExlbmd0aChyb3dzOiBudW1iZXIsIGNvbHVtbnMgPSAxKTogbnVtYmVyIHtcbiAgICByZXR1cm4gKHJvd3MgPDwgZ2V0TG9nMihjb2x1bW5zKSkgPj4gNTtcbiAgfVxuXG4gIGdldENvb3JkaW5hdGVzKHJvdzogbnVtYmVyLCBjb2x1bW4gPSAxKTogW2J1Y2tldDogbnVtYmVyLCBwb3NpdGlvbjogbnVtYmVyXSB7XG4gICAgY29uc3QgaW5kZXggPSAocm93IDw8IHRoaXMuc2l6ZSkgKyBjb2x1bW47XG4gICAgY29uc3QgYnVja2V0ID0gaW5kZXggPj4gNTtcbiAgICByZXR1cm4gW2J1Y2tldCwgaW5kZXggLSAoYnVja2V0IDw8IDUpXTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBpbmRleCBvZiBhbiBpdGVtIGhvbGRpbmcgdGhlIGJpdCBhdCBnaXZlbiBjb29yZGluYXRlcy5cbiAgICpcbiAgICogQHBhcmFtIHJvd3MgdGhlIHJvdyBpbmRleFxuICAgKiBAcGFyYW0gY29sdW1ucyB0aGUgY29sdW1uIGluZGV4XG4gICAqIEByZXR1cm4gdGhlIGl0ZW0gaW5kZXhcbiAgICovXG4gIGdldEluZGV4KHJvdzogbnVtYmVyLCBjb2x1bW4gPSAxKTogbnVtYmVyIHtcbiAgICBjb25zdCBpbmRleCA9IChyb3cgPDwgdGhpcy5zaXplKSArIGNvbHVtbjtcbiAgICByZXR1cm4gaW5kZXggPj4gNTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBiaXQgYXQgZ2l2ZW4gY29vcmRpbmF0ZXMuXG4gICAqXG4gICAqIEBwYXJhbSByb3dzIHRoZSByb3cgaW5kZXhcbiAgICogQHBhcmFtIGNvbHVtbnMgdGhlIGNvbHVtbiBpbmRleFxuICAgKiBAcmV0dXJuIHRoZSBiaXRcbiAgICovXG4gIGdldFZhbHVlKHJvdzogbnVtYmVyLCBjb2x1bW46IG51bWJlcik6IEJpdCB7XG4gICAgY29uc3QgW2J1Y2tldCwgcG9zaXRpb25dID0gdGhpcy5nZXRDb29yZGluYXRlcyhyb3csIGNvbHVtbik7XG4gICAgcmV0dXJuICgodGhpc1tidWNrZXRdID4+IHBvc2l0aW9uKSAmIDEpIGFzIEJpdDtcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXRzIHRoZSBiaXQgYXQgZ2l2ZW4gY29vcmRpbmF0ZXMuXG4gICAqXG4gICAqIEBwYXJhbSByb3dzIHRoZSByb3cgaW5kZXhcbiAgICogQHBhcmFtIGNvbHVtbnMgdGhlIGNvbHVtbiBpbmRleFxuICAgKiBAcGFyYW0gdmFsdWUgdGhlIGJpdFxuICAgKiBAcmV0dXJuIHRoZSBncmlkXG4gICAqL1xuICBzZXRWYWx1ZShyb3c6IG51bWJlciwgY29sdW1uOiBudW1iZXIsIHZhbHVlOiBCaXQgPSAxKTogdGhpcyB7XG4gICAgY29uc3QgW2J1Y2tldCwgcG9zaXRpb25dID0gdGhpcy5nZXRDb29yZGluYXRlcyhyb3csIGNvbHVtbiB8fCAwKTtcbiAgICB0aGlzW2J1Y2tldF0gPSAodGhpc1tidWNrZXRdICYgfigxIDw8IHBvc2l0aW9uKSkgfCAodmFsdWUgPDwgcG9zaXRpb24pO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIENyZWF0ZXMgYW4gYXJyYXkgb2YgYXJyYXlzIHJlcHJlc2VudGluZyByb3dzIG9mIHRoZSBncmlkLlxuICAgKlxuICAgKiBAcmV0dXJuIGFuIGFycmF5IG9mIGFycmF5c1xuICAgKi9cbiAgdG9BcnJheXMoKTogQXJyYXk8QXJyYXk8Qml0Pj4ge1xuICAgIGNvbnN0IHsgcm93cywgY29sdW1ucyB9ID0gdGhpcztcbiAgICBjb25zdCByZXN1bHQ6IEFycmF5PEFycmF5PEJpdD4+ID0gbmV3IEFycmF5KHJvd3MpO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgcm93czsgaSsrKSB7XG4gICAgICByZXN1bHRbaV0gPSBuZXcgQXJyYXkoY29sdW1ucyk7XG4gICAgICBmb3IgKGxldCBqID0gMDsgaiA8IGNvbHVtbnM7IGorKykge1xuICAgICAgICByZXN1bHRbaV1bal0gPSB0aGlzLmdldFZhbHVlKGksIGopO1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gcmVzdWx0O1xuICB9XG59XG4iXX0= | ||
//# sourceMappingURL=binary-grid.js.map |
@@ -1,8 +0,2 @@ | ||
/** | ||
* Extends Array to implement the Binary Heap data structure. | ||
* // TODO (docs) document priority queue operations | ||
* // todo add heapsort? | ||
*/ | ||
export class BinaryHeap extends Array { | ||
// deno-lint-ignore no-explicit-any | ||
constructor(...args) { | ||
@@ -15,9 +9,2 @@ super(...args); | ||
} | ||
/** | ||
* The comparator function used by the heap. | ||
* | ||
* @param a first value to compare | ||
* @param b second value to compare | ||
* @return whether first value is less than the second | ||
*/ | ||
static compare(a, b) { | ||
@@ -31,32 +18,11 @@ return a < b; | ||
} | ||
/** | ||
* Get left child index from parent index. | ||
* | ||
* @param index the parent index | ||
* @return the index of the left child | ||
*/ | ||
static getLeftIndex(index) { | ||
return (index << 1) + 1; | ||
} | ||
/** | ||
* Get left child index from parent index. | ||
* | ||
* @param index the child index | ||
* @return the index of the parent | ||
*/ | ||
static getParentIndex(index) { | ||
return (index - 1) >> 1; | ||
} | ||
/** | ||
* Get right child index from parent index. | ||
* | ||
* @param index the parent index | ||
* @return the index of the right child | ||
*/ | ||
static getRightIndex(index) { | ||
return (index << 1) + 2; | ||
} | ||
/** | ||
* Checks if a given collection is a valid binary heap. | ||
*/ | ||
static isHeap(heap) { | ||
@@ -72,21 +38,8 @@ for (let i = heap.length - 1; i > -1; i--) { | ||
} | ||
/** | ||
* Creates a new BinaryHeap with a variable number of arguments, | ||
* regardless of number or type of the arguments. | ||
* | ||
* @param elements the elements of which to create the heap | ||
* @return the new BinaryHeap | ||
*/ | ||
static of(...elements) { | ||
return super.of(...elements).heapify(); | ||
} | ||
/** | ||
* Check whether the index is whithin the heap. | ||
*/ | ||
has(index) { | ||
return index >= 0 && index < this.length; | ||
} | ||
/** | ||
* Restores the binary heap. | ||
*/ | ||
heapify() { | ||
@@ -98,26 +51,11 @@ for (let i = this.length >> 1; i >= 0; i--) { | ||
} | ||
/** | ||
* Checks whether the array is a valid binary heap. | ||
*/ | ||
isHeap() { | ||
return this.constructor.isHeap(this); | ||
} | ||
/** | ||
* Returns the left child of an element at a given index. | ||
*/ | ||
left(index) { | ||
return this[this.constructor.getLeftIndex(index)]; | ||
} | ||
/** | ||
* Returns the parent of an element at a given index. | ||
*/ | ||
parent(index) { | ||
return this[this.constructor.getParentIndex(index)]; | ||
} | ||
/** | ||
* Adds items to the heap. | ||
* | ||
* @param elements items to add | ||
* @return new length of the heap | ||
*/ | ||
push(...elements) { | ||
@@ -130,8 +68,2 @@ for (let i = 0; i < elements.length; i++) { | ||
} | ||
/** | ||
* Returns the first (min/max) element of the heap and replaces it with a given element. | ||
* | ||
* @param element the element to replace the first element of the heap | ||
* @return the first element of the heap | ||
*/ | ||
replace(element) { | ||
@@ -143,13 +75,6 @@ const first = this[0]; | ||
} | ||
/** | ||
* Returns the right child of an element at a given index. | ||
*/ | ||
right(index) { | ||
return this[this.constructor.getRightIndex(index)]; | ||
} | ||
/** | ||
* Extracts the first element of the heap. | ||
*/ | ||
shift() { | ||
// extract min/max | ||
if (this.length < 2) | ||
@@ -194,10 +119,2 @@ return this.pop(); | ||
} | ||
/** | ||
* Changes elements of the heap. | ||
* | ||
* @param start starting index | ||
* @param deleteCount the amount of elements to delete | ||
* @param items elements to add | ||
* @return the deleted elements | ||
*/ | ||
splice(start, deleteCount, ...items) { | ||
@@ -225,16 +142,5 @@ const deletedItems = deleteCount === undefined | ||
} | ||
/** | ||
* Adds elements to the heap. | ||
* | ||
* @param items elements to add | ||
* @return the new length of the heap | ||
*/ | ||
unshift(...items) { | ||
return this.push(...items); | ||
} | ||
/** | ||
* Updates the position of an element inside the heap. | ||
* | ||
* @param index the index of the element to update | ||
*/ | ||
update(index) { | ||
@@ -253,3 +159,3 @@ const { compare, getLeftIndex } = this.constructor; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmluYXJ5LWhlYXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJiaW5hcnktaGVhcC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLQSxNQUFNLE9BQU8sVUFBYyxTQUFRLEtBQVE7SUFFekMsWUFBWSxHQUFHLElBQVc7UUFDeEIsS0FBSyxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUM7UUFDZixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDakIsQ0FBQztJQUVELE1BQU0sS0FBSyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUM7UUFDekIsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO0lBU0QsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFVLEVBQUUsQ0FBVTtRQUNuQyxPQUFnQixDQUFDLEdBQVksQ0FBQyxDQUFDO0lBQ2pDLENBQUM7SUFNRCxNQUFNLENBQUMsSUFBSSxDQUNULFFBQW9DLEVBQ3BDLEtBQThCLEVBQzlCLE9BQWlCO1FBRWpCLE9BQVEsQ0FBQyxLQUFLLEtBQUssU0FBUztZQUMxQixDQUFDLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsS0FBSyxFQUFFLE9BQU8sQ0FBQztZQUN0QyxDQUFDLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBbUIsQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUN4RCxDQUFDO0lBUUQsTUFBTSxDQUFDLFlBQVksQ0FBQyxLQUFhO1FBQy9CLE9BQU8sQ0FBQyxLQUFLLElBQUksQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzFCLENBQUM7SUFRRCxNQUFNLENBQUMsY0FBYyxDQUFDLEtBQWE7UUFDakMsT0FBTyxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDMUIsQ0FBQztJQVFELE1BQU0sQ0FBQyxhQUFhLENBQUMsS0FBYTtRQUNoQyxPQUFPLENBQUMsS0FBSyxJQUFJLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUMxQixDQUFDO0lB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Q0FBQyxHQUFHLEVBQUUsQ0FBQztnQkFDeEIsS0FBSyxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQyxFQUFFLElBQVMsQ0FBQyxDQUFDO2dCQUNsQyxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO2FBQ3RCO1NBQ0Y7YUFBTTtZQUNMLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztTQUNoQjtRQUNELE9BQU8sWUFBWSxDQUFDO0lBQ3RCLENBQUM7SUFRRCxPQUFPLENBQUMsR0FBRyxLQUFlO1FBQ3hCLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFDO0lBQzdCLENBQUM7SUFPRCxNQUFNLENBQUMsS0FBYTtRQUNsQixNQUFNLEVBQUUsT0FBTyxFQUFFLFlBQVksRUFBRSxHQUFHLElBQUksQ0FBQyxXQUFnQyxDQUFDO1FBQ3hFLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDbEMsTUFBTSxTQUFTLEdBQUcsWUFBWSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3RDLElBQ0UsSUFBSSxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUM7WUFDbkIsQ0FBQyxNQUFNLEtBQUssU0FBUyxJQUFJLE9BQU8sQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFDdEQ7WUFDQSxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQ3RCO2FBQU07WUFDTCxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQ3BCO0lBQ0gsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlbmRzIEFycmF5IHRvIGltcGxlbWVudCB0aGUgQmluYXJ5IEhlYXAgZGF0YSBzdHJ1Y3R1cmUuXG4gKiAvLyBUT0RPIChkb2NzKSBkb2N1bWVudCBwcmlvcml0eSBxdWV1ZSBvcGVyYXRpb25zXG4gKiAvLyB0b2RvIGFkZCBoZWFwc29ydD9cbiAqL1xuZXhwb3J0IGNsYXNzIEJpbmFyeUhlYXA8VD4gZXh0ZW5kcyBBcnJheTxUPiB7XG4gIC8vIGRlbm8tbGludC1pZ25vcmUgbm8tZXhwbGljaXQtYW55XG4gIGNvbnN0cnVjdG9yKC4uLmFyZ3M6IGFueVtdKSB7XG4gICAgc3VwZXIoLi4uYXJncyk7XG4gICAgdGhpcy5oZWFwaWZ5KCk7XG4gIH1cblxuICBzdGF0aWMgZ2V0IFtTeW1ib2wuc3BlY2llc10oKTogQXJyYXlDb25zdHJ1Y3RvciB7XG4gICAgcmV0dXJuIEFycmF5O1xuICB9XG5cbiAgLyoqXG4gICAqIFRoZSBjb21wYXJhdG9yIGZ1bmN0aW9uIHVzZWQgYnkgdGhlIGhlYXAuXG4gICAqXG4gICAqIEBwYXJhbSBhIGZpcnN0IHZhbHVlIHRvIGNvbXBhcmVcbiAgICogQHBhcmFtIGIgc2Vjb25kIHZhbHVlIHRvIGNvbXBhcmVcbiAgICogQHJldHVybiB3aGV0aGVyIGZpcnN0IHZhbHVlIGlzIGxlc3MgdGhhbiB0aGUgc2Vjb25kXG4gICAqL1xuICBzdGF0aWMgY29tcGFyZShhOiB1bmtub3duLCBiOiB1bmtub3duKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIDxudW1iZXI+IGEgPCA8bnVtYmVyPiBiO1xuICB9XG5cbiAgLyoqXG4gICAqIENyZWF0ZXMgYSBuZXcgQmluYXJ5SGVhcCBmcm9tIGEgZ2l2ZW4gYXJyYXktbGlrZSBvYmplY3QuXG4gICAqL1xuICBzdGF0aWMgZnJvbTxUPihpdGVyYWJsZTogSXRlcmFibGU8VD4gfCBBcnJheUxpa2U8VD4pOiBCaW5hcnlIZWFwPFQ+O1xuICBzdGF0aWMgZnJvbTxULCBVPihcbiAgICBpdGVyYWJsZTogSXRlcmFibGU8VD4gfCBBcnJheUxpa2U8VD4sXG4gICAgbWFwZm4/OiAodjogVCwgazogbnVtYmVyKSA9PiBVLFxuICAgIHRoaXNBcmc/OiB1bmtub3duLFxuICApOiBCaW5hcnlIZWFwPFU+IHtcbiAgICByZXR1cm4gKChtYXBmbiAhPT0gdW5kZWZpbmVkXG4gICAgICA/IHN1cGVyLmZyb20oaXRlcmFibGUsIG1hcGZuLCB0aGlzQXJnKVxuICAgICAgOiBzdXBlci5mcm9tKGl0ZXJhYmxlKSkgYXMgQmluYXJ5SGVhcDxVPikuaGVhcGlmeSgpO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCBsZWZ0IGNoaWxkIGluZGV4IGZyb20gcGFyZW50IGluZGV4LlxuICAgKlxuICAgKiBAcGFyYW0gaW5kZXggdGhlIHBhcmVudCBpbmRleFxuICAgKiBAcmV0dXJuIHRoZSBpbmRleCBvZiB0aGUgbGVmdCBjaGlsZFxuICAgKi9cbiAgc3RhdGljIGdldExlZnRJbmRleChpbmRleDogbnVtYmVyKTogbnVtYmVyIHtcbiAgICByZXR1cm4gKGluZGV4IDw8IDEpICsgMTtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgbGVmdCBjaGlsZCBpbmRleCBmcm9tIHBhcmVudCBpbmRleC5cbiAgICpcbiAgICogQHBhcmFtIGluZGV4IHRoZSBjaGlsZCBpbmRleFxuICAgKiBAcmV0dXJuIHRoZSBpbmRleCBvZiB0aGUgcGFyZW50XG4gICAqL1xuICBzdGF0aWMgZ2V0UGFyZW50SW5kZXgoaW5kZXg6IG51bWJlcik6IG51bWJlciB7XG4gICAgcmV0dXJuIChpbmRleCAtIDEpID4+IDE7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHJpZ2h0IGNoaWxkIGluZGV4IGZyb20gcGFyZW50IGluZGV4LlxuICAgKlxuICAgKiBAcGFyYW0gaW5kZXggdGhlIHBhcmVudCBpbmRleFxuICAgKiBAcmV0dXJuIHRoZSBpbmRleCBvZiB0aGUgcmlnaHQgY2hpbGRcbiAgICovXG4gIHN0YXRpYyBnZXRSaWdodEluZGV4KGluZGV4OiBudW1iZXIpOiBudW1iZXIge1xuICAgIHJldHVybiAoaW5kZXggPDwgMSkgKyAyO1xuICB9XG5cbiAgLyoqXG4gICAqIENoZWNrcyBpZiBhIGdpdmVuIGNvbGxlY3Rpb24gaXMgYSB2YWxpZCBiaW5hcnkgaGVhcC5cbiAgICovXG4gIHN0YXRpYyBpc0hlYXA8VD4oaGVhcDogQXJyYXlMaWtlPFQ+KTogYm9vbGVhbiB7XG4gICAgZm9yIChsZXQgaSA9IGhlYXAubGVuZ3RoIC0gMTsgaSA+IC0xOyBpLS0pIHtcbiAgICAgIGNvbnN0IHBhcmVudEluZGV4ID0gdGhpcy5nZXRQYXJlbnRJbmRleChpKTtcbiAgICAgIGlmIChwYXJlbnRJbmRleCA8IDApIGJyZWFrO1xuICAgICAgaWYgKCF0aGlzLmNvbXBhcmUoaGVhcFtwYXJlbnRJbmRleF0sIGhlYXBbaV0pKSByZXR1cm4gZmFsc2U7XG4gICAgfVxuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgLyoqXG4gICAqIENyZWF0ZXMgYSBuZXcgQmluYXJ5SGVhcCB3aXRoIGEgdmFyaWFibGUgbnVtYmVyIG9mIGFyZ3VtZW50cyxcbiAgICogcmVnYXJkbGVzcyBvZiBudW1iZXIgb3IgdHlwZSBvZiB0aGUgYXJndW1lbnRzLlxuICAgKlxuICAgKiBAcGFyYW0gZWxlbWVudHMgdGhlIGVsZW1lbnRzIG9mIHdoaWNoIHRvIGNyZWF0ZSB0aGUgaGVhcFxuICAgKiBAcmV0dXJuIHRoZSBuZXcgQmluYXJ5SGVhcFxuICAgKi9cbiAgc3RhdGljIG9mPFQ+KC4uLmVsZW1lbnRzOiBBcnJheTxUPik6IEJpbmFyeUhlYXA8VD4ge1xuICAgIHJldHVybiAoc3VwZXIub2YoLi4uZWxlbWVudHMpIGFzIEJpbmFyeUhlYXA8VD4pLmhlYXBpZnkoKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDaGVjayB3aGV0aGVyIHRoZSBpbmRleCBpcyB3aGl0aGluIHRoZSBoZWFwLlxuICAgKi9cbiAgaGFzKGluZGV4OiBudW1iZXIpOiBib29sZWFuIHtcbiAgICByZXR1cm4gaW5kZXggPj0gMCAmJiBpbmRleCA8IHRoaXMubGVuZ3RoO1xuICB9XG5cbiAgLyoqXG4gICAqIFJlc3RvcmVzIHRoZSBiaW5hcnkgaGVhcC5cbiAgICovXG4gIGhlYXBpZnkoKTogdGhpcyB7XG4gICAgZm9yIChsZXQgaSA9IHRoaXMubGVuZ3RoID4+IDE7IGkgPj0gMDsgaS0tKSB7XG4gICAgICB0aGlzLnNpZnREb3duKGkpO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBDaGVja3Mgd2hldGhlciB0aGUgYXJyYXkgaXMgYSB2YWxpZCBiaW5hcnkgaGVhcC5cbiAgICovXG4gIGlzSGVhcCgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gKHRoaXMuY29uc3RydWN0b3IgYXMgdHlwZW9mIEJpbmFyeUhlYXApLmlzSGVhcCh0aGlzKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBsZWZ0IGNoaWxkIG9mIGFuIGVsZW1lbnQgYXQgYSBnaXZlbiBpbmRleC5cbiAgICovXG4gIGxlZnQoaW5kZXg6IG51bWJlcik6IFQge1xuICAgIHJldHVybiB0aGlzWyh0aGlzLmNvbnN0cnVjdG9yIGFzIHR5cGVvZiBCaW5hcnlIZWFwKS5nZXRMZWZ0SW5kZXgoaW5kZXgpXTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBwYXJlbnQgb2YgYW4gZWxlbWVudCBhdCBhIGdpdmVuIGluZGV4LlxuICAgKi9cbiAgcGFyZW50KGluZGV4OiBudW1iZXIpOiBUIHtcbiAgICByZXR1cm4gdGhpc1sodGhpcy5jb25zdHJ1Y3RvciBhcyB0eXBlb2YgQmluYXJ5SGVhcCkuZ2V0UGFyZW50SW5kZXgoaW5kZXgpXTtcbiAgfVxuXG4gIC8qKlxuICAgKiBBZGRzIGl0ZW1zIHRvIHRoZSBoZWFwLlxuICAgKlxuICAgKiBAcGFyYW0gZWxlbWVudHMgaXRlbXMgdG8gYWRkXG4gICAqIEByZXR1cm4gbmV3IGxlbmd0aCBvZiB0aGUgaGVhcFxuICAgKi9cbiAgcHVzaCguLi5lbGVtZW50czogQXJyYXk8VD4pOiBudW1iZXIge1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgZWxlbWVudHMubGVuZ3RoOyBpKyspIHtcbiAgICAgIHN1cGVyLnB1c2goZWxlbWVudHNbaV0pO1xuICAgICAgdGhpcy5zaWZ0VXAodGhpcy5sZW5ndGggLSAxKTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMubGVuZ3RoO1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIGZpcnN0IChtaW4vbWF4KSBlbGVtZW50IG9mIHRoZSBoZWFwIGFuZCByZXBsYWNlcyBpdCB3aXRoIGEgZ2l2ZW4gZWxlbWVudC5cbiAgICpcbiAgICogQHBhcmFtIGVsZW1lbnQgdGhlIGVsZW1lbnQgdG8gcmVwbGFjZSB0aGUgZmlyc3QgZWxlbWVudCBvZiB0aGUgaGVhcFxuICAgKiBAcmV0dXJuIHRoZSBmaXJzdCBlbGVtZW50IG9mIHRoZSBoZWFwXG4gICAqL1xuICByZXBsYWNlKGVsZW1lbnQ6IFQpOiBUIHtcbiAgICBjb25zdCBmaXJzdCA9IHRoaXNbMF07XG4gICAgdGhpc1swXSA9IGVsZW1lbnQ7XG4gICAgdGhpcy5zaWZ0RG93bigwKTtcbiAgICByZXR1cm4gZmlyc3Q7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyB0aGUgcmlnaHQgY2hpbGQgb2YgYW4gZWxlbWVudCBhdCBhIGdpdmVuIGluZGV4LlxuICAgKi9cbiAgcmlnaHQoaW5kZXg6IG51bWJlcik6IFQge1xuICAgIHJldHVybiB0aGlzWyh0aGlzLmNvbnN0cnVjdG9yIGFzIHR5cGVvZiBCaW5hcnlIZWFwKS5nZXRSaWdodEluZGV4KGluZGV4KV07XG4gIH1cblxuICAvKipcbiAgICogRXh0cmFjdHMgdGhlIGZpcnN0IGVsZW1lbnQgb2YgdGhlIGhlYXAuXG4gICAqL1xuICBzaGlmdCgpOiBUIHwgdW5kZWZpbmVkIHtcbiAgICAvLyBleHRyYWN0IG1pbi9tYXhcbiAgICBpZiAodGhpcy5sZW5ndGggPCAyKSByZXR1cm4gdGhpcy5wb3AoKTtcbiAgICBjb25zdCBpdGVtID0gdGhpc1swXTtcbiAgICB0aGlzWzBdID0gdGhpcy5wb3AoKSBhcyBUO1xuICAgIHRoaXMuc2lmdERvd24oMCk7XG4gICAgcmV0dXJuIGl0ZW07XG4gIH1cblxuICBzaWZ0RG93bihzdGFydDogbnVtYmVyKTogdm9pZCB7XG4gICAgY29uc3QgeyBnZXRSaWdodEluZGV4LCBnZXRMZWZ0SW5kZXgsIGNvbXBhcmUgfSA9IHRoaXNcbiAgICAgIC5jb25zdHJ1Y3RvciBhcyB0eXBlb2YgQmluYXJ5SGVhcDtcbiAgICBsZXQgaW5kZXggPSBzdGFydDtcbiAgICBsZXQgbGVmdEluZGV4ID0gZ2V0TGVmdEluZGV4KGluZGV4KTtcbiAgICBsZXQgcmlnaHRJbmRleCA9IGdldFJpZ2h0SW5kZXgoaW5kZXgpO1xuICAgIGxldCBuZXh0SW5kZXg7XG4gICAgd2hpbGUgKHRoaXMuaGFzKGxlZnRJbmRleCkpIHtcbiAgICAgIGlmICh0aGlzLmhhcyhyaWdodEluZGV4KSAmJiBjb21wYXJlKHRoaXNbcmlnaHRJbmRleF0sIHRoaXNbbGVmdEluZGV4XSkpIHtcbiAgICAgICAgbmV4dEluZGV4ID0gcmlnaHRJbmRleDtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIG5leHRJbmRleCA9IGxlZnRJbmRleDtcbiAgICAgIH1cblxuICAgICAgaWYgKGNvbXBhcmUodGhpc1tpbmRleF0sIHRoaXNbbmV4dEluZGV4XSkpIGJyZWFrO1xuICAgICAgW3RoaXNbaW5kZXhdLCB0aGlzW25leHRJbmRleF1dID0gW3RoaXNbbmV4dEluZGV4XSwgdGhpc1tpbmRleF1dO1xuICAgICAgaW5kZXggPSBuZXh0SW5kZXg7XG4gICAgICBsZWZ0SW5kZXggPSBnZXRMZWZ0SW5kZXgoaW5kZXgpO1xuICAgICAgcmlnaHRJbmRleCA9IGdldFJpZ2h0SW5kZXgoaW5kZXgpO1xuICAgIH1cbiAgfVxuXG4gIHNpZnRVcChzdGFydDogbnVtYmVyKTogdm9pZCB7XG4gICAgY29uc3QgeyBnZXRQYXJlbnRJbmRleCwgY29tcGFyZSB9ID0gdGhpcy5jb25zdHJ1Y3RvciBhcyB0eXBlb2YgQmluYXJ5SGVhcDtcbiAgICBsZXQgaW5kZXggPSBzdGFydDtcbiAgICBsZXQgcGFyZW50SW5kZXggPSBnZXRQYXJlbnRJbmRleChpbmRleCk7XG4gICAgd2hpbGUgKHRoaXMuaGFzKHBhcmVudEluZGV4KSAmJiAhY29tcGFyZSh0aGlzW3BhcmVudEluZGV4XSwgdGhpc1tpbmRleF0pKSB7XG4gICAgICBbdGhpc1tpbmRleF0sIHRoaXNbcGFyZW50SW5kZXhdXSA9IFt0aGlzW3BhcmVudEluZGV4XSwgdGhpc1tpbmRleF1dO1xuICAgICAgaW5kZXggPSBwYXJlbnRJbmRleDtcbiAgICAgIHBhcmVudEluZGV4ID0gZ2V0UGFyZW50SW5kZXgoaW5kZXgpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBDaGFuZ2VzIGVsZW1lbnRzIG9mIHRoZSBoZWFwLlxuICAgKlxuICAgKiBAcGFyYW0gc3RhcnQgc3RhcnRpbmcgaW5kZXhcbiAgICogQHBhcmFtIGRlbGV0ZUNvdW50IHRoZSBhbW91bnQgb2YgZWxlbWVudHMgdG8gZGVsZXRlXG4gICAqIEBwYXJhbSBpdGVtcyBlbGVtZW50cyB0byBhZGRcbiAgICogQHJldHVybiB0aGUgZGVsZXRlZCBlbGVtZW50c1xuICAgKi9cbiAgc3BsaWNlKHN0YXJ0OiBudW1iZXIsIGRlbGV0ZUNvdW50PzogbnVtYmVyLCAuLi5pdGVtczogQXJyYXk8VD4pOiBBcnJheTxUPiB7XG4gICAgY29uc3QgZGVsZXRlZEl0ZW1zID0gZGVsZXRlQ291bnQgPT09IHVuZGVmaW5lZFxuICAgICAgPyBzdXBlci5zcGxpY2Uoc3RhcnQpXG4gICAgICA6IHN1cGVyLnNwbGljZShzdGFydCwgZGVsZXRlQ291bnQsIC4uLml0ZW1zKTtcbiAgICBjb25zdCBpc1NpbmdsZSA9IGRlbGV0ZWRJdGVtcy5sZW5ndGggPCAyICYmIGl0ZW1zLmxlbmd0aCA8IDI7XG4gICAgaWYgKGlzU2luZ2xlKSB7XG4gICAgICBjb25zdCBpbmRleCA9IHN0YXJ0O1xuICAgICAgY29uc3QgaXNSZXBsYWNlbWVudCA9IGl0ZW1zLmxlbmd0aCA9PT0gMTtcbiAgICAgIGlmIChpc1JlcGxhY2VtZW50KSB7XG4gICAgICAgIHRoaXMudXBkYXRlKGluZGV4KTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGNvbnN0IGxhc3QgPSB0aGlzLnBvcCgpO1xuICAgICAgICBzdXBlci5zcGxpY2UoaW5kZXgsIDAsIGxhc3QgYXMgVCk7XG4gICAgICAgIHRoaXMuc2lmdERvd24oaW5kZXgpO1xuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLmhlYXBpZnkoKTtcbiAgICB9XG4gICAgcmV0dXJuIGRlbGV0ZWRJdGVtcztcbiAgfVxuXG4gIC8qKlxuICAgKiBBZGRzIGVsZW1lbnRzIHRvIHRoZSBoZWFwLlxuICAgKlxuICAgKiBAcGFyYW0gaXRlbXMgZWxlbWVudHMgdG8gYWRkXG4gICAqIEByZXR1cm4gdGhlIG5ldyBsZW5ndGggb2YgdGhlIGhlYXBcbiAgICovXG4gIHVuc2hpZnQoLi4uaXRlbXM6IEFycmF5PFQ+KTogbnVtYmVyIHtcbiAgICByZXR1cm4gdGhpcy5wdXNoKC4uLml0ZW1zKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBVcGRhdGVzIHRoZSBwb3NpdGlvbiBvZiBhbiBlbGVtZW50IGluc2lkZSB0aGUgaGVhcC5cbiAgICpcbiAgICogQHBhcmFtIGluZGV4IHRoZSBpbmRleCBvZiB0aGUgZWxlbWVudCB0byB1cGRhdGVcbiAgICovXG4gIHVwZGF0ZShpbmRleDogbnVtYmVyKTogdm9pZCB7XG4gICAgY29uc3QgeyBjb21wYXJlLCBnZXRMZWZ0SW5kZXggfSA9IHRoaXMuY29uc3RydWN0b3IgYXMgdHlwZW9mIEJpbmFyeUhlYXA7XG4gICAgY29uc3QgcGFyZW50ID0gdGhpcy5wYXJlbnQoaW5kZXgpO1xuICAgIGNvbnN0IGxlZnRJbmRleCA9IGdldExlZnRJbmRleChpbmRleCk7XG4gICAgaWYgKFxuICAgICAgdGhpcy5oYXMobGVmdEluZGV4KSAmJlxuICAgICAgKHBhcmVudCA9PT0gdW5kZWZpbmVkIHx8IGNvbXBhcmUocGFyZW50LCB0aGlzW2luZGV4XSkpXG4gICAgKSB7XG4gICAgICB0aGlzLnNpZnREb3duKGluZGV4KTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5zaWZ0VXAoaW5kZXgpO1xuICAgIH1cbiAgfVxufVxuIl19 | ||
//# sourceMappingURL=binary-heap.js.map |
export class BinaryView extends DataView { | ||
static viewLength = 0; | ||
static decode(view, start = 0, length = view.byteLength) { | ||
@@ -6,4 +7,5 @@ return new Uint8Array(view.buffer.slice(view.byteOffset + start, view.byteOffset + start + length)); | ||
static encode(value, view, start = 0, length) { | ||
const valueLength = value.byteLength - value.byteOffset; | ||
const size = !length || valueLength < length ? valueLength : length; | ||
const size = !length || value.byteLength < length | ||
? value.byteLength | ||
: length; | ||
new Uint8Array(view.buffer, view.byteOffset, view.byteLength).set(new Uint8Array(value.buffer, value.byteOffset, size), start); | ||
@@ -28,9 +30,3 @@ return size; | ||
} | ||
Object.defineProperty(BinaryView, "viewLength", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: 0 | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmluYXJ5LXZpZXcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJiaW5hcnktdmlldy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8sVUFBVyxTQUFRLFFBQVE7SUFDdEMsTUFBTSxDQUFDLFVBQVUsR0FBRyxDQUFDLENBQUM7SUFDdEIsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFjLEVBQUUsS0FBSyxHQUFHLENBQUMsRUFBRSxNQUFNLEdBQUcsSUFBSSxDQUFDLFVBQVU7UUFDL0QsT0FBTyxJQUFJLFVBQVUsQ0FDbkIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQ2YsSUFBSSxDQUFDLFVBQVUsR0FBRyxLQUFLLEVBQ3ZCLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxHQUFHLE1BQU0sQ0FDakMsQ0FDRixDQUFDO0lBQ0osQ0FBQztJQUNELE1BQU0sQ0FBQyxNQUFNLENBQUMsS0FBaUIsRUFBRSxJQUFjLEVBQUUsS0FBSyxHQUFHLENBQUMsRUFBRSxNQUFlO1FBQ3pFLE1BQU0sSUFBSSxHQUFHLENBQUMsTUFBTSxJQUFJLEtBQUssQ0FBQyxVQUFVLEdBQUcsTUFBTTtZQUMvQyxDQUFDLENBQUMsS0FBSyxDQUFDLFVBQVU7WUFDbEIsQ0FBQyxDQUFDLE1BQU0sQ0FBQztRQUNYLElBQUksVUFBVSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLFVBQVUsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsR0FBRyxDQUMvRCxJQUFJLFVBQVUsQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFLEtBQUssQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLEVBQ3BELEtBQUssQ0FDTixDQUFDO1FBQ0YsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFpQjtRQUMzQixPQUFPLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsS0FBSyxDQUFDLFVBQVUsRUFBRSxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDcEUsQ0FBQztJQUVELE1BQU0sQ0FBQyxTQUFTLENBQUMsSUFBWTtRQUMzQixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxHQUFHO1FBQ0QsT0FBUSxJQUFJLENBQUMsV0FBaUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDOUQsQ0FBQztJQUNELEdBQUcsQ0FBQyxLQUFpQjtRQUNsQixJQUFJLENBQUMsV0FBaUMsQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFDRCxNQUFNO1FBQ0osT0FBTyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUM7SUFDcEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgUHJpbWl0aXZlVmlldyB9IGZyb20gXCIuL3ZpZXctdHlwZXMudHNcIjtcblxuZXhwb3J0IGNsYXNzIEJpbmFyeVZpZXcgZXh0ZW5kcyBEYXRhVmlldyBpbXBsZW1lbnRzIFByaW1pdGl2ZVZpZXc8VWludDhBcnJheT4ge1xuICBzdGF0aWMgdmlld0xlbmd0aCA9IDA7XG4gIHN0YXRpYyBkZWNvZGUodmlldzogRGF0YVZpZXcsIHN0YXJ0ID0gMCwgbGVuZ3RoID0gdmlldy5ieXRlTGVuZ3RoKSB7XG4gICAgcmV0dXJuIG5ldyBVaW50OEFycmF5KFxuICAgICAgdmlldy5idWZmZXIuc2xpY2UoXG4gICAgICAgIHZpZXcuYnl0ZU9mZnNldCArIHN0YXJ0LFxuICAgICAgICB2aWV3LmJ5dGVPZmZzZXQgKyBzdGFydCArIGxlbmd0aCxcbiAgICAgICksXG4gICAgKTtcbiAgfVxuICBzdGF0aWMgZW5jb2RlKHZhbHVlOiBVaW50OEFycmF5LCB2aWV3OiBEYXRhVmlldywgc3RhcnQgPSAwLCBsZW5ndGg/OiBudW1iZXIpIHtcbiAgICBjb25zdCBzaXplID0gIWxlbmd0aCB8fCB2YWx1ZS5ieXRlTGVuZ3RoIDwgbGVuZ3RoXG4gICAgICA/IHZhbHVlLmJ5dGVMZW5ndGhcbiAgICAgIDogbGVuZ3RoO1xuICAgIG5ldyBVaW50OEFycmF5KHZpZXcuYnVmZmVyLCB2aWV3LmJ5dGVPZmZzZXQsIHZpZXcuYnl0ZUxlbmd0aCkuc2V0KFxuICAgICAgbmV3IFVpbnQ4QXJyYXkodmFsdWUuYnVmZmVyLCB2YWx1ZS5ieXRlT2Zmc2V0LCBzaXplKSxcbiAgICAgIHN0YXJ0LFxuICAgICk7XG4gICAgcmV0dXJuIHNpemU7XG4gIH1cblxuICBzdGF0aWMgZnJvbSh2YWx1ZTogVWludDhBcnJheSkge1xuICAgIHJldHVybiBuZXcgdGhpcyh2YWx1ZS5idWZmZXIsIHZhbHVlLmJ5dGVPZmZzZXQsIHZhbHVlLmJ5dGVMZW5ndGgpO1xuICB9XG5cbiAgc3RhdGljIGdldExlbmd0aChzaXplOiBudW1iZXIpIHtcbiAgICByZXR1cm4gc2l6ZTtcbiAgfVxuXG4gIGdldCgpIHtcbiAgICByZXR1cm4gKHRoaXMuY29uc3RydWN0b3IgYXMgdHlwZW9mIEJpbmFyeVZpZXcpLmRlY29kZSh0aGlzKTtcbiAgfVxuICBzZXQodmFsdWU6IFVpbnQ4QXJyYXkpIHtcbiAgICAodGhpcy5jb25zdHJ1Y3RvciBhcyB0eXBlb2YgQmluYXJ5VmlldykuZW5jb2RlKHZhbHVlLCB0aGlzKTtcbiAgfVxuICB0b0pTT04oKSB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0KCk7XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=binary-view.js.map |
@@ -1,59 +0,15 @@ | ||
/** | ||
* Uses Uint32Array as an array or vector of bits. It's a simpler version of BitField | ||
* that only sets and checks individual bits. | ||
* | ||
* @example | ||
* const array = BitArray.create(10); | ||
* array.getBit(0); | ||
* //=> 0 | ||
* array.setBit(0).getBit(0); | ||
* //=> 1 | ||
* array.size; | ||
* //=> 10 | ||
* array.length; | ||
* //=> 1 | ||
*/ | ||
export class BitArray extends Uint32Array { | ||
constructor() { | ||
super(...arguments); | ||
Object.defineProperty(this, "lastPosition", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: { bucket: 0, position: 0 } | ||
}); | ||
} | ||
lastPosition = { bucket: 0, position: 0 }; | ||
static get [Symbol.species]() { | ||
return Uint32Array; | ||
} | ||
/** | ||
* The amount of bits in the array. | ||
*/ | ||
get size() { | ||
return this.length << 5; | ||
} | ||
/** | ||
* Creates a BitArray of the specified size. | ||
* | ||
* @param size the maximum amount of bits in the array | ||
* @return a new BitArray | ||
*/ | ||
static create(size) { | ||
return new this(this.getLength(size)); | ||
} | ||
/** | ||
* Returns the length of the underlying TypedArray required to hold the given amount of bits. | ||
* | ||
* @param size the amount of bits | ||
* @return the required length | ||
*/ | ||
static getLength(size) { | ||
return Math.ceil(size / 32); | ||
} | ||
/** | ||
* Returns the bit at a given index. | ||
* | ||
* @param index the index | ||
* @return the bit | ||
*/ | ||
getBit(index) { | ||
@@ -69,9 +25,2 @@ const { bucket, position } = this.getBitPosition(index); | ||
} | ||
/** | ||
* Sets the bit at a given index. | ||
* | ||
* @param index the index | ||
* @param value the value | ||
* @return this | ||
*/ | ||
setBit(index, value = 1) { | ||
@@ -83,3 +32,3 @@ const { bucket, position } = this.getBitPosition(index); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYml0LWFycmF5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYml0LWFycmF5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNCQSxNQUFNLE9BQU8sUUFBUyxTQUFRLFdBQVc7SUFDdkMsWUFBWSxHQUFnQixFQUFFLE1BQU0sRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLENBQUMsRUFBRSxDQUFDO0lBRXZELE1BQU0sS0FBSyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUM7UUFDekIsT0FBTyxXQUFXLENBQUM7SUFDckIsQ0FBQztJQUtELElBQUksSUFBSTtRQUNOLE9BQU8sSUFBSSxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUM7SUFDMUIsQ0FBQztJQVFELE1BQU0sQ0FBQyxNQUFNLENBRVgsSUFBWTtRQUVaLE9BQU8sSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBb0IsQ0FBQztJQUMzRCxDQUFDO0lBUUQsTUFBTSxDQUFDLFNBQVMsQ0FBQyxJQUFZO1FBQzNCLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFDOUIsQ0FBQztJQVFELE1BQU0sQ0FBQyxLQUFhO1FBQ2xCLE1BQU0sRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN4RCxPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFRLENBQUM7SUFDakQsQ0FBQztJQUVELGNBQWMsQ0FBQyxLQUFhO1FBQzFCLE1BQU0sTUFBTSxHQUFHLEtBQUssSUFBSSxDQUFDLENBQUM7UUFDMUIsSUFBSSxDQUFDLFlBQVksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ2xDLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxHQUFHLEtBQUssR0FBRyxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUMsQ0FBQztRQUNuRCxPQUFPLElBQUksQ0FBQyxZQUFZLENBQUM7SUFDM0IsQ0FBQztJQVNELE1BQU0sQ0FBQyxLQUFhLEVBQUUsUUFBYSxDQUFDO1FBQ2xDLE1BQU0sRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN4RCxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsSUFBSSxRQUFRLENBQUMsQ0FBQyxHQUFHLENBQUMsS0FBSyxJQUFJLFFBQVEsQ0FBQyxDQUFDO1FBQ3ZFLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBCaXQgfSBmcm9tIFwiLi91dGlsaXR5LXR5cGVzLnRzXCI7XG5cbnR5cGUgQml0UG9zaXRpb24gPSB7XG4gIGJ1Y2tldDogbnVtYmVyO1xuICBwb3NpdGlvbjogbnVtYmVyO1xufTtcblxuLyoqXG4gKiBVc2VzIFVpbnQzMkFycmF5IGFzIGFuIGFycmF5IG9yIHZlY3RvciBvZiBiaXRzLiBJdCdzIGEgc2ltcGxlciB2ZXJzaW9uIG9mIEJpdEZpZWxkXG4gKiB0aGF0IG9ubHkgc2V0cyBhbmQgY2hlY2tzIGluZGl2aWR1YWwgYml0cy5cbiAqXG4gKiBAZXhhbXBsZVxuICogY29uc3QgYXJyYXkgPSBCaXRBcnJheS5jcmVhdGUoMTApO1xuICogYXJyYXkuZ2V0Qml0KDApO1xuICogLy89PiAwXG4gKiBhcnJheS5zZXRCaXQoMCkuZ2V0Qml0KDApO1xuICogLy89PiAxXG4gKiBhcnJheS5zaXplO1xuICogLy89PiAxMFxuICogYXJyYXkubGVuZ3RoO1xuICogLy89PiAxXG4gKi9cbmV4cG9ydCBjbGFzcyBCaXRBcnJheSBleHRlbmRzIFVpbnQzMkFycmF5IHtcbiAgbGFzdFBvc2l0aW9uOiBCaXRQb3NpdGlvbiA9IHsgYnVja2V0OiAwLCBwb3NpdGlvbjogMCB9O1xuXG4gIHN0YXRpYyBnZXQgW1N5bWJvbC5zcGVjaWVzXSgpOiBVaW50MzJBcnJheUNvbnN0cnVjdG9yIHtcbiAgICByZXR1cm4gVWludDMyQXJyYXk7XG4gIH1cblxuICAvKipcbiAgICogVGhlIGFtb3VudCBvZiBiaXRzIGluIHRoZSBhcnJheS5cbiAgICovXG4gIGdldCBzaXplKCk6IG51bWJlciB7XG4gICAgcmV0dXJuIHRoaXMubGVuZ3RoIDw8IDU7XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlcyBhIEJpdEFycmF5IG9mIHRoZSBzcGVjaWZpZWQgc2l6ZS5cbiAgICpcbiAgICogQHBhcmFtIHNpemUgdGhlIG1heGltdW0gYW1vdW50IG9mIGJpdHMgaW4gdGhlIGFycmF5XG4gICAqIEByZXR1cm4gYSBuZXcgQml0QXJyYXlcbiAgICovXG4gIHN0YXRpYyBjcmVhdGU8VCBleHRlbmRzIHR5cGVvZiBCaXRBcnJheT4oXG4gICAgdGhpczogVCxcbiAgICBzaXplOiBudW1iZXIsXG4gICk6IEluc3RhbmNlVHlwZTxUPiB7XG4gICAgcmV0dXJuIG5ldyB0aGlzKHRoaXMuZ2V0TGVuZ3RoKHNpemUpKSBhcyBJbnN0YW5jZVR5cGU8VD47XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyB0aGUgbGVuZ3RoIG9mIHRoZSB1bmRlcmx5aW5nIFR5cGVkQXJyYXkgcmVxdWlyZWQgdG8gaG9sZCB0aGUgZ2l2ZW4gYW1vdW50IG9mIGJpdHMuXG4gICAqXG4gICAqIEBwYXJhbSBzaXplIHRoZSBhbW91bnQgb2YgYml0c1xuICAgKiBAcmV0dXJuIHRoZSByZXF1aXJlZCBsZW5ndGhcbiAgICovXG4gIHN0YXRpYyBnZXRMZW5ndGgoc2l6ZTogbnVtYmVyKTogbnVtYmVyIHtcbiAgICByZXR1cm4gTWF0aC5jZWlsKHNpemUgLyAzMik7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyB0aGUgYml0IGF0IGEgZ2l2ZW4gaW5kZXguXG4gICAqXG4gICAqIEBwYXJhbSBpbmRleCB0aGUgaW5kZXhcbiAgICogQHJldHVybiB0aGUgYml0XG4gICAqL1xuICBnZXRCaXQoaW5kZXg6IG51bWJlcik6IEJpdCB7XG4gICAgY29uc3QgeyBidWNrZXQsIHBvc2l0aW9uIH0gPSB0aGlzLmdldEJpdFBvc2l0aW9uKGluZGV4KTtcbiAgICByZXR1cm4gKCh0aGlzW2J1Y2tldF0gPj4gcG9zaXRpb24pICYgMSkgYXMgQml0O1xuICB9XG5cbiAgZ2V0Qml0UG9zaXRpb24oaW5kZXg6IG51bWJlcik6IEJpdFBvc2l0aW9uIHtcbiAgICBjb25zdCBidWNrZXQgPSBpbmRleCA+PiA1O1xuICAgIHRoaXMubGFzdFBvc2l0aW9uLmJ1Y2tldCA9IGJ1Y2tldDtcbiAgICB0aGlzLmxhc3RQb3NpdGlvbi5wb3NpdGlvbiA9IGluZGV4IC0gKGJ1Y2tldCA8PCA1KTtcbiAgICByZXR1cm4gdGhpcy5sYXN0UG9zaXRpb247XG4gIH1cblxuICAvKipcbiAgICogU2V0cyB0aGUgYml0IGF0IGEgZ2l2ZW4gaW5kZXguXG4gICAqXG4gICAqIEBwYXJhbSBpbmRleCB0aGUgaW5kZXhcbiAgICogQHBhcmFtIHZhbHVlIHRoZSB2YWx1ZVxuICAgKiBAcmV0dXJuIHRoaXNcbiAgICovXG4gIHNldEJpdChpbmRleDogbnVtYmVyLCB2YWx1ZTogQml0ID0gMSk6IHRoaXMge1xuICAgIGNvbnN0IHsgYnVja2V0LCBwb3NpdGlvbiB9ID0gdGhpcy5nZXRCaXRQb3NpdGlvbihpbmRleCk7XG4gICAgdGhpc1tidWNrZXRdID0gKHRoaXNbYnVja2V0XSAmIH4oMSA8PCBwb3NpdGlvbikpIHwgKHZhbHVlIDw8IHBvc2l0aW9uKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxufVxuIl19 | ||
//# sourceMappingURL=bit-array.js.map |
export {}; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYml0LWZpZWxkLXR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYml0LWZpZWxkLXR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIEJpdEZpZWxkU3RydWN0dXJlPFxuICBLIGV4dGVuZHMgUHJvcGVydHlLZXksXG4gIE4gZXh0ZW5kcyBudW1iZXIgfCBiaWdpbnQgPSBudW1iZXIsXG4+IHtcbiAgdmFsdWU6IE47XG4gIC8qKlxuICAgKiBJdGVyYXRlcyBvdmVyIG51bWJlcnMgc3RvcmVkIGluIHRoZSBpbnN0YW5jZS5cbiAgICovXG4gIFtTeW1ib2wuaXRlcmF0b3JdKCk6IEdlbmVyYXRvcjxudW1iZXI+O1xuICAvKipcbiAgICogUmV0dXJucyB0aGUgdmFsdWUgb2YgYSBnaXZlbiBmaWVsZC5cbiAgICpcbiAgICogQHBhcmFtIGZpZWxkIHRoZSBuYW1lIG9mIHRoZSBmaWVsZFxuICAgKiBAcmV0dXJuIHZhbHVlIG9mIHRoZSBmaWVsZFxuICAgKi9cbiAgZ2V0KGZpZWxkOiBLKTogbnVtYmVyO1xuICAvKipcbiAgICogQ2hlY2tzIHdoZXRoZXIgdGhlIGluc3RhbmNlIGhhcyBhbGwgdGhlIHNwZWNpZmllZCBmaWVsZHMgc2V0IHRvIDEuIFVzZWZ1bCBmb3IgYml0IGZsYWdzLlxuICAgKlxuICAgKiBAcGFyYW0gZmllbGRzIG5hbWVzIG9mIHRoZSBmaWVsZHMgdG8gY2hlY2tcbiAgICogQHJldHVybiB3aGV0aGVyIGFsbCB0aGUgc3BlY2lmaWVkIGZpZWxkcyBhcmUgc2V0IGluIHRoZSBpbnN0YW5jZVxuICAgKi9cbiAgaGFzKC4uLmZpZWxkczogQXJyYXk8Sz4pOiBib29sZWFuO1xuICAvKipcbiAgICogQ2hlY2tzIGlmIHRoZSBpbnN0YW5jZSBjb250YWlucyBhbGwgdGhlIGtleS12YWx1ZSBwYWlycyBsaXN0ZWQgaW4gbWF0Y2hlci5cbiAgICogVXNlIGBCaWdCaXRGaWVsZC5nZXRNYXRjaGVyYCB0byBnZXQgYW4gYXJyYXkgb2YgcHJlY29tcHV0ZWQgdmFsdWVzXG4gICAqIHRoYXQgeW91IGNhbiB1c2UgdG8gZWZmaWNpZW50bHkgY29tcGFyZSBtdWx0aXBsZSBpbnN0YW5jZXNcbiAgICogdG8gdGhlIHNhbWUga2V5LXZhbHVlIHBhaXJzIGFzIHNob3duIGluIHRoZSBleGFtcGxlcyBiZWxvdy5cbiAgICpcbiAgICogQHBhcmFtIG1hdGNoZXIgYW4gb2JqZWN0IHdpdGgga2V5LXZhbHVlIHBhaXJzLCBvciBhbiBhcnJheSBvZiBwcmVjb21wdXRlZCBtYXRjaGVyIHZhbHVlc1xuICAgKiBAcmV0dXJuIHdoZXRoZXIgdGhlIGluc3RhbmNlIG1hdGNoZXMgd2l0aCB0aGUgcHJvdmlkZWQgZmllbGRzXG4gICAqL1xuICBtYXRjaChtYXRjaGVyOiBQYXJ0aWFsPFJlY29yZDxLLCBudW1iZXI+PiB8IFtOLCBOXSk6IGJvb2xlYW47XG4gIC8qKlxuICAgKiBTdG9yZXMgYSBnaXZlbiB2YWx1ZSBpbiBhIGZpZWxkLlxuICAgKlxuICAgKiBAcGFyYW0gZmllbGQgbmFtZSBvZiB0aGUgZmllbGRcbiAgICogQHBhcmFtIHZhbHVlIHZhbHVlIG9mIHRoZSBmaWVsZFxuICAgKiBAcmV0dXJuIHRoZSBpbnN0YW5jZVxuICAgKi9cbiAgc2V0KGZpZWxkOiBLLCB2YWx1ZT86IG51bWJlcik6IHRoaXM7XG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBiaWdpbnQgdmFsdWUgb2YgYW4gaW5zdGFuY2UuXG4gICAqL1xuICB0b0pTT04oKTogTjtcbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIG9iamVjdCByZXByZXNlbnRhdGlvbiBvZiB0aGUgaW5zdGFuY2UsXG4gICAqIHdpdGggZmllbGQgbmFtZXMgYXMgcHJvcGVydGllcyB3aXRoIGNvcnJlc3BvbmRpbmcgdmFsdWVzLlxuICAgKi9cbiAgdG9PYmplY3QoKTogUmVjb3JkPEssIG51bWJlcj47XG4gIC8qKlxuICAgKiBSZXR1cm5zIGEgc3RyaW5nIHJlcHJlc2VudGluZyB0aGUgdmFsdWUgb2YgdGhlIGluc3RhbmNlLlxuICAgKi9cbiAgdG9TdHJpbmcoKTogc3RyaW5nO1xuICAvKipcbiAgICogUmV0dXJucyB0aGUgYmlnaW50IHZhbHVlIG9mIGFuIGluc3RhbmNlLlxuICAgKi9cbiAgdmFsdWVPZigpOiBOO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEJpdEZpZWxkQ29uc3RydWN0b3I8XG4gIEsgZXh0ZW5kcyBQcm9wZXJ0eUtleSxcbiAgTiBleHRlbmRzIG51bWJlciB8IGJpZ2ludCA9IG51bWJlcixcbj4ge1xuICBzY2hlbWE6IFJlY29yZDxLLCBOPjtcbiAgZmllbGRzOiBBcnJheTxLPjtcbiAgbWFza3M6IFJlY29yZDxLLCBOPjtcbiAgb2Zmc2V0czogUmVjb3JkPEssIE4+O1xuICBtYXNrOiBOO1xuICBzaXplOiBOO1xuICAvKipcbiAgICogQHBhcmFtIGRhdGEgYSBzaW5nbGUgbnVtZXJpY2FsIHZhbHVlIG9mIHRoZSBiaXRmaWVsZCxcbiAgICogYSBiaXRmaWVsZCwgb3IgYSBtYXAgb2YgZmllbGQgbmFtZXMgd2l0aCB0aGVpciByZXNwZWN0aXZlIHZhbHVlc1xuICAgKi9cbiAgbmV3IChcbiAgICBkYXRhPzogTiB8IEJpdEZpZWxkU3RydWN0dXJlPEssIE4+IHwgQXJyYXk8bnVtYmVyPiB8IFJlY29yZDxLLCBudW1iZXI+LFxuICApOiBCaXRGaWVsZFN0cnVjdHVyZTxLLCBOPjtcbiAgLyoqXG4gICAqIERlY29kZXMgYSBudW1lcmljIHZhbHVlIGludG8gaXRzIG9iamVjdCByZXByZXNlbnRhdGlvbiBhY2NvcmRpbmcgdG8gdGhlIHNjaGVtYS5cbiAgICpcbiAgICogQHBhcmFtIGRhdGEgYSBudW1lcmljIHZhbHVlXG4gICAqIEByZXR1cm4gb2JqZWN0IHJlcHJlc2VudGF0aW9uXG4gICAqL1xuICBkZWNvZGUoZGF0YTogTik6IFJlY29yZDxLLCBudW1iZXI+O1xuICAvKipcbiAgICogRW5jb2RlcyBhIGdpdmVuIGxpc3Qgb2YgbnVtYmVycyBvciBtYXAgb2YgZmllbGRzIGFuZCB0aGVpciByZXNwZWN0aXZlIHZhbHVlc1xuICAgKiBpbnRvIGEgc2luZ2xlIG51bWVyaWMgdmFsdWUgYWNjb3JkaW5nIHRvIHRoZSBzY2hlbWEuXG4gICAqXG4gICAqIEBwYXJhbSBkYXRhIGEgbGlzdCBvZiBudW1iZXJzIG9yIGFuIG9iamVjdCB0byBlbmNvZGVcbiAgICogQHJldHVybiBlbmNvZGVkIG51bWVyaWMgdmFsdWVcbiAgICovXG4gIGVuY29kZShkYXRhOiBBcnJheTxudW1iZXI+IHwgUmVjb3JkPEssIG51bWJlcj4pOiBOO1xuICAvKipcbiAgICogQ3JlYXRlcyBhIHR1cGxlIG9mIHZhbHVlcyB0byBiZSB1c2VkIGFzIGEgbWF0Y2hlclxuICAgKiB0byBlZmZpY2llbnRseSBtYXRjaCBhZ2FpbnN0IG11bHRpcGxlIGluc3RhbmNlcy5cbiAgICpcbiAgICogQHBhcmFtIG1hdGNoZXIgYW4gb2JqZWN0IGNvbnRhaW5pbmcgZmllbGQgbmFtZXMgYW5kIHRoZWlyIHZhbHVlc1xuICAgKiBAcmV0dXJuIGEgdHVwbGUgb2YgcHJlY29tcHV0ZWQgdmFsdWVzXG4gICAqL1xuICBnZXRNYXRjaGVyKG1hdGNoZXI6IFBhcnRpYWw8UmVjb3JkPEssIG51bWJlcj4+KTogW04sIE5dO1xuICAvKipcbiAgICogUmV0dXJucyB0aGUgbWluaW11bSBhbW91bnQgb2YgYml0cyBuZWNlc3NhcnkgdG8gaG9sZCBhIGdpdmVuIG51bWJlci5cbiAgICpcbiAgICogQHBhcmFtIG51bWJlclxuICAgKiBAcmV0dXJuIHRoZSBhbW91bnQgb2YgYml0c1xuICAgKi9cbiAgZ2V0TWluU2l6ZSh2YWx1ZTogbnVtYmVyKTogbnVtYmVyO1xuICAvKipcbiAgICogQ2hlY2tzIGlmIGEgZ2l2ZW4gc2V0IG9mIHZhbHVlcyBhcmUgdmFsaWQgYWNjb3JkaW5nIHRvIHRoZSBzY2hlbWEuXG4gICAqXG4gICAqIEBwYXJhbSBkYXRhIGEgbWFwIG9mIGZpZWxkIG5hbWVzIGFuZCB0aGVpciB2YWx1ZXMgdG8gY2hlY2tcbiAgICogQHJldHVybiB3aGV0aGVyIGFsbCBwYWlycyBhcmUgdmFsaWRcbiAgICovXG4gIGlzVmFsaWQoZGF0YTogUGFydGlhbDxSZWNvcmQ8SywgbnVtYmVyPj4pOiBib29sZWFuO1xuICAvKipcbiAgICogVGhlIHN0YXRpYyB2ZXJzaW9uIG9mIGBCaXRGaWVsZCNtYXRjaGAsIG1hdGNoZXMgYSBnaXZlbiB2YWx1ZSBhZ2FpbnN0IGEgcHJlY29tcHV0ZWQgbWF0Y2hlci5cbiAgICpcbiAgICogQHBhcmFtIHZhbHVlIGEgdmFsdWUgdG8gY2hlY2tcbiAgICogQHBhcmFtIG1hdGNoZXIgYSBwcmVjb21wdXRlZCBzZXQgb2YgdmFsdWVzXG4gICAqL1xuICBtYXRjaCh2YWx1ZTogTiwgbWF0Y2hlcjogW04sIE5dKTogYm9vbGVhbjtcbn1cbiJdfQ== | ||
//# sourceMappingURL=bit-field-types.js.map |
@@ -5,9 +5,10 @@ import { getBitSize } from "./utilities.js"; | ||
class BitField { | ||
static schema; | ||
static fields; | ||
static masks; | ||
static offsets; | ||
static mask = 2 << 30; | ||
static size = 31; | ||
value = 0; | ||
constructor(data = 0) { | ||
Object.defineProperty(this, "value", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: 0 | ||
}); | ||
this.value = typeof data === "number" | ||
@@ -123,37 +124,3 @@ ? data | ||
} | ||
Object.defineProperty(BitField, "mask", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: 2 << 30 | ||
}); | ||
Object.defineProperty(BitField, "size", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: 31 | ||
}); | ||
/** | ||
* Creates a BitField class from with a given schema. BitField uses numbers as bitfields | ||
* to store and operate on data using bitwise operations. The size of the field is limited to 31 bits, | ||
* for a larger bitfields consider using BigBitField class that uses bigints instead. | ||
* | ||
* @param schema the schema | ||
* @returns the BitFieldClass | ||
* | ||
* @example | ||
* const Field = BitFieldMixin({ width: 8, height: 8 }); | ||
* const field = new Field({ width: 100, height: 200 }); | ||
* field.get('width'); | ||
* //=> 100; | ||
* field.get('height'); | ||
* //=> 200 | ||
* field.set('width', 18); | ||
* field.get('width'); | ||
* //=> 18 | ||
* field.toObject(); | ||
* //=> { width: 18, height: 200 } | ||
*/ | ||
export function BitFieldMixin(schema) { | ||
var _a; | ||
const fields = Object.keys(schema); | ||
@@ -173,44 +140,10 @@ const masks = {}; | ||
} | ||
return _a = class extends BitField { | ||
constructor() { | ||
super(...arguments); | ||
Object.defineProperty(this, "size", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: lastOffset | ||
}); | ||
Object.defineProperty(this, "mask", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: 2 << (lastOffset - 1) | ||
}); | ||
} | ||
}, | ||
Object.defineProperty(_a, "schema", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: schema | ||
}), | ||
Object.defineProperty(_a, "fields", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: fields | ||
}), | ||
Object.defineProperty(_a, "masks", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: masks | ||
}), | ||
Object.defineProperty(_a, "offsets", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: offsets | ||
}), | ||
_a; | ||
return class extends BitField { | ||
static schema = schema; | ||
static fields = fields; | ||
static masks = masks; | ||
static offsets = offsets; | ||
size = lastOffset; | ||
mask = 2 << (lastOffset - 1); | ||
}; | ||
} | ||
@@ -251,3 +184,3 @@ const _BitField = BitFieldMixin({ | ||
export { _BitField as BitField }; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYml0LWZpZWxkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYml0LWZpZWxkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQU01QyxNQUFNLFFBQVEsR0FBRyxVQUFVLENBQUM7QUFDNUIsTUFBTSxnQkFBZ0IsR0FBRyxFQUFFLENBQUM7QUFFNUIsTUFBTSxRQUFRO0lBR1osTUFBTSxDQUFDLE1BQU0sQ0FBOEI7SUFDM0MsTUFBTSxDQUFDLE1BQU0sQ0FBcUI7SUFDbEMsTUFBTSxDQUFDLEtBQUssQ0FBOEI7SUFDMUMsTUFBTSxDQUFDLE9BQU8sQ0FBOEI7SUFDNUMsTUFBTSxDQUFDLElBQUksR0FBRyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3RCLE1BQU0sQ0FBQyxJQUFJLEdBQUcsRUFBRSxDQUFDO0lBQ2pCLEtBQUssR0FBRyxDQUFDLENBQUM7SUFFVixZQUNFLE9BQWlFLENBQUM7UUFFbEUsSUFBSSxDQUFDLEtBQUssR0FBRyxPQUFPLElBQUksS0FBSyxRQUFRO1lBQ25DLENBQUMsQ0FBQyxJQUFJO1lBQ04sQ0FBQyxDQUFDLElBQUksWUFBWSxRQUFRO2dCQUMxQixDQUFDLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtnQkFDaEIsQ0FBQyxDQUFFLElBQUksQ0FBQyxXQUErQixDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN6RCxDQUFDO0lBRUQsTUFBTSxDQUFDLE1BQU0sQ0FDWCxJQUFZO1FBRVosTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQTJCLENBQUM7UUFDaEQsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQWtCLENBQUM7UUFDdkMsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQTBCLENBQUM7UUFDOUMsTUFBTSxNQUFNLEdBQUcsRUFBdUIsQ0FBQztRQUN2QyxJQUFJLEtBQUssR0FBRyxJQUFJLENBQUM7UUFDakIsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUU7WUFDdEMsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ3hCLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUMzQixNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsS0FBSyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNyQyxLQUFLLEtBQUssSUFBSSxDQUFDO1NBQ2hCO1FBQ0QsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQztJQUVELE1BQU0sQ0FBQyxNQUFNLENBQ1gsSUFBdUM7UUFFdkMsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQTJCLENBQUM7UUFDaEQsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQWtCLENBQUM7UUFDdkMsTUFBTSxLQUFLLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7WUFDL0IsQ0FBQyxDQUFDLElBQUk7WUFDTixDQUFDLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1FBQzFDLElBQUksTUFBTSxHQUFHLENBQUMsQ0FBQztRQUNmLEtBQUssSUFBSSxDQUFDLEdBQUcsTUFBTSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRTtZQUMzQyxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDeEIsTUFBTSxPQUFPLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ3pCLE1BQU0sS0FBSyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDekIsTUFBTSxJQUFJLE9BQU8sQ0FBQztTQUNuQjtRQUNELE9BQU8sTUFBTSxDQUFDO0lBQ2hCLENBQUM7SUFFRCxNQUFNLENBQUMsVUFBVSxDQUNmLE9BQW1DO1FBRW5DLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxLQUEwQixDQUFDO1FBQzlDLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxPQUE0QixDQUFDO1FBQ2xELE1BQU0sTUFBTSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFhLENBQUM7UUFDaEQsSUFBSSxJQUFJLEdBQUcsQ0FBQyxDQUFDO1FBQ2IsSUFBSSxLQUFLLEdBQUcsQ0FBQyxDQUFDO1FBQ2QsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUU7WUFDdEMsTUFBTSxTQUFTLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQzVCLE1BQU0sU0FBUyxHQUFHLEtBQUssQ0FBQyxTQUFTLENBQUMsSUFBSSxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDekQsTUFBTSxVQUFVLEdBQUcsT0FBTyxDQUFDLFNBQVMsQ0FBRSxDQUFDO1lBQ3ZDLEtBQUssR0FBRyxDQUFDLEtBQUssR0FBRyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsVUFBVSxJQUFJLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDO1lBQ2xFLElBQUksSUFBSSxTQUFTLENBQUM7U0FDbkI7UUFDRCxPQUFPLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLENBQUM7SUFDbkMsQ0FBQztJQUVELE1BQU0sQ0FBQyxVQUFVLENBQUMsTUFBYztRQUM5QixPQUFPLFVBQVUsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUM1QixDQUFDO0lBRUQsTUFBTSxDQUFDLE9BQU8sQ0FDWixJQUFPO1FBRVAsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQVUsQ0FBQztRQUM5QixNQUFNLE1BQU0sR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBYSxDQUFDO1FBQzdDLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxNQUFNLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFO1lBQ3RDLE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN4QixNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDMUIsSUFBSSxDQUFDLEtBQUssR0FBRyxRQUFRLENBQUMsS0FBSyxLQUFLLElBQUksS0FBSyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUM7Z0JBQUUsT0FBTyxLQUFLLENBQUM7U0FDeEU7UUFDRCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxNQUFNLENBQUMsS0FBSyxDQUFDLEtBQWEsRUFBRSxPQUF5QjtRQUNuRCxPQUFPLENBQUMsS0FBSyxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBRUQsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUM7UUFDaEIsTUFBTSxNQUFNLEdBQUksSUFBSSxDQUFDLFdBQXNDLENBQUMsTUFBTSxDQUFDO1FBQ25FLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxNQUFNLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFO1lBQ3RDLE1BQU0sSUFBSSxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztTQUMzQjtJQUNILENBQUM7SUFFRCxHQUFHLENBQUMsS0FBUTtRQUNWLE1BQU0sRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLEdBQUcsSUFBSSxDQUFDLFdBQXFDLENBQUM7UUFDdEUsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLElBQUksT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3ZELENBQUM7SUFFRCxHQUFHLENBQUMsR0FBRyxNQUFnQjtRQUNyQixNQUFNLEVBQUUsT0FBTyxFQUFFLEdBQUcsSUFBSSxDQUFDLFdBQXFDLENBQUM7UUFDL0QsSUFBSSxJQUFJLEdBQUcsQ0FBQyxDQUFDO1FBQ2IsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUU7WUFDdEMsSUFBSSxJQUFJLENBQUMsSUFBSSxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDakM7UUFDRCxJQUFJLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQztRQUNuQixPQUFPLElBQUksQ0FBQyxLQUFLLEtBQUssSUFBSSxDQUFDO0lBQzdCLENBQUM7SUFFRCxLQUFLLENBQUMsT0FBc0Q7UUFDMUQsT0FBUSxJQUFJLENBQUMsV0FBc0MsQ0FBQyxLQUFLLENBQ3ZELElBQUksQ0FBQyxLQUFLLEVBQ1YsS0FBSyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUM7WUFDcEIsQ0FBQyxDQUFDLE9BQU87WUFDVCxDQUFDLENBQUUsSUFBSSxDQUFDLFdBQXNDLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUNyRSxDQUFDO0lBQ0osQ0FBQztJQUVELEdBQUcsQ0FBQyxLQUFRLEVBQUUsS0FBSyxHQUFHLENBQUM7UUFDckIsTUFBTSxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsR0FBRyxJQUFJLENBQUMsV0FBcUMsQ0FBQztRQUN0RSxJQUFJLENBQUMsS0FBSyxHQUFHLENBQUMsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxJQUFJLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1lBQzNELENBQUMsS0FBSyxJQUFJLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1FBQzVCLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELE1BQU07UUFDSixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDcEIsQ0FBQztJQUVELFFBQVE7UUFDTixPQUFRLElBQUksQ0FBQyxXQUFzQyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDekUsQ0FBQztJQUVELFFBQVE7UUFDTixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDL0IsQ0FBQztJQUVELE9BQU87UUFDTCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDcEIsQ0FBQzs7QUF3QkgsTUFBTSxVQUFVLGFBQWEsQ0FHM0IsTUFBUztJQUNULE1BQU0sTUFBTSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFhLENBQUM7SUFDL0MsTUFBTSxLQUFLLEdBQUcsRUFBdUIsQ0FBQztJQUN0QyxNQUFNLE9BQU8sR0FBRyxFQUF1QixDQUFDO0lBQ3hDLElBQUksVUFBVSxHQUFHLENBQUMsQ0FBQztJQUNuQixLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsTUFBTSxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRTtRQUN0QyxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDeEIsTUFBTSxJQUFJLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzNCLEtBQUssQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNyQyxPQUFPLENBQUMsS0FBSyxDQUFDLEdBQUcsVUFBVSxDQUFDO1FBQzVCLFVBQVUsSUFBSSxJQUFJLENBQUM7S0FDcEI7SUFDRCxJQUFJLFVBQVUsR0FBRyxnQkFBZ0IsRUFBRTtRQUNqQyxNQUFNLFNBQVMsQ0FBQyxpREFBaUQsQ0FBQyxDQUFDO0tBQ3BFO0lBRUQsT0FBTyxLQUFNLFNBQVEsUUFBVztRQUM5QixNQUFNLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUN2QixNQUFNLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUN2QixNQUFNLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNyQixNQUFNLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztRQUN6QixJQUFJLEdBQUcsVUFBVSxDQUFDO1FBQ2xCLElBQUksR0FBRyxDQUFDLElBQUksQ0FBQyxVQUFVLEdBQUcsQ0FBQyxDQUFDLENBQUM7S0FDOUIsQ0FBQztBQUNKLENBQUM7QUFFRCxNQUFNLFNBQVMsR0FBRyxhQUFhLENBQUM7SUFDOUIsQ0FBQyxFQUFFLENBQUM7SUFDSixDQUFDLEVBQUUsQ0FBQztJQUNKLENBQUMsRUFBRSxDQUFDO0lBQ0osQ0FBQyxFQUFFLENBQUM7SUFDSixDQUFDLEVBQUUsQ0FBQztJQUNKLENBQUMsRUFBRSxDQUFDO0lBQ0osQ0FBQyxFQUFFLENBQUM7SUFDSixDQUFDLEVBQUUsQ0FBQztJQUNKLENBQUMsRUFBRSxDQUFDO0lBQ0osQ0FBQyxFQUFFLENBQUM7SUFDSixFQUFFLEVBQUUsQ0FBQztJQUNMLEVBQUUsRUFBRSxDQUFDO0lBQ0wsRUFBRSxFQUFFLENBQUM7SUFDTCxFQUFFLEVBQUUsQ0FBQztJQUNMLEVBQUUsRUFBRSxDQUFDO0lBQ0wsRUFBRSxFQUFFLENBQUM7SUFDTCxFQUFFLEVBQUUsQ0FBQztJQUNMLEVBQUUsRUFBRSxDQUFDO0lBQ0wsRUFBRSxFQUFFLENBQUM7SUFDTCxFQUFFLEVBQUUsQ0FBQztJQUNMLEVBQUUsRUFBRSxDQUFDO0lBQ0wsRUFBRSxFQUFFLENBQUM7SUFDTCxFQUFFLEVBQUUsQ0FBQztJQUNMLEVBQUUsRUFBRSxDQUFDO0lBQ0wsRUFBRSxFQUFFLENBQUM7SUFDTCxFQUFFLEVBQUUsQ0FBQztJQUNMLEVBQUUsRUFBRSxDQUFDO0lBQ0wsRUFBRSxFQUFFLENBQUM7SUFDTCxFQUFFLEVBQUUsQ0FBQztJQUNMLEVBQUUsRUFBRSxDQUFDO0lBQ0wsRUFBRSxFQUFFLENBQUM7Q0FDTixDQUFDLENBQUM7QUFFSCxPQUFPLEVBQUUsU0FBUyxJQUFJLFFBQVEsRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0Qml0U2l6ZSB9IGZyb20gXCIuL3V0aWxpdGllcy50c1wiO1xuaW1wb3J0IHR5cGUge1xuICBCaXRGaWVsZENvbnN0cnVjdG9yLFxuICBCaXRGaWVsZFN0cnVjdHVyZSxcbn0gZnJvbSBcIi4vYml0LWZpZWxkLXR5cGVzLnRzXCI7XG5cbmNvbnN0IFNJR05fQklUID0gMjE0NzQ4MzY0NztcbmNvbnN0IE1BWF9CSVRXSVNFX1NJWkUgPSAzMTtcblxuY2xhc3MgQml0RmllbGQ8XG4gIEsgZXh0ZW5kcyBQcm9wZXJ0eUtleSxcbj4gaW1wbGVtZW50cyBCaXRGaWVsZFN0cnVjdHVyZTxLLCBudW1iZXI+IHtcbiAgc3RhdGljIHNjaGVtYTogUmVjb3JkPFByb3BlcnR5S2V5LCBudW1iZXI+O1xuICBzdGF0aWMgZmllbGRzOiBBcnJheTxQcm9wZXJ0eUtleT47XG4gIHN0YXRpYyBtYXNrczogUmVjb3JkPFByb3BlcnR5S2V5LCBudW1iZXI+O1xuICBzdGF0aWMgb2Zmc2V0czogUmVjb3JkPFByb3BlcnR5S2V5LCBudW1iZXI+O1xuICBzdGF0aWMgbWFzayA9IDIgPDwgMzA7XG4gIHN0YXRpYyBzaXplID0gMzE7XG4gIHZhbHVlID0gMDtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBkYXRhOiBudW1iZXIgfCBCaXRGaWVsZDxLPiB8IEFycmF5PG51bWJlcj4gfCBSZWNvcmQ8SywgbnVtYmVyPiA9IDAsXG4gICkge1xuICAgIHRoaXMudmFsdWUgPSB0eXBlb2YgZGF0YSA9PT0gXCJudW1iZXJcIlxuICAgICAgPyBkYXRhXG4gICAgICA6IGRhdGEgaW5zdGFuY2VvZiBCaXRGaWVsZFxuICAgICAgPyBkYXRhLnZhbHVlT2YoKVxuICAgICAgOiAodGhpcy5jb25zdHJ1Y3RvciBhcyB0eXBlb2YgQml0RmllbGQpLmVuY29kZShkYXRhKTtcbiAgfVxuXG4gIHN0YXRpYyBkZWNvZGU8SyBleHRlbmRzIFByb3BlcnR5S2V5PihcbiAgICBkYXRhOiBudW1iZXIsXG4gICk6IFJlY29yZDxLLCBudW1iZXI+IHtcbiAgICBjb25zdCBzY2hlbWEgPSB0aGlzLnNjaGVtYSBhcyBSZWNvcmQ8SywgbnVtYmVyPjtcbiAgICBjb25zdCBmaWVsZHMgPSB0aGlzLmZpZWxkcyBhcyBBcnJheTxLPjtcbiAgICBjb25zdCBtYXNrcyA9IHRoaXMubWFza3MgYXMgUmVjb3JkPEssIG51bWJlcj47XG4gICAgY29uc3QgcmVzdWx0ID0ge30gYXMgUmVjb3JkPEssIG51bWJlcj47XG4gICAgbGV0IHZhbHVlID0gZGF0YTtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IGZpZWxkcy5sZW5ndGg7IGkrKykge1xuICAgICAgY29uc3QgZmllbGQgPSBmaWVsZHNbaV07XG4gICAgICBjb25zdCBzaXplID0gc2NoZW1hW2ZpZWxkXTtcbiAgICAgIHJlc3VsdFtmaWVsZF0gPSB2YWx1ZSAmIG1hc2tzW2ZpZWxkXTtcbiAgICAgIHZhbHVlID4+PSBzaXplO1xuICAgIH1cbiAgICByZXR1cm4gcmVzdWx0O1xuICB9XG5cbiAgc3RhdGljIGVuY29kZTxLIGV4dGVuZHMgUHJvcGVydHlLZXk+KFxuICAgIGRhdGE6IEFycmF5PG51bWJlcj4gfCBSZWNvcmQ8SywgbnVtYmVyPixcbiAgKTogbnVtYmVyIHtcbiAgICBjb25zdCBzY2hlbWEgPSB0aGlzLnNjaGVtYSBhcyBSZWNvcmQ8SywgbnVtYmVyPjtcbiAgICBjb25zdCBmaWVsZHMgPSB0aGlzLmZpZWxkcyBhcyBBcnJheTxLPjtcbiAgICBjb25zdCBhcnJheSA9IEFycmF5LmlzQXJyYXkoZGF0YSlcbiAgICAgID8gZGF0YVxuICAgICAgOiBmaWVsZHMubWFwKChuYW1lKSA9PiBkYXRhW25hbWVdIHx8IDApO1xuICAgIGxldCByZXN1bHQgPSAwO1xuICAgIGZvciAobGV0IGkgPSBmaWVsZHMubGVuZ3RoIC0gMTsgaSA+PSAwOyBpLS0pIHtcbiAgICAgIGNvbnN0IGZpZWxkID0gZmllbGRzW2ldO1xuICAgICAgY29uc3QgY3VycmVudCA9IGFycmF5W2ldO1xuICAgICAgcmVzdWx0IDw8PSBzY2hlbWFbZmllbGRdO1xuICAgICAgcmVzdWx0IHw9IGN1cnJlbnQ7XG4gICAgfVxuICAgIHJldHVybiByZXN1bHQ7XG4gIH1cblxuICBzdGF0aWMgZ2V0TWF0Y2hlcjxLIGV4dGVuZHMgUHJvcGVydHlLZXk+KFxuICAgIG1hdGNoZXI6IFBhcnRpYWw8UmVjb3JkPEssIG51bWJlcj4+LFxuICApOiBbbnVtYmVyLCBudW1iZXJdIHtcbiAgICBjb25zdCBtYXNrcyA9IHRoaXMubWFza3MgYXMgUmVjb3JkPEssIG51bWJlcj47XG4gICAgY29uc3Qgb2Zmc2V0cyA9IHRoaXMub2Zmc2V0cyBhcyBSZWNvcmQ8SywgbnVtYmVyPjtcbiAgICBjb25zdCBmaWVsZHMgPSBPYmplY3Qua2V5cyhtYXRjaGVyKSBhcyBBcnJheTxLPjtcbiAgICBsZXQgbWFzayA9IDA7XG4gICAgbGV0IHZhbHVlID0gMDtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IGZpZWxkcy5sZW5ndGg7IGkrKykge1xuICAgICAgY29uc3QgZmllbGROYW1lID0gZmllbGRzW2ldO1xuICAgICAgY29uc3QgZmllbGRNYXNrID0gbWFza3NbZmllbGROYW1lXSA8PCBvZmZzZXRzW2ZpZWxkTmFtZV07XG4gICAgICBjb25zdCBmaWVsZFZhbHVlID0gbWF0Y2hlcltmaWVsZE5hbWVdITtcbiAgICAgIHZhbHVlID0gKHZhbHVlICYgfmZpZWxkTWFzaykgfCAoZmllbGRWYWx1ZSA8PCBvZmZzZXRzW2ZpZWxkTmFtZV0pO1xuICAgICAgbWFzayB8PSBmaWVsZE1hc2s7XG4gICAgfVxuICAgIHJldHVybiBbdmFsdWUsIHRoaXMubWFzayBeIG1hc2tdO1xuICB9XG5cbiAgc3RhdGljIGdldE1pblNpemUobnVtYmVyOiBudW1iZXIpOiBudW1iZXIge1xuICAgIHJldHVybiBnZXRCaXRTaXplKG51bWJlcik7XG4gIH1cblxuICBzdGF0aWMgaXNWYWxpZDxUIGV4dGVuZHMgUmVjb3JkPEssIG51bWJlcj4sIEsgZXh0ZW5kcyBrZXlvZiBUPihcbiAgICBkYXRhOiBULFxuICApOiBib29sZWFuIHtcbiAgICBjb25zdCBtYXNrcyA9IHRoaXMubWFza3MgYXMgVDtcbiAgICBjb25zdCBmaWVsZHMgPSBPYmplY3Qua2V5cyhkYXRhKSBhcyBBcnJheTxLPjtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IGZpZWxkcy5sZW5ndGg7IGkrKykge1xuICAgICAgY29uc3QgZmllbGQgPSBmaWVsZHNbaV07XG4gICAgICBjb25zdCB2YWx1ZSA9IGRhdGFbZmllbGRdO1xuICAgICAgaWYgKCh2YWx1ZSAmIFNJR05fQklUKSAhPT0gdmFsdWUgfHwgdmFsdWUgPiBtYXNrc1tmaWVsZF0pIHJldHVybiBmYWxzZTtcbiAgICB9XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICBzdGF0aWMgbWF0Y2godmFsdWU6IG51bWJlciwgbWF0Y2hlcjogW251bWJlciwgbnVtYmVyXSk6IGJvb2xlYW4ge1xuICAgIHJldHVybiAodmFsdWUgJiBtYXRjaGVyWzFdKSA9PT0gbWF0Y2hlclswXTtcbiAgfVxuXG4gICpbU3ltYm9sLml0ZXJhdG9yXSgpOiBHZW5lcmF0b3I8bnVtYmVyPiB7XG4gICAgY29uc3QgZmllbGRzID0gKHRoaXMuY29uc3RydWN0b3IgYXMgQml0RmllbGRDb25zdHJ1Y3RvcjxLPikuZmllbGRzO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgZmllbGRzLmxlbmd0aDsgaSsrKSB7XG4gICAgICB5aWVsZCB0aGlzLmdldChmaWVsZHNbaV0pO1xuICAgIH1cbiAgfVxuXG4gIGdldChmaWVsZDogSyk6IG51bWJlciB7XG4gICAgY29uc3QgeyBvZmZzZXRzLCBtYXNrcyB9ID0gdGhpcy5jb25zdHJ1Y3RvciBhcyBCaXRGaWVsZENvbnN0cnVjdG9yPEs+O1xuICAgIHJldHVybiAodGhpcy52YWx1ZSA+PiBvZmZzZXRzW2ZpZWxkXSkgJiBtYXNrc1tmaWVsZF07XG4gIH1cblxuICBoYXMoLi4uZmllbGRzOiBBcnJheTxLPik6IGJvb2xlYW4ge1xuICAgIGNvbnN0IHsgb2Zmc2V0cyB9ID0gdGhpcy5jb25zdHJ1Y3RvciBhcyBCaXRGaWVsZENvbnN0cnVjdG9yPEs+O1xuICAgIGxldCBtYXNrID0gMDtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IGZpZWxkcy5sZW5ndGg7IGkrKykge1xuICAgICAgbWFzayB8PSAxIDw8IG9mZnNldHNbZmllbGRzW2ldXTtcbiAgICB9XG4gICAgbWFzayB8PSB0aGlzLnZhbHVlO1xuICAgIHJldHVybiB0aGlzLnZhbHVlID09PSBtYXNrO1xuICB9XG5cbiAgbWF0Y2gobWF0Y2hlcjogUGFydGlhbDxSZWNvcmQ8SywgbnVtYmVyPj4gfCBbbnVtYmVyLCBudW1iZXJdKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuICh0aGlzLmNvbnN0cnVjdG9yIGFzIEJpdEZpZWxkQ29uc3RydWN0b3I8Sz4pLm1hdGNoKFxuICAgICAgdGhpcy52YWx1ZSxcbiAgICAgIEFycmF5LmlzQXJyYXkobWF0Y2hlcilcbiAgICAgICAgPyBtYXRjaGVyXG4gICAgICAgIDogKHRoaXMuY29uc3RydWN0b3IgYXMgQml0RmllbGRDb25zdHJ1Y3RvcjxLPikuZ2V0TWF0Y2hlcihtYXRjaGVyKSxcbiAgICApO1xuICB9XG5cbiAgc2V0KGZpZWxkOiBLLCB2YWx1ZSA9IDEpOiB0aGlzIHtcbiAgICBjb25zdCB7IG9mZnNldHMsIG1hc2tzIH0gPSB0aGlzLmNvbnN0cnVjdG9yIGFzIEJpdEZpZWxkQ29uc3RydWN0b3I8Sz47XG4gICAgdGhpcy52YWx1ZSA9ICh0aGlzLnZhbHVlICYgfihtYXNrc1tmaWVsZF0gPDwgb2Zmc2V0c1tmaWVsZF0pKSB8XG4gICAgICAodmFsdWUgPDwgb2Zmc2V0c1tmaWVsZF0pO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgdG9KU09OKCkge1xuICAgIHJldHVybiB0aGlzLnZhbHVlO1xuICB9XG5cbiAgdG9PYmplY3QoKTogUmVjb3JkPEssIG51bWJlcj4ge1xuICAgIHJldHVybiAodGhpcy5jb25zdHJ1Y3RvciBhcyBCaXRGaWVsZENvbnN0cnVjdG9yPEs+KS5kZWNvZGUodGhpcy52YWx1ZSk7XG4gIH1cblxuICB0b1N0cmluZygpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLnZhbHVlLnRvU3RyaW5nKCk7XG4gIH1cblxuICB2YWx1ZU9mKCk6IG51bWJlciB7XG4gICAgcmV0dXJuIHRoaXMudmFsdWU7XG4gIH1cbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgQml0RmllbGQgY2xhc3MgZnJvbSB3aXRoIGEgZ2l2ZW4gc2NoZW1hLiBCaXRGaWVsZCB1c2VzIG51bWJlcnMgYXMgYml0ZmllbGRzXG4gKiB0byBzdG9yZSBhbmQgb3BlcmF0ZSBvbiBkYXRhIHVzaW5nIGJpdHdpc2Ugb3BlcmF0aW9ucy4gVGhlIHNpemUgb2YgdGhlIGZpZWxkIGlzIGxpbWl0ZWQgdG8gMzEgYml0cyxcbiAqIGZvciBhIGxhcmdlciBiaXRmaWVsZHMgY29uc2lkZXIgdXNpbmcgQmlnQml0RmllbGQgY2xhc3MgdGhhdCB1c2VzIGJpZ2ludHMgaW5zdGVhZC5cbiAqXG4gKiBAcGFyYW0gc2NoZW1hIHRoZSBzY2hlbWFcbiAqIEByZXR1cm5zIHRoZSBCaXRGaWVsZENsYXNzXG4gKlxuICogQGV4YW1wbGVcbiAqIGNvbnN0IEZpZWxkID0gQml0RmllbGRNaXhpbih7IHdpZHRoOiA4LCBoZWlnaHQ6IDggfSk7XG4gKiBjb25zdCBmaWVsZCA9IG5ldyBGaWVsZCh7IHdpZHRoOiAxMDAsIGhlaWdodDogMjAwIH0pO1xuICogZmllbGQuZ2V0KCd3aWR0aCcpO1xuICogLy89PiAxMDA7XG4gKiBmaWVsZC5nZXQoJ2hlaWdodCcpO1xuICogLy89PiAyMDBcbiAqIGZpZWxkLnNldCgnd2lkdGgnLCAxOCk7XG4gKiBmaWVsZC5nZXQoJ3dpZHRoJyk7XG4gKiAvLz0+IDE4XG4gKiBmaWVsZC50b09iamVjdCgpO1xuICogLy89PiB7IHdpZHRoOiAxOCwgaGVpZ2h0OiAyMDAgfVxuICovXG5leHBvcnQgZnVuY3Rpb24gQml0RmllbGRNaXhpbjxcbiAgVCBleHRlbmRzIFJlY29yZDxLLCBudW1iZXI+LFxuICBLIGV4dGVuZHMga2V5b2YgVCxcbj4oc2NoZW1hOiBUKTogQml0RmllbGRDb25zdHJ1Y3RvcjxLPiB7XG4gIGNvbnN0IGZpZWxkcyA9IE9iamVjdC5rZXlzKHNjaGVtYSkgYXMgQXJyYXk8Sz47XG4gIGNvbnN0IG1hc2tzID0ge30gYXMgUmVjb3JkPEssIG51bWJlcj47XG4gIGNvbnN0IG9mZnNldHMgPSB7fSBhcyBSZWNvcmQ8SywgbnVtYmVyPjtcbiAgbGV0IGxhc3RPZmZzZXQgPSAwO1xuICBmb3IgKGxldCBpID0gMDsgaSA8IGZpZWxkcy5sZW5ndGg7IGkrKykge1xuICAgIGNvbnN0IGZpZWxkID0gZmllbGRzW2ldO1xuICAgIGNvbnN0IHNpemUgPSBzY2hlbWFbZmllbGRdO1xuICAgIG1hc2tzW2ZpZWxkXSA9ICgyIDw8IChzaXplIC0gMSkpIC0gMTtcbiAgICBvZmZzZXRzW2ZpZWxkXSA9IGxhc3RPZmZzZXQ7XG4gICAgbGFzdE9mZnNldCArPSBzaXplO1xuICB9XG4gIGlmIChsYXN0T2Zmc2V0ID4gTUFYX0JJVFdJU0VfU0laRSkge1xuICAgIHRocm93IFR5cGVFcnJvcihcIlRoZSB0b3RhbCBzaXplIG9mIHRoZSBiaXRmaWVsZCBleGNlZWRzIDMxIGJpdHMuXCIpO1xuICB9XG5cbiAgcmV0dXJuIGNsYXNzIGV4dGVuZHMgQml0RmllbGQ8Sz4ge1xuICAgIHN0YXRpYyBzY2hlbWEgPSBzY2hlbWE7XG4gICAgc3RhdGljIGZpZWxkcyA9IGZpZWxkcztcbiAgICBzdGF0aWMgbWFza3MgPSBtYXNrcztcbiAgICBzdGF0aWMgb2Zmc2V0cyA9IG9mZnNldHM7XG4gICAgc2l6ZSA9IGxhc3RPZmZzZXQ7XG4gICAgbWFzayA9IDIgPDwgKGxhc3RPZmZzZXQgLSAxKTtcbiAgfTtcbn1cblxuY29uc3QgX0JpdEZpZWxkID0gQml0RmllbGRNaXhpbih7XG4gIDA6IDEsXG4gIDE6IDEsXG4gIDI6IDEsXG4gIDM6IDEsXG4gIDQ6IDEsXG4gIDU6IDEsXG4gIDY6IDEsXG4gIDc6IDEsXG4gIDg6IDEsXG4gIDk6IDEsXG4gIDEwOiAxLFxuICAxMTogMSxcbiAgMTI6IDEsXG4gIDEzOiAxLFxuICAxNDogMSxcbiAgMTU6IDEsXG4gIDE2OiAxLFxuICAxNzogMSxcbiAgMTg6IDEsXG4gIDE5OiAxLFxuICAyMDogMSxcbiAgMjE6IDEsXG4gIDIyOiAxLFxuICAyMzogMSxcbiAgMjQ6IDEsXG4gIDI1OiAxLFxuICAyNjogMSxcbiAgMjc6IDEsXG4gIDI4OiAxLFxuICAyOTogMSxcbiAgMzA6IDEsXG59KTtcblxuZXhwb3J0IHsgX0JpdEZpZWxkIGFzIEJpdEZpZWxkIH07XG4iXX0= | ||
//# sourceMappingURL=bit-field.js.map |
83
graph.js
@@ -12,20 +12,5 @@ import { BinaryHeap } from "./binary-heap.js"; | ||
} | ||
/** | ||
* Creates a Graph class extending a given adjacency structure. | ||
*/ | ||
export function GraphMixin(Base) { | ||
/** | ||
* Extends an adjacency list/matrix structure and provides methods for traversal (BFS, DFS), | ||
* pathfinding (Dijkstra, Bellman-Ford), spanning tree construction (BFS, Prim), etc. | ||
*/ | ||
class Graph extends Base { | ||
constructor() { | ||
super(...arguments); | ||
Object.defineProperty(this, "_colors", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: void 0 | ||
}); | ||
} | ||
_colors; | ||
get colors() { | ||
@@ -38,5 +23,2 @@ return (this._colors || | ||
} | ||
/** | ||
* Checks whether the graph is acyclic. | ||
*/ | ||
isAcyclic() { | ||
@@ -49,10 +31,2 @@ for (const vertex of this.traverse(true, 0, false, true)) { | ||
} | ||
/** | ||
* Returns a list of vertices along the shortest path between two given vertices. | ||
* | ||
* @param start the starting vertex | ||
* @param end the ending vertex | ||
* @param isAcyclic whether the graph is acyclic | ||
* @param isNonNegative whether all edges are non-negative | ||
*/ | ||
path(start, end, isAcyclic = false, isNonNegative = false) { | ||
@@ -81,16 +55,5 @@ const { weighted } = this | ||
} | ||
/** | ||
* Resets all coloring of vertices done during traversals. | ||
*/ | ||
resetColors() { | ||
this.colors.fill(0); | ||
} | ||
/** | ||
* For all. | ||
* | ||
* @param start | ||
* @param end | ||
* @param distances | ||
* @param predecessors | ||
*/ | ||
searchBellmanFord(start, end, distances, predecessors) { | ||
@@ -115,10 +78,2 @@ const { vertices } = this; | ||
} | ||
/** | ||
* For non-negative edges. | ||
* | ||
* @param start | ||
* @param end | ||
* @param distances | ||
* @param predecessors | ||
*/ | ||
searchDijkstra(start, end, distances, predecessors) { | ||
@@ -150,10 +105,2 @@ this.resetColors(); | ||
} | ||
/** | ||
* For DAGs only. | ||
* | ||
* @param start | ||
* @param end | ||
* @param distances | ||
* @param predecessors | ||
*/ | ||
searchTopological(start, end, distances, predecessors) { | ||
@@ -180,9 +127,2 @@ distances[start] = 0; | ||
} | ||
/** | ||
* For unweighted graphs. | ||
* | ||
* @param start the starting vertex | ||
* @param end the ending vertex | ||
* @param predecessors | ||
*/ | ||
searchUnweighted(start, end, predecessors) { | ||
@@ -210,5 +150,2 @@ let lastPredecessor = start; | ||
} | ||
/** | ||
* Returns a list of vertexes sorted topologically. | ||
*/ | ||
topologicalSort() { | ||
@@ -221,12 +158,2 @@ const result = []; | ||
} | ||
/** | ||
* Does a Breadth-First or Depth-First traversal of the graph. | ||
* | ||
* @param isDFS whether to do DFS traversal, does BFS otherwise | ||
* @param start the vertex to start at | ||
* @param gray whether to return vertices upon entering | ||
* @param white whether to return edges upon first encountering | ||
* @param black whether to return vertices after processing | ||
* @return the vertex at each step | ||
*/ | ||
*traverse(isDFS = false, start = 0, gray = true, white = false, black = false) { | ||
@@ -255,8 +182,2 @@ this.resetColors(); | ||
} | ||
/** | ||
* Returns a minimal spanning tree of the graph. | ||
* Uses the Prim's algorithm for weighted graphs and BFS tree for unweighted graphs. | ||
* | ||
* @param start | ||
*/ | ||
tree(start = 0) { | ||
@@ -296,3 +217,3 @@ const { weighted } = this | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JhcGguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJncmFwaC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFOUMsTUFBTSxDQUFDLE1BQU0sTUFBTSxHQUFHO0lBQ3BCLEtBQUssRUFBRSxDQUFDO0lBQ1IsSUFBSSxFQUFFLENBQUM7SUFDUCxLQUFLLEVBQUUsQ0FBQztDQUNBLENBQUM7QUFNWCxNQUFNLFVBQVcsU0FBUSxVQUFrQjtJQUN6QyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQVMsRUFBRSxDQUFTO1FBQ2pDLE9BQU8sQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ25CLENBQUM7Q0FDRjtBQUtELE1BQU0sVUFBVSxVQUFVLENBR3hCLElBQU87SUFRUCxNQUFNLEtBQU0sU0FBUSxJQUFJO1FBQ3RCLE9BQU8sQ0FBYztRQUVyQixJQUFJLE1BQU07WUFDUixPQUFPLENBQ0wsSUFBSSxDQUFDLE9BQU87Z0JBQ1osQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxVQUFVLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUMvRCxDQUFDO1FBQ0osQ0FBQztRQUVELFFBQVEsQ0FBQyxNQUFjLEVBQUUsS0FBYTtZQUNwQyxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLEtBQUssS0FBSyxDQUFDO1FBQ3ZDLENBQUM7UUFLRCxTQUFTO1lBQ1AsS0FBSyxNQUFNLE1BQU0sSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDLEVBQUUsS0FBSyxFQUFFLElBQUksQ0FBQyxFQUFFO2dCQUN4RCxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLEtBQUssQ0FBQztvQkFBRSxPQUFPLEtBQUssQ0FBQzthQUN4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UUFBUSxDQUFDLElBQUksRUFBRSxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksTUFBTSxHQUFHLFNBQVMsQ0FBQyxJQUFJLENBQUMsRUFBRTt3QkFDaEUsU0FBUztxQkFDVjtvQkFDRCxTQUFTLENBQUMsSUFBSSxDQUFDLEdBQUcsTUFBTSxDQUFDO29CQUN6QixZQUFZLENBQUMsSUFBSSxDQUFDLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQztvQkFDOUIsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7aUJBQ25DO2FBQ0Y7WUFDRCxPQUFPLFlBQVksQ0FBQztRQUN0QixDQUFDO0tBQ0Y7SUFFRCxPQUFPLEtBQUssQ0FBQztBQUNmLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIEFkamFjZW5jeVN0cnVjdHVyZSxcbiAgQWRqYWNlbmN5U3RydWN0dXJlQ29uc3RydWN0b3IsXG4gIFR5cGVkQXJyYXlDb25zdHJ1Y3RvcnMsXG59IGZyb20gXCIuL3V0aWxpdHktdHlwZXMudHNcIjtcbmltcG9ydCB7IEJpbmFyeUhlYXAgfSBmcm9tIFwiLi9iaW5hcnktaGVhcC50c1wiO1xuXG5leHBvcnQgY29uc3QgQ29sb3JzID0ge1xuICBXSElURTogMCxcbiAgR1JBWTogMSxcbiAgQkxBQ0s6IDIsXG59IGFzIGNvbnN0O1xuXG5leHBvcnQgdHlwZSBDb2xvcnMgPSB0eXBlb2YgQ29sb3JzW2tleW9mIHR5cGVvZiBDb2xvcnNdO1xuXG50eXBlIFZlcnRleCA9IHsgZTogbnVtYmVyOyB3OiBudW1iZXIgfTtcblxuY2xhc3MgVmVydGV4SGVhcCBleHRlbmRzIEJpbmFyeUhlYXA8VmVydGV4PiB7XG4gIHN0YXRpYyBjb21wYXJlKGE6IFZlcnRleCwgYjogVmVydGV4KTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIGEudyA8IGIudztcbiAgfVxufVxuXG4vKipcbiAqIENyZWF0ZXMgYSBHcmFwaCBjbGFzcyBleHRlbmRpbmcgYSBnaXZlbiBhZGphY2VuY3kgc3RydWN0dXJlLlxuICovXG5leHBvcnQgZnVuY3Rpb24gR3JhcGhNaXhpbjxcbiAgVCBleHRlbmRzIFR5cGVkQXJyYXlDb25zdHJ1Y3RvcnMsXG4gIFUgZXh0ZW5kcyBBZGphY2VuY3lTdHJ1Y3R1cmVDb25zdHJ1Y3RvcjxUPixcbj4oQmFzZTogVSkge1xuICAvLyBkZW5vLWxpbnQtaWdub3JlIG5vLWVtcHR5LWludGVyZmFjZVxuICBpbnRlcmZhY2UgR3JhcGggZXh0ZW5kcyBBZGphY2VuY3lTdHJ1Y3R1cmUge31cblxuICAvKipcbiAgICogRXh0ZW5kcyBhbiBhZGphY2VuY3kgbGlzdC9tYXRyaXggc3RydWN0dXJlIGFuZCBwcm92aWRlcyBtZXRob2RzIGZvciB0cmF2ZXJzYWwgKEJGUywgREZTKSxcbiAgICogcGF0aGZpbmRpbmcgKERpamtzdHJhLCBCZWxsbWFuLUZvcmQpLCBzcGFubmluZyB0cmVlIGNvbnN0cnVjdGlvbiAoQkZTLCBQcmltKSwgZXRjLlxuICAgKi9cbiAgY2xhc3MgR3JhcGggZXh0ZW5kcyBCYXNlIHtcbiAgICBfY29sb3JzPzogVWludDhBcnJheTtcblxuICAgIGdldCBjb2xvcnMoKTogVWludDhBcnJheSB7XG4gICAgICByZXR1cm4gKFxuICAgICAgICB0aGlzLl9jb2xvcnMgfHxcbiAgICAgICAgKCh0aGlzLl9jb2xvcnMgPSBuZXcgVWludDhBcnJheSh0aGlzLnZlcnRpY2VzKSksIHRoaXMuX2NvbG9ycylcbiAgICAgICk7XG4gICAgfVxuXG4gICAgaGFzQ29sb3IodmVydGV4OiBudW1iZXIsIGNvbG9yOiBDb2xvcnMpOiBib29sZWFuIHtcbiAgICAgIHJldHVybiB0aGlzLmNvbG9yc1t2ZXJ0ZXhdID09PSBjb2xvcjtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBDaGVja3Mgd2hldGhlciB0aGUgZ3JhcGggaXMgYWN5Y2xpYy5cbiAgICAgKi9cbiAgICBpc0FjeWNsaWMoKTogYm9vbGVhbiB7XG4gICAgICBmb3IgKGNvbnN0IHZlcnRleCBvZiB0aGlzLnRyYXZlcnNlKHRydWUsIDAsIGZhbHNlLCB0cnVlKSkge1xuICAgICAgICBpZiAoIXRoaXMuaGFzQ29sb3IodmVydGV4LCBDb2xvcnMuV0hJVEUpKSByZXR1cm4gZmFsc2U7XG4gICAgICB9XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBSZXR1cm5zIGEgbGlzdCBvZiB2ZXJ0aWNlcyBhbG9uZyB0aGUgc2hvcnRlc3QgcGF0aCBiZXR3ZWVuIHR3byBnaXZlbiB2ZXJ0aWNlcy5cbiAgICAgKlxuICAgICAqIEBwYXJhbSBzdGFydCB0aGUgc3RhcnRpbmcgdmVydGV4XG4gICAgICogQHBhcmFtIGVuZCB0aGUgZW5kaW5nIHZlcnRleFxuICAgICAqIEBwYXJhbSBpc0FjeWNsaWMgd2hldGhlciB0aGUgZ3JhcGggaXMgYWN5Y2xpY1xuICAgICAqIEBwYXJhbSBpc05vbk5lZ2F0aXZlIHdoZXRoZXIgYWxsIGVkZ2VzIGFyZSBub24tbmVnYXRpdmVcbiAgICAgKi9cbiAgICBwYXRoKFxuICAgICAgc3RhcnQ6IG51bWJlcixcbiAgICAgIGVuZDogbnVtYmVyLFxuICAgICAgaXNBY3ljbGljID0gZmFsc2UsXG4gICAgICBpc05vbk5lZ2F0aXZlID0gZmFsc2UsXG4gICAgKTogQXJyYXk8bnVtYmVyPiB7XG4gICAgICBjb25zdCB7IHdlaWdodGVkIH0gPSB0aGlzXG4gICAgICAgIC5jb25zdHJ1Y3RvciBhcyBBZGphY2VuY3lTdHJ1Y3R1cmVDb25zdHJ1Y3RvcjxUeXBlZEFycmF5Q29uc3RydWN0b3JzPjtcbiAgICAgIGNvbnN0IHsgdmVydGljZXMgfSA9IHRoaXM7XG4gICAgICBjb25zdCBwcmVkZWNlc3NvcnMgPSBuZXcgQXJyYXkodmVydGljZXMpLmZpbGwoLTEpO1xuICAgICAgY29uc3QgZGlzdGFuY2VzID0gbmV3IEFycmF5KHZlcnRpY2VzKS5maWxsKEluZmluaXR5KTtcbiAgICAgIGNvbnN0IGlzRm91bmQgPSAhd2VpZ2h0ZWRcbiAgICAgICAgPyB0aGlzLnNlYXJjaFVud2VpZ2h0ZWQoc3RhcnQsIGVuZCwgcHJlZGVjZXNzb3JzKVxuICAgICAgICA6IGlzQWN5Y2xpY1xuICAgICAgICA/IHRoaXMuc2VhcmNoVG9wb2xvZ2ljYWwoc3RhcnQsIGVuZCwgZGlzdGFuY2VzLCBwcmVkZWNlc3NvcnMpXG4gICAgICAgIDogaXNOb25OZWdhdGl2ZVxuICAgICAgICA/IHRoaXMuc2VhcmNoRGlqa3N0cmEoc3RhcnQsIGVuZCwgZGlzdGFuY2VzLCBwcmVkZWNlc3NvcnMpXG4gICAgICAgIDogdGhpcy5zZWFyY2hCZWxsbWFuRm9yZChzdGFydCwgZW5kLCBkaXN0YW5jZXMsIHByZWRlY2Vzc29ycyk7XG4gICAgICBpZiAoIWlzRm91bmQpIHJldHVybiBbXTtcbiAgICAgIGNvbnN0IHBhdGggPSBbXTtcbiAgICAgIGxldCBsYXN0ID0gZW5kO1xuICAgICAgd2hpbGUgKH5sYXN0KSB7XG4gICAgICAgIHBhdGgudW5zaGlmdChsYXN0KTtcbiAgICAgICAgbGFzdCA9IHByZWRlY2Vzc29yc1tsYXN0XTtcbiAgICAgIH1cbiAgICAgIHJldHVybiBwYXRoO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFJlc2V0cyBhbGwgY29sb3Jpbmcgb2YgdmVydGljZXMgZG9uZSBkdXJpbmcgdHJhdmVyc2Fscy5cbiAgICAgKi9cbiAgICByZXNldENvbG9ycygpOiB2b2lkIHtcbiAgICAgIHRoaXMuY29sb3JzLmZpbGwoMCk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogRm9yIGFsbC5cbiAgICAgKlxuICAgICAqIEBwYXJhbSBzdGFydFxuICAgICAqIEBwYXJhbSBlbmRcbiAgICAgKiBAcGFyYW0gZGlzdGFuY2VzXG4gICAgICogQHBhcmFtIHByZWRlY2Vzc29yc1xuICAgICAqL1xuICAgIHNlYXJjaEJlbGxtYW5Gb3JkKFxuICAgICAgc3RhcnQ6IG51bWJlcixcbiAgICAgIGVuZDogbnVtYmVyLFxuICAgICAgZGlzdGFuY2VzOiBBcnJheTxudW1iZXI+LFxuICAgICAgcHJlZGVjZXNzb3JzOiBBcnJheTxudW1iZXI+LFxuICAgICk6IGJvb2xlYW4ge1xuICAgICAgY29uc3QgeyB2ZXJ0aWNlcyB9ID0gdGhpcztcbiAgICAgIGRpc3RhbmNlc1tzdGFydF0gPSAwO1xuICAgICAgbGV0IGlzRm91bmQgPSBmYWxzZTtcbiAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdmVydGljZXM7IGkrKykge1xuICAgICAgICBmb3IgKGNvbnN0IGVkZ2Ugb2YgdGhpcy5vdXRFZGdlcyhpKSkge1xuICAgICAgICAgIGNvbnN0IHdlaWdodCA9IHRoaXMuZ2V0RWRnZShpLCBlZGdlKTtcbiAgICAgICAgICBjb25zdCBkaXN0YW5jZSA9IGRpc3RhbmNlc1tpXSArIHdlaWdodDtcbiAgICAgICAgICBpZiAoZGlzdGFuY2VzW2VkZ2VdID4gZGlzdGFuY2UpIHtcbiAgICAgICAgICAgIGRpc3RhbmNlc1tlZGdlXSA9IGRpc3RhbmNlO1xuICAgICAgICAgICAgcHJlZGVjZXNzb3JzW2VkZ2VdID0gaTtcbiAgICAgICAgICAgIGlmIChlZGdlID09PSBlbmQpIHtcbiAgICAgICAgICAgICAgaXNGb3VuZCA9IHRydWU7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgICByZXR1cm4gaXNGb3VuZDtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBGb3Igbm9uLW5lZ2F0aXZlIGVkZ2VzLlxuICAgICAqXG4gICAgICogQHBhcmFtIHN0YXJ0XG4gICAgICogQHBhcmFtIGVuZFxuICAgICAqIEBwYXJhbSBkaXN0YW5jZXNcbiAgICAgKiBAcGFyYW0gcHJlZGVjZXNzb3JzXG4gICAgICovXG4gICAgc2VhcmNoRGlqa3N0cmEoXG4gICAgICBzdGFydDogbnVtYmVyLFxuICAgICAgZW5kOiBudW1iZXIsXG4gICAgICBkaXN0YW5jZXM6IEFycmF5PG51bWJlcj4sXG4gICAgICBwcmVkZWNlc3NvcnM6IEFycmF5PG51bWJlcj4sXG4gICAgKTogYm9vbGVhbiB7XG4gICAgICB0aGlzLnJlc2V0Q29sb3JzKCk7XG4gICAgICBjb25zdCBoZWFwID0gbmV3IFZlcnRleEhlYXAoKTtcbiAgICAgIGRpc3RhbmNlc1tzdGFydF0gPSAwO1xuICAgICAgaGVhcC5wdXNoKHsgZTogc3RhcnQsIHc6IHRoaXNbc3RhcnRdIH0pO1xuICAgICAgbGV0IGlzRm91bmQgPSBmYWxzZTtcbiAgICAgIHdoaWxlIChoZWFwLmxlbmd0aCkge1xuICAgICAgICBjb25zdCB2ZXJ0ZXggPSBoZWFwLnNoaWZ0KCkhO1xuICAgICAgICBpZiAodGhpcy5oYXNDb2xvcih2ZXJ0ZXguZSwgQ29sb3JzLkdSQVkpKSBjb250aW51ZTtcbiAgICAgICAgdGhpcy5zZXRDb2xvcih2ZXJ0ZXguZSwgQ29sb3JzLkdSQVkpO1xuICAgICAgICBmb3IgKGNvbnN0IGVkZ2Ugb2YgdGhpcy5vdXRFZGdlcyh2ZXJ0ZXguZSkpIHtcbiAgICAgICAgICBjb25zdCB3ZWlnaHQgPSB0aGlzLmdldEVkZ2UodmVydGV4LmUsIGVkZ2UpO1xuICAgICAgICAgIGNvbnN0IGRpc3RhbmNlID0gZGlzdGFuY2VzW3ZlcnRleC5lXSArIHdlaWdodDtcbiAgICAgICAgICBpZiAoZGlzdGFuY2UgPCBkaXN0YW5jZXNbZWRnZV0pIHtcbiAgICAgICAgICAgIGRpc3RhbmNlc1tlZGdlXSA9IGRpc3RhbmNlO1xuICAgICAgICAgICAgcHJlZGVjZXNzb3JzW2VkZ2VdID0gdmVydGV4LmU7XG4gICAgICAgICAgICBoZWFwLnB1c2goeyBlOiBlZGdlLCB3OiBkaXN0YW5jZSB9KTtcbiAgICAgICAgICB9XG4gICAgICAgICAgaWYgKGVkZ2UgPT09IGVuZCkge1xuICAgICAgICAgICAgaXNGb3VuZCA9IHRydWU7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgICByZXR1cm4gaXNGb3VuZDtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBGb3IgREFHcyBvbmx5LlxuICAgICAqXG4gICAgICogQHBhcmFtIHN0YXJ0XG4gICAgICogQHBhcmFtIGVuZFxuICAgICAqIEBwYXJhbSBkaXN0YW5jZXNcbiAgICAgKiBAcGFyYW0gcHJlZGVjZXNzb3JzXG4gICAgICovXG4gICAgc2VhcmNoVG9wb2xvZ2ljYWwoXG4gICAgICBzdGFydDogbnVtYmVyLFxuICAgICAgZW5kOiBudW1iZXIsXG4gICAgICBkaXN0YW5jZXM6IEFycmF5PG51bWJlcj4sXG4gICAgICBwcmVkZWNlc3NvcnM6IEFycmF5PG51bWJlcj4sXG4gICAgKTogYm9vbGVhbiB7XG4gICAgICBkaXN0YW5jZXNbc3RhcnRdID0gMDtcbiAgICAgIGxldCBsYXN0UHJlZGVjZXNzb3IgPSBzdGFydDtcbiAgICAgIGxldCBpc0ZvdW5kID0gZmFsc2U7XG4gICAgICBmb3IgKGNvbnN0IHZlcnRleCBvZiB0aGlzLnRyYXZlcnNlKHRydWUsIHN0YXJ0LCB0cnVlLCB0cnVlKSkge1xuICAgICAgICBpZiAoIXRoaXMuaGFzQ29sb3IodmVydGV4LCBDb2xvcnMuR1JBWSkpIHtcbiAgICAgICAgICBjb25zdCB3ZWlnaHQgPSB0aGlzLmdldEVkZ2UobGFzdFByZWRlY2Vzc29yLCB2ZXJ0ZXgpO1xuICAgICAgICAgIGlmIChkaXN0YW5jZXNbdmVydGV4XSA+IGRpc3RhbmNlc1tsYXN0UHJlZGVjZXNzb3JdICsgd2VpZ2h0KSB7XG4gICAgICAgICAgICBkaXN0YW5jZXNbdmVydGV4XSA9IGRpc3RhbmNlc1tsYXN0UHJlZGVjZXNzb3JdICsgd2VpZ2h0O1xuICAgICAgICAgICAgcHJlZGVjZXNzb3JzW3ZlcnRleF0gPSBsYXN0UHJlZGVjZXNzb3I7XG4gICAgICAgICAgfVxuICAgICAgICB9IGVsc2UgaWYgKCF0aGlzLmhhc0NvbG9yKHZlcnRleCwgQ29sb3JzLkJMQUNLKSkge1xuICAgICAgICAgIGxhc3RQcmVkZWNlc3NvciA9IHZlcnRleDtcbiAgICAgICAgfVxuICAgICAgICBpZiAodmVydGV4ID09PSBlbmQpIHtcbiAgICAgICAgICBpc0ZvdW5kID0gdHJ1ZTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgcmV0dXJuIGlzRm91bmQ7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogRm9yIHVud2VpZ2h0ZWQgZ3JhcGhzLlxuICAgICAqXG4gICAgICogQHBhcmFtIHN0YXJ0IHRoZSBzdGFydGluZyB2ZXJ0ZXhcbiAgICAgKiBAcGFyYW0gZW5kIHRoZSBlbmRpbmcgdmVydGV4XG4gICAgICogQHBhcmFtIHByZWRlY2Vzc29yc1xuICAgICAqL1xuICAgIHNlYXJjaFVud2VpZ2h0ZWQoXG4gICAgICBzdGFydDogbnVtYmVyLFxuICAgICAgZW5kOiBudW1iZXIgfCB1bmRlZmluZWQsXG4gICAgICBwcmVkZWNlc3NvcnM6IEFycmF5PG51bWJlcj4sXG4gICAgKTogYm9vbGVhbiB7XG4gICAgICBsZXQgbGFzdFByZWRlY2Vzc29yID0gc3RhcnQ7XG4gICAgICBsZXQgaXNGb3VuZCA9IGZhbHNlO1xuICAgICAgZm9yIChjb25zdCB2ZXJ0ZXggb2YgdGhpcy50cmF2ZXJzZShmYWxzZSwgc3RhcnQsIHRydWUsIHRydWUpKSB7XG4gICAgICAgIGlmICh0aGlzLmhhc0NvbG9yKHZlcnRleCwgQ29sb3JzLkJMQUNLKSkgY29udGludWU7XG4gICAgICAgIGlmICh0aGlzLmhhc0NvbG9yKHZlcnRleCwgQ29sb3JzLldISVRFKSkge1xuICAgICAgICAgIHByZWRlY2Vzc29yc1t2ZXJ0ZXhdID0gbGFzdFByZWRlY2Vzc29yO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGxhc3RQcmVkZWNlc3NvciA9IHZlcnRleDtcbiAgICAgICAgfVxuICAgICAgICBpZiAodmVydGV4ID09PSBlbmQpIHtcbiAgICAgICAgICBpc0ZvdW5kID0gdHJ1ZTtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgcmV0dXJuIGlzRm91bmQ7XG4gICAgfVxuXG4gICAgc2V0Q29sb3IodmVydGV4OiBudW1iZXIsIGNvbG9yOiBDb2xvcnMpOiB2b2lkIHtcbiAgICAgIHRoaXMuY29sb3JzW3ZlcnRleF0gPSBjb2xvcjtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBSZXR1cm5zIGEgbGlzdCBvZiB2ZXJ0ZXhlcyBzb3J0ZWQgdG9wb2xvZ2ljYWxseS5cbiAgICAgKi9cbiAgICB0b3BvbG9naWNhbFNvcnQoKTogQXJyYXk8bnVtYmVyPiB7XG4gICAgICBjb25zdCByZXN1bHQ6IEFycmF5PG51bWJlcj4gPSBbXTtcbiAgICAgIGZvciAoY29uc3QgdmVydGV4IG9mIHRoaXMudHJhdmVyc2UodHJ1ZSwgMCwgZmFsc2UsIGZhbHNlLCB0cnVlKSkge1xuICAgICAgICByZXN1bHQudW5zaGlmdCh2ZXJ0ZXgpO1xuICAgICAgfVxuICAgICAgcmV0dXJuIHJlc3VsdDtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBEb2VzIGEgQnJlYWR0aC1GaXJzdCBvciBEZXB0aC1GaXJzdCB0cmF2ZXJzYWwgb2YgdGhlIGdyYXBoLlxuICAgICAqXG4gICAgICogQHBhcmFtIGlzREZTIHdoZXRoZXIgdG8gZG8gREZTIHRyYXZlcnNhbCwgZG9lcyBCRlMgb3RoZXJ3aXNlXG4gICAgICogQHBhcmFtIHN0YXJ0IHRoZSB2ZXJ0ZXggdG8gc3RhcnQgYXRcbiAgICAgKiBAcGFyYW0gZ3JheSB3aGV0aGVyIHRvIHJldHVybiB2ZXJ0aWNlcyB1cG9uIGVudGVyaW5nXG4gICAgICogQHBhcmFtIHdoaXRlIHdoZXRoZXIgdG8gcmV0dXJuIGVkZ2VzIHVwb24gZmlyc3QgZW5jb3VudGVyaW5nXG4gICAgICogQHBhcmFtIGJsYWNrIHdoZXRoZXIgdG8gcmV0dXJuIHZlcnRpY2VzIGFmdGVyIHByb2Nlc3NpbmdcbiAgICAgKiBAcmV0dXJuIHRoZSB2ZXJ0ZXggYXQgZWFjaCBzdGVwXG4gICAgICovXG4gICAgKnRyYXZlcnNlKFxuICAgICAgaXNERlMgPSBmYWxzZSxcbiAgICAgIHN0YXJ0ID0gMCxcbiAgICAgIGdyYXkgPSB0cnVlLFxuICAgICAgd2hpdGUgPSBmYWxzZSxcbiAgICAgIGJsYWNrID0gZmFsc2UsXG4gICAgKSB7XG4gICAgICB0aGlzLnJlc2V0Q29sb3JzKCk7XG4gICAgICBjb25zdCBwcm9jZXNzaW5nID0gW3N0YXJ0XTtcbiAgICAgIGNvbnN0IFtwdXNoLCBwdWxsXTogQXJyYXk8a2V5b2YgQXJyYXk8bnVtYmVyPj4gPSBpc0RGU1xuICAgICAgICA/IFtcInB1c2hcIiwgXCJwb3BcIl1cbiAgICAgICAgOiBbXCJwdXNoXCIsIFwic2hpZnRcIl07XG4gICAgICB3aGlsZSAocHJvY2Vzc2luZy5sZW5ndGgpIHtcbiAgICAgICAgY29uc3QgdmVydGV4ID0gcHJvY2Vzc2luZ1twdWxsXSgpITtcbiAgICAgICAgdGhpcy5zZXRDb2xvcih2ZXJ0ZXgsIENvbG9ycy5HUkFZKTtcbiAgICAgICAgaWYgKGdyYXkpIHlpZWxkIHZlcnRleDtcbiAgICAgICAgZm9yIChjb25zdCBlZGdlIG9mIHRoaXMub3V0RWRnZXModmVydGV4KSkge1xuICAgICAgICAgIGlmICh0aGlzLmhhc0NvbG9yKGVkZ2UsIENvbG9ycy5XSElURSkpIHtcbiAgICAgICAgICAgIHByb2Nlc3NpbmdbcHVzaF0oZWRnZSk7XG4gICAgICAgICAgfVxuICAgICAgICAgIGlmICh3aGl0ZSkgeWllbGQgZWRnZTtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLnNldENvbG9yKHZlcnRleCwgQ29sb3JzLkJMQUNLKTtcbiAgICAgICAgaWYgKGJsYWNrKSB5aWVsZCB2ZXJ0ZXg7XG4gICAgICB9XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogUmV0dXJucyBhIG1pbmltYWwgc3Bhbm5pbmcgdHJlZSBvZiB0aGUgZ3JhcGguXG4gICAgICogVXNlcyB0aGUgUHJpbSdzIGFsZ29yaXRobSBmb3Igd2VpZ2h0ZWQgZ3JhcGhzIGFuZCBCRlMgdHJlZSBmb3IgdW53ZWlnaHRlZCBncmFwaHMuXG4gICAgICpcbiAgICAgKiBAcGFyYW0gc3RhcnRcbiAgICAgKi9cbiAgICB0cmVlKHN0YXJ0ID0gMCkge1xuICAgICAgY29uc3QgeyB3ZWlnaHRlZCB9ID0gdGhpc1xuICAgICAgICAuY29uc3RydWN0b3IgYXMgQWRqYWNlbmN5U3RydWN0dXJlQ29uc3RydWN0b3I8VHlwZWRBcnJheUNvbnN0cnVjdG9ycz47XG4gICAgICBjb25zdCB7IHZlcnRpY2VzIH0gPSB0aGlzO1xuICAgICAgY29uc3QgcHJlZGVjZXNzb3JzID0gbmV3IEFycmF5KHZlcnRpY2VzKS5maWxsKC0xKTtcbiAgICAgIGlmICghd2VpZ2h0ZWQpIHtcbiAgICAgICAgdGhpcy5zZWFyY2hVbndlaWdodGVkKHN0YXJ0LCB1bmRlZmluZWQsIHByZWRlY2Vzc29ycyk7XG4gICAgICAgIHJldHVybiBwcmVkZWNlc3NvcnM7XG4gICAgICB9XG4gICAgICB0aGlzLnJlc2V0Q29sb3JzKCk7XG4gICAgICBjb25zdCBkaXN0YW5jZXMgPSBuZXcgQXJyYXkodmVydGljZXMpLmZpbGwoSW5maW5pdHkpO1xuICAgICAgY29uc3QgaGVhcCA9IG5ldyBWZXJ0ZXhIZWFwKCk7XG4gICAgICBkaXN0YW5jZXNbc3RhcnRdID0gMDtcbiAgICAgIGhlYXAucHVzaCh7IGU6IHN0YXJ0LCB3OiB0aGlzWzBdIH0pO1xuICAgICAgd2hpbGUgKGhlYXAubGVuZ3RoKSB7XG4gICAgICAgIGNvbnN0IHZlcnRleCA9IGhlYXAuc2hpZnQoKSE7XG4gICAgICAgIGlmICh0aGlzLmhhc0NvbG9yKHZlcnRleC5lLCBDb2xvcnMuR1JBWSkpIGNvbnRpbnVlO1xuICAgICAgICB0aGlzLnNldENvbG9yKHZlcnRleC5lLCBDb2xvcnMuR1JBWSk7XG4gICAgICAgIGZvciAoY29uc3QgZWRnZSBvZiB0aGlzLm91dEVkZ2VzKHZlcnRleC5lKSkge1xuICAgICAgICAgIGNvbnN0IHdlaWdodCA9IHRoaXMuZ2V0RWRnZSh2ZXJ0ZXguZSwgZWRnZSk7XG4gICAgICAgICAgaWYgKHRoaXMuaGFzQ29sb3IoZWRnZSwgQ29sb3JzLkdSQVkpIHx8IHdlaWdodCA+IGRpc3RhbmNlc1tlZGdlXSkge1xuICAgICAgICAgICAgY29udGludWU7XG4gICAgICAgICAgfVxuICAgICAgICAgIGRpc3RhbmNlc1tlZGdlXSA9IHdlaWdodDtcbiAgICAgICAgICBwcmVkZWNlc3NvcnNbZWRnZV0gPSB2ZXJ0ZXguZTtcbiAgICAgICAgICBoZWFwLnB1c2goeyBlOiBlZGdlLCB3OiB3ZWlnaHQgfSk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIHJldHVybiBwcmVkZWNlc3NvcnM7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIEdyYXBoO1xufVxuIl19 | ||
//# sourceMappingURL=graph.js.map |
80
grid.js
import { getLog2 } from "./utilities.js"; | ||
/** | ||
* Creates a Grid class extending a given Array-like class. | ||
*/ | ||
export function GridMixin(Base) { | ||
/** | ||
* Extends built-in indexed collections to handle 2 dimensional data. | ||
*/ | ||
return class Grid extends Base { | ||
constructor() { | ||
super(...arguments); | ||
Object.defineProperty(this, "size", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: 0 | ||
}); | ||
} | ||
size = 0; | ||
static get [Symbol.species]() { | ||
return Base; | ||
} | ||
/** | ||
* Number of columns in the grid. | ||
*/ | ||
get columns() { | ||
return 1 << this.size; | ||
} | ||
/** | ||
* Specifies the number of columns of the grid. | ||
*/ | ||
set columns(columns) { | ||
this.size = getLog2(columns); | ||
} | ||
/** | ||
* Number of rows in the grid. | ||
*/ | ||
get rows() { | ||
//@ts-ignore 2339 | ||
return this.length >> this.size; | ||
} | ||
/** | ||
* Creates a grid of specified dimensions. | ||
* | ||
* @param rows the amount of rows | ||
* @param columns the amount of columns | ||
* @return a new grid | ||
*/ | ||
static create(rows, columns = 1) { | ||
@@ -55,12 +24,5 @@ const offset = getLog2(columns); | ||
} | ||
/** | ||
* Creates a grid from an array of arrays. | ||
* | ||
* @param arrays the array of arrays | ||
* @return a new grid | ||
*/ | ||
static fromArrays(arrays) { | ||
const rows = arrays.length; | ||
// find longest array to get the column size | ||
let columns = arrays[0].length; // if !arrays[0].length | ||
let columns = arrays[0].length; | ||
for (let i = 0; i < rows; i++) { | ||
@@ -72,5 +34,3 @@ if (arrays[i].length > columns) | ||
columns = 1 << offset; | ||
// create grid of the required length | ||
const grid = this.create(rows, columns); | ||
// fill the grid with values from arrays | ||
for (let i = 0; i < rows; i++) { | ||
@@ -84,9 +44,2 @@ const rowId = i << offset; | ||
} | ||
/** | ||
* Returns the length of the underlying Array required to hold the grid of specified dimensions. | ||
* | ||
* @param rows the amount of rows | ||
* @param columns the amount of columns | ||
* @return the required length | ||
*/ | ||
static getLength(rows, columns = 1) { | ||
@@ -98,30 +51,8 @@ return rows << getLog2(columns); | ||
} | ||
/** | ||
* Returns the index of an element at given coordinates. | ||
* | ||
* @param rows the row index | ||
* @param columns the column index | ||
* @return the element index | ||
*/ | ||
getIndex(row, column = 1) { | ||
return (row << this.size) + column; | ||
} | ||
/** | ||
* Returns the element at given coordinates. | ||
* | ||
* @param rows the row index | ||
* @param columns the column index | ||
* @return the element | ||
*/ | ||
getValue(row, column) { | ||
return this[this.getIndex(row, column)]; | ||
} | ||
/** | ||
* Sets the element at given coordinates. | ||
* | ||
* @param rows the row index | ||
* @param columns the column index | ||
* @param value the element | ||
* @return the grid | ||
*/ | ||
setValue(row, column, value) { | ||
@@ -131,7 +62,2 @@ this[this.getIndex(row, column)] = value; | ||
} | ||
/** | ||
* Creates an array of arrays representing rows of the grid. | ||
* | ||
* @return an array of arrays | ||
*/ | ||
toArrays() { | ||
@@ -151,3 +77,3 @@ const { rows, columns, size } = this; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImdyaWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBS3pDLE1BQU0sVUFBVSxTQUFTLENBS3ZCLElBQU87SUFJUCxPQUFPLE1BQU0sSUFBSyxTQUFRLElBQUk7UUFHNUIsSUFBSSxHQUFHLENBQUMsQ0FBQztRQUVULE1BQU0sS0FBSyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUM7WUFDekIsT0FBTyxJQUFJLENBQUM7UUFDZCxDQUFDO1FBS0QsSUFBSSxPQUFPO1lBQ1QsT0FBTyxDQUFDLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQztRQUN4QixDQUFDO1FBS0QsSUFBSSxPQUFPLENBQUMsT0FBTztZQUNqQixJQUFJLENBQUMsSUFBSSxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUMvQixDQUFDO1FBS0QsSUFBSSxJQUFJO1lBRU4sT0FBTyxJQUFJLENBQUMsTUFBTSxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUM7UUFDbEMsQ0FBQztRQVNELE1BQU0sQ0FBQyxNQUFNLENBRVgsSUFBWSxFQUNaLE9BQU8sR0FBRyxDQUFDO1lBRVgsTUFBTSxNQUFNLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQ2hDLE1BQU0sTUFBTSxHQUFHLElBQUksSUFBSSxNQUFNLENBQUM7WUFDOUIsTUFBTSxJQUFJLEdBQUcsSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDOUIsSUFBSSxDQUFDLElBQUksR0FBRyxNQUFNLENBQUM7WUFDbkIsT0FBTyxJQUF1QixDQUFDO1FBQ2pDLENBQUM7UUFRRCxNQUFNLENBQUMsVUFBVSxDQUVmLE1BQThCO1lBRTlCLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUM7WUFHM0IsSUFBSSxPQUFPLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0s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IHsgQ29uc3RydWN0b3IsIFR5cGVkQXJyYXlDb25zdHJ1Y3RvcnMgfSBmcm9tIFwiLi91dGlsaXR5LXR5cGVzLnRzXCI7XG5pbXBvcnQgeyBnZXRMb2cyIH0gZnJvbSBcIi4vdXRpbGl0aWVzLnRzXCI7XG5cbi8qKlxuICogQ3JlYXRlcyBhIEdyaWQgY2xhc3MgZXh0ZW5kaW5nIGEgZ2l2ZW4gQXJyYXktbGlrZSBjbGFzcy5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIEdyaWRNaXhpbjxcbiAgSXRlbVR5cGUgPSBudW1iZXIsXG4gIFUgZXh0ZW5kcyBDb25zdHJ1Y3RvcjxBcnJheTxJdGVtVHlwZT4+IHwgVHlwZWRBcnJheUNvbnN0cnVjdG9ycyA9IENvbnN0cnVjdG9yPFxuICAgIEFycmF5PEl0ZW1UeXBlPlxuICA+LFxuPihCYXNlOiBVKSB7XG4gIC8qKlxuICAgKiBFeHRlbmRzIGJ1aWx0LWluIGluZGV4ZWQgY29sbGVjdGlvbnMgdG8gaGFuZGxlIDIgZGltZW5zaW9uYWwgZGF0YS5cbiAgICovXG4gIHJldHVybiBjbGFzcyBHcmlkIGV4dGVuZHMgQmFzZSB7XG4gICAgW2tleTogbnVtYmVyXTogSXRlbVR5cGVcblxuICAgIHNpemUgPSAwO1xuXG4gICAgc3RhdGljIGdldCBbU3ltYm9sLnNwZWNpZXNdKCkge1xuICAgICAgcmV0dXJuIEJhc2U7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogTnVtYmVyIG9mIGNvbHVtbnMgaW4gdGhlIGdyaWQuXG4gICAgICovXG4gICAgZ2V0IGNvbHVtbnMoKSB7XG4gICAgICByZXR1cm4gMSA8PCB0aGlzLnNpemU7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogU3BlY2lmaWVzIHRoZSBudW1iZXIgb2YgY29sdW1ucyBvZiB0aGUgZ3JpZC5cbiAgICAgKi9cbiAgICBzZXQgY29sdW1ucyhjb2x1bW5zKSB7XG4gICAgICB0aGlzLnNpemUgPSBnZXRMb2cyKGNvbHVtbnMpO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIE51bWJlciBvZiByb3dzIGluIHRoZSBncmlkLlxuICAgICAqL1xuICAgIGdldCByb3dzKCkge1xuICAgICAgLy9AdHMtaWdub3JlIDIzMzlcbiAgICAgIHJldHVybiB0aGlzLmxlbmd0aCA+PiB0aGlzLnNpemU7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQ3JlYXRlcyBhIGdyaWQgb2Ygc3BlY2lmaWVkIGRpbWVuc2lvbnMuXG4gICAgICpcbiAgICAgKiBAcGFyYW0gcm93cyB0aGUgYW1vdW50IG9mIHJvd3NcbiAgICAgKiBAcGFyYW0gY29sdW1ucyB0aGUgYW1vdW50IG9mIGNvbHVtbnNcbiAgICAgKiBAcmV0dXJuIGEgbmV3IGdyaWRcbiAgICAgKi9cbiAgICBzdGF0aWMgY3JlYXRlPFQgZXh0ZW5kcyB0eXBlb2YgR3JpZD4oXG4gICAgICB0aGlzOiBULFxuICAgICAgcm93czogbnVtYmVyLFxuICAgICAgY29sdW1ucyA9IDEsXG4gICAgKTogSW5zdGFuY2VUeXBlPFQ+IHtcbiAgICAgIGNvbnN0IG9mZnNldCA9IGdldExvZzIoY29sdW1ucyk7XG4gICAgICBjb25zdCBsZW5ndGggPSByb3dzIDw8IG9mZnNldDtcbiAgICAgIGNvbnN0IGdyaWQgPSBuZXcgdGhpcyhsZW5ndGgpO1xuICAgICAgZ3JpZC5zaXplID0gb2Zmc2V0O1xuICAgICAgcmV0dXJuIGdyaWQgYXMgSW5zdGFuY2VUeXBlPFQ+O1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIENyZWF0ZXMgYSBncmlkIGZyb20gYW4gYXJyYXkgb2YgYXJyYXlzLlxuICAgICAqXG4gICAgICogQHBhcmFtIGFycmF5cyB0aGUgYXJyYXkgb2YgYXJyYXlzXG4gICAgICogQHJldHVybiBhIG5ldyBncmlkXG4gICAgICovXG4gICAgc3RhdGljIGZyb21BcnJheXM8VCBleHRlbmRzIHR5cGVvZiBHcmlkPihcbiAgICAgIHRoaXM6IFQsXG4gICAgICBhcnJheXM6IEFycmF5PEFycmF5PEl0ZW1UeXBlPj4sXG4gICAgKTogSW5zdGFuY2VUeXBlPFQ+IHtcbiAgICAgIGNvbnN0IHJvd3MgPSBhcnJheXMubGVuZ3RoO1xuXG4gICAgICAvLyBmaW5kIGxvbmdlc3QgYXJyYXkgdG8gZ2V0IHRoZSBjb2x1bW4gc2l6ZVxuICAgICAgbGV0IGNvbHVtbnMgPSBhcnJheXNbMF0ubGVuZ3RoOyAvLyBpZiAhYXJyYXlzWzBdLmxlbmd0aFxuICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCByb3dzOyBpKyspIHtcbiAgICAgICAgaWYgKGFycmF5c1tpXS5sZW5ndGggPiBjb2x1bW5zKSBjb2x1bW5zID0gYXJyYXlzW2ldLmxlbmd0aDtcbiAgICAgIH1cbiAgICAgIGNvbnN0IG9mZnNldCA9IGdldExvZzIoY29sdW1ucyk7XG4gICAgICBjb2x1bW5zID0gMSA8PCBvZmZzZXQ7XG5cbiAgICAgIC8vIGNyZWF0ZSBncmlkIG9mIHRoZSByZXF1aXJlZCBsZW5ndGhcbiAgICAgIGNvbnN0IGdyaWQgPSB0aGlzLmNyZWF0ZShyb3dzLCBjb2x1bW5zKTtcblxuICAgICAgLy8gZmlsbCB0aGUgZ3JpZCB3aXRoIHZhbHVlcyBmcm9tIGFycmF5c1xuICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCByb3dzOyBpKyspIHtcbiAgICAgICAgY29uc3Qgcm93SWQgPSBpIDw8IG9mZnNldDtcbiAgICAgICAgZm9yIChsZXQgaiA9IDA7IGogPCBhcnJheXNbaV0ubGVuZ3RoOyBqKyspIHtcbiAgICAgICAgICBncmlkW3Jvd0lkICsgal0gPSBhcnJheXNbaV1bal07XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGdyaWQ7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogUmV0dXJucyB0aGUgbGVuZ3RoIG9mIHRoZSB1bmRlcmx5aW5nIEFycmF5IHJlcXVpcmVkIHRvIGhvbGQgdGhlIGdyaWQgb2Ygc3BlY2lmaWVkIGRpbWVuc2lvbnMuXG4gICAgICpcbiAgICAgKiBAcGFyYW0gcm93cyB0aGUgYW1vdW50IG9mIHJvd3NcbiAgICAgKiBAcGFyYW0gY29sdW1ucyB0aGUgYW1vdW50IG9mIGNvbHVtbnNcbiAgICAgKiBAcmV0dXJuIHRoZSByZXF1aXJlZCBsZW5ndGhcbiAgICAgKi9cbiAgICBzdGF0aWMgZ2V0TGVuZ3RoKHJvd3M6IG51bWJlciwgY29sdW1ucyA9IDEpOiBudW1iZXIge1xuICAgICAgcmV0dXJuIHJvd3MgPDwgZ2V0TG9nMihjb2x1bW5zKTtcbiAgICB9XG5cbiAgICBnZXRDb29yZGluYXRlcyhpbmRleDogbnVtYmVyKTogW3JvdzogbnVtYmVyLCBjb2x1bW46IG51bWJlcl0ge1xuICAgICAgcmV0dXJuIFtpbmRleCA+PiB0aGlzLnNpemUsIGluZGV4ICYgKCgxIDw8IHRoaXMuc2l6ZSkgLSAxKV07XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogUmV0dXJucyB0aGUgaW5kZXggb2YgYW4gZWxlbWVudCBhdCBnaXZlbiBjb29yZGluYXRlcy5cbiAgICAgKlxuICAgICAqIEBwYXJhbSByb3dzIHRoZSByb3cgaW5kZXhcbiAgICAgKiBAcGFyYW0gY29sdW1ucyB0aGUgY29sdW1uIGluZGV4XG4gICAgICogQHJldHVybiB0aGUgZWxlbWVudCBpbmRleFxuICAgICAqL1xuICAgIGdldEluZGV4KHJvdzogbnVtYmVyLCBjb2x1bW4gPSAxKTogbnVtYmVyIHtcbiAgICAgIHJldHVybiAocm93IDw8IHRoaXMuc2l6ZSkgKyBjb2x1bW47XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogUmV0dXJucyB0aGUgZWxlbWVudCBhdCBnaXZlbiBjb29yZGluYXRlcy5cbiAgICAgKlxuICAgICAqIEBwYXJhbSByb3dzIHRoZSByb3cgaW5kZXhcbiAgICAgKiBAcGFyYW0gY29sdW1ucyB0aGUgY29sdW1uIGluZGV4XG4gICAgICogQHJldHVybiB0aGUgZWxlbWVudFxuICAgICAqL1xuICAgIGdldFZhbHVlKHJvdzogbnVtYmVyLCBjb2x1bW46IG51bWJlcik6IEl0ZW1UeXBlIHtcbiAgICAgIHJldHVybiB0aGlzW3RoaXMuZ2V0SW5kZXgocm93LCBjb2x1bW4pXTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBTZXRzIHRoZSBlbGVtZW50IGF0IGdpdmVuIGNvb3JkaW5hdGVzLlxuICAgICAqXG4gICAgICogQHBhcmFtIHJvd3MgdGhlIHJvdyBpbmRleFxuICAgICAqIEBwYXJhbSBjb2x1bW5zIHRoZSBjb2x1bW4gaW5kZXhcbiAgICAgKiBAcGFyYW0gdmFsdWUgdGhlIGVsZW1lbnRcbiAgICAgKiBAcmV0dXJuIHRoZSBncmlkXG4gICAgICovXG4gICAgc2V0VmFsdWUocm93OiBudW1iZXIsIGNvbHVtbjogbnVtYmVyLCB2YWx1ZTogSXRlbVR5cGUpOiB0aGlzIHtcbiAgICAgIHRoaXNbdGhpcy5nZXRJbmRleChyb3csIGNvbHVtbildID0gdmFsdWU7XG4gICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBDcmVhdGVzIGFuIGFycmF5IG9mIGFycmF5cyByZXByZXNlbnRpbmcgcm93cyBvZiB0aGUgZ3JpZC5cbiAgICAgKlxuICAgICAqIEByZXR1cm4gYW4gYXJyYXkgb2YgYXJyYXlzXG4gICAgICovXG4gICAgdG9BcnJheXMoKTogQXJyYXk8QXJyYXk8SXRlbVR5cGU+PiB7XG4gICAgICBjb25zdCB7IHJvd3MsIGNvbHVtbnMsIHNpemUgfSA9IHRoaXM7XG4gICAgICBjb25zdCByZXN1bHQ6IEFycmF5PEFycmF5PEl0ZW1UeXBlPj4gPSBbXTtcbiAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgcm93czsgaSsrKSB7XG4gICAgICAgIGNvbnN0IHJvd09mZnNldCA9IGkgPDwgc2l6ZTtcbiAgICAgICAgcmVzdWx0W2ldID0gW107XG4gICAgICAgIGZvciAobGV0IGogPSAwOyBqIDwgY29sdW1uczsgaisrKSB7XG4gICAgICAgICAgcmVzdWx0W2ldW2pdID0gdGhpc1tyb3dPZmZzZXQgKyBqXTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgcmV0dXJuIHJlc3VsdDtcbiAgICB9XG4gIH07XG59XG4iXX0= | ||
//# sourceMappingURL=grid.js.map |
{ | ||
"name": "structurae", | ||
"version": "4.0.0-pre.10", | ||
"version": "4.0.0-pre.11", | ||
"description": "Data structures for performance-sensitive modern JavaScript applications.", | ||
@@ -5,0 +5,0 @@ "main": "index.js", |
50
pool.js
import { BitArray } from "./bit-array.js"; | ||
import { getLSBIndex } from "./utilities.js"; | ||
/** | ||
* Implements a fast algorithm to manage availability of objects in an object pool using a BitArray. | ||
* | ||
* @example | ||
* // create a pool of 1600 indexes | ||
* const pool = Pool.create(100 * 16); | ||
* | ||
* // get the next available index and make it unavailable | ||
* pool.get(); | ||
* //=> 0 | ||
* pool.get(); | ||
* //=> 1 | ||
* | ||
* // set index available | ||
* pool.free(0); | ||
* pool.get(); | ||
* //=> 0 | ||
* | ||
* pool.get(); | ||
* //=> 2 | ||
*/ | ||
export class Pool extends BitArray { | ||
constructor() { | ||
super(...arguments); | ||
Object.defineProperty(this, "nextAvailable", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: 0 | ||
}); | ||
} | ||
/** | ||
* Creates a Pool of the specified size. | ||
* | ||
* @param size the size of the pool | ||
* @return a new Pool | ||
*/ | ||
nextAvailable = 0; | ||
static create(size) { | ||
@@ -45,7 +10,2 @@ const pool = new this(this.getLength(size)); | ||
} | ||
/** | ||
* Makes a given index available. | ||
* | ||
* @param index index to be freed | ||
*/ | ||
free(index) { | ||
@@ -56,7 +16,2 @@ const { bucket, position } = this.getBitPosition(index); | ||
} | ||
/** | ||
* Gets the next available index in the pool. | ||
* | ||
* @return the next available index | ||
*/ | ||
get() { | ||
@@ -69,3 +24,2 @@ const { nextAvailable } = this; | ||
this[nextAvailable] &= ~(1 << index); | ||
// record is full, find next empty | ||
if (this[nextAvailable] === 0) { | ||
@@ -83,3 +37,3 @@ this.nextAvailable = -1; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9vbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInBvb2wudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzFDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQXVCN0MsTUFBTSxPQUFPLElBQUssU0FBUSxRQUFRO0lBQ2hDLGFBQWEsR0FBRyxDQUFDLENBQUM7SUFRbEIsTUFBTSxDQUFDLE1BQU0sQ0FFWCxJQUFZO1FBRVosTUFBTSxJQUFJLEdBQUcsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1FBQzVDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDdEIsT0FBTyxJQUF1QixDQUFDO0lBQ2pDLENBQUM7SUFPRCxJQUFJLENBQUMsS0FBYTtRQUNoQixNQUFNLEVBQUUsTUFBTSxFQUFFLFFBQVEsRUFBRSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDeEQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxRQUFRLENBQUM7UUFDOUIsSUFBSSxDQUFDLGFBQWEsR0FBRyxNQUFNLENBQUM7SUFDOUIsQ0FBQztJQU9ELEdBQUc7UUFDRCxNQUFNLEVBQUUsYUFBYSxFQUFFLEdBQUcsSUFBSSxDQUFDO1FBQy9CLElBQUksQ0FBQyxDQUFDLGFBQWE7WUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDO1FBQy9CLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUNuQyxNQUFNLEtBQUssR0FBRyxXQUFXLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDbEMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxDQUFDLENBQUM7UUFHckMsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQzdCLElBQUksQ0FBQyxhQUFhLEdBQUcsQ0FBQyxDQUFDLENBQUM7WUFDeEIsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUU7Z0JBQ3BDLElBQUksSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsRUFBRTtvQkFDakIsSUFBSSxDQUFDLGFBQWEsR0FBRyxDQUFDLENBQUM7b0JBQ3ZCLE1BQU07aUJBQ1A7YUFDRjtTQUNGO1FBRUQsT0FBTyxDQUFDLGFBQWEsSUFBSSxDQUFDLENBQUMsR0FBRyxLQUFLLENBQUM7SUFDdEMsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQml0QXJyYXkgfSBmcm9tIFwiLi9iaXQtYXJyYXkudHNcIjtcbmltcG9ydCB7IGdldExTQkluZGV4IH0gZnJvbSBcIi4vdXRpbGl0aWVzLnRzXCI7XG5cbi8qKlxuICogSW1wbGVtZW50cyBhIGZhc3QgYWxnb3JpdGhtIHRvIG1hbmFnZSBhdmFpbGFiaWxpdHkgb2Ygb2JqZWN0cyBpbiBhbiBvYmplY3QgcG9vbCB1c2luZyBhIEJpdEFycmF5LlxuICpcbiAqIEBleGFtcGxlXG4gKiAvLyBjcmVhdGUgYSBwb29sIG9mIDE2MDAgaW5kZXhlc1xuICogY29uc3QgcG9vbCA9IFBvb2wuY3JlYXRlKDEwMCAqIDE2KTtcbiAqXG4gKiAvLyBnZXQgdGhlIG5leHQgYXZhaWxhYmxlIGluZGV4IGFuZCBtYWtlIGl0IHVuYXZhaWxhYmxlXG4gKiBwb29sLmdldCgpO1xuICogLy89PiAwXG4gKiBwb29sLmdldCgpO1xuICogLy89PiAxXG4gKlxuICogLy8gc2V0IGluZGV4IGF2YWlsYWJsZVxuICogcG9vbC5mcmVlKDApO1xuICogcG9vbC5nZXQoKTtcbiAqIC8vPT4gMFxuICpcbiAqIHBvb2wuZ2V0KCk7XG4gKiAvLz0+IDJcbiAqL1xuZXhwb3J0IGNsYXNzIFBvb2wgZXh0ZW5kcyBCaXRBcnJheSB7XG4gIG5leHRBdmFpbGFibGUgPSAwO1xuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgUG9vbCBvZiB0aGUgc3BlY2lmaWVkIHNpemUuXG4gICAqXG4gICAqIEBwYXJhbSBzaXplIHRoZSBzaXplIG9mIHRoZSBwb29sXG4gICAqIEByZXR1cm4gYSBuZXcgUG9vbFxuICAgKi9cbiAgc3RhdGljIGNyZWF0ZTxUIGV4dGVuZHMgdHlwZW9mIEJpdEFycmF5PihcbiAgICB0aGlzOiBULFxuICAgIHNpemU6IG51bWJlcixcbiAgKTogSW5zdGFuY2VUeXBlPFQ+IHtcbiAgICBjb25zdCBwb29sID0gbmV3IHRoaXModGhpcy5nZXRMZW5ndGgoc2l6ZSkpO1xuICAgIHBvb2wuZmlsbCg0Mjk0OTY3Mjk1KTtcbiAgICByZXR1cm4gcG9vbCBhcyBJbnN0YW5jZVR5cGU8VD47XG4gIH1cblxuICAvKipcbiAgICogTWFrZXMgYSBnaXZlbiBpbmRleCBhdmFpbGFibGUuXG4gICAqXG4gICAqIEBwYXJhbSBpbmRleCBpbmRleCB0byBiZSBmcmVlZFxuICAgKi9cbiAgZnJlZShpbmRleDogbnVtYmVyKTogdm9pZCB7XG4gICAgY29uc3QgeyBidWNrZXQsIHBvc2l0aW9uIH0gPSB0aGlzLmdldEJpdFBvc2l0aW9uKGluZGV4KTtcbiAgICB0aGlzW2J1Y2tldF0gfD0gMSA8PCBwb3NpdGlvbjtcbiAgICB0aGlzLm5leHRBdmFpbGFibGUgPSBidWNrZXQ7XG4gIH1cblxuICAvKipcbiAgICogR2V0cyB0aGUgbmV4dCBhdmFpbGFibGUgaW5kZXggaW4gdGhlIHBvb2wuXG4gICAqXG4gICAqIEByZXR1cm4gdGhlIG5leHQgYXZhaWxhYmxlIGluZGV4XG4gICAqL1xuICBnZXQoKTogbnVtYmVyIHtcbiAgICBjb25zdCB7IG5leHRBdmFpbGFibGUgfSA9IHRoaXM7XG4gICAgaWYgKCF+bmV4dEF2YWlsYWJsZSkgcmV0dXJuIC0xO1xuICAgIGNvbnN0IHJlY29yZCA9IHRoaXNbbmV4dEF2YWlsYWJsZV07XG4gICAgY29uc3QgaW5kZXggPSBnZXRMU0JJbmRleChyZWNvcmQpO1xuICAgIHRoaXNbbmV4dEF2YWlsYWJsZV0gJj0gfigxIDw8IGluZGV4KTtcblxuICAgIC8vIHJlY29yZCBpcyBmdWxsLCBmaW5kIG5leHQgZW1wdHlcbiAgICBpZiAodGhpc1tuZXh0QXZhaWxhYmxlXSA9PT0gMCkge1xuICAgICAgdGhpcy5uZXh0QXZhaWxhYmxlID0gLTE7XG4gICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMubGVuZ3RoOyBpKyspIHtcbiAgICAgICAgaWYgKHRoaXNbaV0gIT09IDApIHtcbiAgICAgICAgICB0aGlzLm5leHRBdmFpbGFibGUgPSBpO1xuICAgICAgICAgIGJyZWFrO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIChuZXh0QXZhaWxhYmxlIDw8IDUpICsgaW5kZXg7XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=pool.js.map |
import { BitArray } from "./bit-array.js"; | ||
import { getLSBIndex, popCount32 } from "./utilities.js"; | ||
/** | ||
* A bit array that supports constant time rank and O(logN) time select operations. | ||
* | ||
* @example | ||
* const array = RankedBitArray.create(10); | ||
* array.setBit(1).setBit(3).setBit(7); | ||
* array.rank(2); | ||
* //=> 1 | ||
* array.rank(7); | ||
* //=> 2 | ||
* array.select(2); | ||
* //=> 3 | ||
*/ | ||
export class RankedBitArray extends BitArray { | ||
/** | ||
* The amount of bits in the array. | ||
*/ | ||
get size() { | ||
return (this.length >> 1) << 5; | ||
} | ||
/** | ||
* Returns the length of the underlying TypedArray required to hold the given amount of bits. | ||
* | ||
* @param size the amount of bits | ||
* @return the required length | ||
*/ | ||
static getLength(size) { | ||
return Math.ceil(size / 32) << 1; | ||
} | ||
/** | ||
* Returns the rank of a bit at a given index. | ||
* | ||
* @param index the index | ||
* @return the rank | ||
*/ | ||
rank(index) { | ||
const { bucket, position } = this.getBitPosition(index); | ||
const value = this[bucket]; | ||
// mask out following bits | ||
const masked = value & ((1 << position) - 1); | ||
@@ -47,8 +18,2 @@ const localRank = popCount32(masked); | ||
} | ||
/** | ||
* Returns the select of a bit at a given index. | ||
* | ||
* @param index the index | ||
* @return the select | ||
*/ | ||
select(index) { | ||
@@ -68,3 +33,2 @@ const middle = this.length >> 1; | ||
else if (index === this[bucketRankId - 1]) { | ||
// preceded by a duplicate | ||
right = bucketRankId - 1; | ||
@@ -92,9 +56,2 @@ } | ||
} | ||
/** | ||
* Sets the bit at a given index. | ||
* | ||
* @param index the index | ||
* @param value the value | ||
* @return this | ||
*/ | ||
setBit(index, value = 1) { | ||
@@ -109,3 +66,3 @@ super.setBit(index, value); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFua2VkLWJpdC1hcnJheS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInJhbmtlZC1iaXQtYXJyYXkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzFDLE9BQU8sRUFBRSxXQUFXLEVBQUUsVUFBVSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFlekQsTUFBTSxPQUFPLGNBQWUsU0FBUSxRQUFRO0lBSTFDLElBQUksSUFBSTtRQUNOLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNqQyxDQUFDO0lBUUQsTUFBTSxDQUFDLFNBQVMsQ0FBQyxJQUFZO1FBQzNCLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ25DLENBQUM7SUFRRCxJQUFJLENBQUMsS0FBYTtRQUNoQixNQUFNLEVBQUUsTUFBTSxFQUFFLFFBQVEsRUFBRSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDeEQsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRTNCLE1BQU0sTUFBTSxHQUFHLEtBQUssR0FBRyxDQUFDLENBQUMsQ0FBQyxJQUFJLFFBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBQzdDLE1BQU0sU0FBUyxHQUFHLFVBQVUsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNyQyxNQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLElBQUksQ0FBQyxDQUFDLEdBQUcsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDdEUsT0FBTyxVQUFVLEdBQUcsU0FBUyxDQUFDO0lBQ2hDLENBQUM7SUFRRCxNQUFNLENBQUMsS0FBYTtRQUNsQixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxJQUFJLENBQUMsQ0FBQztRQUNoQyxJQUFJLElBQUksR0FBRyxNQUFNLENBQUM7UUFDbEIsSUFBSSxLQUFLLEdBQUcsSUFBSSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7UUFDNUIsSUFBSSxZQUFZLEdBQUcsQ0FBQyxDQUFDO1FBQ3JCLE9BQU8sSUFBSSxJQUFJLEtBQUssRUFBRTtZQUNwQixZQUFZLEdBQUcsQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQ25DLElBQUksS0FBSyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsRUFBRTtnQkFDOUIsSUFBSSxHQUFHLFlBQVksR0FBRyxDQUFDLENBQUM7YUFDekI7aUJBQU0sSUFBSSxLQUFLLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxFQUFFO2dCQUNyQyxLQUFLLEdBQUcsWUFBWSxHQUFHLENBQUMsQ0FBQzthQUMxQjtpQkFBTSxJQUFJLEtBQUssS0FBSyxJQUFJLENBQUMsWUFBWSxHQUFHLENBQUMsQ0FBQyxFQUFFO2dCQUUzQyxLQUFLLEdBQUcsWUFBWSxHQUFHLENBQUMsQ0FBQzthQUMxQjtpQkFBTTtnQkFDTCxNQUFNO2FBQ1A7U0FDRjtRQUNELFlBQVksR0FBRyxLQUFLLEtBQUssSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztRQUVsRSxJQUFJLFlBQVksSUFBSSxJQUFJLENBQUMsTUFBTTtZQUFFLE9BQU8sQ0FBQyxDQUFDLENBQUM7UUFFM0MsSUFBSSxJQUFJLEdBQUcsWUFBWSxHQUFHLE1BQU0sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFlBQVksR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzlELE1BQU0sTUFBTSxHQUFHLFlBQVksR0FBRyxNQUFNLENBQUM7UUFDckMsSUFBSSxLQUFLLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3pCLE9BQU8sS0FBSyxFQUFFO1lBQ1osTUFBTSxRQUFRLEdBQUcsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ3BDLEtBQUssSUFBSSxLQUFLLEdBQUcsQ0FBQyxDQUFDO1lBQ25CLElBQUksRUFBRSxDQUFDO1lBQ1AsSUFBSSxJQUFJLEtBQUssS0FBSyxFQUFFO2dCQUNsQixPQUFPLENBQUMsTUFBTSxJQUFJLENBQUMsQ0FBQyxHQUFHLFFBQVEsQ0FBQzthQUNqQztTQUNGO1FBQ0QsT0FBTyxDQUFDLENBQUMsQ0FBQztJQUNaLENBQUM7SUFTRCxNQUFNLENBQUMsS0FBYSxFQUFFLFFBQWEsQ0FBQztRQUNsQyxLQUFLLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQztRQUMzQixNQUFNLE1BQU0sR0FBRyxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUM7UUFDM0IsS0FDRSxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxNQUFNLElBQUksQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxNQUFNLEVBQ3JELENBQUMsR0FBRyxJQUFJLENBQUMsTUFBTSxFQUNmLENBQUMsRUFBRSxFQUNIO1lBQ0EsSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLE1BQU0sQ0FBQztTQUNuQjtRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBCaXQgfSBmcm9tIFwiLi91dGlsaXR5LXR5cGVzLnRzXCI7XG5pbXBvcnQgeyBCaXRBcnJheSB9IGZyb20gXCIuL2JpdC1hcnJheS50c1wiO1xuaW1wb3J0IHsgZ2V0TFNCSW5kZXgsIHBvcENvdW50MzIgfSBmcm9tIFwiLi91dGlsaXRpZXMudHNcIjtcblxuLyoqXG4gKiBBIGJpdCBhcnJheSB0aGF0IHN1cHBvcnRzIGNvbnN0YW50IHRpbWUgcmFuayBhbmQgTyhsb2dOKSB0aW1lIHNlbGVjdCBvcGVyYXRpb25zLlxuICpcbiAqIEBleGFtcGxlXG4gKiBjb25zdCBhcnJheSA9IFJhbmtlZEJpdEFycmF5LmNyZWF0ZSgxMCk7XG4gKiBhcnJheS5zZXRCaXQoMSkuc2V0Qml0KDMpLnNldEJpdCg3KTtcbiAqIGFycmF5LnJhbmsoMik7XG4gKiAvLz0+IDFcbiAqIGFycmF5LnJhbmsoNyk7XG4gKiAvLz0+IDJcbiAqIGFycmF5LnNlbGVjdCgyKTtcbiAqIC8vPT4gM1xuICovXG5leHBvcnQgY2xhc3MgUmFua2VkQml0QXJyYXkgZXh0ZW5kcyBCaXRBcnJheSB7XG4gIC8qKlxuICAgKiBUaGUgYW1vdW50IG9mIGJpdHMgaW4gdGhlIGFycmF5LlxuICAgKi9cbiAgZ2V0IHNpemUoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gKHRoaXMubGVuZ3RoID4+IDEpIDw8IDU7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyB0aGUgbGVuZ3RoIG9mIHRoZSB1bmRlcmx5aW5nIFR5cGVkQXJyYXkgcmVxdWlyZWQgdG8gaG9sZCB0aGUgZ2l2ZW4gYW1vdW50IG9mIGJpdHMuXG4gICAqXG4gICAqIEBwYXJhbSBzaXplIHRoZSBhbW91bnQgb2YgYml0c1xuICAgKiBAcmV0dXJuIHRoZSByZXF1aXJlZCBsZW5ndGhcbiAgICovXG4gIHN0YXRpYyBnZXRMZW5ndGgoc2l6ZTogbnVtYmVyKTogbnVtYmVyIHtcbiAgICByZXR1cm4gTWF0aC5jZWlsKHNpemUgLyAzMikgPDwgMTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSByYW5rIG9mIGEgYml0IGF0IGEgZ2l2ZW4gaW5kZXguXG4gICAqXG4gICAqIEBwYXJhbSBpbmRleCB0aGUgaW5kZXhcbiAgICogQHJldHVybiB0aGUgcmFua1xuICAgKi9cbiAgcmFuayhpbmRleDogbnVtYmVyKTogbnVtYmVyIHtcbiAgICBjb25zdCB7IGJ1Y2tldCwgcG9zaXRpb24gfSA9IHRoaXMuZ2V0Qml0UG9zaXRpb24oaW5kZXgpO1xuICAgIGNvbnN0IHZhbHVlID0gdGhpc1tidWNrZXRdO1xuICAgIC8vIG1hc2sgb3V0IGZvbGxvd2luZyBiaXRzXG4gICAgY29uc3QgbWFza2VkID0gdmFsdWUgJiAoKDEgPDwgcG9zaXRpb24pIC0gMSk7XG4gICAgY29uc3QgbG9jYWxSYW5rID0gcG9wQ291bnQzMihtYXNrZWQpO1xuICAgIGNvbnN0IGJ1Y2tldFJhbmsgPSBidWNrZXQgPyB0aGlzWyh0aGlzLmxlbmd0aCA+PiAxKSArIGJ1Y2tldCAtIDFdIDogMDtcbiAgICByZXR1cm4gYnVja2V0UmFuayArIGxvY2FsUmFuaztcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBzZWxlY3Qgb2YgYSBiaXQgYXQgYSBnaXZlbiBpbmRleC5cbiAgICpcbiAgICogQHBhcmFtIGluZGV4IHRoZSBpbmRleFxuICAgKiBAcmV0dXJuIHRoZSBzZWxlY3RcbiAgICovXG4gIHNlbGVjdChpbmRleDogbnVtYmVyKTogbnVtYmVyIHtcbiAgICBjb25zdCBtaWRkbGUgPSB0aGlzLmxlbmd0aCA+PiAxO1xuICAgIGxldCBsZWZ0ID0gbWlkZGxlO1xuICAgIGxldCByaWdodCA9IHRoaXMubGVuZ3RoIC0gMTtcbiAgICBsZXQgYnVja2V0UmFua0lkID0gMDtcbiAgICB3aGlsZSAobGVmdCA8PSByaWdodCkge1xuICAgICAgYnVja2V0UmFua0lkID0gKHJpZ2h0ICsgbGVmdCkgPj4gMTtcbiAgICAgIGlmIChpbmRleCA+IHRoaXNbYnVja2V0UmFua0lkXSkge1xuICAgICAgICBsZWZ0ID0gYnVja2V0UmFua0lkICsgMTtcbiAgICAgIH0gZWxzZSBpZiAoaW5kZXggPCB0aGlzW2J1Y2tldFJhbmtJZF0pIHtcbiAgICAgICAgcmlnaHQgPSBidWNrZXRSYW5rSWQgLSAxO1xuICAgICAgfSBlbHNlIGlmIChpbmRleCA9PT0gdGhpc1tidWNrZXRSYW5rSWQgLSAxXSkge1xuICAgICAgICAvLyBwcmVjZWRlZCBieSBhIGR1cGxpY2F0ZVxuICAgICAgICByaWdodCA9IGJ1Y2tldFJhbmtJZCAtIDE7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBicmVhaztcbiAgICAgIH1cbiAgICB9XG4gICAgYnVja2V0UmFua0lkID0gaW5kZXggPT09IHRoaXNbYnVja2V0UmFua0lkXSA/IGJ1Y2tldFJhbmtJZCA6IGxlZnQ7XG5cbiAgICBpZiAoYnVja2V0UmFua0lkID49IHRoaXMubGVuZ3RoKSByZXR1cm4gLTE7XG5cbiAgICBsZXQgcmFuayA9IGJ1Y2tldFJhbmtJZCA+IG1pZGRsZSA/IHRoaXNbYnVja2V0UmFua0lkIC0gMV0gOiAwO1xuICAgIGNvbnN0IGJ1Y2tldCA9IGJ1Y2tldFJhbmtJZCAtIG1pZGRsZTtcbiAgICBsZXQgdmFsdWUgPSB0aGlzW2J1Y2tldF07XG4gICAgd2hpbGUgKHZhbHVlKSB7XG4gICAgICBjb25zdCBwb3NpdGlvbiA9IGdldExTQkluZGV4KHZhbHVlKTtcbiAgICAgIHZhbHVlICY9IHZhbHVlIC0gMTtcbiAgICAgIHJhbmsrKztcbiAgICAgIGlmIChyYW5rID09PSBpbmRleCkge1xuICAgICAgICByZXR1cm4gKGJ1Y2tldCA8PCA1KSArIHBvc2l0aW9uO1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gLTE7XG4gIH1cblxuICAvKipcbiAgICogU2V0cyB0aGUgYml0IGF0IGEgZ2l2ZW4gaW5kZXguXG4gICAqXG4gICAqIEBwYXJhbSBpbmRleCB0aGUgaW5kZXhcbiAgICogQHBhcmFtIHZhbHVlIHRoZSB2YWx1ZVxuICAgKiBAcmV0dXJuIHRoaXNcbiAgICovXG4gIHNldEJpdChpbmRleDogbnVtYmVyLCB2YWx1ZTogQml0ID0gMSk6IHRoaXMge1xuICAgIHN1cGVyLnNldEJpdChpbmRleCwgdmFsdWUpO1xuICAgIGNvbnN0IGNoYW5nZSA9IHZhbHVlIHx8IC0xO1xuICAgIGZvciAoXG4gICAgICBsZXQgaSA9ICh0aGlzLmxlbmd0aCA+PiAxKSArIHRoaXMubGFzdFBvc2l0aW9uLmJ1Y2tldDtcbiAgICAgIGkgPCB0aGlzLmxlbmd0aDtcbiAgICAgIGkrK1xuICAgICkge1xuICAgICAgdGhpc1tpXSArPSBjaGFuZ2U7XG4gICAgfVxuICAgIHJldHVybiB0aGlzO1xuICB9XG59XG4iXX0= | ||
//# sourceMappingURL=ranked-bit-array.js.map |
@@ -57,3 +57,3 @@ # Structurae | ||
``` | ||
import {...} from "https://deno.land/x/structurae@4.0.0-pre.9/index.ts" | ||
import {...} from "https://deno.land/x/structurae@4.0.0-pre.11/index.ts" | ||
``` | ||
@@ -280,2 +280,29 @@ | ||
#### Dictionaries | ||
Objects and maps described above assume that all properties of encoded objects | ||
are known and defined beforehand, however, if the properties are not known, and | ||
we are dealing with an object used as a lookup table (also called map, hash map, | ||
or records in TypeScript) with varying amount of properties and known type of | ||
values, we can use a dictionary view: | ||
```typescript | ||
const NumberDict = View.create<Record<number, string | undefined>>({ | ||
$id: "NumberDict", | ||
type: "object", | ||
btype: "dict", // dictionaries use btype dict | ||
// the type of keys are defined in the `propertyNames` field of a schema | ||
// the keys must be either fixed sized strings or numbers | ||
propertyNames: { type: "number", btype: "uint8" }, | ||
// the type of values defined in `addtionalProperties` field | ||
// values can be of any supported type | ||
additionalProperties: { type: "string" }, | ||
}); | ||
const dict = NumberDict.from({ 1: "a", 2: "bcd", 3: undefined }); | ||
dict.get(1); //=> "a" | ||
dict.get(3); //=> undefined | ||
dict.get(10); //=> undefined | ||
dict.get(2); //=> "bcd" | ||
``` | ||
#### Arrays and Vectors | ||
@@ -282,0 +309,0 @@ |
@@ -1,21 +0,3 @@ | ||
/** | ||
* Extends Array to handle sorted data. | ||
*/ | ||
export class SortedArray extends Array { | ||
constructor() { | ||
super(...arguments); | ||
Object.defineProperty(this, "unique", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: false | ||
}); | ||
} | ||
/** | ||
* The default comparator. | ||
* | ||
* @param a the first value | ||
* @param b the second value | ||
* @throws RangeError if the comparison is unstable | ||
*/ | ||
unique = false; | ||
static compare(a, b) { | ||
@@ -37,28 +19,2 @@ if (a > b) | ||
} | ||
/** | ||
* Returns the difference of two sorted arrays, | ||
* i.e. elements present in the first array but not in the second array. | ||
* If `symmetric=true` finds the symmetric difference of two arrays, that is, | ||
* the elements that are absent in one or another array. | ||
* | ||
* @param a the first array | ||
* @param b the second array | ||
* @param [symmetric=false] whether to get symmetric difference. | ||
* @param [comparator] the comparator static used to sort the arrays | ||
* @param [container] an array-like object to hold the results | ||
* @return the difference of the arrays | ||
* @example | ||
* | ||
* SortedArray.getDifference([1, 2, 3, 4, 8], [2, 4, 6, 7, 9]); | ||
* //=> [ 1, 3, 8 ] | ||
* | ||
* // symmetric difference of sorted arrays: | ||
* SortedArray.getDifference(first, second, true); | ||
* //=> [ 1, 3, 6, 7, 8, 9 ] | ||
* // difference using a custom comparator: | ||
* const customComparator = (a, b) => (a > b ? -1 : a < b ? 1 : 0); | ||
* SortedArray.getDifference([8, 4, 3, 2, 1], [9, 7, 6, 4, 2], false, customComparator); | ||
* //=> [ 8, 3, 1 ] | ||
*/ | ||
static getDifference(a, b, symmetric = false, comparator = this.compare, container = []) { | ||
@@ -95,15 +51,2 @@ let i = 0; | ||
} | ||
/** | ||
* Returns the amount of differing elements in the first array. | ||
* | ||
* @param a the first array | ||
* @param b the second array | ||
* @param [symmetric=false] whether to use symmetric difference | ||
* @param [comparator] the comparator static used to sort the arrays | ||
* @return the amount of differing elements | ||
* @example | ||
* | ||
* SortedArray.getDifferenceScore([1, 2, 3, 4, 8], [2, 4, 6, 7, 9]); | ||
* //=> 3 | ||
*/ | ||
static getDifferenceScore(a, b, symmetric = false, comparator = this.compare) { | ||
@@ -113,17 +56,2 @@ const score = this.getIntersectionScore(a, b, comparator); | ||
} | ||
/** | ||
* Uses binary search to find the index of an element inside a sorted array. | ||
* | ||
* @param arr the array to search | ||
* @param target the target value to search for | ||
* @param [comparator] a custom comparator | ||
* @param [rank=false] whether to return the element's rank if the element isn't found | ||
* @param [start] the start position of the search | ||
* @param [end] the end position of the search | ||
* @return the index of the searched element or it's rank | ||
* @example | ||
* | ||
* SortedArray.getIndex([1, 2, 3, 4, 8], 4); | ||
* //=> 3 | ||
*/ | ||
static getIndex(arr, target, comparator = this.compare, rank = false, start = 0, end = arr.length - 1) { | ||
@@ -148,20 +76,2 @@ let left = start; | ||
} | ||
/** | ||
* Returns the intersection of two sorted arrays. | ||
* | ||
* @param a the first array | ||
* @param b the second array | ||
* @param [comparator] the comparator static used to sort the arrays | ||
* @param [container] an array-like object to hold the results | ||
* @return the intersection of the arrays | ||
* @example | ||
* | ||
* SortedArray.getIntersection([1, 2, 3, 4, 8], [2, 4, 6, 7, 9]); | ||
* //=> [ 2, 4 ] | ||
* | ||
* // intersection using a custom comparator: | ||
* const customComparator = (a, b) => (a > b ? -1 : a < b ? 1 : 0); | ||
* SortedArray.getIntersection([8, 4, 3, 2, 1], [9, 7, 6, 4, 2], customComparator); | ||
* //=> [ 4, 2 ] | ||
*/ | ||
static getIntersection(a, b, comparator = this.compare, container = []) { | ||
@@ -186,14 +96,2 @@ let i = 0; | ||
} | ||
/** | ||
* Returns the amount of common elements in two sorted arrays. | ||
* | ||
* @param a the first array | ||
* @param b the second array | ||
* @param [comparator] the comparator static used to sort the arrays | ||
* @return the amount of different elements | ||
* @example | ||
* | ||
* SortedArray.getIntersection([1, 2, 3, 4, 8], [2, 4, 6, 7, 9]); | ||
* //=> 2 | ||
*/ | ||
static getIntersectionScore(a, b, comparator = this.compare) { | ||
@@ -219,20 +117,2 @@ let score = 0; | ||
} | ||
/** | ||
* Returns a range of elements of a sorted array from the start through the end inclusively. | ||
* | ||
* @param arr the array | ||
* @param [start] the starting item | ||
* @param [end] the ending item | ||
* @param [comparator] a custom comparator | ||
* @param [subarray] return a subarray instead of copying resulting value with slice | ||
* @return the range of items | ||
* @example | ||
* | ||
* SortedArray.getRange([1, 2, 3, 4, 8], 2, 4); | ||
* //=> [ 2, 3, 4 ] | ||
* | ||
* const customComparator = (a, b) => (a > b ? -1 : a < b ? 1 : 0); | ||
* SortedArray.getRange([8, 4, 3, 2, 1], 8, 3, customComparator); | ||
* //=> [ 8, 4, 3 ] | ||
*/ | ||
static getRange(arr, start, end, comparator, subarray) { | ||
@@ -247,27 +127,5 @@ const startIndex = start === undefined | ||
? arr.subarray(startIndex, endIndex) | ||
: // deno-lint-ignore no-explicit-any | ||
: | ||
arr.slice(startIndex, endIndex); | ||
} | ||
/** | ||
* Returns the union of two sorted arrays as a sorted array. | ||
* | ||
* @param a the first array | ||
* @param b the second array | ||
* @param [unique=false] whether to avoid duplicating items when merging unique arrays | ||
* @param [comparator] the comparator static used to sort the arrays | ||
* @param [container] an array-like object to hold the results | ||
* @return the union of the arrays | ||
* @example | ||
* | ||
* SortedArray.getUnion([1, 2, 3, 4, 8], [2, 4, 6, 7, 9]); | ||
* //=> [ 1, 2, 2, 3, 4, 4, 6, 7, 8, 9 ] | ||
* | ||
* // union of sorted arrays without duplicates: | ||
* SortedArray.getUnion([1, 2, 3, 4, 8], [2, 4, 6, 7, 9], true); | ||
* //=> [ 1, 2, 3, 4, 6, 7, 8, 9 ] | ||
* | ||
* //union using a custom comparator: | ||
* SortedArray.getUnion([8, 4, 3, 2, 1], [9, 7, 6, 4, 2], true, customComparator); | ||
* //=> [ 9, 8, 7, 6, 4, 3, 2, 1 ] | ||
*/ | ||
static getUnion(a, b, unique = false, comparator = this.compare, container = []) { | ||
@@ -304,14 +162,2 @@ let i = 0; | ||
} | ||
/** | ||
* Returns an array of unique elements from a sorted array. | ||
* | ||
* @param arr the sorted array | ||
* @param [comparator] a custom comparator | ||
* @param [container] an array-like object to hold the results | ||
* @return the sorted array without duplicates | ||
* @example | ||
* | ||
* SortedArray.getUnique([1, 1, 2, 2, 3, 4]); | ||
* //=> [ 1, 2, 3, 4 ] | ||
*/ | ||
static getUnique(arr, comparator = this.compare, container = []) { | ||
@@ -326,14 +172,2 @@ container[0] = arr[0]; | ||
} | ||
/** | ||
* Checks whether an array is sorted according to a provided comparator. | ||
* | ||
* @param arr the array to check | ||
* @param [comparator] a custom comparator | ||
* @return whether the array is sorted | ||
* | ||
* @example | ||
* | ||
* SortedArray.isSorted([1, 2, 3, 4, 8]); | ||
* //=> true | ||
*/ | ||
static isSorted(arr, comparator = this.compare) { | ||
@@ -346,13 +180,2 @@ for (let i = 1; i < arr.length; i++) { | ||
} | ||
/** | ||
* Checks whether an array has any duplicating elements. | ||
* | ||
* @param arr the array to check | ||
* @param [comparator] a custom comparator | ||
* @return whether the array has duplicating elements | ||
* @example | ||
* | ||
* SortedArray.isUnique([1, 2, 2, 3, 4]); | ||
* //=> false | ||
*/ | ||
static isUnique(arr, comparator = this.compare) { | ||
@@ -365,9 +188,2 @@ for (let i = 1; i < arr.length; i++) { | ||
} | ||
/** | ||
* Creates a new SortedArray instance with a variable number of arguments, | ||
* regardless of number or type of the arguments | ||
* | ||
* @param elements the elements of which to create the array | ||
* @return the new SortedArray | ||
*/ | ||
static of(...elements) { | ||
@@ -378,12 +194,5 @@ const result = super.of(...elements); | ||
} | ||
/** | ||
* Returns a merger of the array with one or more provided sorted arrays. | ||
* | ||
* @param arrays sorted array(s) to merge | ||
* @return a new SortedArray | ||
*/ | ||
concat(...arrays) { | ||
const constructor = this.constructor; | ||
let result = this.slice(0); | ||
// TODO rewrite | ||
for (let i = 0; i < arrays.length; i++) { | ||
@@ -394,54 +203,14 @@ result = constructor.getUnion(result, arrays[i], this.unique, constructor.compare, new constructor()); | ||
} | ||
/** | ||
* Uses binary search to quickly check if the element is the array. | ||
* @param element the element to check | ||
* @return whether the element is in the array | ||
*/ | ||
includes(element) { | ||
return !!~this.indexOf(element); | ||
} | ||
/** | ||
* Looks for the index of a given element in the array or -1 | ||
* | ||
* @param element the element to look for | ||
* @return the element's index in the array or -1 | ||
*/ | ||
indexOf(element) { | ||
return this.constructor.getIndex(this, element); | ||
} | ||
/** | ||
* Checks if the array is sorted. | ||
* | ||
* @return whether the array is sorted | ||
* @example | ||
* | ||
* //=> SortedArray [ 2, 3, 4, 5, 9 ]; | ||
* SortedArray.isSorted(); | ||
* //=> true | ||
* SortedArray.reverse(); | ||
* SortedArray.isSorted(); | ||
* //=> false; | ||
*/ | ||
isSorted() { | ||
return this.constructor.isSorted(this); | ||
} | ||
/** | ||
* Checks if the array has duplicating elements. | ||
* | ||
* @return whether the array has duplicating elements | ||
* @example | ||
* | ||
* //=> SortedArray [ 2, 3, 3, 4, 5, 9 ]; | ||
* SortedArray.isUnique(); | ||
* //=> false; | ||
*/ | ||
isUnique() { | ||
return this.constructor.isUnique(this); | ||
} | ||
/** | ||
* Adds provided elements to the array preserving the sorted order of the array. | ||
* | ||
* @param elements the elements to add to the array | ||
* @return the new length of the array | ||
*/ | ||
push(...elements) { | ||
@@ -472,19 +241,2 @@ const { compare } = this.constructor; | ||
} | ||
/** | ||
* Returns a range of elements of the array that are greater or equal to the provided | ||
* starting element and less or equal to the provided ending element. | ||
* | ||
* @param start the starting element | ||
* @param end the ending element | ||
* @return the resulting range of elements | ||
* @example | ||
* | ||
* //=> SortedArray [ 2, 3, 4, 5, 9 ]; | ||
* SortedArray.range(3, 5); | ||
* // => [ 3, 4, 5 ] | ||
* SortedArray.range(undefined, 4); | ||
* // => [ 2, 3, 4 ] | ||
* SortedArray.range(4); | ||
* // => [ 4, 5, 8 ] | ||
*/ | ||
range(start, end) { | ||
@@ -494,15 +246,2 @@ const constructor = this.constructor; | ||
} | ||
/** | ||
* Returns the rank of an element in the array. | ||
* | ||
* @param element the element to look for | ||
* @return the rank in the array | ||
* @example | ||
* | ||
* //=> SortedArray [ 2, 3, 4, 5, 9 ]; | ||
* SortedArray.rank(1); | ||
* // => 0 | ||
* SortedArray.rank(6); | ||
* // => 4 | ||
*/ | ||
rank(element) { | ||
@@ -512,13 +251,2 @@ const constructor = this.constructor; | ||
} | ||
/** | ||
* Implements in-place replacement of the array elements. | ||
* | ||
* @param arr an array of new elements to use | ||
* | ||
* @example | ||
* | ||
* //=> SortedArray [ 2, 3, 4, 5, 9 ]; | ||
* sortedArray.set([1, 2, 3]); | ||
* //=> SortedArray [ 1, 2, 3 ] | ||
*/ | ||
set(arr) { | ||
@@ -531,7 +259,2 @@ this.length = arr.length; | ||
} | ||
/** | ||
* Sorts the array with a provided compare function. | ||
* | ||
* @param compareFunction the function to use for comparison | ||
*/ | ||
sort(compareFunction = this | ||
@@ -541,10 +264,2 @@ .constructor.compare) { | ||
} | ||
/** | ||
* Changes the array by removing existing elements and adding new ones. | ||
* | ||
* @param start the index at which to start changing the array | ||
* @param deleteCount the amount of old elements to delete | ||
* @param elements the elements to add to the array | ||
* @return an array of deleted elements | ||
*/ | ||
splice(start, deleteCount, ...elements) { | ||
@@ -555,11 +270,2 @@ const deletedElements = super.splice(start, deleteCount); | ||
} | ||
/** | ||
* Removes duplicating elements from the array. | ||
* | ||
* @example | ||
* | ||
* //=> SortedArray [ 2, 2, 3, 4, 5, 5, 9 ]; | ||
* sortedArray.uniquify(); | ||
* // => SortedArray [ 2, 3, 4, 5, 9 ] | ||
*/ | ||
uniquify() { | ||
@@ -569,8 +275,2 @@ const constructor = this.constructor; | ||
} | ||
/** | ||
* Adds provided elements to the array preserving the sorted order of the array. | ||
* | ||
* @param elements the elements to add to the array | ||
* @return the new length of the array | ||
*/ | ||
unshift(...elements) { | ||
@@ -580,3 +280,3 @@ return this.push(...elements); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29ydGVkLWFycmF5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsic29ydGVkLWFycmF5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU9BLE1BQU0sT0FBTyxXQUFzQixTQUFRLEtBQWU7SUFDeEQsTUFBTSxHQUFHLEtBQUssQ0FBQztJQVNmLE1BQU0sQ0FBQyxPQUFPLENBQUksQ0FBSSxFQUFFLENBQUk7UUFDMUIsSUFBSSxDQUFDLEdBQUcsQ0FBQztZQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQ3BCLElBQUksQ0FBQyxHQUFHLENBQUM7WUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDO1FBQ3JCLElBQUksQ0FBQyxLQUFLLENBQUM7WUFBRSxPQUFPLENBQUMsQ0FBQztRQUN0QixNQUFNLElBQUksVUFBVSxDQUFDLHNCQUFzQixDQUFDLENBQUM7SUFDL0MsQ0FBQztJQU9ELE1BQU0sQ0FBQyxJQUFJLENBQ1QsUUFBb0MsRUFDcEMsS0FBOEIsRUFDOUIsT0FBaUI7UUFFakIsTUFBTSxNQUFNLEdBQ1YsQ0FBQyxLQUFLLEtBQUssU0FBUztZQUNsQixDQUFDLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsS0FBSyxFQUFFLE9BQU8sQ0FBQztZQUN0QyxDQUFDLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBbUIsQ0FBQztRQUM5QyxNQUFNLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDZCxPQUFPLE1BQU0sQ0FBQztJQUNoQixDQUFDO0lBNEJELE1BQU0sQ0FBQyxhQUFhLENBQ2xCLENBQUksRUFDSixDQUFJLEVBQ0osU0FBUyxHQUFHLEtBQUssRUFDakIsYUFBNEIsSUFBSSxDQUFDLE9BQU8sRUFDeEMsWUFBZ0IsRUFBbUI7UUFFbkMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ1YsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ1YsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sSUFBSSxDQUFDLEdBQUcs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QUFDLE9BQU87UUFFN0MsT0FBTyxLQUFLLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDO0lBQ3JDLENBQUM7SUFVRCxNQUFNLENBQ0osS0FBYSxFQUNiLFdBQW1CLEVBQ25CLEdBQUcsUUFBeUI7UUFFNUIsTUFBTSxlQUFlLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FDbEMsS0FBSyxFQUNMLFdBQVcsQ0FDYSxDQUFDO1FBQzNCLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxRQUFRLENBQUMsQ0FBQztRQUN2QixPQUFPLGVBQWUsQ0FBQztJQUN6QixDQUFDO0lBV0QsUUFBUTtRQUNOLE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxXQUFpQyxDQUFDO1FBQzNELE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FDYixXQUFXLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxXQUFXLENBQUMsT0FBTyxFQUFFLElBQUksV0FBVyxFQUFFLENBQUMsQ0FDcEUsQ0FBQztJQUNKLENBQUM7SUFRRCxPQUFPLENBQUMsR0FBRyxRQUF5QjtRQUNsQyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxRQUFRLENBQUMsQ0FBQztJQUNoQyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEluZGV4ZWRDb2xsZWN0aW9uIH0gZnJvbSBcIi4vdXRpbGl0eS10eXBlcy50c1wiO1xuXG5leHBvcnQgdHlwZSBDb21wYXJhdG9yPFQ+ID0gKGE6IFQsIGI6IFQpID0+IC0xIHwgMCB8IDE7XG5cbi8qKlxuICogRXh0ZW5kcyBBcnJheSB0byBoYW5kbGUgc29ydGVkIGRhdGEuXG4gKi9cbmV4cG9ydCBjbGFzcyBTb3J0ZWRBcnJheTxJdGVtVHlwZT4gZXh0ZW5kcyBBcnJheTxJdGVtVHlwZT4ge1xuICB1bmlxdWUgPSBmYWxzZTtcblxuICAvKipcbiAgICogVGhlIGRlZmF1bHQgY29tcGFyYXRvci5cbiAgICpcbiAgICogQHBhcmFtIGEgdGhlIGZpcnN0IHZhbHVlXG4gICAqIEBwYXJhbSBiIHRoZSBzZWNvbmQgdmFsdWVcbiAgICogQHRocm93cyBSYW5nZUVycm9yIGlmIHRoZSBjb21wYXJpc29uIGlzIHVuc3RhYmxlXG4gICAqL1xuICBzdGF0aWMgY29tcGFyZTxUPihhOiBULCBiOiBUKTogLTEgfCAwIHwgMSB7XG4gICAgaWYgKGEgPiBiKSByZXR1cm4gMTtcbiAgICBpZiAoYSA8IGIpIHJldHVybiAtMTtcbiAgICBpZiAoYSA9PT0gYikgcmV0dXJuIDA7XG4gICAgdGhyb3cgbmV3IFJhbmdlRXJyb3IoXCJVbnN0YWJsZSBjb21wYXJpc29uLlwiKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgbmV3IFNvcnRlZEFycmF5IGZyb20gYSBnaXZlbiBhcnJheS1saWtlIG9iamVjdC5cbiAgICovXG4gIHN0YXRpYyBmcm9tPFQ+KGl0ZXJhYmxlOiBJdGVyYWJsZTxUPiB8IEFycmF5TGlrZTxUPik6IFNvcnRlZEFycmF5PFQ+O1xuXG4gIHN0YXRpYyBmcm9tPFQsIFU+KFxuICAgIGl0ZXJhYmxlOiBJdGVyYWJsZTxUPiB8IEFycmF5TGlrZTxUPixcbiAgICBtYXBmbj86ICh2OiBULCBrOiBudW1iZXIpID0+IFUsXG4gICAgdGhpc0FyZz86IHVua25vd24sXG4gICk6IFNvcnRlZEFycmF5PFU+IHtcbiAgICBjb25zdCByZXN1bHQgPVxuICAgICAgKG1hcGZuICE9PSB1bmRlZmluZWRcbiAgICAgICAgPyBzdXBlci5mcm9tKGl0ZXJhYmxlLCBtYXBmbiwgdGhpc0FyZylcbiAgICAgICAgOiBzdXBlci5mcm9tKGl0ZXJhYmxlKSkgYXMgU29ydGVkQXJyYXk8VT47XG4gICAgcmVzdWx0LnNvcnQoKTtcbiAgICByZXR1cm4gcmVzdWx0O1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIGRpZmZlcmVuY2Ugb2YgdHdvIHNvcnRlZCBhcnJheXMsXG4gICAqIGkuZS4gZWxlbWVudHMgcHJlc2VudCBpbiB0aGUgZmlyc3QgYXJyYXkgYnV0IG5vdCBpbiB0aGUgc2Vjb25kIGFycmF5LlxuICAgKiBJZiBgc3ltbWV0cmljPXRydWVgIGZpbmRzIHRoZSBzeW1tZXRyaWMgZGlmZmVyZW5jZSBvZiB0d28gYXJyYXlzLCB0aGF0IGlzLFxuICAgKiB0aGUgZWxlbWVudHMgdGhhdCBhcmUgYWJzZW50IGluIG9uZSBvciBhbm90aGVyIGFycmF5LlxuICAgKlxuICAgKiBAcGFyYW0gYSB0aGUgZmlyc3QgYXJyYXlcbiAgICogQHBhcmFtIGIgdGhlIHNlY29uZCBhcnJheVxuICAgKiBAcGFyYW0gW3N5bW1ldHJpYz1mYWxzZV0gd2hldGhlciB0byBnZXQgc3ltbWV0cmljIGRpZmZlcmVuY2UuXG4gICAqIEBwYXJhbSBbY29tcGFyYXRvcl0gdGhlIGNvbXBhcmF0b3Igc3RhdGljIHVzZWQgdG8gc29ydCB0aGUgYXJyYXlzXG4gICAqIEBwYXJhbSBbY29udGFpbmVyXSBhbiBhcnJheS1saWtlIG9iamVjdCB0byBob2xkIHRoZSByZXN1bHRzXG4gICAqIEByZXR1cm4gdGhlIGRpZmZlcmVuY2Ugb2YgdGhlIGFycmF5c1xuICAgKiBAZXhhbXBsZVxuICAgKlxuICAgKiBTb3J0ZWRBcnJheS5nZXREaWZmZXJlbmNlKFsxLCAyLCAzLCA0LCA4XSwgWzIsIDQsIDYsIDcsIDldKTtcbiAgICogLy89PiBbIDEsIDMsIDggXVxuICAgKlxuICAgKiAvLyBzeW1tZXRyaWMgZGlmZmVyZW5jZSBvZiBzb3J0ZWQgYXJyYXlzOlxuICAgKiBTb3J0ZWRBcnJheS5nZXREaWZmZXJlbmNlKGZpcnN0LCBzZWNvbmQsIHRydWUpO1xuICAgKiAvLz0+IFsgMSwgMywgNiwgNywgOCwgOSBdXG5cbiAgICogLy8gZGlmZmVyZW5jZSB1c2luZyBhIGN1c3RvbSBjb21wYXJhdG9yOlxuICAgKiBjb25zdCBjdXN0b21Db21wYXJhdG9yID0gKGEsIGIpID0+IChhID4gYiA/IC0xIDogYSA8IGIgPyAxIDogMCk7XG4gICAqIFNvcnRlZEFycmF5LmdldERpZmZlcmVuY2UoWzgsIDQsIDMsIDIsIDFdLCBbOSwgNywgNiwgNCwgMl0sIGZhbHNlLCBjdXN0b21Db21wYXJhdG9yKTtcbiAgICogLy89PiBbIDgsIDMsIDEgXVxuICAgKi9cbiAgc3RhdGljIGdldERpZmZlcmVuY2U8VCwgVSBleHRlbmRzIEluZGV4ZWRDb2xsZWN0aW9uPFQ+PihcbiAgICBhOiBVLFxuICAgIGI6IFUsXG4gICAgc3ltbWV0cmljID0gZmFsc2UsXG4gICAgY29tcGFyYXRvcjogQ29tcGFyYXRvcjxUPiA9IHRoaXMuY29tcGFyZSxcbiAgICBjb250YWluZXI6IFUgPSAoW10gYXMgdW5rbm93bikgYXMgVSxcbiAgKTogdHlwZW9mIGNvbnRhaW5lciB7XG4gICAgbGV0IGkgPSAwO1xuICAgIGxldCBqID0gMDtcbiAgICB3aGlsZSAoaSA8IGEubGVuZ3RoICYmIGogPCBiLmxlbmd0aCkge1xuICAgICAgY29uc3QgY29tcGFyZWQgPSBjb21wYXJhdG9yKGFbaV0sIGJbal0pO1xuICAgICAgaWYgKGNvbXBhcmVkID4gMCkge1xuICAgICAgICBpZiAoc3ltbWV0cmljKSBjb250YWluZXJbY29udGFpbmVyLmxlbmd0aF0gPSBiW2pdO1xuICAgICAgICBqKys7XG4gICAgICB9IGVsc2UgaWYgKGNvbXBhcmVkIDwgMCkge1xuICAgICAgICBjb250YWluZXJbY29udGFpbmVyLmxlbmd0aF0gPSBhW2ldO1xuICAgICAgICBpKys7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBpKys7XG4gICAgICAgIGorKztcbiAgICAgIH1cbiAgICB9XG4gICAgd2hpbGUgKGkgPCBhLmxlbmd0aCkge1xuICAgICAgY29udGFpbmVyW2NvbnRhaW5lci5sZW5ndGhdID0gYVtpXTtcbiAgICAgIGkrKztcbiAgICB9XG4gICAgaWYgKHN5bW1ldHJpYykge1xuICAgICAgd2hpbGUgKGogPCBiLmxlbmd0aCkge1xuICAgICAgICBjb250YWluZXJbY29udGFpbmVyLmxlbmd0aF0gPSBiW2pdO1xuICAgICAgICBqKys7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBjb250YWluZXI7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyB0aGUgYW1vdW50IG9mIGRpZmZlcmluZyBlbGVtZW50cyBpbiB0aGUgZmlyc3QgYXJyYXkuXG4gICAqXG4gICAqIEBwYXJhbSBhIHRoZSBmaXJzdCBhcnJheVxuICAgKiBAcGFyYW0gYiB0aGUgc2Vjb25kIGFycmF5XG4gICAqIEBwYXJhbSBbc3ltbWV0cmljPWZhbHNlXSB3aGV0aGVyIHRvIHVzZSBzeW1tZXRyaWMgZGlmZmVyZW5jZVxuICAgKiBAcGFyYW0gW2NvbXBhcmF0b3JdIHRoZSBjb21wYXJhdG9yIHN0YXRpYyB1c2VkIHRvIHNvcnQgdGhlIGFycmF5c1xuICAgKiBAcmV0dXJuIHRoZSBhbW91bnQgb2YgZGlmZmVyaW5nIGVsZW1lbnRzXG4gICAqIEBleGFtcGxlXG4gICAqXG4gICAqIFNvcnRlZEFycmF5LmdldERpZmZlcmVuY2VTY29yZShbMSwgMiwgMywgNCwgOF0sIFsyLCA0LCA2LCA3LCA5XSk7XG4gICAqIC8vPT4gM1xuICAgKi9cbiAgc3RhdGljIGdldERpZmZlcmVuY2VTY29yZTxULCBVIGV4dGVuZHMgSW5kZXhlZENvbGxlY3Rpb248VD4+KFxuICAgIGE6IFUsXG4gICAgYjogVSxcbiAgICBzeW1tZXRyaWMgPSBmYWxzZSxcbiAgICBjb21wYXJhdG9yID0gdGhpcy5jb21wYXJlLFxuICApOiBudW1iZXIge1xuICAgIGNvbnN0IHNjb3JlID0gdGhpcy5nZXRJbnRlcnNlY3Rpb25TY29yZShhLCBiLCBjb21wYXJhdG9yKTtcbiAgICByZXR1cm4gc3ltbWV0cmljID8gYS5sZW5ndGggKyBiLmxlbmd0aCAtIDIgKiBzY29yZSA6IGEubGVuZ3RoIC0gc2NvcmU7XG4gIH1cblxuICAvKipcbiAgICogVXNlcyBiaW5hcnkgc2VhcmNoIHRvIGZpbmQgdGhlIGluZGV4IG9mIGFuIGVsZW1lbnQgaW5zaWRlIGEgc29ydGVkIGFycmF5LlxuICAgKlxuICAgKiBAcGFyYW0gYXJyIHRoZSBhcnJheSB0byBzZWFyY2hcbiAgICogQHBhcmFtIHRhcmdldCB0aGUgdGFyZ2V0IHZhbHVlIHRvIHNlYXJjaCBmb3JcbiAgICogQHBhcmFtIFtjb21wYXJhdG9yXSBhIGN1c3RvbSBjb21wYXJhdG9yXG4gICAqIEBwYXJhbSBbcmFuaz1mYWxzZV0gd2hldGhlciB0byByZXR1cm4gdGhlIGVsZW1lbnQncyByYW5rIGlmIHRoZSBlbGVtZW50IGlzbid0IGZvdW5kXG4gICAqIEBwYXJhbSBbc3RhcnRdIHRoZSBzdGFydCBwb3NpdGlvbiBvZiB0aGUgc2VhcmNoXG4gICAqIEBwYXJhbSBbZW5kXSB0aGUgZW5kIHBvc2l0aW9uIG9mIHRoZSBzZWFyY2hcbiAgICogQHJldHVybiB0aGUgaW5kZXggb2YgdGhlIHNlYXJjaGVkIGVsZW1lbnQgb3IgaXQncyByYW5rXG4gICAqIEBleGFtcGxlXG4gICAqXG4gICAqIFNvcnRlZEFycmF5LmdldEluZGV4KFsxLCAyLCAzLCA0LCA4XSwgNCk7XG4gICAqIC8vPT4gM1xuICAgKi9cbiAgc3RhdGljIGdldEluZGV4PFQsIFUgZXh0ZW5kcyBJbmRleGVkQ29sbGVjdGlvbjxUPj4oXG4gICAgYXJyOiBVLFxuICAgIHRhcmdldDogVCxcbiAgICBjb21wYXJhdG9yOiBDb21wYXJhdG9yPFQ+ID0gdGhpcy5jb21wYXJlLFxuICAgIHJhbmsgPSBmYWxzZSxcbiAgICBzdGFydCA9IDAsXG4gICAgZW5kID0gYXJyLmxlbmd0aCAtIDEsXG4gICk6IG51bWJlciB7XG4gICAgbGV0IGxlZnQgPSBzdGFydDtcbiAgICBsZXQgcmlnaHQgPSBlbmQ7XG4gICAgbGV0IG07XG4gICAgd2hpbGUgKGxlZnQgPD0gcmlnaHQpIHtcbiAgICAgIG0gPSAobGVmdCArIHJpZ2h0KSA+PiAxO1xuICAgICAgY29uc3QgY29tcGFyZWQgPSBjb21wYXJhdG9yKGFyclttXSwgdGFyZ2V0KTtcbiAgICAgIGlmIChjb21wYXJlZCA8IDApIHtcbiAgICAgICAgbGVmdCA9IG0gKyAxO1xuICAgICAgfSBlbHNlIGlmIChjb21wYXJlZCA+IDApIHtcbiAgICAgICAgcmlnaHQgPSBtIC0gMTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiBtO1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gcmFuayA/IGxlZnQgOiAtMTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBpbnRlcnNlY3Rpb24gb2YgdHdvIHNvcnRlZCBhcnJheXMuXG4gICAqXG4gICAqIEBwYXJhbSBhIHRoZSBmaXJzdCBhcnJheVxuICAgKiBAcGFyYW0gYiB0aGUgc2Vjb25kIGFycmF5XG4gICAqIEBwYXJhbSBbY29tcGFyYXRvcl0gdGhlIGNvbXBhcmF0b3Igc3RhdGljIHVzZWQgdG8gc29ydCB0aGUgYXJyYXlzXG4gICAqIEBwYXJhbSBbY29udGFpbmVyXSBhbiBhcnJheS1saWtlIG9iamVjdCB0byBob2xkIHRoZSByZXN1bHRzXG4gICAqIEByZXR1cm4gdGhlIGludGVyc2VjdGlvbiBvZiB0aGUgYXJyYXlzXG4gICAqIEBleGFtcGxlXG4gICAqXG4gICAqIFNvcnRlZEFycmF5LmdldEludGVyc2VjdGlvbihbMSwgMiwgMywgNCwgOF0sIFsyLCA0LCA2LCA3LCA5XSk7XG4gICAqIC8vPT4gWyAyLCA0IF1cbiAgICpcbiAgICogLy8gaW50ZXJzZWN0aW9uIHVzaW5nIGEgY3VzdG9tIGNvbXBhcmF0b3I6XG4gICAqIGNvbnN0IGN1c3RvbUNvbXBhcmF0b3IgPSAoYSwgYikgPT4gKGEgPiBiID8gLTEgOiBhIDwgYiA/IDEgOiAwKTtcbiAgICogU29ydGVkQXJyYXkuZ2V0SW50ZXJzZWN0aW9uKFs4LCA0LCAzLCAyLCAxXSwgWzksIDcsIDYsIDQsIDJdLCBjdXN0b21Db21wYXJhdG9yKTtcbiAgICogLy89PiBbIDQsIDIgXVxuICAgKi9cbiAgc3RhdGljIGdldEludGVyc2VjdGlvbjxULCBVIGV4dGVuZHMgSW5kZXhlZENvbGxlY3Rpb248VD4+KFxuICAgIGE6IFUsXG4gICAgYjogVSxcbiAgICBjb21wYXJhdG9yOiBDb21wYXJhdG9yPFQ+ID0gdGhpcy5jb21wYXJlLFxuICAgIGNvbnRhaW5lcjogVSA9IChbXSBhcyB1bmtub3duKSBhcyBVLFxuICApOiBVIHtcbiAgICBsZXQgaSA9IDA7XG4gICAgbGV0IGogPSAwO1xuICAgIHdoaWxlIChpIDwgYS5sZW5ndGggJiYgaiA8IGIubGVuZ3RoKSB7XG4gICAgICBjb25zdCBjb21wYXJlZCA9IGNvbXBhcmF0b3IoYVtpXSwgYltqXSk7XG4gICAgICBpZiAoY29tcGFyZWQgPiAwKSB7XG4gICAgICAgIGorKztcbiAgICAgIH0gZWxzZSBpZiAoY29tcGFyZWQgPCAwKSB7XG4gICAgICAgIGkrKztcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGNvbnRhaW5lcltjb250YWluZXIubGVuZ3RoXSA9IGFbaV07XG4gICAgICAgIGkrKztcbiAgICAgICAgaisrO1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gY29udGFpbmVyO1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIGFtb3VudCBvZiBjb21tb24gZWxlbWVudHMgaW4gdHdvIHNvcnRlZCBhcnJheXMuXG4gICAqXG4gICAqIEBwYXJhbSBhIHRoZSBmaXJzdCBhcnJheVxuICAgKiBAcGFyYW0gYiB0aGUgc2Vjb25kIGFycmF5XG4gICAqIEBwYXJhbSBbY29tcGFyYXRvcl0gdGhlIGNvbXBhcmF0b3Igc3RhdGljIHVzZWQgdG8gc29ydCB0aGUgYXJyYXlzXG4gICAqIEByZXR1cm4gdGhlIGFtb3VudCBvZiBkaWZmZXJlbnQgZWxlbWVudHNcbiAgICogQGV4YW1wbGVcbiAgICpcbiAgICogU29ydGVkQXJyYXkuZ2V0SW50ZXJzZWN0aW9uKFsxLCAyLCAzLCA0LCA4XSwgWzIsIDQsIDYsIDcsIDldKTtcbiAgICogLy89PiAyXG4gICAqL1xuICBzdGF0aWMgZ2V0SW50ZXJzZWN0aW9uU2NvcmU8VCwgVSBleHRlbmRzIEluZGV4ZWRDb2xsZWN0aW9uPFQ+PihcbiAgICBhOiBVLFxuICAgIGI6IFUsXG4gICAgY29tcGFyYXRvcjogQ29tcGFyYXRvcjxUPiA9IHRoaXMuY29tcGFyZSxcbiAgKTogbnVtYmVyIHtcbiAgICBsZXQgc2NvcmUgPSAwO1xuICAgIGxldCBpID0gMDtcbiAgICBsZXQgaiA9IDA7XG4gICAgd2hpbGUgKGkgPCBhLmxlbmd0aCAmJiBqIDwgYi5sZW5ndGgpIHtcbiAgICAgIGNvbnN0IGNvbXBhcmVkID0gY29tcGFyYXRvcihhW2ldLCBiW2pdKTtcbiAgICAgIGlmIChjb21wYXJlZCA+IDApIHtcbiAgICAgICAgaisrO1xuICAgICAgfSBlbHNlIGlmIChjb21wYXJlZCA8IDApIHtcbiAgICAgICAgaSsrO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgc2NvcmUrKztcbiAgICAgICAgaSsrO1xuICAgICAgICBqKys7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBzY29yZTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIGEgcmFuZ2Ugb2YgZWxlbWVudHMgb2YgYSBzb3J0ZWQgYXJyYXkgZnJvbSB0aGUgc3RhcnQgdGhyb3VnaCB0aGUgZW5kIGluY2x1c2l2ZWx5LlxuICAgKlxuICAgKiBAcGFyYW0gYXJyIHRoZSBhcnJheVxuICAgKiBAcGFyYW0gW3N0YXJ0XSB0aGUgc3RhcnRpbmcgaXRlbVxuICAgKiBAcGFyYW0gW2VuZF0gdGhlIGVuZGluZyBpdGVtXG4gICAqIEBwYXJhbSBbY29tcGFyYXRvcl0gYSBjdXN0b20gY29tcGFyYXRvclxuICAgKiBAcGFyYW0gW3N1YmFycmF5XSByZXR1cm4gYSBzdWJhcnJheSBpbnN0ZWFkIG9mIGNvcHlpbmcgcmVzdWx0aW5nIHZhbHVlIHdpdGggc2xpY2VcbiAgICogQHJldHVybiB0aGUgcmFuZ2Ugb2YgaXRlbXNcbiAgICogQGV4YW1wbGVcbiAgICpcbiAgICogU29ydGVkQXJyYXkuZ2V0UmFuZ2UoWzEsIDIsIDMsIDQsIDhdLCAyLCA0KTtcbiAgICogLy89PiBbIDIsIDMsIDQgXVxuICAgKlxuICAgKiBjb25zdCBjdXN0b21Db21wYXJhdG9yID0gKGEsIGIpID0+IChhID4gYiA/IC0xIDogYSA8IGIgPyAxIDogMCk7XG4gICAqIFNvcnRlZEFycmF5LmdldFJhbmdlKFs4LCA0LCAzLCAyLCAxXSwgOCwgMywgY3VzdG9tQ29tcGFyYXRvcik7XG4gICAqIC8vPT4gWyA4LCA0LCAzIF1cbiAgICovXG4gIHN0YXRpYyBnZXRSYW5nZTxULCBVIGV4dGVuZHMgSW5kZXhlZENvbGxlY3Rpb248VD4+KFxuICAgIGFycjogVSxcbiAgICBzdGFydD86IFQsXG4gICAgZW5kPzogVCxcbiAgICBjb21wYXJhdG9yPzogQ29tcGFyYXRvcjxUPixcbiAgICBzdWJhcnJheT86IGJvb2xlYW4sXG4gICk6IFUge1xuICAgIGNvbnN0IHN0YXJ0SW5kZXggPSBzdGFydCA9PT0gdW5kZWZpbmVkXG4gICAgICA/IDBcbiAgICAgIDogdGhpcy5nZXRJbmRleDxULCBVPihhcnIsIHN0YXJ0LCBjb21wYXJhdG9yLCB0cnVlKTtcbiAgICBjb25zdCBlbmRJbmRleCA9IGVuZCA9PT0gdW5kZWZpbmVkXG4gICAgICA/IGFyci5sZW5ndGhcbiAgICAgIDogdGhpcy5nZXRJbmRleChhcnIsIGVuZCwgY29tcGFyYXRvciwgdHJ1ZSwgc3RhcnRJbmRleCkgKyAxO1xuICAgIHJldHVybiBzdWJhcnJheVxuICAgICAgPyAoYXJyIGFzIHVua25vd24gYXMgSW50MzJBcnJheSkuc3ViYXJyYXkoc3RhcnRJbmRleCwgZW5kSW5kZXgpXG4gICAgICA6IC8vIGRlbm8tbGludC1pZ25vcmUgbm8tZXhwbGljaXQtYW55XG4gICAgICAgIChhcnIgYXMgYW55KS5zbGljZShzdGFydEluZGV4LCBlbmRJbmRleCk7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyB0aGUgdW5pb24gb2YgdHdvIHNvcnRlZCBhcnJheXMgYXMgYSBzb3J0ZWQgYXJyYXkuXG4gICAqXG4gICAqIEBwYXJhbSBhIHRoZSBmaXJzdCBhcnJheVxuICAgKiBAcGFyYW0gYiB0aGUgc2Vjb25kIGFycmF5XG4gICAqIEBwYXJhbSBbdW5pcXVlPWZhbHNlXSB3aGV0aGVyIHRvIGF2b2lkIGR1cGxpY2F0aW5nIGl0ZW1zIHdoZW4gbWVyZ2luZyB1bmlxdWUgYXJyYXlzXG4gICAqIEBwYXJhbSBbY29tcGFyYXRvcl0gdGhlIGNvbXBhcmF0b3Igc3RhdGljIHVzZWQgdG8gc29ydCB0aGUgYXJyYXlzXG4gICAqIEBwYXJhbSBbY29udGFpbmVyXSBhbiBhcnJheS1saWtlIG9iamVjdCB0byBob2xkIHRoZSByZXN1bHRzXG4gICAqIEByZXR1cm4gdGhlIHVuaW9uIG9mIHRoZSBhcnJheXNcbiAgICogQGV4YW1wbGVcbiAgICpcbiAgICogU29ydGVkQXJyYXkuZ2V0VW5pb24oWzEsIDIsIDMsIDQsIDhdLCBbMiwgNCwgNiwgNywgOV0pO1xuICAgKiAvLz0+IFsgMSwgMiwgMiwgMywgNCwgNCwgNiwgNywgOCwgOSBdXG4gICAqXG4gICAqIC8vIHVuaW9uIG9mIHNvcnRlZCBhcnJheXMgd2l0aG91dCBkdXBsaWNhdGVzOlxuICAgKiBTb3J0ZWRBcnJheS5nZXRVbmlvbihbMSwgMiwgMywgNCwgOF0sIFsyLCA0LCA2LCA3LCA5XSwgdHJ1ZSk7XG4gICAqIC8vPT4gWyAxLCAyLCAzLCA0LCA2LCA3LCA4LCA5IF1cbiAgICpcbiAgICogLy91bmlvbiB1c2luZyBhIGN1c3RvbSBjb21wYXJhdG9yOlxuICAgKiBTb3J0ZWRBcnJheS5nZXRVbmlvbihbOCwgNCwgMywgMiwgMV0sIFs5LCA3LCA2LCA0LCAyXSwgdHJ1ZSwgY3VzdG9tQ29tcGFyYXRvcik7XG4gICAqIC8vPT4gWyA5LCA4LCA3LCA2LCA0LCAzLCAyLCAxIF1cbiAgICovXG4gIHN0YXRpYyBnZXRVbmlvbjxULCBVIGV4dGVuZHMgSW5kZXhlZENvbGxlY3Rpb248VD4+KFxuICAgIGE6IEluZGV4ZWRDb2xsZWN0aW9uPFQ+LFxuICAgIGI6IEluZGV4ZWRDb2xsZWN0aW9uPFQ+LFxuICAgIHVuaXF1ZSA9IGZhbHNlLFxuICAgIGNvbXBhcmF0b3I6IENvbXBhcmF0b3I8VD4gPSB0aGlzLmNvbXBhcmUsXG4gICAgY29udGFpbmVyOiBVID0gKFtdIGFzIHVua25vd24pIGFzIFUsXG4gICk6IFUge1xuICAgIGxldCBpID0gMDtcbiAgICBsZXQgaiA9IDA7XG4gICAgd2hpbGUgKGkgPCBhLmxlbmd0aCAmJiBqIDwgYi5sZW5ndGgpIHtcbiAgICAgIGNvbnN0IGNvbXBhcmVkID0gY29tcGFyYXRvcihhW2ldLCBiW2pdKTtcbiAgICAgIGlmIChjb21wYXJlZCA+IDApIHtcbiAgICAgICAgY29udGFpbmVyW2NvbnRhaW5lci5sZW5ndGhdID0gYltqXTtcbiAgICAgICAgaisrO1xuICAgICAgfSBlbHNlIGlmIChjb21wYXJlZCA8IDApIHtcbiAgICAgICAgY29udGFpbmVyW2NvbnRhaW5lci5sZW5ndGhdID0gYVtpXTtcbiAgICAgICAgaSsrO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgY29udGFpbmVyW2NvbnRhaW5lci5sZW5ndGhdID0gYVtpXTtcbiAgICAgICAgaWYgKCF1bmlxdWUpIGNvbnRhaW5lcltjb250YWluZXIubGVuZ3RoXSA9IGJbal07XG4gICAgICAgIGkrKztcbiAgICAgICAgaisrO1xuICAgICAgfVxuICAgIH1cbiAgICB3aGlsZSAoaSA8IGEubGVuZ3RoKSB7XG4gICAgICBjb250YWluZXJbY29udGFpbmVyLmxlbmd0aF0gPSBhW2ldO1xuICAgICAgaSsrO1xuICAgIH1cbiAgICB3aGlsZSAoaiA8IGIubGVuZ3RoKSB7XG4gICAgICBjb250YWluZXJbY29udGFpbmVyLmxlbmd0aF0gPSBiW2pdO1xuICAgICAgaisrO1xuICAgIH1cbiAgICByZXR1cm4gY29udGFpbmVyO1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgYW4gYXJyYXkgb2YgdW5pcXVlIGVsZW1lbnRzIGZyb20gYSBzb3J0ZWQgYXJyYXkuXG4gICAqXG4gICAqIEBwYXJhbSBhcnIgdGhlIHNvcnRlZCBhcnJheVxuICAgKiBAcGFyYW0gW2NvbXBhcmF0b3JdIGEgY3VzdG9tIGNvbXBhcmF0b3JcbiAgICogQHBhcmFtIFtjb250YWluZXJdIGFuIGFycmF5LWxpa2Ugb2JqZWN0IHRvIGhvbGQgdGhlIHJlc3VsdHNcbiAgICogQHJldHVybiB0aGUgc29ydGVkIGFycmF5IHdpdGhvdXQgZHVwbGljYXRlc1xuICAgKiBAZXhhbXBsZVxuICAgKlxuICAgKiBTb3J0ZWRBcnJheS5nZXRVbmlxdWUoWzEsIDEsIDIsIDIsIDMsIDRdKTtcbiAgICogLy89PiBbIDEsIDIsIDMsIDQgXVxuICAgKi9cbiAgc3RhdGljIGdldFVuaXF1ZTxULCBVIGV4dGVuZHMgSW5kZXhlZENvbGxlY3Rpb248VD4+KFxuICAgIGFycjogSW5kZXhlZENvbGxlY3Rpb248VD4sXG4gICAgY29tcGFyYXRvcjogQ29tcGFyYXRvcjxUPiA9IHRoaXMuY29tcGFyZSxcbiAgICBjb250YWluZXI6IFUgPSAoW10gYXMgdW5rbm93bikgYXMgVSxcbiAgKTogdHlwZW9mIGNvbnRhaW5lciB7XG4gICAgY29udGFpbmVyWzBdID0gYXJyWzBdO1xuICAgIGZvciAobGV0IGkgPSAxOyBpIDwgYXJyLmxlbmd0aDsgaSsrKSB7XG4gICAgICBpZiAoY29tcGFyYXRvcihhcnJbaSAtIDFdLCBhcnJbaV0pICE9PSAwKSB7XG4gICAgICAgIGNvbnRhaW5lcltjb250YWluZXIubGVuZ3RoXSA9IGFycltpXTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIGNvbnRhaW5lcjtcbiAgfVxuXG4gIC8qKlxuICAgKiBDaGVja3Mgd2hldGhlciBhbiBhcnJheSBpcyBzb3J0ZWQgYWNjb3JkaW5nIHRvIGEgcHJvdmlkZWQgY29tcGFyYXRvci5cbiAgICpcbiAgICogQHBhcmFtIGFyciB0aGUgYXJyYXkgdG8gY2hlY2tcbiAgICogQHBhcmFtIFtjb21wYXJhdG9yXSBhIGN1c3RvbSBjb21wYXJhdG9yXG4gICAqIEByZXR1cm4gd2hldGhlciB0aGUgYXJyYXkgaXMgc29ydGVkXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqXG4gICAqIFNvcnRlZEFycmF5LmlzU29ydGVkKFsxLCAyLCAzLCA0LCA4XSk7XG4gICAqIC8vPT4gdHJ1ZVxuICAgKi9cbiAgc3RhdGljIGlzU29ydGVkPFQsIFUgZXh0ZW5kcyBJbmRleGVkQ29sbGVjdGlvbjxUPj4oXG4gICAgYXJyOiBVLFxuICAgIGNvbXBhcmF0b3I6IENvbXBhcmF0b3I8VD4gPSB0aGlzLmNvbXBhcmUsXG4gICk6IGJvb2xlYW4ge1xuICAgIGZvciAobGV0IGkgPSAxOyBpIDwgYXJyLmxlbmd0aDsgaSsrKSB7XG4gICAgICBpZiAoY29tcGFyYXRvcihhcnJbaSAtIDFdLCBhcnJbaV0pID4gMCkgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDaGVja3Mgd2hldGhlciBhbiBhcnJheSBoYXMgYW55IGR1cGxpY2F0aW5nIGVsZW1lbnRzLlxuICAgKlxuICAgKiBAcGFyYW0gYXJyIHRoZSBhcnJheSB0byBjaGVja1xuICAgKiBAcGFyYW0gW2NvbXBhcmF0b3JdIGEgY3VzdG9tIGNvbXBhcmF0b3JcbiAgICogQHJldHVybiB3aGV0aGVyIHRoZSBhcnJheSBoYXMgZHVwbGljYXRpbmcgZWxlbWVudHNcbiAgICogQGV4YW1wbGVcbiAgICpcbiAgICogU29ydGVkQXJyYXkuaXNVbmlxdWUoWzEsIDIsIDIsIDMsIDRdKTtcbiAgICogLy89PiBmYWxzZVxuICAgKi9cbiAgc3RhdGljIGlzVW5pcXVlPFQsIFUgZXh0ZW5kcyBJbmRleGVkQ29sbGVjdGlvbjxUPj4oXG4gICAgYXJyOiBVLFxuICAgIGNvbXBhcmF0b3I6IENvbXBhcmF0b3I8VD4gPSB0aGlzLmNvbXBhcmUsXG4gICkge1xuICAgIGZvciAobGV0IGkgPSAxOyBpIDwgYXJyLmxlbmd0aDsgaSsrKSB7XG4gICAgICBpZiAoY29tcGFyYXRvcihhcnJbaSAtIDFdLCBhcnJbaV0pID09PSAwKSByZXR1cm4gZmFsc2U7XG4gICAgfVxuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgLyoqXG4gICAqIENyZWF0ZXMgYSBuZXcgU29ydGVkQXJyYXkgaW5zdGFuY2Ugd2l0aCBhIHZhcmlhYmxlIG51bWJlciBvZiBhcmd1bWVudHMsXG4gICAqIHJlZ2FyZGxlc3Mgb2YgbnVtYmVyIG9yIHR5cGUgb2YgdGhlIGFyZ3VtZW50c1xuICAgKlxuICAgKiBAcGFyYW0gZWxlbWVudHMgdGhlIGVsZW1lbnRzIG9mIHdoaWNoIHRvIGNyZWF0ZSB0aGUgYXJyYXlcbiAgICogQHJldHVybiB0aGUgbmV3IFNvcnRlZEFycmF5XG4gICAqL1xuICBzdGF0aWMgb2Y8VT4oLi4uZWxlbWVudHM6IEFycmF5PFU+KTogU29ydGVkQXJyYXk8VT4ge1xuICAgIGNvbnN0IHJlc3VsdCA9IChzdXBlci5vZiguLi5lbGVtZW50cykgYXMgdW5rbm93bikgYXMgU29ydGVkQXJyYXk8VT47XG4gICAgcmVzdWx0LnNvcnQoKTtcbiAgICByZXR1cm4gcmVzdWx0O1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgYSBtZXJnZXIgb2YgdGhlIGFycmF5IHdpdGggb25lIG9yIG1vcmUgcHJvdmlkZWQgc29ydGVkIGFycmF5cy5cbiAgICpcbiAgICogQHBhcmFtIGFycmF5cyBzb3J0ZWQgYXJyYXkocykgdG8gbWVyZ2VcbiAgICogQHJldHVybiBhIG5ldyBTb3J0ZWRBcnJheVxuICAgKi9cbiAgY29uY2F0KC4uLmFycmF5czogQXJyYXk8QXJyYXk8SXRlbVR5cGU+Pik6IFNvcnRlZEFycmF5PEl0ZW1UeXBlPiB7XG4gICAgY29uc3QgY29uc3RydWN0b3IgPSB0aGlzLmNvbnN0cnVjdG9yIGFzIHR5cGVvZiBTb3J0ZWRBcnJheTtcbiAgICBsZXQgcmVzdWx0ID0gdGhpcy5zbGljZSgwKSBhcyBTb3J0ZWRBcnJheTxJdGVtVHlwZT47XG4gICAgLy8gVE9ETyByZXdyaXRlXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBhcnJheXMubGVuZ3RoOyBpKyspIHtcbiAgICAgIHJlc3VsdCA9IGNvbnN0cnVjdG9yLmdldFVuaW9uKFxuICAgICAgICByZXN1bHQsXG4gICAgICAgIGFycmF5c1tpXSxcbiAgICAgICAgdGhpcy51bmlxdWUsXG4gICAgICAgIGNvbnN0cnVjdG9yLmNvbXBhcmUsXG4gICAgICAgIG5ldyBjb25zdHJ1Y3RvcjxJdGVtVHlwZT4oKSBhcyB0aGlzLFxuICAgICAgKTtcbiAgICB9XG4gICAgcmV0dXJuIHJlc3VsdDtcbiAgfVxuXG4gIC8qKlxuICAgKiBVc2VzIGJpbmFyeSBzZWFyY2ggdG8gcXVpY2tseSBjaGVjayBpZiB0aGUgZWxlbWVudCBpcyB0aGUgYXJyYXkuXG4gICAqIEBwYXJhbSBlbGVtZW50IHRoZSBlbGVtZW50IHRvIGNoZWNrXG4gICAqIEByZXR1cm4gd2hldGhlciB0aGUgZWxlbWVudCBpcyBpbiB0aGUgYXJyYXlcbiAgICovXG4gIGluY2x1ZGVzKGVsZW1lbnQ6IEl0ZW1UeXBlKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuICEhfnRoaXMuaW5kZXhPZihlbGVtZW50KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBMb29rcyBmb3IgdGhlIGluZGV4IG9mIGEgZ2l2ZW4gZWxlbWVudCBpbiB0aGUgYXJyYXkgb3IgLTFcbiAgICpcbiAgICogQHBhcmFtIGVsZW1lbnQgdGhlIGVsZW1lbnQgdG8gbG9vayBmb3JcbiAgICogQHJldHVybiB0aGUgZWxlbWVudCdzIGluZGV4IGluIHRoZSBhcnJheSBvciAtMVxuICAgKi9cbiAgaW5kZXhPZihlbGVtZW50OiBJdGVtVHlwZSk6IG51bWJlciB7XG4gICAgcmV0dXJuICh0aGlzLmNvbnN0cnVjdG9yIGFzIHR5cGVvZiBTb3J0ZWRBcnJheSkuZ2V0SW5kZXgodGhpcywgZWxlbWVudCk7XG4gIH1cblxuICAvKipcbiAgICogQ2hlY2tzIGlmIHRoZSBhcnJheSBpcyBzb3J0ZWQuXG4gICAqXG4gICAqIEByZXR1cm4gd2hldGhlciB0aGUgYXJyYXkgaXMgc29ydGVkXG4gICAqIEBleGFtcGxlXG4gICAqXG4gICAqIC8vPT4gU29ydGVkQXJyYXkgWyAyLCAzLCA0LCA1LCA5IF07XG4gICAqIFNvcnRlZEFycmF5LmlzU29ydGVkKCk7XG4gICAqIC8vPT4gdHJ1ZVxuICAgKiBTb3J0ZWRBcnJheS5yZXZlcnNlKCk7XG4gICAqIFNvcnRlZEFycmF5LmlzU29ydGVkKCk7XG4gICAqIC8vPT4gZmFsc2U7XG4gICAqL1xuICBpc1NvcnRlZCgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gKHRoaXMuY29uc3RydWN0b3IgYXMgdHlwZW9mIFNvcnRlZEFycmF5KS5pc1NvcnRlZCh0aGlzKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDaGVja3MgaWYgdGhlIGFycmF5IGhhcyBkdXBsaWNhdGluZyBlbGVtZW50cy5cbiAgICpcbiAgICogQHJldHVybiB3aGV0aGVyIHRoZSBhcnJheSBoYXMgZHVwbGljYXRpbmcgZWxlbWVudHNcbiAgICogQGV4YW1wbGVcbiAgICpcbiAgICogLy89PiBTb3J0ZWRBcnJheSBbIDIsIDMsIDMsIDQsIDUsIDkgXTtcbiAgICogU29ydGVkQXJyYXkuaXNVbmlxdWUoKTtcbiAgICogLy89PiBmYWxzZTtcbiAgICovXG4gIGlzVW5pcXVlKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiAodGhpcy5jb25zdHJ1Y3RvciBhcyB0eXBlb2YgU29ydGVkQXJyYXkpLmlzVW5pcXVlKHRoaXMpO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZHMgcHJvdmlkZWQgZWxlbWVudHMgdG8gdGhlIGFycmF5IHByZXNlcnZpbmcgdGhlIHNvcnRlZCBvcmRlciBvZiB0aGUgYXJyYXkuXG4gICAqXG4gICAqIEBwYXJhbSBlbGVtZW50cyB0aGUgZWxlbWVudHMgdG8gYWRkIHRvIHRoZSBhcnJheVxuICAgKiBAcmV0dXJuIHRoZSBuZXcgbGVuZ3RoIG9mIHRoZSBhcnJheVxuICAgKi9cbiAgcHVzaCguLi5lbGVtZW50czogQXJyYXk8SXRlbVR5cGU+KTogbnVtYmVyIHtcbiAgICBjb25zdCB7IGNvbXBhcmUgfSA9IHRoaXMuY29uc3RydWN0b3IgYXMgdHlwZW9mIFNvcnRlZEFycmF5O1xuICAgIGNvbnN0IG0gPSB0aGlzLmxlbmd0aDtcbiAgICBpZiAoIW0pIHJldHVybiBzdXBlci5wdXNoKC4uLmVsZW1lbnRzLnNvcnQoY29tcGFyZSkpO1xuICAgIGNvbnN0IHRvQWRkID0gdGhpcy51bmlxdWVcbiAgICAgID8gZWxlbWVudHMuZmlsdGVyKChlbCkgPT4gIX50aGlzLmluZGV4T2YoZWwpKVxuICAgICAgOiBlbGVtZW50cztcbiAgICBjb25zdCBuID0gdG9BZGQubGVuZ3RoO1xuICAgIGlmICghbikgcmV0dXJuIG07XG4gICAgdG9BZGQuc29ydChjb21wYXJlKTtcbiAgICBmb3IgKGxldCBpID0gbiAtIDE7IGkgPj0gMDsgaS0tKSB7XG4gICAgICBsZXQgajtcbiAgICAgIGNvbnN0IGxhc3QgPSB0aGlzW20gLSAxXTtcbiAgICAgIGZvciAoaiA9IG0gLSAyOyBqID49IDAgJiYgY29tcGFyZSh0aGlzW2pdLCB0b0FkZFtpXSkgPT09IDE7IGotLSkge1xuICAgICAgICB0aGlzW2ogKyAxXSA9IHRoaXNbal07XG4gICAgICB9XG4gICAgICBpZiAoaiAhPT0gbSAtIDIgfHwgY29tcGFyZShsYXN0LCB0b0FkZFtpXSkgPT09IDEpIHtcbiAgICAgICAgdGhpc1tqICsgMV0gPSB0b0FkZFtpXTtcbiAgICAgICAgdG9BZGRbaV0gPSBsYXN0O1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gc3VwZXIucHVzaCguLi50b0FkZCk7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyBhIHJhbmdlIG9mIGVsZW1lbnRzIG9mIHRoZSBhcnJheSB0aGF0IGFyZSBncmVhdGVyIG9yIGVxdWFsIHRvIHRoZSBwcm92aWRlZFxuICAgKiBzdGFydGluZyBlbGVtZW50IGFuZCBsZXNzIG9yIGVxdWFsIHRvIHRoZSBwcm92aWRlZCBlbmRpbmcgZWxlbWVudC5cbiAgICpcbiAgICogQHBhcmFtIHN0YXJ0IHRoZSBzdGFydGluZyBlbGVtZW50XG4gICAqIEBwYXJhbSBlbmQgdGhlIGVuZGluZyBlbGVtZW50XG4gICAqIEByZXR1cm4gdGhlIHJlc3VsdGluZyByYW5nZSBvZiBlbGVtZW50c1xuICAgKiBAZXhhbXBsZVxuICAgKlxuICAgKiAvLz0+IFNvcnRlZEFycmF5IFsgMiwgMywgNCwgNSwgOSBdO1xuICAgKiBTb3J0ZWRBcnJheS5yYW5nZSgzLCA1KTtcbiAgICogLy8gPT4gWyAzLCA0LCA1IF1cbiAgICogU29ydGVkQXJyYXkucmFuZ2UodW5kZWZpbmVkLCA0KTtcbiAgICogLy8gPT4gWyAyLCAzLCA0IF1cbiAgICogU29ydGVkQXJyYXkucmFuZ2UoNCk7XG4gICAqIC8vID0+IFsgNCwgNSwgOCBdXG4gICAqL1xuICByYW5nZShzdGFydD86IEl0ZW1UeXBlLCBlbmQ/OiBJdGVtVHlwZSk6IFNvcnRlZEFycmF5PEl0ZW1UeXBlPiB7XG4gICAgY29uc3QgY29uc3RydWN0b3IgPSB0aGlzLmNvbnN0cnVjdG9yIGFzIHR5cGVvZiBTb3J0ZWRBcnJheTtcbiAgICByZXR1cm4gY29uc3RydWN0b3IuZ2V0UmFuZ2UodGhpcywgc3RhcnQsIGVuZCwgY29uc3RydWN0b3IuY29tcGFyZSwgZmFsc2UpO1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIHJhbmsgb2YgYW4gZWxlbWVudCBpbiB0aGUgYXJyYXkuXG4gICAqXG4gICAqIEBwYXJhbSBlbGVtZW50IHRoZSBlbGVtZW50IHRvIGxvb2sgZm9yXG4gICAqIEByZXR1cm4gdGhlIHJhbmsgaW4gdGhlIGFycmF5XG4gICAqIEBleGFtcGxlXG4gICAqXG4gICAqIC8vPT4gU29ydGVkQXJyYXkgWyAyLCAzLCA0LCA1LCA5IF07XG4gICAqIFNvcnRlZEFycmF5LnJhbmsoMSk7XG4gICAqIC8vID0+IDBcbiAgICogU29ydGVkQXJyYXkucmFuayg2KTtcbiAgICogLy8gPT4gNFxuICAgKi9cbiAgcmFuayhlbGVtZW50OiBJdGVtVHlwZSk6IG51bWJlciB7XG4gICAgY29uc3QgY29uc3RydWN0b3IgPSB0aGlzLmNvbnN0cnVjdG9yIGFzIHR5cGVvZiBTb3J0ZWRBcnJheTtcbiAgICByZXR1cm4gY29uc3RydWN0b3IuZ2V0SW5kZXgodGhpcywgZWxlbWVudCwgY29uc3RydWN0b3IuY29tcGFyZSwgdHJ1ZSk7XG4gIH1cblxuICAvKipcbiAgICogSW1wbGVtZW50cyBpbi1wbGFjZSByZXBsYWNlbWVudCBvZiB0aGUgYXJyYXkgZWxlbWVudHMuXG4gICAqXG4gICAqIEBwYXJhbSBhcnIgYW4gYXJyYXkgb2YgbmV3IGVsZW1lbnRzIHRvIHVzZVxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKlxuICAgKiAvLz0+IFNvcnRlZEFycmF5IFsgMiwgMywgNCwgNSwgOSBdO1xuICAgKiBzb3J0ZWRBcnJheS5zZXQoWzEsIDIsIDNdKTtcbiAgICogLy89PiBTb3J0ZWRBcnJheSBbIDEsIDIsIDMgXVxuICAgKi9cbiAgc2V0KGFycjogQXJyYXk8SXRlbVR5cGU+KTogdGhpcyB7XG4gICAgdGhpcy5sZW5ndGggPSBhcnIubGVuZ3RoO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgYXJyLmxlbmd0aDsgaSsrKSB7XG4gICAgICB0aGlzW2ldID0gYXJyW2ldO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBTb3J0cyB0aGUgYXJyYXkgd2l0aCBhIHByb3ZpZGVkIGNvbXBhcmUgZnVuY3Rpb24uXG4gICAqXG4gICAqIEBwYXJhbSBjb21wYXJlRnVuY3Rpb24gdGhlIGZ1bmN0aW9uIHRvIHVzZSBmb3IgY29tcGFyaXNvblxuICAgKi9cbiAgc29ydChcbiAgICBjb21wYXJlRnVuY3Rpb246IENvbXBhcmF0b3I8SXRlbVR5cGU+ID0gKHRoaXNcbiAgICAgIC5jb25zdHJ1Y3RvciBhcyB0eXBlb2YgU29ydGVkQXJyYXkpLmNvbXBhcmUsXG4gICk6IHRoaXMge1xuICAgIHJldHVybiBzdXBlci5zb3J0KGNvbXBhcmVGdW5jdGlvbik7XG4gIH1cblxuICAvKipcbiAgICogQ2hhbmdlcyB0aGUgYXJyYXkgYnkgcmVtb3ZpbmcgZXhpc3RpbmcgZWxlbWVudHMgYW5kIGFkZGluZyBuZXcgb25lcy5cbiAgICpcbiAgICogQHBhcmFtIHN0YXJ0IHRoZSBpbmRleCBhdCB3aGljaCB0byBzdGFydCBjaGFuZ2luZyB0aGUgYXJyYXlcbiAgICogQHBhcmFtIGRlbGV0ZUNvdW50IHRoZSBhbW91bnQgb2Ygb2xkIGVsZW1lbnRzIHRvIGRlbGV0ZVxuICAgKiBAcGFyYW0gZWxlbWVudHMgdGhlIGVsZW1lbnRzIHRvIGFkZCB0byB0aGUgYXJyYXlcbiAgICogQHJldHVybiBhbiBhcnJheSBvZiBkZWxldGVkIGVsZW1lbnRzXG4gICAqL1xuICBzcGxpY2UoXG4gICAgc3RhcnQ6IG51bWJlcixcbiAgICBkZWxldGVDb3VudDogbnVtYmVyLFxuICAgIC4uLmVsZW1lbnRzOiBBcnJheTxJdGVtVHlwZT5cbiAgKTogU29ydGVkQXJyYXk8SXRlbVR5cGU+IHtcbiAgICBjb25zdCBkZWxldGVkRWxlbWVudHMgPSBzdXBlci5zcGxpY2UoXG4gICAgICBzdGFydCxcbiAgICAgIGRlbGV0ZUNvdW50LFxuICAgICkgYXMgU29ydGVkQXJyYXk8SXRlbVR5cGU+O1xuICAgIHRoaXMucHVzaCguLi5lbGVtZW50cyk7XG4gICAgcmV0dXJuIGRlbGV0ZWRFbGVtZW50cztcbiAgfVxuXG4gIC8qKlxuICAgKiBSZW1vdmVzIGR1cGxpY2F0aW5nIGVsZW1lbnRzIGZyb20gdGhlIGFycmF5LlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKlxuICAgKiAvLz0+IFNvcnRlZEFycmF5IFsgMiwgMiwgMywgNCwgNSwgNSwgOSBdO1xuICAgKiBzb3J0ZWRBcnJheS51bmlxdWlmeSgpO1xuICAgKiAvLyA9PiBTb3J0ZWRBcnJheSBbIDIsIDMsIDQsIDUsIDkgXVxuICAgKi9cbiAgdW5pcXVpZnkoKSB7XG4gICAgY29uc3QgY29uc3RydWN0b3IgPSB0aGlzLmNvbnN0cnVjdG9yIGFzIHR5cGVvZiBTb3J0ZWRBcnJheTtcbiAgICByZXR1cm4gdGhpcy5zZXQoXG4gICAgICBjb25zdHJ1Y3Rvci5nZXRVbmlxdWUodGhpcywgY29uc3RydWN0b3IuY29tcGFyZSwgbmV3IGNvbnN0cnVjdG9yKCkpLFxuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogQWRkcyBwcm92aWRlZCBlbGVtZW50cyB0byB0aGUgYXJyYXkgcHJlc2VydmluZyB0aGUgc29ydGVkIG9yZGVyIG9mIHRoZSBhcnJheS5cbiAgICpcbiAgICogQHBhcmFtIGVsZW1lbnRzIHRoZSBlbGVtZW50cyB0byBhZGQgdG8gdGhlIGFycmF5XG4gICAqIEByZXR1cm4gdGhlIG5ldyBsZW5ndGggb2YgdGhlIGFycmF5XG4gICAqL1xuICB1bnNoaWZ0KC4uLmVsZW1lbnRzOiBBcnJheTxJdGVtVHlwZT4pIHtcbiAgICByZXR1cm4gdGhpcy5wdXNoKC4uLmVsZW1lbnRzKTtcbiAgfVxufVxuIl19 | ||
//# sourceMappingURL=sorted-array.js.map |
@@ -1,46 +0,16 @@ | ||
/** | ||
* Creates a SymmetricGrid class extending a given Array-like class. | ||
*/ | ||
export function SymmetricGridMixin(Base) { | ||
/** | ||
* Implements a grid to handle symmetric or triangular matrices using half the space required for a normal grid. | ||
*/ | ||
return class SymmetricGrid extends Base { | ||
constructor() { | ||
super(...arguments); | ||
Object.defineProperty(this, "size", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: 0 | ||
}); | ||
} | ||
size = 0; | ||
static get [Symbol.species]() { | ||
return Base; | ||
} | ||
/** | ||
* Number of columns in the grid. | ||
*/ | ||
get columns() { | ||
return this.size; | ||
} | ||
/** | ||
* Specifies the number of columns of the grid. | ||
*/ | ||
set columns(columns) { | ||
this.size = columns; | ||
} | ||
/** | ||
* Number of rows in the grid. | ||
*/ | ||
get rows() { | ||
return this.size; | ||
} | ||
/** | ||
* Creates a grid of specified dimensions. | ||
* | ||
* @param rows the amount of rows | ||
* @param columns the amount of columns | ||
* @return a new grid | ||
*/ | ||
static create(columns) { | ||
@@ -52,8 +22,2 @@ const length = this.getLength(columns); | ||
} | ||
/** | ||
* Creates a grid from an array of arrays. | ||
* | ||
* @param arrays the array of arrays | ||
* @return a new grid | ||
*/ | ||
static fromArrays(arrays) { | ||
@@ -71,9 +35,2 @@ const rows = arrays.length; | ||
} | ||
/** | ||
* Returns the length of the underlying Array required to hold the grid of specified dimensions. | ||
* | ||
* @param rows the amount of rows | ||
* @param columns the amount of columns | ||
* @return the required length | ||
*/ | ||
static getLength(rows) { | ||
@@ -87,9 +44,2 @@ return ((rows + 1) * rows) >> 1; | ||
} | ||
/** | ||
* Returns the index of an element at given coordinates. | ||
* | ||
* @param rows the row index | ||
* @param columns the column index | ||
* @return the element index | ||
*/ | ||
getIndex(row, column) { | ||
@@ -99,20 +49,5 @@ const [x, y] = row >= column ? [column, row] : [row, column]; | ||
} | ||
/** | ||
* Returns the element at given coordinates. | ||
* | ||
* @param rows the row index | ||
* @param columns the column index | ||
* @return the element | ||
*/ | ||
getValue(row, column) { | ||
return this[this.getIndex(row, column)]; | ||
} | ||
/** | ||
* Sets the element at given coordinates. | ||
* | ||
* @param rows the row index | ||
* @param columns the column index | ||
* @param value the element | ||
* @return the grid | ||
*/ | ||
setValue(row, column, value) { | ||
@@ -122,7 +57,2 @@ this[this.getIndex(row, column)] = value; | ||
} | ||
/** | ||
* Creates an array of arrays representing rows of the grid. | ||
* | ||
* @return an array of arrays | ||
*/ | ||
toArrays() { | ||
@@ -145,3 +75,3 @@ const { rows } = this; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ltbWV0cmljLWdyaWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJzeW1tZXRyaWMtZ3JpZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLQSxNQUFNLFVBQVUsa0JBQWtCLENBS2hDLElBQU87SUFJUCxPQUFPLE1BQU0sYUFBYyxTQUFRLElBQUk7UUFHckMsSUFBSSxHQUFHLENBQUMsQ0FBQztRQUVULE1BQU0sS0FBSyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUM7WUFDekIsT0FBTyxJQUFJLENBQUM7UUFDZCxDQUFDO1FBS0QsSUFBSSxPQUFPO1lBQ1QsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDO1FBQ25CLENBQUM7UUFLRCxJQUFJLE9BQU8sQ0FBQyxPQUFPO1lBQ2pCLElBQUksQ0FBQyxJQUFJLEdBQUcsT0FBTyxDQUFDO1FBQ3RCLENBQUM7UUFLRCxJQUFJLElBQUk7WUFDTixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUM7UUFDbkIsQ0FBQztRQVNELE1BQU0sQ0FBQyxNQUFNLENBRVgsT0FBZTtZQUVmLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDdkMsTUFBTSxJQUFJLEdBQUcsSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDOUIsSUFBSSxDQUFDLElBQUksR0FBRyxPQUFPLENBQUM7WUFDcEIsT0FBTyxJQUF1QixDQUFDO1FBQ2pDLENBQUM7UUFRRCxNQUFNLENBQUMsVUFBVSxDQUVmLE1BQThCO1lBRTlCLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUM7WUFDM0IsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUMvQixJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDVixLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsSUFBSSxFQUFFLENBQUMsRUFBRSxFQUFFO2dCQUM3QixLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFO29CQUMzQixJQUFJLENBQUMsQ0FBQyxDQUFDLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO29CQUN2QixDQUFDLEVBQUUsQ0FBQztpQkFDTDthQUNGO1lBQ0QsT0FBTyxJQUFJLENBQUM7UUFDZCxDQUFDO1FBU0QsTUFBTSxDQUFDLFNBQVMsQ0FBQyxJQUFZO1lBQzNCLE9BQU8sQ0FBQyxDQUFDLElBQUksR0FBRyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDbEMsQ0FBQztRQUVELGNBQWMsQ0FBQyxLQUFhO1lBQzFCLE1BQU0sR0FBRyxHQUFHLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLEtBQUssSUFBSSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDbkQsTUFBTSxNQUFNLEdBQUcsS0FBSyxHQUFHLENBQUMsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztZQUNoRCxPQUFPLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ3ZCLENBQUM7UUFTRCxRQUFRLENBQUMsR0FBVyxFQUFFLE1BQWM7WUFDbEMsTUFBTSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsR0FBRyxHQUFHLElBQUksTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLEVBQUUsTUFBTSxDQUFDLENBQUM7WUFDN0QsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1FBQ2xDLENBQUM7UUFTRCxRQUFRLENBQUMsR0FBVyxFQUFFLE1BQWM7WUFDbEMsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQztRQUMxQyxDQUFDO1FBVUQsUUFBUSxDQUFDLEdBQVcsRUFBRSxNQUFjLEVBQUUsS0FBZTtZQUNuRCxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLEVBQUUsTUFBTSxDQUFDLENBQUMsR0FBRyxLQUFLLENBQUM7WUFDekMsT0FBTyxJQUFJLENBQUM7UUFDZCxDQUFDO1FBT0QsUUFBUTtZQUNOLE1BQU0sRUFBRSxJQUFJLEVBQUUsR0FBRyxJQUFJLENBQUM7WUFDdEIsTUFBTSxNQUFNLEdBQTJCLElBQUksS0FBSyxDQUFDLElBQUksQ0FBQztpQkFDbkQsSUFBSSxDQUFDLENBQUMsQ0FBQztpQkFDUCxHQUFHLENBQUMsR0FBRyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUM7WUFDakIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ1YsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLElBQUksRUFBRSxDQUFDLEVBQUUsRUFBRTtnQkFDN0IsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRTtvQkFDM0IsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztvQkFDdkIsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztvQkFDdkIsQ0FBQyxFQUFFLENBQUM7aUJBQ0w7YUFDRjtZQUNELE9BQU8sTUFBTSxDQUFDO1FBQ2hCLENBQUM7S0FDRixDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQ29uc3RydWN0b3IsIFR5cGVkQXJyYXlDb25zdHJ1Y3RvcnMgfSBmcm9tIFwiLi91dGlsaXR5LXR5cGVzLnRzXCI7XG5cbi8qKlxuICogQ3JlYXRlcyBhIFN5bW1ldHJpY0dyaWQgY2xhc3MgZXh0ZW5kaW5nIGEgZ2l2ZW4gQXJyYXktbGlrZSBjbGFzcy5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIFN5bW1ldHJpY0dyaWRNaXhpbjxcbiAgSXRlbVR5cGUgPSBudW1iZXIsXG4gIFUgZXh0ZW5kcyBDb25zdHJ1Y3RvcjxBcnJheTxJdGVtVHlwZT4+IHwgVHlwZWRBcnJheUNvbnN0cnVjdG9ycyA9IENvbnN0cnVjdG9yPFxuICAgIEFycmF5PEl0ZW1UeXBlPlxuICA+LFxuPihCYXNlOiBVKSB7XG4gIC8qKlxuICAgKiBJbXBsZW1lbnRzIGEgZ3JpZCB0byBoYW5kbGUgc3ltbWV0cmljIG9yIHRyaWFuZ3VsYXIgbWF0cmljZXMgdXNpbmcgaGFsZiB0aGUgc3BhY2UgcmVxdWlyZWQgZm9yIGEgbm9ybWFsIGdyaWQuXG4gICAqL1xuICByZXR1cm4gY2xhc3MgU3ltbWV0cmljR3JpZCBleHRlbmRzIEJhc2Uge1xuICAgIFtrZXk6IG51bWJlcl06IEl0ZW1UeXBlXG5cbiAgICBzaXplID0gMDtcblxuICAgIHN0YXRpYyBnZXQgW1N5bWJvbC5zcGVjaWVzXSgpIHtcbiAgICAgIHJldHVybiBCYXNlO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIE51bWJlciBvZiBjb2x1bW5zIGluIHRoZSBncmlkLlxuICAgICAqL1xuICAgIGdldCBjb2x1bW5zKCkge1xuICAgICAgcmV0dXJuIHRoaXMuc2l6ZTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBTcGVjaWZpZXMgdGhlIG51bWJlciBvZiBjb2x1bW5zIG9mIHRoZSBncmlkLlxuICAgICAqL1xuICAgIHNldCBjb2x1bW5zKGNvbHVtbnMpIHtcbiAgICAgIHRoaXMuc2l6ZSA9IGNvbHVtbnM7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogTnVtYmVyIG9mIHJvd3MgaW4gdGhlIGdyaWQuXG4gICAgICovXG4gICAgZ2V0IHJvd3MoKSB7XG4gICAgICByZXR1cm4gdGhpcy5zaXplO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIENyZWF0ZXMgYSBncmlkIG9mIHNwZWNpZmllZCBkaW1lbnNpb25zLlxuICAgICAqXG4gICAgICogQHBhcmFtIHJvd3MgdGhlIGFtb3VudCBvZiByb3dzXG4gICAgICogQHBhcmFtIGNvbHVtbnMgdGhlIGFtb3VudCBvZiBjb2x1bW5zXG4gICAgICogQHJldHVybiBhIG5ldyBncmlkXG4gICAgICovXG4gICAgc3RhdGljIGNyZWF0ZTxUIGV4dGVuZHMgdHlwZW9mIFN5bW1ldHJpY0dyaWQ+KFxuICAgICAgdGhpczogVCxcbiAgICAgIGNvbHVtbnM6IG51bWJlcixcbiAgICApOiBJbnN0YW5jZVR5cGU8VD4ge1xuICAgICAgY29uc3QgbGVuZ3RoID0gdGhpcy5nZXRMZW5ndGgoY29sdW1ucyk7XG4gICAgICBjb25zdCBncmlkID0gbmV3IHRoaXMobGVuZ3RoKTtcbiAgICAgIGdyaWQuc2l6ZSA9IGNvbHVtbnM7XG4gICAgICByZXR1cm4gZ3JpZCBhcyBJbnN0YW5jZVR5cGU8VD47XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQ3JlYXRlcyBhIGdyaWQgZnJvbSBhbiBhcnJheSBvZiBhcnJheXMuXG4gICAgICpcbiAgICAgKiBAcGFyYW0gYXJyYXlzIHRoZSBhcnJheSBvZiBhcnJheXNcbiAgICAgKiBAcmV0dXJuIGEgbmV3IGdyaWRcbiAgICAgKi9cbiAgICBzdGF0aWMgZnJvbUFycmF5czxUIGV4dGVuZHMgdHlwZW9mIFN5bW1ldHJpY0dyaWQ+KFxuICAgICAgdGhpczogVCxcbiAgICAgIGFycmF5czogQXJyYXk8QXJyYXk8SXRlbVR5cGU+PixcbiAgICApOiBJbnN0YW5jZVR5cGU8VD4ge1xuICAgICAgY29uc3Qgcm93cyA9IGFycmF5cy5sZW5ndGg7XG4gICAgICBjb25zdCBncmlkID0gdGhpcy5jcmVhdGUocm93cyk7XG4gICAgICBsZXQgayA9IDA7XG4gICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHJvd3M7IGkrKykge1xuICAgICAgICBmb3IgKGxldCBqID0gMDsgaiA8PSBpOyBqKyspIHtcbiAgICAgICAgICBncmlkW2tdID0gYXJyYXlzW2ldW2pdO1xuICAgICAgICAgIGsrKztcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgcmV0dXJuIGdyaWQ7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogUmV0dXJucyB0aGUgbGVuZ3RoIG9mIHRoZSB1bmRlcmx5aW5nIEFycmF5IHJlcXVpcmVkIHRvIGhvbGQgdGhlIGdyaWQgb2Ygc3BlY2lmaWVkIGRpbWVuc2lvbnMuXG4gICAgICpcbiAgICAgKiBAcGFyYW0gcm93cyB0aGUgYW1vdW50IG9mIHJvd3NcbiAgICAgKiBAcGFyYW0gY29sdW1ucyB0aGUgYW1vdW50IG9mIGNvbHVtbnNcbiAgICAgKiBAcmV0dXJuIHRoZSByZXF1aXJlZCBsZW5ndGhcbiAgICAgKi9cbiAgICBzdGF0aWMgZ2V0TGVuZ3RoKHJvd3M6IG51bWJlcik6IG51bWJlciB7XG4gICAgICByZXR1cm4gKChyb3dzICsgMSkgKiByb3dzKSA+PiAxO1xuICAgIH1cblxuICAgIGdldENvb3JkaW5hdGVzKGluZGV4OiBudW1iZXIpOiBbcm93OiBudW1iZXIsIGNvbHVtbjogbnVtYmVyXSB7XG4gICAgICBjb25zdCByb3cgPSAoTWF0aC5zcXJ0KChpbmRleCA8PCAzKSArIDEpIC0gMSkgPj4gMTtcbiAgICAgIGNvbnN0IGNvbHVtbiA9IGluZGV4IC0gKChyb3cgKiAocm93ICsgMSkpID4+IDEpO1xuICAgICAgcmV0dXJuIFtyb3csIGNvbHVtbl07XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogUmV0dXJucyB0aGUgaW5kZXggb2YgYW4gZWxlbWVudCBhdCBnaXZlbiBjb29yZGluYXRlcy5cbiAgICAgKlxuICAgICAqIEBwYXJhbSByb3dzIHRoZSByb3cgaW5kZXhcbiAgICAgKiBAcGFyYW0gY29sdW1ucyB0aGUgY29sdW1uIGluZGV4XG4gICAgICogQHJldHVybiB0aGUgZWxlbWVudCBpbmRleFxuICAgICAqL1xuICAgIGdldEluZGV4KHJvdzogbnVtYmVyLCBjb2x1bW46IG51bWJlcik6IG51bWJlciB7XG4gICAgICBjb25zdCBbeCwgeV0gPSByb3cgPj0gY29sdW1uID8gW2NvbHVtbiwgcm93XSA6IFtyb3csIGNvbHVtbl07XG4gICAgICByZXR1cm4geCArICgoKHkgKyAxKSAqIHkpID4+IDEpO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFJldHVybnMgdGhlIGVsZW1lbnQgYXQgZ2l2ZW4gY29vcmRpbmF0ZXMuXG4gICAgICpcbiAgICAgKiBAcGFyYW0gcm93cyB0aGUgcm93IGluZGV4XG4gICAgICogQHBhcmFtIGNvbHVtbnMgdGhlIGNvbHVtbiBpbmRleFxuICAgICAqIEByZXR1cm4gdGhlIGVsZW1lbnRcbiAgICAgKi9cbiAgICBnZXRWYWx1ZShyb3c6IG51bWJlciwgY29sdW1uOiBudW1iZXIpOiBJdGVtVHlwZSB7XG4gICAgICByZXR1cm4gdGhpc1t0aGlzLmdldEluZGV4KHJvdywgY29sdW1uKV07XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogU2V0cyB0aGUgZWxlbWVudCBhdCBnaXZlbiBjb29yZGluYXRlcy5cbiAgICAgKlxuICAgICAqIEBwYXJhbSByb3dzIHRoZSByb3cgaW5kZXhcbiAgICAgKiBAcGFyYW0gY29sdW1ucyB0aGUgY29sdW1uIGluZGV4XG4gICAgICogQHBhcmFtIHZhbHVlIHRoZSBlbGVtZW50XG4gICAgICogQHJldHVybiB0aGUgZ3JpZFxuICAgICAqL1xuICAgIHNldFZhbHVlKHJvdzogbnVtYmVyLCBjb2x1bW46IG51bWJlciwgdmFsdWU6IEl0ZW1UeXBlKTogdGhpcyB7XG4gICAgICB0aGlzW3RoaXMuZ2V0SW5kZXgocm93LCBjb2x1bW4pXSA9IHZhbHVlO1xuICAgICAgcmV0dXJuIHRoaXM7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQ3JlYXRlcyBhbiBhcnJheSBvZiBhcnJheXMgcmVwcmVzZW50aW5nIHJvd3Mgb2YgdGhlIGdyaWQuXG4gICAgICpcbiAgICAgKiBAcmV0dXJuIGFuIGFycmF5IG9mIGFycmF5c1xuICAgICAqL1xuICAgIHRvQXJyYXlzKCk6IEFycmF5PEFycmF5PEl0ZW1UeXBlPj4ge1xuICAgICAgY29uc3QgeyByb3dzIH0gPSB0aGlzO1xuICAgICAgY29uc3QgYXJyYXlzOiBBcnJheTxBcnJheTxJdGVtVHlwZT4+ID0gbmV3IEFycmF5KHJvd3MpXG4gICAgICAgIC5maWxsKDApXG4gICAgICAgIC5tYXAoKCkgPT4gW10pO1xuICAgICAgbGV0IGsgPSAwO1xuICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCByb3dzOyBpKyspIHtcbiAgICAgICAgZm9yIChsZXQgaiA9IDA7IGogPD0gaTsgaisrKSB7XG4gICAgICAgICAgYXJyYXlzW2ldW2pdID0gdGhpc1trXTtcbiAgICAgICAgICBhcnJheXNbal1baV0gPSB0aGlzW2tdO1xuICAgICAgICAgIGsrKztcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgcmV0dXJuIGFycmF5cztcbiAgICB9XG4gIH07XG59XG4iXX0= | ||
//# sourceMappingURL=symmetric-grid.js.map |
@@ -11,3 +11,5 @@ import type { ComplexView, ContainerView, PrimitiveView, ViewConstructor, ViewInstance } from "./view-types"; | ||
static getLength<T>(value: Array<T>): number; | ||
static getOffset(index: number, view: DataView, start?: number): [start: number, length: number] | undefined; | ||
static getSize(view: DataView, start?: number): number; | ||
static indexOf<T>(value: T, view: DataView, startIndex?: number, startOffset?: number): number; | ||
[Symbol.iterator](): Generator<ViewInstance<T> | undefined>; | ||
@@ -17,4 +19,5 @@ at(index: number): T | undefined; | ||
getLength(index: number): number; | ||
getLayout(index: number): [number, number] | undefined; | ||
getOffset(index: number): [number, number] | undefined; | ||
getView(index: number): ViewInstance<T> | undefined; | ||
indexOf(value: T, start?: number): number; | ||
set(index: number, value: T): void; | ||
@@ -21,0 +24,0 @@ setView(index: number, value: DataView): void; |
export class VectorView extends DataView { | ||
static View; | ||
static viewLength = 0; | ||
static maxView; | ||
get size() { | ||
@@ -13,7 +10,5 @@ return this.constructor.getSize(this); | ||
for (let i = 0; i < size; i++) { | ||
const offset = (i + 1) << 2; | ||
const startOffset = view.getUint32(start + offset, true); | ||
const end = view.getUint32(start + offset + 4, true); | ||
array[i] = startOffset !== end | ||
? View.decode(view, start + startOffset, end - startOffset) | ||
const offset = this.getOffset(i, view, start); | ||
array[i] = offset | ||
? View.decode(view, start + offset[0], offset[1]) | ||
: undefined; | ||
@@ -41,2 +36,3 @@ } | ||
itemLength = View.getLength(value.length || 1); | ||
// stop encoding if no more space is available | ||
if (itemLength > availableSpace) | ||
@@ -72,5 +68,29 @@ continue; | ||
} | ||
static getOffset(index, view, start = 0) { | ||
const offset = start + ((index + 1) << 2); | ||
const begin = view.getUint32(offset, true); | ||
const end = view.getUint32(offset + 4, true); | ||
if (begin === end) | ||
return undefined; | ||
return [begin, end - begin]; | ||
} | ||
static getSize(view, start = 0) { | ||
return view.getUint32(start, true); | ||
} | ||
static indexOf(value, view, startIndex = 0, startOffset = 0) { | ||
const size = this.getSize(view, startOffset); | ||
const valueView = this.View.from(value); | ||
outer: for (let i = startIndex; i < size; i++) { | ||
const offset = this.getOffset(i, view, startOffset); | ||
if (!offset || offset[1] !== valueView.byteLength) | ||
continue; | ||
for (let j = 0; j < valueView.byteLength; j++) { | ||
if (valueView.getUint8(j) !== view.getUint8(offset[0] + j)) { | ||
continue outer; | ||
} | ||
} | ||
return i; | ||
} | ||
return -1; | ||
} | ||
*[Symbol.iterator]() { | ||
@@ -90,23 +110,16 @@ const { size } = this; | ||
.View; | ||
const layout = this.getLayout(index); | ||
if (!layout) | ||
const offset = this.getOffset(index); | ||
if (!offset) | ||
return undefined; | ||
return View.decode(this, layout[0], layout[1]); | ||
return View.decode(this, offset[0], offset[1]); | ||
} | ||
getLength(index) { | ||
const layout = this.getLayout(index); | ||
if (!layout) | ||
return 0; | ||
return layout[1]; | ||
const offset = this.getOffset(index); | ||
return offset ? offset[1] : 0; | ||
} | ||
getLayout(index) { | ||
getOffset(index) { | ||
const length = this.getUint32(0, true); | ||
if (index >= length) | ||
return undefined; | ||
const startOffset = (index + 1) << 2; | ||
const start = this.getUint32(startOffset, true); | ||
const end = this.getUint32(startOffset + 4, true); | ||
if (start === end) | ||
return undefined; | ||
return [start, end - start]; | ||
return this.constructor.getOffset(index, this, 0); | ||
} | ||
@@ -116,20 +129,23 @@ getView(index) { | ||
.View; | ||
const layout = this.getLayout(index); | ||
if (!layout) | ||
const offset = this.getOffset(index); | ||
if (!offset) | ||
return undefined; | ||
return new View(this.buffer, this.byteOffset + layout[0], layout[1]); | ||
return new View(this.buffer, this.byteOffset + offset[0], offset[1]); | ||
} | ||
indexOf(value, start = 0) { | ||
return this.constructor.indexOf(value, this, start, 0); | ||
} | ||
set(index, value) { | ||
const View = this.constructor | ||
.View; | ||
const layout = this.getLayout(index); | ||
if (!layout) | ||
const offset = this.getOffset(index); | ||
if (!offset) | ||
return undefined; | ||
View.encode(value, this, this.byteOffset + layout[0], layout[1]); | ||
View.encode(value, this, this.byteOffset + offset[0], offset[1]); | ||
} | ||
setView(index, value) { | ||
const layout = this.getLayout(index); | ||
if (!layout) | ||
const offset = this.getOffset(index); | ||
if (!offset) | ||
return undefined; | ||
new Uint8Array(this.buffer, this.byteOffset + layout[0], layout[1]).set(new Uint8Array(value.buffer, value.byteOffset, value.byteLength)); | ||
new Uint8Array(this.buffer, this.byteOffset + offset[0], offset[1]).set(new Uint8Array(value.buffer, value.byteOffset, value.byteLength)); | ||
} | ||
@@ -140,3 +156,9 @@ toJSON() { | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVjdG9yLXZpZXcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ2ZWN0b3Itdmlldy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRQSxNQUFNLE9BQU8sVUFBYyxTQUFRLFFBQVE7SUFDekMsTUFBTSxDQUFDLElBQUksQ0FHVDtJQUNGLE1BQU0sQ0FBQyxVQUFVLEdBQUcsQ0FBQyxDQUFDO0lBQ3RCLE1BQU0sQ0FBQyxPQUFPLENBQVc7SUFFekIsSUFBSSxJQUFJO1FBQ04sT0FBUSxJQUFJLENBQUMsV0FBaUMsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDL0QsQ0FBQztJQUVELE1BQU0sQ0FBQyxNQUFNLENBQUksSUFBYyxFQUFFLEtBQUssR0FBRyxDQUFDO1FBQ3hDLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxJQUEwQixDQUFDO1FBQzdDLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ3ZDLE1BQU0sS0FBSyxHQUFHLElBQUksS0FBSyxDQUFDLElBQUksQ0FBeUIsQ0FBQztRQUN0RCxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsSUFBSSxFQUFFLENBQUMsRUFBRSxFQUFFO1lBQzdCLE1BQU0sTUFBTSxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUM1QixNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssR0FBRyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7WUFDekQsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEdBQUcsTUFBTSxHQUFHLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQztZQUNyRCxLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsV0FBVyxLQUFLLEdBQUc7Z0JBQzVCLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksRUFB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QUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIENvbXBsZXhWaWV3LFxuICBDb250YWluZXJWaWV3LFxuICBQcmltaXRpdmVWaWV3LFxuICBWaWV3Q29uc3RydWN0b3IsXG4gIFZpZXdJbnN0YW5jZSxcbn0gZnJvbSBcIi4vdmlldy10eXBlcy50c1wiO1xuXG5leHBvcnQgY2xhc3MgVmVjdG9yVmlldzxUPiBleHRlbmRzIERhdGFWaWV3IGltcGxlbWVudHMgQ29udGFpbmVyVmlldzxUPiB7XG4gIHN0YXRpYyBWaWV3OiBWaWV3Q29uc3RydWN0b3I8XG4gICAgdW5rbm93bixcbiAgICBQcmltaXRpdmVWaWV3PHVua25vd24+IHwgQ29udGFpbmVyVmlldzx1bmtub3duPiB8IENvbXBsZXhWaWV3PHVua25vd24+XG4gID47XG4gIHN0YXRpYyB2aWV3TGVuZ3RoID0gMDtcbiAgc3RhdGljIG1heFZpZXc6IERhdGFWaWV3O1xuXG4gIGdldCBzaXplKCk6IG51bWJlciB7XG4gICAgcmV0dXJuICh0aGlzLmNvbnN0cnVjdG9yIGFzIHR5cGVvZiBWZWN0b3JWaWV3KS5nZXRTaXplKHRoaXMpO1xuICB9XG5cbiAgc3RhdGljIGRlY29kZTxUPih2aWV3OiBEYXRhVmlldywgc3RhcnQgPSAwKTogQXJyYXk8VCB8IHVuZGVmaW5lZD4ge1xuICAgIGNvbnN0IFZpZXcgPSB0aGlzLlZpZXcgYXMgVmlld0NvbnN0cnVjdG9yPFQ+O1xuICAgIGNvbnN0IHNpemUgPSB0aGlzLmdldFNpemUodmlldywgc3RhcnQpO1xuICAgIGNvbnN0IGFycmF5ID0gbmV3IEFycmF5KHNpemUpIGFzIEFycmF5PFQgfCB1bmRlZmluZWQ+O1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgc2l6ZTsgaSsrKSB7XG4gICAgICBjb25zdCBvZmZzZXQgPSAoaSArIDEpIDw8IDI7XG4gICAgICBjb25zdCBzdGFydE9mZnNldCA9IHZpZXcuZ2V0VWludDMyKHN0YXJ0ICsgb2Zmc2V0LCB0cnVlKTtcbiAgICAgIGNvbnN0IGVuZCA9IHZpZXcuZ2V0VWludDMyKHN0YXJ0ICsgb2Zmc2V0ICsgNCwgdHJ1ZSk7XG4gICAgICBhcnJheVtpXSA9IHN0YXJ0T2Zmc2V0ICE9PSBlbmRcbiAgICAgICAgPyBWaWV3LmRlY29kZSh2aWV3LCBzdGFydCArIHN0YXJ0T2Zmc2V0LCBlbmQgLSBzdGFydE9mZnNldClcbiAgICAgICAgOiB1bmRlZmluZWQ7XG4gICAgfVxuICAgIHJldHVybiBhcnJheTtcbiAgfVxuXG4gIHN0YXRpYyBlbmNvZGU8VD4oXG4gICAgdmFsdWU6IEFycmF5PFQ+LFxuICAgIHZpZXc6IERhdGFWaWV3LFxuICAgIHN0YXJ0ID0gMCxcbiAgICBsZW5ndGg/OiBudW1iZXIsXG4gICk6IG51bWJlciB7XG4gICAgY29uc3QgeyBWaWV3IH0gPSB0aGlzO1xuICAgIGNvbnN0IGl0ZW1zID0gdmFsdWUubGVuZ3RoO1xuICAgIGNvbnN0IGxhc3RPZmZzZXQgPSAoaXRlbXMgKyAxKSA8PCAyO1xuICAgIGxldCBlbmQgPSBsYXN0T2Zmc2V0ICsgNDtcbiAgICBsZXQgYXZhaWxhYmxlU3BhY2UgPSAobGVuZ3RoID8/IHZpZXcuYnl0ZUxlbmd0aCkgLSBlbmQ7XG4gICAgaWYgKGF2YWlsYWJsZVNwYWNlIDwgMSkgcmV0dXJuIDA7XG4gICAgdmlldy5zZXRVaW50MzIoc3RhcnQsIGl0ZW1zLCB0cnVlKTtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IGl0ZW1zOyBpKyspIHtcbiAgICAgIGNvbnN0IGl0ZW0gPSB2YWx1ZVtpXTtcbiAgICAgIGNvbnN0IGl0ZW1PZmZzZXQgPSAoaSArIDEpIDw8IDI7XG4gICAgICB2aWV3LnNldFVpbnQzMihzdGFydCArIGl0ZW1PZmZzZXQsIGVuZCwgdHJ1ZSk7XG4gICAgICBsZXQgaXRlbUxlbmd0aCA9IDA7XG4gICAgICBpZiAoaXRlbSAhPSBudWxsKSB7XG4gICAgICAgIGNvbnN0IGNhcmV0ID0gc3RhcnQgKyBlbmQ7XG4gICAgICAgIGlmIChWaWV3LnZpZXdMZW5ndGggfHwgVmlldy5pdGVtTGVuZ3RoKSB7XG4gICAgICAgICAgaXRlbUxlbmd0aCA9IFZpZXcuZ2V0TGVuZ3RoKHZhbHVlLmxlbmd0aCB8fCAxKTtcbiAgICAgICAgICAvLyBzdG9wIGVuY29kaW5nIGlmIG5vIG1vcmUgc3BhY2UgaXMgYXZhaWxhYmxlXG4gICAgICAgICAgaWYgKGl0ZW1MZW5ndGggPiBhdmFpbGFibGVTcGFjZSkgY29udGludWU7XG4gICAgICAgICAgVmlldy5lbmNvZGUoaXRlbSwgdmlldywgY2FyZXQsIGl0ZW1MZW5ndGgpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGl0ZW1MZW5ndGggPSBWaWV3LmVuY29kZShcbiAgICAgICAgICAgIGl0ZW0sXG4gICAgICAgICAgICB2aWV3LFxuICAgICAgICAgICAgY2FyZXQsXG4gICAgICAgICAgICBsZW5ndGggPyBhdmFpbGFibGVTcGFjZSA6IHVuZGVmaW5lZCxcbiAgICAgICAgICApO1xuICAgICAgICB9XG4gICAgICAgIGVuZCArPSBpdGVtTGVuZ3RoO1xuICAgICAgICBhdmFpbGFibGVTcGFjZSAtPSBpdGVtTGVuZ3RoO1xuICAgICAgfVxuICAgIH1cbiAgICB2aWV3LnNldFVpbnQzMihzdGFydCArIGxhc3RPZmZzZXQsIGVuZCwgdHJ1ZSk7XG4gICAgcmV0dXJuIGVuZDtcbiAgfVxuXG4gIHN0YXRpYyBmcm9tPFQsIFUgZXh0ZW5kcyBWZWN0b3JWaWV3PFQ+Pih2YWx1ZTogQXJyYXk8VD4pOiBVIHtcbiAgICBjb25zdCB7IG1heFZpZXcgfSA9IHRoaXM7XG4gICAgY29uc3QgZW5kID0gdGhpcy5lbmNvZGUodmFsdWUsIG1heFZpZXcpO1xuICAgIHJldHVybiBuZXcgdGhpcyhtYXhWaWV3LmJ1ZmZlci5zbGljZSgwLCBlbmQpKSBhcyBVO1xuICB9XG5cbiAgc3RhdGljIGdldExlbmd0aDxUPih2YWx1ZTogQXJyYXk8VD4pOiBudW1iZXIge1xuICAgIGNvbnN0IHsgVmlldyB9ID0gdGhpcztcbiAgICBjb25zdCBpdGVtcyA9IHZhbHVlLmxlbmd0aDtcbiAgICBsZXQgbGVuZ3RoID0gKGl0ZW1zICsgMikgPDwgMjtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHZhbHVlLmxlbmd0aDsgaSsrKSB7XG4gICAgICBpZiAodmFsdWVbaV0gIT09IHVuZGVmaW5lZCkge1xuICAgICAgICBsZW5ndGggKz0gVmlldy5nZXRMZW5ndGgodmFsdWVbaV0pO1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gbGVuZ3RoO1xuICB9XG5cbiAgc3RhdGljIGdldFNpemUodmlldzogRGF0YVZpZXcsIHN0YXJ0ID0gMCk6IG51bWJlciB7XG4gICAgcmV0dXJuIHZpZXcuZ2V0VWludDMyKHN0YXJ0LCB0cnVlKTtcbiAgfVxuXG4gICpbU3ltYm9sLml0ZXJhdG9yXSgpOiBHZW5lcmF0b3I8Vmlld0luc3RhbmNlPFQ+IHwgdW5kZWZpbmVkPiB7XG4gICAgY29uc3QgeyBzaXplIH0gPSB0aGlzO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgc2l6ZTsgaSsrKSB7XG4gICAgICB5aWVsZCB0aGlzLmdldFZpZXcoaSk7XG4gICAgfVxuICB9XG5cbiAgYXQoaW5kZXg6IG51bWJlcik6IFQgfCB1bmRlZmluZWQge1xuICAgIGlmIChpbmRleCA8IDApIHJldHVybiB0aGlzLmdldCh0aGlzLnNpemUgKyBpbmRleCk7XG4gICAgcmV0dXJuIHRoaXMuZ2V0KGluZGV4KTtcbiAgfVxuXG4gIGdldChpbmRleDogbnVtYmVyKTogVCB8IHVuZGVmaW5lZCB7XG4gICAgY29uc3QgVmlldyA9ICh0aGlzLmNvbnN0cnVjdG9yIGFzIHR5cGVvZiBWZWN0b3JWaWV3KVxuICAgICAgLlZpZXcgYXMgVmlld0NvbnN0cnVjdG9yPFQ+O1xuICAgIGNvbnN0IGxheW91dCA9IHRoaXMuZ2V0TGF5b3V0KGluZGV4KTtcbiAgICBpZiAoIWxheW91dCkgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICByZXR1cm4gVmlldy5kZWNvZGUodGhpcywgbGF5b3V0WzBdLCBsYXlvdXRbMV0pO1xuICB9XG5cbiAgZ2V0TGVuZ3RoKGluZGV4OiBudW1iZXIpOiBudW1iZXIge1xuICAgIGNvbnN0IGxheW91dCA9IHRoaXMuZ2V0TGF5b3V0KGluZGV4KTtcbiAgICBpZiAoIWxheW91dCkgcmV0dXJuIDA7XG4gICAgcmV0dXJuIGxheW91dFsxXTtcbiAgfVxuXG4gIGdldExheW91dChpbmRleDogbnVtYmVyKTogW251bWJlciwgbnVtYmVyXSB8IHVuZGVmaW5lZCB7XG4gICAgY29uc3QgbGVuZ3RoID0gdGhpcy5nZXRVaW50MzIoMCwgdHJ1ZSk7XG4gICAgaWYgKGluZGV4ID49IGxlbmd0aCkgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICBjb25zdCBzdGFydE9mZnNldCA9IChpbmRleCArIDEpIDw8IDI7XG4gICAgY29uc3Qgc3RhcnQgPSB0aGlzLmdldFVpbnQzMihzdGFydE9mZnNldCwgdHJ1ZSk7XG4gICAgY29uc3QgZW5kID0gdGhpcy5nZXRVaW50MzIoc3RhcnRPZmZzZXQgKyA0LCB0cnVlKTtcbiAgICBpZiAoc3RhcnQgPT09IGVuZCkgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICByZXR1cm4gW3N0YXJ0LCBlbmQgLSBzdGFydF07XG4gIH1cblxuICBnZXRWaWV3KGluZGV4OiBudW1iZXIpOiBWaWV3SW5zdGFuY2U8VD4gfCB1bmRlZmluZWQge1xuICAgIGNvbnN0IFZpZXcgPSAodGhpcy5jb25zdHJ1Y3RvciBhcyB0eXBlb2YgVmVjdG9yVmlldylcbiAgICAgIC5WaWV3IGFzIFZpZXdDb25zdHJ1Y3RvcjxUPjtcbiAgICBjb25zdCBsYXlvdXQgPSB0aGlzLmdldExheW91dChpbmRleCk7XG4gICAgaWYgKCFsYXlvdXQpIHJldHVybiB1bmRlZmluZWQ7XG4gICAgcmV0dXJuIG5ldyBWaWV3KHRoaXMuYnVmZmVyLCB0aGlzLmJ5dGVPZmZzZXQgKyBsYXlvdXRbMF0sIGxheW91dFsxXSk7XG4gIH1cblxuICBzZXQoaW5kZXg6IG51bWJlciwgdmFsdWU6IFQpOiB2b2lkIHtcbiAgICBjb25zdCBWaWV3ID0gKHRoaXMuY29uc3RydWN0b3IgYXMgdHlwZW9mIFZlY3RvclZpZXcpXG4gICAgICAuVmlldyBhcyBWaWV3Q29uc3RydWN0b3I8VD47XG4gICAgY29uc3QgbGF5b3V0ID0gdGhpcy5nZXRMYXlvdXQoaW5kZXgpO1xuICAgIGlmICghbGF5b3V0KSByZXR1cm4gdW5kZWZpbmVkO1xuICAgIFZpZXcuZW5jb2RlKHZhbHVlLCB0aGlzLCB0aGlzLmJ5dGVPZmZzZXQgKyBsYXlvdXRbMF0sIGxheW91dFsxXSk7XG4gIH1cblxuICBzZXRWaWV3KGluZGV4OiBudW1iZXIsIHZhbHVlOiBEYXRhVmlldyk6IHZvaWQge1xuICAgIGNvbnN0IGxheW91dCA9IHRoaXMuZ2V0TGF5b3V0KGluZGV4KTtcbiAgICBpZiAoIWxheW91dCkgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICBuZXcgVWludDhBcnJheSh0aGlzLmJ1ZmZlciwgdGhpcy5ieXRlT2Zmc2V0ICsgbGF5b3V0WzBdLCBsYXlvdXRbMV0pLnNldChcbiAgICAgIG5ldyBVaW50OEFycmF5KHZhbHVlLmJ1ZmZlciwgdmFsdWUuYnl0ZU9mZnNldCwgdmFsdWUuYnl0ZUxlbmd0aCksXG4gICAgKTtcbiAgfVxuXG4gIHRvSlNPTigpOiBBcnJheTxUIHwgdW5kZWZpbmVkPiB7XG4gICAgcmV0dXJuICh0aGlzLmNvbnN0cnVjdG9yIGFzIHR5cGVvZiBWZWN0b3JWaWV3KS5kZWNvZGUodGhpcywgMCk7XG4gIH1cbn1cbiJdfQ== | ||
Object.defineProperty(VectorView, "viewLength", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: 0 | ||
}); | ||
//# sourceMappingURL=vector-view.js.map |
@@ -50,2 +50,11 @@ import { Constructor } from "./utility-types"; | ||
/** | ||
* Returns the index within the view of the first occurrence | ||
* of the specified value, starting the search at start. | ||
* Returns -1 if the value is not found. | ||
* | ||
* @param value the to search for | ||
* @return index of the value or -1 if not found | ||
*/ | ||
indexOf(value: T, start?: number): number; | ||
/** | ||
* Sets a given JavaScript value to an item at a given index. | ||
@@ -129,2 +138,3 @@ * | ||
ObjectConstructor?: Constructor<T>; | ||
View?: unknown; | ||
new (...args: any[]): Instance; | ||
@@ -189,5 +199,7 @@ /** | ||
}; | ||
propertyNames?: ViewSchema<number> | ViewSchema<string>; | ||
additionalProperties?: ViewSchema<T[keyof T]>; | ||
type: [T] extends [number | bigint | undefined] ? "number" | "integer" : [T] extends [string | ArrayBufferLike | undefined] ? "string" : [T] extends [boolean | undefined] ? "boolean" : T extends Array<unknown> ? "array" : T extends object ? "object" : never; | ||
btype?: T extends number ? ViewSchemaNumberType : T extends ArrayBufferLike ? "binary" : T extends Array<unknown> ? "vector" : T extends object ? "map" : never; | ||
btype?: T extends number ? ViewSchemaNumberType : T extends ArrayBufferLike ? "binary" : T extends Array<unknown> ? "vector" : T extends object ? "map" | "dict" : never; | ||
default?: T; | ||
} |
export {}; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlldy10eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInZpZXctdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8vIGRlbm8tbGludC1pZ25vcmUtZmlsZSBiYW4tdHlwZXNcbmltcG9ydCB7IENvbnN0cnVjdG9yIH0gZnJvbSBcIi4vdXRpbGl0eS10eXBlcy50c1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFByaW1pdGl2ZVZpZXc8VD4gZXh0ZW5kcyBEYXRhVmlldyB7XG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBKYXZhU2NyaXB0IHZhbHVlIG9mIHRoZSB2aWV3LlxuICAgKi9cbiAgZ2V0KCk6IFQ7XG5cbiAgLyoqXG4gICAqIFNldHMgdGhlIEphdmFTY3JpcHQgdmFsdWUgb2YgdGhlIHZpZXcuXG4gICAqL1xuICBzZXQodmFsdWU6IFQpOiB2b2lkO1xuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBKYXZhU2NyaXB0IHZhbHVlIG9mIHRoZSB2aWV3LlxuICAgKi9cbiAgdG9KU09OKCk6IFQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29udGFpbmVyVmlldzxUPiBleHRlbmRzIERhdGFWaWV3IHtcbiAgLyoqXG4gICAqIFRoZSBhbW91bnQgb2YgaXRlbXMgaW4gdGhlIHZpZXcuXG4gICAqL1xuICBzaXplOiBudW1iZXI7XG4gIFtTeW1ib2wuaXRlcmF0b3JdKCk6IEdlbmVyYXRvcjxWaWV3SW5zdGFuY2U8VD4gfCB1bmRlZmluZWQ+O1xuXG4gIC8qKlxuICAgKiBHZXQgdGhlIEphdmFTY3JpcHQgdmFsdWUgb2YgYW4gaXRlbS5cbiAgICpcbiAgICogQHBhcmFtIGluZGV4IHRoZSBvZiB0aGUgaXRlbS5cbiAgICovXG4gIGF0KGluZGV4OiBudW1iZXIpOiBUIHwgdW5kZWZpbmVkO1xuXG4gIC8qKlxuICAgKiBHZXQgdGhlIEphdmFTY3JpcHQgdmFsdWUgb2YgYW4gaXRlbS5cbiAgICpcbiAgICogQHBhcmFtIGluZGV4IHRoZSBpbmRleCBvZiB0aGUgaXRlbVxuICAgKiBAcmV0dXJuIHRoZSBpdGVtXG4gICAqL1xuICBnZXQoaW5kZXg6IG51bWJlcik6IFQgfCB1bmRlZmluZWQ7XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIGJ5dGUgbGVuZ3RoIG9mIGFuIGl0ZW0gYXQgYSBnaXZlbiBpbmRleC5cbiAgICpcbiAgICogQHBhcmFtIGluZGV4IHRoZSBpbmRleCBvZiB0aGUgaXRlbVxuICAgKiBAcmV0dXJuIHRoZSBieXRlIGxlbmd0aFxuICAgKi9cbiAgZ2V0TGVuZ3RoKGluZGV4OiBudW1iZXIpOiBudW1iZXI7XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIHZpZXcgb2YgYW4gaXRlbSBhdCBhIGdpdmVuIGluZGV4XG4gICAqXG4gICAqIEBwYXJhbSBpbmRleCB0aGUgaW5kZXggb2YgdGhlIGl0ZW1cbiAgICogQHJldHVybiBhIHZpZXcgb2YgdGhlIGl0ZW1cbiAgICovXG4gIGdldFZpZXcoaW5kZXg6IG51bWJlcik6IFZpZXdJbnN0YW5jZTxUPiB8IHVuZGVmaW5lZDtcblxuICAvKipcbiAgICogU2V0cyBhIGdpdmVuIEphdmFTY3JpcHQgdmFsdWUgdG8gYW4gaXRlbSBhdCBhIGdpdmVuIGluZGV4LlxuICAgKlxuICAgKiBAcGFyYW0gaW5kZXggdGhlIGluZGV4IG9mIHRoZSBpdGVtXG4gICAqIEBwYXJhbSB2YWx1ZSB0aGUgSmF2YVNjcmlwdCB2YWx1ZSB0byBzZXRcbiAgICovXG4gIHNldChpbmRleDogbnVtYmVyLCB2YWx1ZTogVCk6IHZvaWQ7XG5cbiAgLyoqXG4gICAqIFNldHMgYSBnaXZlbiB2aWV3IHRvIGFuIGl0ZW0gYXQgYSBnaXZlbiBpbmRleC5cbiAgICpcbiAgICogQHBhcmFtIGluZGV4IHRoZSBpbmRleCBvZiB0aGUgaXRlbVxuICAgKiBAcGFyYW0gdmlldyB0aGUgdmlldyB0byBzZXRcbiAgICovXG4gIHNldFZpZXcoaW5kZXg6IG51bWJlciwgdmlldzogRGF0YVZpZXcpOiB2b2lkO1xuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBKYXZhU2NyaXB0IHZhbHVlIG9mIHRoZSB2aWV3LlxuICAgKlxuICAgKiBAcmV0dXJuIHRoZSBqYXZhc2NyaXB0IHZhbHVlXG4gICAqL1xuICB0b0pTT04oKTogQXJyYXk8VCB8IHVuZGVmaW5lZD47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29tcGxleFZpZXc8VD4gZXh0ZW5kcyBEYXRhVmlldyB7XG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBKYXZhU2NyaXB0IHZhbHVlIG9mIGEgZ2l2ZW4gZmllbGQuXG4gICAqXG4gICAqIEBwYXJhbSBmaWVsZCB0aGUgZmllbGQgbmFtZVxuICAgKiBAcmV0dXJuIHRoZSBKYXZhU2NyaXB0IHZhbHVlXG4gICAqL1xuICBnZXQ8UCBleHRlbmRzIGtleW9mIFQ+KGZpZWxkOiBQKTogVFtQXSB8IHVuZGVmaW5lZDtcblxuICAvKipcbiAgICogUmV0dXJucyB0aGUgYnl0ZSBsZW5ndGggb2YgYSBnaXZlbiBmaWVsZC5cbiAgICpcbiAgICogQHBhcmFtIGZpZWxkIHRoZSBmaWVsZCBuYW1lXG4gICAqIEByZXR1cm4gdGhlIGJ5dGUgbGVuZ3RoXG4gICAqL1xuICBnZXRMZW5ndGg8UCBleHRlbmRzIGtleW9mIFQ+KGZpZWxkOiBQKTogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSB2aWV3IG9mIGEgZmllbGQuXG4gICAqXG4gICAqIEBwYXJhbSBmaWVsZCB0aGUgZmllbGQgbmFtZVxuICAgKiBAcmV0dXJuIHRoZSB2aWV3XG4gICAqL1xuICBnZXRWaWV3PFAgZXh0ZW5kcyBrZXlvZiBUPihmaWVsZDogUCk6IFZpZXdJbnN0YW5jZTxUW1BdPiB8IHVuZGVmaW5lZDtcblxuICAvKipcbiAgICogU2V0IGEgSmF2YVNjcmlwdCB2YWx1ZSB0byBhIGZpZWxkLlxuICAgKlxuICAgKiBAcGFyYW0gZmllbGQgdGhlIGZpZWxkIG5hbWVcbiAgICogQHBhcmFtIHZhbHVlIHRoZSBKYXZhU2NyaXB0IHZhbHVlXG4gICAqL1xuICBzZXQ8UCBleHRlbmRzIGtleW9mIFQ+KGZpZWxkOiBQLCB2YWx1ZTogVFtQXSk6IHZvaWQ7XG5cbiAgLyoqXG4gICAqIFNldCBhIHZpZXcgdG8gYSBnaXZlbiBmaWVsZC5cbiAgICpcbiAgICogQHBhcmFtIGZpZWxkIHRoZSBmaWVsZCBuYW1lXG4gICAqIEBwYXJhbSB2aWV3IHRoZSB2aWV3XG4gICAqL1xuICBzZXRWaWV3PFAgZXh0ZW5kcyBrZXlvZiBUPihmaWVsZDogUCwgdmlldzogRGF0YVZpZXcpOiB2b2lkO1xuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBKYXZhU2NyaXB0IHZhbHVlIG9mIHRoZSB2aWV3LlxuICAgKlxuICAgKiBAcmV0dXJuIHRoZSBqYXZhc2NyaXB0IHZhbHVlXG4gICAqL1xuICB0b0pTT04oKTogVDtcbn1cblxuZXhwb3J0IHR5cGUgVmlld0luc3RhbmNlPFQ+ID0gW1RdIGV4dGVuZHNcbiAgW2Jvb2xlYW4gfCBudW1iZXIgfCBzdHJpbmcgfCBiaWdpbnQgfCBBcnJheUJ1ZmZlckxpa2VdID8gUHJpbWl0aXZlVmlldzxUPlxuICA6IFQgZXh0ZW5kcyBBcnJheTxpbmZlciBVPiA/IENvbnRhaW5lclZpZXc8VT5cbiAgOiBUIGV4dGVuZHMgb2JqZWN0ID8gQ29tcGxleFZpZXc8VD5cbiAgOiBuZXZlcjtcblxuZXhwb3J0IGludGVyZmFjZSBWaWV3Q29uc3RydWN0b3I8VCwgSW5zdGFuY2UgPSBWaWV3SW5zdGFuY2U8VD4+IHtcbiAgLyoqXG4gICAqIFRoZSBieXRlIGxlbmd0aCBvZiB0aGUgdmlldy5cbiAgICovXG4gIHZpZXdMZW5ndGg6IG51bWJlcjtcbiAgLyoqXG4gICAqIFRoZSBieXRlIGxlbmd0aCBvZiBhbiBpdGVtIGluc2lkZSB0aGUgY29udGFpbmVyIHZpZXcuXG4gICAqL1xuICBpdGVtTGVuZ3RoPzogbnVtYmVyO1xuICBsYXlvdXQ/OiBWaWV3TGF5b3V0PFQ+O1xuICBkZWZhdWx0RGF0YT86IFVpbnQ4QXJyYXk7XG4gIE9iamVjdENvbnN0cnVjdG9yPzogQ29uc3RydWN0b3I8VD47XG5cbiAgLy8gZGVuby1saW50LWlnbm9yZSBuby1leHBsaWNpdC1hbnlcbiAgbmV3ICguLi5hcmdzOiBhbnlbXSk6IEluc3RhbmNlO1xuICAvKipcbiAgICogRGVjb2RlcyBhIGdpdmVuIHZpZXcgaW50byBjb3JyZXNwb25kaW5nIEphdmFTY3JpcHQgdmFsdWUuXG4gICAqXG4gICAqIEBwYXJhbSB2aWV3IHRoZSB2aWV3IHRvIGRlY29kZVxuICAgKiBAcGFyYW0gc3RhcnQgdGhlIHN0YXJ0aW5nIG9mZnNldFxuICAgKiBAcGFyYW0gbGVuZ3RoIHRoZSBieXRlIGxlbmd0aCB0byBkZWNvZGVcbiAgICogQHJldHVybiB0aGUgSmF2YVNjcmlwdCB2YWx1ZVxuICAgKi9cbiAgZGVjb2RlKHZpZXc6IERhdGFWaWV3LCBzdGFydD86IG51bWJlciwgbGVuZ3RoPzogbnVtYmVyKTogVDtcbiAgLyoqXG4gICAqIEVuY29kZXMgYSBKYXZhU2NyaXB0IHZhbHVlIGludG8gYSBnaXZlbiB2aWV3LlxuICAgKlxuICAgKiBAcGFyYW0gdmFsdWUgdGhlIHZhbHVlIGVuY29kZVxuICAgKiBAcGFyYW0gdmlldyB0aGUgdmlldyB0byBlbmNvZGUgaW50b1xuICAgKiBAcGFyYW0gc3RhcnQgdGhlIG9mZnNldCB0byBzdGFydCBlbmNvZGluZ1xuICAgKiBAcGFyYW0gbGVuZ3RoIHRoZSBieXRlIGxlbmd0aCB0byBlbmNvZGVcbiAgICogQHJldHVybiB0aGUgYW1vdW50IG9mIHdyaXR0ZW4gYnl0ZXNcbiAgICovXG4gIGVuY29kZSh2YWx1ZTogVCwgdmlldzogRGF0YVZpZXcsIHN0YXJ0PzogbnVtYmVyLCBsZW5ndGg/OiBudW1iZXIpOiBudW1iZXI7XG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgdmlldyBmcm9tIGEgZ2l2ZW4gSmF2YVNjcmlwdCB2YWx1ZS5cbiAgICpcbiAgICogQHBhcmFtIHZhbHVlIHRoZSBKYXZhU2NyaXB0IHZhbHVlXG4gICAqL1xuICBmcm9tKHZhbHVlOiBUKTogSW5zdGFuY2U7XG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBsZW5ndGggb2YgdGhlIHZpZXcuXG4gICAqXG4gICAqIEBwYXJhbSBzaXplIHRoZSBhbW91bnQgb2YgaXRlbXMgZm9yIEFycmF5VmlldyBvciB0aGUgdmFsdWUgZm9yIE1hcFZpZXcgYW5kIFZlY3RvclZpZXdcbiAgICovXG4gIGdldExlbmd0aChzaXplPzogbnVtYmVyIHwgdW5rbm93bik6IG51bWJlcjtcbn1cblxuZXhwb3J0IHR5cGUgVmlld0ZpZWxkTGF5b3V0PFQ+ID0ge1xuICBWaWV3OiBWaWV3Q29uc3RydWN0b3I8VD47XG4gIHN0YXJ0OiBudW1iZXI7XG4gIGxlbmd0aDogbnVtYmVyO1xuICBkZWZhdWx0PzogVDtcbiAgcmVxdWlyZWQ/OiBib29sZWFuO1xufTtcblxuZXhwb3J0IHR5cGUgVmlld0xheW91dDxUPiA9IHtcbiAgW2tleSBpbiBrZXlvZiBUXTogVmlld0ZpZWxkTGF5b3V0PFRba2V5XT47XG59O1xuXG5leHBvcnQgdHlwZSBWaWV3U2NoZW1hUHJpbWl0aXZlVHlwZSA9XG4gIHwgXCJzdHJpbmdcIlxuICB8IFwibnVtYmVyXCJcbiAgfCBcImludGVnZXJcIlxuICB8IFwiYm9vbGVhblwiO1xuXG5leHBvcnQgdHlwZSBWaWV3U2NoZW1hTnVtYmVyVHlwZSA9XG4gIHwgXCJpbnQ4XCJcbiAgfCBcInVpbnQ4XCJcbiAgfCBcImludDE2XCJcbiAgfCBcInVpbnQxNlwiXG4gIHwgXCJpbnQzMlwiXG4gIHwgXCJ1aW50MzJcIlxuICB8IFwiZmxvYXQzMlwiXG4gIHwgXCJmbG9hdDY0XCJcbiAgfCBcImJpZ2ludDY0XCJcbiAgfCBcImJpZ3VpbnQ2NFwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFZpZXdTY2hlbWE8VD4ge1xuICAkaWQ/OiBzdHJpbmc7XG4gICRyZWY/OiBgIyR7c3RyaW5nfWA7XG4gIG1heExlbmd0aD86IG51bWJlcjtcbiAgbWluTGVuZ3RoPzogbnVtYmVyO1xuICBtaW5pbXVtPzogbnVtYmVyO1xuICBtYXhpbXVtPzogbnVtYmVyO1xuICBpdGVtcz86IFQgZXh0ZW5kcyBBcnJheTxpbmZlciBVPiA/IFZpZXdTY2hlbWE8VT4gOiBuZXZlcjtcbiAgbWF4SXRlbXM/OiBudW1iZXI7XG4gIG1pbkl0ZW1zPzogbnVtYmVyO1xuICByZXF1aXJlZD86IEFycmF5PGtleW9mIFQ+O1xuICBwcm9wZXJ0aWVzPzoge1xuICAgIFtQIGluIGtleW9mIFRdOiBWaWV3U2NoZW1hPFRbUF0+O1xuICB9O1xuICB0eXBlOiBbVF0gZXh0ZW5kcyBbbnVtYmVyIHwgYmlnaW50IHwgdW5kZWZpbmVkXSA/IFwibnVtYmVyXCIgfCBcImludGVnZXJcIlxuICAgIDogW1RdIGV4dGVuZHMgW3N0cmluZyB8IEFycmF5QnVmZmVyTGlrZSB8IHVuZGVmaW5lZF0gPyBcInN0cmluZ1wiXG4gICAgOiBbVF0gZXh0ZW5kcyBbYm9vbGVhbiB8IHVuZGVmaW5lZF0gPyBcImJvb2xlYW5cIlxuICAgIDogVCBleHRlbmRzIEFycmF5PHVua25vd24+ID8gXCJhcnJheVwiXG4gICAgOiBUIGV4dGVuZHMgb2JqZWN0ID8gXCJvYmplY3RcIlxuICAgIDogbmV2ZXI7XG4gIGJ0eXBlPzogVCBleHRlbmRzIG51bWJlciA/IFZpZXdTY2hlbWFOdW1iZXJUeXBlXG4gICAgOiBUIGV4dGVuZHMgQXJyYXlCdWZmZXJMaWtlID8gXCJiaW5hcnlcIlxuICAgIDogVCBleHRlbmRzIEFycmF5PHVua25vd24+ID8gXCJ2ZWN0b3JcIlxuICAgIDogVCBleHRlbmRzIG9iamVjdCA/IFwibWFwXCJcbiAgICA6IG5ldmVyO1xuICBkZWZhdWx0PzogVDtcbn1cbiJdfQ== | ||
//# sourceMappingURL=view-types.js.map |
@@ -6,2 +6,3 @@ import type { ComplexView, ContainerView, PrimitiveView, ViewConstructor, ViewFieldLayout, ViewInstance, ViewLayout, ViewSchema } from "./view-types"; | ||
import { MapView } from "./map-view"; | ||
import { DictView } from "./dict-view"; | ||
import { TypedArrayView } from "./typed-array-view"; | ||
@@ -20,2 +21,3 @@ import { Constructor } from "./utility-types"; | ||
static MapClass: typeof MapView; | ||
static DictClass: typeof DictView; | ||
static _maxView: DataView; | ||
@@ -35,2 +37,3 @@ static get maxView(): DataView; | ||
static getObjectView<T extends object>(schema: ViewSchema<T>, constructor?: Constructor<T>): ViewConstructor<T, ComplexView<T>>; | ||
static getDictView<T extends object>(schema: ViewSchema<T>): ViewConstructor<T, ComplexView<T>>; | ||
static getSchemaId(schema: ViewSchema<any>): string; | ||
@@ -37,0 +40,0 @@ static getSchemaOrdering(schema: ViewSchema<unknown>): Array<ViewSchema<object>>; |
43
view.js
@@ -7,2 +7,3 @@ import { BooleanView } from "./boolean-view.js"; | ||
import { MapView } from "./map-view.js"; | ||
import { DictView } from "./dict-view.js"; | ||
import { StringView } from "./string-view.js"; | ||
@@ -30,7 +31,10 @@ import { TypedArrayView } from "./typed-array-view.js"; | ||
? this.getMapView(objectSchema, objectCtor) | ||
: this.getObjectView(objectSchema, objectCtor); | ||
: objectSchema.btype === "dict" | ||
? this.getDictView(objectSchema) | ||
: this.getObjectView(objectSchema, objectCtor); | ||
// cache the view by id | ||
this.Views.set(id, View); | ||
// cache by tag if present | ||
const tag = objectSchema.properties[this.tagName]?.default; | ||
const tag = objectSchema.properties && | ||
objectSchema.properties[this.tagName]?.default; | ||
if (typeof tag === "number") { | ||
@@ -366,2 +370,31 @@ this.TaggedViews.set(tag, View); | ||
} | ||
static getDictView(schema) { | ||
var _a; | ||
const maxView = this.maxView; | ||
const KeyView = this.getExistingView(schema.propertyNames); | ||
const ValueView = this.getExistingView(schema.additionalProperties); | ||
const KeysView = this.getArrayView(KeyView, schema.propertyNames?.maxLength); | ||
const ValuesView = this.getVectorView(ValueView, maxView); | ||
return _a = class extends this.DictClass { | ||
}, | ||
Object.defineProperty(_a, "maxView", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: maxView | ||
}), | ||
Object.defineProperty(_a, "KeysView", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: KeysView | ||
}), | ||
Object.defineProperty(_a, "ValuesView", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: ValuesView | ||
}), | ||
_a; | ||
} | ||
// deno-lint-ignore no-explicit-any | ||
@@ -525,3 +558,9 @@ static getSchemaId(schema) { | ||
}); | ||
Object.defineProperty(View, "DictClass", { | ||
enumerable: true, | ||
configurable: true, | ||
writable: true, | ||
value: DictView | ||
}); | ||
//# sourceMappingURL=view.js.map |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
787436
99
1010
6351