UNPKG

ember-legacy-class-transform

Version:
160 lines (159 loc) 14.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); class ListNode { constructor(value) { this.next = null; this.prev = null; this.value = value; } } exports.ListNode = ListNode; class LinkedList { constructor() { this.clear(); } static fromSlice(slice) { let list = new LinkedList(); slice.forEachNode(n => list.append(n.clone())); return list; } head() { return this._head; } tail() { return this._tail; } clear() { this._head = this._tail = null; } isEmpty() { return this._head === null; } toArray() { let out = []; this.forEachNode(n => out.push(n)); return out; } splice(start, end, reference) { let before; if (reference === null) { before = this._tail; this._tail = end; } else { before = reference.prev; end.next = reference; reference.prev = end; } if (before) { before.next = start; start.prev = before; } } nextNode(node) { return node.next; } prevNode(node) { return node.prev; } forEachNode(callback) { let node = this._head; while (node !== null) { callback(node); node = node.next; } } contains(needle) { let node = this._head; while (node !== null) { if (node === needle) return true; node = node.next; } return false; } insertBefore(node, reference = null) { if (reference === null) return this.append(node); if (reference.prev) reference.prev.next = node;else this._head = node; node.prev = reference.prev; node.next = reference; reference.prev = node; return node; } append(node) { let tail = this._tail; if (tail) { tail.next = node; node.prev = tail; node.next = null; } else { this._head = node; } return this._tail = node; } pop() { if (this._tail) return this.remove(this._tail); return null; } prepend(node) { if (this._head) return this.insertBefore(node, this._head); return this._head = this._tail = node; } remove(node) { if (node.prev) node.prev.next = node.next;else this._head = node.next; if (node.next) node.next.prev = node.prev;else this._tail = node.prev; return node; } } exports.LinkedList = LinkedList; class ListSlice { constructor(head, tail) { this._head = head; this._tail = tail; } static toList(slice) { let list = new LinkedList(); slice.forEachNode(n => list.append(n.clone())); return list; } forEachNode(callback) { let node = this._head; while (node !== null) { callback(node); node = this.nextNode(node); } } contains(needle) { let node = this._head; while (node !== null) { if (node === needle) return true; node = node.next; } return false; } head() { return this._head; } tail() { return this._tail; } toArray() { let out = []; this.forEachNode(n => out.push(n)); return out; } nextNode(node) { if (node === this._tail) return null; return node.next; } prevNode(node) { if (node === this._head) return null; return node.prev; } isEmpty() { return false; } } exports.ListSlice = ListSlice; const EMPTY_SLICE = exports.EMPTY_SLICE = new ListSlice(null, null); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["lib/list-utils.js"],"names":["ListNode","constructor","value","next","prev","LinkedList","clear","fromSlice","slice","list","forEachNode","n","append","clone","head","_head","tail","_tail","isEmpty","toArray","out","push","splice","start","end","reference","before","nextNode","node","prevNode","callback","contains","needle","insertBefore","pop","remove","prepend","ListSlice","toList","EMPTY_SLICE"],"mappings":"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","file":"lib/list-utils.js","sourcesContent":["export class ListNode {\n    constructor(value) {\n        this.next = null;\n        this.prev = null;\n        this.value = value;\n    }\n}\nexport class LinkedList {\n    constructor() {\n        this.clear();\n    }\n    static fromSlice(slice) {\n        let list = new LinkedList();\n        slice.forEachNode(n => list.append(n.clone()));\n        return list;\n    }\n    head() {\n        return this._head;\n    }\n    tail() {\n        return this._tail;\n    }\n    clear() {\n        this._head = this._tail = null;\n    }\n    isEmpty() {\n        return this._head === null;\n    }\n    toArray() {\n        let out = [];\n        this.forEachNode(n => out.push(n));\n        return out;\n    }\n    splice(start, end, reference) {\n        let before;\n        if (reference === null) {\n            before = this._tail;\n            this._tail = end;\n        } else {\n            before = reference.prev;\n            end.next = reference;\n            reference.prev = end;\n        }\n        if (before) {\n            before.next = start;\n            start.prev = before;\n        }\n    }\n    nextNode(node) {\n        return node.next;\n    }\n    prevNode(node) {\n        return node.prev;\n    }\n    forEachNode(callback) {\n        let node = this._head;\n        while (node !== null) {\n            callback(node);\n            node = node.next;\n        }\n    }\n    contains(needle) {\n        let node = this._head;\n        while (node !== null) {\n            if (node === needle) return true;\n            node = node.next;\n        }\n        return false;\n    }\n    insertBefore(node, reference = null) {\n        if (reference === null) return this.append(node);\n        if (reference.prev) reference.prev.next = node;else this._head = node;\n        node.prev = reference.prev;\n        node.next = reference;\n        reference.prev = node;\n        return node;\n    }\n    append(node) {\n        let tail = this._tail;\n        if (tail) {\n            tail.next = node;\n            node.prev = tail;\n            node.next = null;\n        } else {\n            this._head = node;\n        }\n        return this._tail = node;\n    }\n    pop() {\n        if (this._tail) return this.remove(this._tail);\n        return null;\n    }\n    prepend(node) {\n        if (this._head) return this.insertBefore(node, this._head);\n        return this._head = this._tail = node;\n    }\n    remove(node) {\n        if (node.prev) node.prev.next = node.next;else this._head = node.next;\n        if (node.next) node.next.prev = node.prev;else this._tail = node.prev;\n        return node;\n    }\n}\nexport class ListSlice {\n    constructor(head, tail) {\n        this._head = head;\n        this._tail = tail;\n    }\n    static toList(slice) {\n        let list = new LinkedList();\n        slice.forEachNode(n => list.append(n.clone()));\n        return list;\n    }\n    forEachNode(callback) {\n        let node = this._head;\n        while (node !== null) {\n            callback(node);\n            node = this.nextNode(node);\n        }\n    }\n    contains(needle) {\n        let node = this._head;\n        while (node !== null) {\n            if (node === needle) return true;\n            node = node.next;\n        }\n        return false;\n    }\n    head() {\n        return this._head;\n    }\n    tail() {\n        return this._tail;\n    }\n    toArray() {\n        let out = [];\n        this.forEachNode(n => out.push(n));\n        return out;\n    }\n    nextNode(node) {\n        if (node === this._tail) return null;\n        return node.next;\n    }\n    prevNode(node) {\n        if (node === this._head) return null;\n        return node.prev;\n    }\n    isEmpty() {\n        return false;\n    }\n}\nexport const EMPTY_SLICE = new ListSlice(null, null);"]}