ember-legacy-class-transform
Version:
The default blueprint for ember-cli addons.
305 lines (251 loc) • 26.6 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.IteratorSynchronizer = exports.ReferenceIterator = exports.IterationArtifacts = exports.ListItem = undefined;
var _util = require("@glimmer/util");
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);
}
var ListItem = exports.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;
}(_util.ListNode);
var IterationArtifacts = exports.IterationArtifacts = function () {
function IterationArtifacts(iterable) {
_classCallCheck(this, IterationArtifacts);
this.map = (0, _util.dict)();
this.list = new _util.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;
}();
var ReferenceIterator = exports.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 = {}));
var IteratorSynchronizer = exports.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}"]}