ember-legacy-class-transform
Version:
The default blueprint for ember-cli addons.
279 lines (228 loc) • 27.3 kB
JavaScript
function _defaults(obj, defaults) { var keys = Object.getOwnPropertyNames(defaults); for (var i = 0; i < keys.length; i++) { var key = keys[i]; var value = Object.getOwnPropertyDescriptor(defaults, key); if (value && value.configurable && obj[key] === undefined) { Object.defineProperty(obj, key, value); } } return obj; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : _defaults(subClass, superClass); }
import { LinkedList, ListNode, dict } from '@glimmer/util';
export var ListItem = function (_ListNode) {
_inherits(ListItem, _ListNode);
function ListItem(iterable, result) {
_classCallCheck(this, ListItem);
var _this = _possibleConstructorReturn(this, _ListNode.call(this, iterable.valueReferenceFor(result)));
_this.retained = false;
_this.seen = false;
_this.key = result.key;
_this.iterable = iterable;
_this.memo = iterable.memoReferenceFor(result);
return _this;
}
ListItem.prototype.update = function update(item) {
this.retained = true;
this.iterable.updateValueReference(this.value, item);
this.iterable.updateMemoReference(this.memo, item);
};
ListItem.prototype.shouldRemove = function shouldRemove() {
return !this.retained;
};
ListItem.prototype.reset = function reset() {
this.retained = false;
this.seen = false;
};
return ListItem;
}(ListNode);
export var IterationArtifacts = function () {
function IterationArtifacts(iterable) {
_classCallCheck(this, IterationArtifacts);
this.map = dict();
this.list = new LinkedList();
this.tag = iterable.tag;
this.iterable = iterable;
}
IterationArtifacts.prototype.isEmpty = function isEmpty() {
var iterator = this.iterator = this.iterable.iterate();
return iterator.isEmpty();
};
IterationArtifacts.prototype.iterate = function iterate() {
var iterator = this.iterator || this.iterable.iterate();
this.iterator = null;
return iterator;
};
IterationArtifacts.prototype.has = function has(key) {
return !!this.map[key];
};
IterationArtifacts.prototype.get = function get(key) {
return this.map[key];
};
IterationArtifacts.prototype.wasSeen = function wasSeen(key) {
var node = this.map[key];
return node && node.seen;
};
IterationArtifacts.prototype.append = function append(item) {
var map = this.map,
list = this.list,
iterable = this.iterable;
var node = map[item.key] = new ListItem(iterable, item);
list.append(node);
return node;
};
IterationArtifacts.prototype.insertBefore = function insertBefore(item, reference) {
var map = this.map,
list = this.list,
iterable = this.iterable;
var node = map[item.key] = new ListItem(iterable, item);
node.retained = true;
list.insertBefore(node, reference);
return node;
};
IterationArtifacts.prototype.move = function move(item, reference) {
var list = this.list;
item.retained = true;
list.remove(item);
list.insertBefore(item, reference);
};
IterationArtifacts.prototype.remove = function remove(item) {
var list = this.list;
list.remove(item);
delete this.map[item.key];
};
IterationArtifacts.prototype.nextNode = function nextNode(item) {
return this.list.nextNode(item);
};
IterationArtifacts.prototype.head = function head() {
return this.list.head();
};
return IterationArtifacts;
}();
export var ReferenceIterator = function () {
// if anyone needs to construct this object with something other than
// an iterable, let @wycats know.
function ReferenceIterator(iterable) {
_classCallCheck(this, ReferenceIterator);
this.iterator = null;
var artifacts = new IterationArtifacts(iterable);
this.artifacts = artifacts;
}
ReferenceIterator.prototype.next = function next() {
var artifacts = this.artifacts;
var iterator = this.iterator = this.iterator || artifacts.iterate();
var item = iterator.next();
if (!item) return null;
return artifacts.append(item);
};
return ReferenceIterator;
}();
var Phase;
(function (Phase) {
Phase[Phase["Append"] = 0] = "Append";
Phase[Phase["Prune"] = 1] = "Prune";
Phase[Phase["Done"] = 2] = "Done";
})(Phase || (Phase = {}));
export var IteratorSynchronizer = function () {
function IteratorSynchronizer(_ref) {
var target = _ref.target,
artifacts = _ref.artifacts;
_classCallCheck(this, IteratorSynchronizer);
this.target = target;
this.artifacts = artifacts;
this.iterator = artifacts.iterate();
this.current = artifacts.head();
}
IteratorSynchronizer.prototype.sync = function sync() {
var phase = Phase.Append;
while (true) {
switch (phase) {
case Phase.Append:
phase = this.nextAppend();
break;
case Phase.Prune:
phase = this.nextPrune();
break;
case Phase.Done:
this.nextDone();
return;
}
}
};
IteratorSynchronizer.prototype.advanceToKey = function advanceToKey(key) {
var current = this.current,
artifacts = this.artifacts;
var seek = current;
while (seek && seek.key !== key) {
seek.seen = true;
seek = artifacts.nextNode(seek);
}
this.current = seek && artifacts.nextNode(seek);
};
IteratorSynchronizer.prototype.nextAppend = function nextAppend() {
var iterator = this.iterator,
current = this.current,
artifacts = this.artifacts;
var item = iterator.next();
if (item === null) {
return this.startPrune();
}
var key = item.key;
if (current && current.key === key) {
this.nextRetain(item);
} else if (artifacts.has(key)) {
this.nextMove(item);
} else {
this.nextInsert(item);
}
return Phase.Append;
};
IteratorSynchronizer.prototype.nextRetain = function nextRetain(item) {
var artifacts = this.artifacts,
current = this.current;
current = current;
current.update(item);
this.current = artifacts.nextNode(current);
this.target.retain(item.key, current.value, current.memo);
};
IteratorSynchronizer.prototype.nextMove = function nextMove(item) {
var current = this.current,
artifacts = this.artifacts,
target = this.target;
var key = item.key;
var found = artifacts.get(item.key);
found.update(item);
if (artifacts.wasSeen(item.key)) {
artifacts.move(found, current);
target.move(found.key, found.value, found.memo, current ? current.key : null);
} else {
this.advanceToKey(key);
}
};
IteratorSynchronizer.prototype.nextInsert = function nextInsert(item) {
var artifacts = this.artifacts,
target = this.target,
current = this.current;
var node = artifacts.insertBefore(item, current);
target.insert(node.key, node.value, node.memo, current ? current.key : null);
};
IteratorSynchronizer.prototype.startPrune = function startPrune() {
this.current = this.artifacts.head();
return Phase.Prune;
};
IteratorSynchronizer.prototype.nextPrune = function nextPrune() {
var artifacts = this.artifacts,
target = this.target,
current = this.current;
if (current === null) {
return Phase.Done;
}
var node = current;
this.current = artifacts.nextNode(node);
if (node.shouldRemove()) {
artifacts.remove(node);
target.delete(node.key);
} else {
node.reset();
}
return Phase.Prune;
};
IteratorSynchronizer.prototype.nextDone = function nextDone() {
this.target.done();
};
return IteratorSynchronizer;
}();
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["lib/iterable.js"],"names":["LinkedList","ListNode","dict","ListItem","iterable","result","valueReferenceFor","retained","seen","key","memo","memoReferenceFor","update","item","updateValueReference","value","updateMemoReference","shouldRemove","reset","IterationArtifacts","map","list","tag","isEmpty","iterator","iterate","has","get","wasSeen","node","append","insertBefore","reference","move","remove","nextNode","head","ReferenceIterator","artifacts","next","Phase","IteratorSynchronizer","target","current","sync","phase","Append","nextAppend","Prune","nextPrune","Done","nextDone","advanceToKey","seek","startPrune","nextRetain","nextMove","nextInsert","retain","found","insert","delete","done"],"mappings":"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","file":"lib/iterable.js","sourcesContent":["import { LinkedList, ListNode, dict, expect } from '@glimmer/util';\nexport class ListItem extends ListNode {\n    constructor(iterable, result) {\n        super(iterable.valueReferenceFor(result));\n        this.retained = false;\n        this.seen = false;\n        this.key = result.key;\n        this.iterable = iterable;\n        this.memo = iterable.memoReferenceFor(result);\n    }\n    update(item) {\n        this.retained = true;\n        this.iterable.updateValueReference(this.value, item);\n        this.iterable.updateMemoReference(this.memo, item);\n    }\n    shouldRemove() {\n        return !this.retained;\n    }\n    reset() {\n        this.retained = false;\n        this.seen = false;\n    }\n}\nexport class IterationArtifacts {\n    constructor(iterable) {\n        this.map = dict();\n        this.list = new LinkedList();\n        this.tag = iterable.tag;\n        this.iterable = iterable;\n    }\n    isEmpty() {\n        let iterator = this.iterator = this.iterable.iterate();\n        return iterator.isEmpty();\n    }\n    iterate() {\n        let iterator = this.iterator || this.iterable.iterate();\n        this.iterator = null;\n        return iterator;\n    }\n    has(key) {\n        return !!this.map[key];\n    }\n    get(key) {\n        return this.map[key];\n    }\n    wasSeen(key) {\n        let node = this.map[key];\n        return node && node.seen;\n    }\n    append(item) {\n        let { map, list, iterable } = this;\n        let node = map[item.key] = new ListItem(iterable, item);\n        list.append(node);\n        return node;\n    }\n    insertBefore(item, reference) {\n        let { map, list, iterable } = this;\n        let node = map[item.key] = new ListItem(iterable, item);\n        node.retained = true;\n        list.insertBefore(node, reference);\n        return node;\n    }\n    move(item, reference) {\n        let { list } = this;\n        item.retained = true;\n        list.remove(item);\n        list.insertBefore(item, reference);\n    }\n    remove(item) {\n        let { list } = this;\n        list.remove(item);\n        delete this.map[item.key];\n    }\n    nextNode(item) {\n        return this.list.nextNode(item);\n    }\n    head() {\n        return this.list.head();\n    }\n}\nexport class ReferenceIterator {\n    // if anyone needs to construct this object with something other than\n    // an iterable, let @wycats know.\n    constructor(iterable) {\n        this.iterator = null;\n        let artifacts = new IterationArtifacts(iterable);\n        this.artifacts = artifacts;\n    }\n    next() {\n        let { artifacts } = this;\n        let iterator = this.iterator = this.iterator || artifacts.iterate();\n        let item = iterator.next();\n        if (!item) return null;\n        return artifacts.append(item);\n    }\n}\nvar Phase;\n(function (Phase) {\n    Phase[Phase[\"Append\"] = 0] = \"Append\";\n    Phase[Phase[\"Prune\"] = 1] = \"Prune\";\n    Phase[Phase[\"Done\"] = 2] = \"Done\";\n})(Phase || (Phase = {}));\nexport class IteratorSynchronizer {\n    constructor({ target, artifacts }) {\n        this.target = target;\n        this.artifacts = artifacts;\n        this.iterator = artifacts.iterate();\n        this.current = artifacts.head();\n    }\n    sync() {\n        let phase = Phase.Append;\n        while (true) {\n            switch (phase) {\n                case Phase.Append:\n                    phase = this.nextAppend();\n                    break;\n                case Phase.Prune:\n                    phase = this.nextPrune();\n                    break;\n                case Phase.Done:\n                    this.nextDone();\n                    return;\n            }\n        }\n    }\n    advanceToKey(key) {\n        let { current, artifacts } = this;\n        let seek = current;\n        while (seek && seek.key !== key) {\n            seek.seen = true;\n            seek = artifacts.nextNode(seek);\n        }\n        this.current = seek && artifacts.nextNode(seek);\n    }\n    nextAppend() {\n        let { iterator, current, artifacts } = this;\n        let item = iterator.next();\n        if (item === null) {\n            return this.startPrune();\n        }\n        let { key } = item;\n        if (current && current.key === key) {\n            this.nextRetain(item);\n        } else if (artifacts.has(key)) {\n            this.nextMove(item);\n        } else {\n            this.nextInsert(item);\n        }\n        return Phase.Append;\n    }\n    nextRetain(item) {\n        let { artifacts, current } = this;\n        current = expect(current, 'BUG: current is empty');\n        current.update(item);\n        this.current = artifacts.nextNode(current);\n        this.target.retain(item.key, current.value, current.memo);\n    }\n    nextMove(item) {\n        let { current, artifacts, target } = this;\n        let { key } = item;\n        let found = artifacts.get(item.key);\n        found.update(item);\n        if (artifacts.wasSeen(item.key)) {\n            artifacts.move(found, current);\n            target.move(found.key, found.value, found.memo, current ? current.key : null);\n        } else {\n            this.advanceToKey(key);\n        }\n    }\n    nextInsert(item) {\n        let { artifacts, target, current } = this;\n        let node = artifacts.insertBefore(item, current);\n        target.insert(node.key, node.value, node.memo, current ? current.key : null);\n    }\n    startPrune() {\n        this.current = this.artifacts.head();\n        return Phase.Prune;\n    }\n    nextPrune() {\n        let { artifacts, target, current } = this;\n        if (current === null) {\n            return Phase.Done;\n        }\n        let node = current;\n        this.current = artifacts.nextNode(node);\n        if (node.shouldRemove()) {\n            artifacts.remove(node);\n            target.delete(node.key);\n        } else {\n            node.reset();\n        }\n        return Phase.Prune;\n    }\n    nextDone() {\n        this.target.done();\n    }\n}"]}