ember-legacy-class-transform
Version:
The default blueprint for ember-cli addons.
206 lines (173 loc) • 16.3 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
function _classCallCheck(instance, Constructor) {
if (!(instance instanceof Constructor)) {
throw new TypeError("Cannot call a class as a function");
}
}
var ListNode = exports.ListNode = function ListNode(value) {
_classCallCheck(this, ListNode);
this.next = null;
this.prev = null;
this.value = value;
};
var LinkedList = exports.LinkedList = function () {
function LinkedList() {
_classCallCheck(this, LinkedList);
this.clear();
}
LinkedList.fromSlice = function fromSlice(slice) {
var list = new LinkedList();
slice.forEachNode(function (n) {
return list.append(n.clone());
});
return list;
};
LinkedList.prototype.head = function head() {
return this._head;
};
LinkedList.prototype.tail = function tail() {
return this._tail;
};
LinkedList.prototype.clear = function clear() {
this._head = this._tail = null;
};
LinkedList.prototype.isEmpty = function isEmpty() {
return this._head === null;
};
LinkedList.prototype.toArray = function toArray() {
var out = [];
this.forEachNode(function (n) {
return out.push(n);
});
return out;
};
LinkedList.prototype.splice = function splice(start, end, reference) {
var before = void 0;
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;
}
};
LinkedList.prototype.nextNode = function nextNode(node) {
return node.next;
};
LinkedList.prototype.prevNode = function prevNode(node) {
return node.prev;
};
LinkedList.prototype.forEachNode = function forEachNode(callback) {
var node = this._head;
while (node !== null) {
callback(node);
node = node.next;
}
};
LinkedList.prototype.contains = function contains(needle) {
var node = this._head;
while (node !== null) {
if (node === needle) return true;
node = node.next;
}
return false;
};
LinkedList.prototype.insertBefore = function insertBefore(node) {
var reference = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 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;
};
LinkedList.prototype.append = function append(node) {
var tail = this._tail;
if (tail) {
tail.next = node;
node.prev = tail;
node.next = null;
} else {
this._head = node;
}
return this._tail = node;
};
LinkedList.prototype.pop = function pop() {
if (this._tail) return this.remove(this._tail);
return null;
};
LinkedList.prototype.prepend = function prepend(node) {
if (this._head) return this.insertBefore(node, this._head);
return this._head = this._tail = node;
};
LinkedList.prototype.remove = function 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;
};
return LinkedList;
}();
var ListSlice = exports.ListSlice = function () {
function ListSlice(head, tail) {
_classCallCheck(this, ListSlice);
this._head = head;
this._tail = tail;
}
ListSlice.toList = function toList(slice) {
var list = new LinkedList();
slice.forEachNode(function (n) {
return list.append(n.clone());
});
return list;
};
ListSlice.prototype.forEachNode = function forEachNode(callback) {
var node = this._head;
while (node !== null) {
callback(node);
node = this.nextNode(node);
}
};
ListSlice.prototype.contains = function contains(needle) {
var node = this._head;
while (node !== null) {
if (node === needle) return true;
node = node.next;
}
return false;
};
ListSlice.prototype.head = function head() {
return this._head;
};
ListSlice.prototype.tail = function tail() {
return this._tail;
};
ListSlice.prototype.toArray = function toArray() {
var out = [];
this.forEachNode(function (n) {
return out.push(n);
});
return out;
};
ListSlice.prototype.nextNode = function nextNode(node) {
if (node === this._tail) return null;
return node.next;
};
ListSlice.prototype.prevNode = function prevNode(node) {
if (node === this._head) return null;
return node.prev;
};
ListSlice.prototype.isEmpty = function isEmpty() {
return false;
};
return ListSlice;
}();
var 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","value","next","prev","LinkedList","clear","fromSlice","slice","list","forEachNode","append","n","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);"]}