Tracking de l'application VApp (IHM du jeu)
This commit is contained in:
29
VApp/node_modules/js-sdsl/dist/cjs/container/HashContainer/Base/index.d.ts
generated
vendored
Normal file
29
VApp/node_modules/js-sdsl/dist/cjs/container/HashContainer/Base/index.d.ts
generated
vendored
Normal file
@ -0,0 +1,29 @@
|
||||
import { Container, ContainerIterator } from "../../ContainerBase";
|
||||
export declare type HashLinkNode<K, V> = {
|
||||
_key: K;
|
||||
_value: V;
|
||||
_pre: HashLinkNode<K, V>;
|
||||
_next: HashLinkNode<K, V>;
|
||||
};
|
||||
export declare abstract class HashContainerIterator<K, V> extends ContainerIterator<K | [K, V]> {
|
||||
abstract readonly container: HashContainer<K, V>;
|
||||
pre(): this;
|
||||
next(): this;
|
||||
}
|
||||
export declare abstract class HashContainer<K, V> extends Container<K | [K, V]> {
|
||||
/**
|
||||
* @description Unique symbol used to tag object.
|
||||
*/
|
||||
readonly HASH_TAG: symbol;
|
||||
clear(): void;
|
||||
/**
|
||||
* @description Remove the element of the specified key.
|
||||
* @param key - The key you want to remove.
|
||||
* @param isObject - Tell us if the type of inserted key is `object` to improve efficiency.<br/>
|
||||
* If a `undefined` value is passed in, the type will be automatically judged.
|
||||
* @returns Whether erase successfully.
|
||||
*/
|
||||
eraseElementByKey(key: K, isObject?: boolean): boolean;
|
||||
eraseElementByIterator(iter: HashContainerIterator<K, V>): HashContainerIterator<K, V>;
|
||||
eraseElementByPos(pos: number): number;
|
||||
}
|
188
VApp/node_modules/js-sdsl/dist/cjs/container/HashContainer/Base/index.js
generated
vendored
Normal file
188
VApp/node_modules/js-sdsl/dist/cjs/container/HashContainer/Base/index.js
generated
vendored
Normal file
@ -0,0 +1,188 @@
|
||||
"use strict";
|
||||
|
||||
Object.defineProperty(exports, "t", {
|
||||
value: true
|
||||
});
|
||||
|
||||
exports.HashContainerIterator = exports.HashContainer = void 0;
|
||||
|
||||
var _ContainerBase = require("../../ContainerBase");
|
||||
|
||||
var _checkObject = _interopRequireDefault(require("../../../utils/checkObject"));
|
||||
|
||||
var _throwError = require("../../../utils/throwError");
|
||||
|
||||
function _interopRequireDefault(t) {
|
||||
return t && t.t ? t : {
|
||||
default: t
|
||||
};
|
||||
}
|
||||
|
||||
class HashContainerIterator extends _ContainerBase.ContainerIterator {
|
||||
constructor(t, e, i) {
|
||||
super(i);
|
||||
this.o = t;
|
||||
this.h = e;
|
||||
if (this.iteratorType === 0) {
|
||||
this.pre = function() {
|
||||
if (this.o.L === this.h) {
|
||||
(0, _throwError.throwIteratorAccessError)();
|
||||
}
|
||||
this.o = this.o.L;
|
||||
return this;
|
||||
};
|
||||
this.next = function() {
|
||||
if (this.o === this.h) {
|
||||
(0, _throwError.throwIteratorAccessError)();
|
||||
}
|
||||
this.o = this.o.B;
|
||||
return this;
|
||||
};
|
||||
} else {
|
||||
this.pre = function() {
|
||||
if (this.o.B === this.h) {
|
||||
(0, _throwError.throwIteratorAccessError)();
|
||||
}
|
||||
this.o = this.o.B;
|
||||
return this;
|
||||
};
|
||||
this.next = function() {
|
||||
if (this.o === this.h) {
|
||||
(0, _throwError.throwIteratorAccessError)();
|
||||
}
|
||||
this.o = this.o.L;
|
||||
return this;
|
||||
};
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
exports.HashContainerIterator = HashContainerIterator;
|
||||
|
||||
class HashContainer extends _ContainerBase.Container {
|
||||
constructor() {
|
||||
super();
|
||||
this.H = [];
|
||||
this.g = {};
|
||||
this.HASH_TAG = Symbol("@@HASH_TAG");
|
||||
Object.setPrototypeOf(this.g, null);
|
||||
this.h = {};
|
||||
this.h.L = this.h.B = this.p = this._ = this.h;
|
||||
}
|
||||
V(t) {
|
||||
const {L: e, B: i} = t;
|
||||
e.B = i;
|
||||
i.L = e;
|
||||
if (t === this.p) {
|
||||
this.p = i;
|
||||
}
|
||||
if (t === this._) {
|
||||
this._ = e;
|
||||
}
|
||||
this.i -= 1;
|
||||
}
|
||||
M(t, e, i) {
|
||||
if (i === undefined) i = (0, _checkObject.default)(t);
|
||||
let s;
|
||||
if (i) {
|
||||
const i = t[this.HASH_TAG];
|
||||
if (i !== undefined) {
|
||||
this.H[i].l = e;
|
||||
return this.i;
|
||||
}
|
||||
Object.defineProperty(t, this.HASH_TAG, {
|
||||
value: this.H.length,
|
||||
configurable: true
|
||||
});
|
||||
s = {
|
||||
u: t,
|
||||
l: e,
|
||||
L: this._,
|
||||
B: this.h
|
||||
};
|
||||
this.H.push(s);
|
||||
} else {
|
||||
const i = this.g[t];
|
||||
if (i) {
|
||||
i.l = e;
|
||||
return this.i;
|
||||
}
|
||||
s = {
|
||||
u: t,
|
||||
l: e,
|
||||
L: this._,
|
||||
B: this.h
|
||||
};
|
||||
this.g[t] = s;
|
||||
}
|
||||
if (this.i === 0) {
|
||||
this.p = s;
|
||||
this.h.B = s;
|
||||
} else {
|
||||
this._.B = s;
|
||||
}
|
||||
this._ = s;
|
||||
this.h.L = s;
|
||||
return ++this.i;
|
||||
}
|
||||
I(t, e) {
|
||||
if (e === undefined) e = (0, _checkObject.default)(t);
|
||||
if (e) {
|
||||
const e = t[this.HASH_TAG];
|
||||
if (e === undefined) return this.h;
|
||||
return this.H[e];
|
||||
} else {
|
||||
return this.g[t] || this.h;
|
||||
}
|
||||
}
|
||||
clear() {
|
||||
const t = this.HASH_TAG;
|
||||
this.H.forEach((function(e) {
|
||||
delete e.u[t];
|
||||
}));
|
||||
this.H = [];
|
||||
this.g = {};
|
||||
Object.setPrototypeOf(this.g, null);
|
||||
this.i = 0;
|
||||
this.p = this._ = this.h.L = this.h.B = this.h;
|
||||
}
|
||||
eraseElementByKey(t, e) {
|
||||
let i;
|
||||
if (e === undefined) e = (0, _checkObject.default)(t);
|
||||
if (e) {
|
||||
const e = t[this.HASH_TAG];
|
||||
if (e === undefined) return false;
|
||||
delete t[this.HASH_TAG];
|
||||
i = this.H[e];
|
||||
delete this.H[e];
|
||||
} else {
|
||||
i = this.g[t];
|
||||
if (i === undefined) return false;
|
||||
delete this.g[t];
|
||||
}
|
||||
this.V(i);
|
||||
return true;
|
||||
}
|
||||
eraseElementByIterator(t) {
|
||||
const e = t.o;
|
||||
if (e === this.h) {
|
||||
(0, _throwError.throwIteratorAccessError)();
|
||||
}
|
||||
this.V(e);
|
||||
return t.next();
|
||||
}
|
||||
eraseElementByPos(t) {
|
||||
if (t < 0 || t > this.i - 1) {
|
||||
throw new RangeError;
|
||||
}
|
||||
let e = this.p;
|
||||
while (t--) {
|
||||
e = e.B;
|
||||
}
|
||||
this.V(e);
|
||||
return this.i;
|
||||
}
|
||||
}
|
||||
|
||||
exports.HashContainer = HashContainer;
|
||||
//# sourceMappingURL=index.js.map
|
1
VApp/node_modules/js-sdsl/dist/cjs/container/HashContainer/Base/index.js.map
generated
vendored
Normal file
1
VApp/node_modules/js-sdsl/dist/cjs/container/HashContainer/Base/index.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
Reference in New Issue
Block a user