UNPKG

ember-legacy-class-transform

Version:
210 lines (207 loc) 22.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.IteratorSynchronizer = exports.ReferenceIterator = exports.IterationArtifacts = exports.ListItem = undefined; var _util = require("@glimmer/util"); class ListItem extends _util.ListNode { constructor(iterable, result) { super(iterable.valueReferenceFor(result)); this.retained = false; this.seen = false; this.key = result.key; this.iterable = iterable; this.memo = iterable.memoReferenceFor(result); } update(item) { this.retained = true; this.iterable.updateValueReference(this.value, item); this.iterable.updateMemoReference(this.memo, item); } shouldRemove() { return !this.retained; } reset() { this.retained = false; this.seen = false; } } exports.ListItem = ListItem; class IterationArtifacts { constructor(iterable) { this.map = (0, _util.dict)(); this.list = new _util.LinkedList(); this.tag = iterable.tag; this.iterable = iterable; } isEmpty() { let iterator = this.iterator = this.iterable.iterate(); return iterator.isEmpty(); } iterate() { let iterator = this.iterator || this.iterable.iterate(); this.iterator = null; return iterator; } has(key) { return !!this.map[key]; } get(key) { return this.map[key]; } wasSeen(key) { let node = this.map[key]; return node && node.seen; } append(item) { let { map, list, iterable } = this; let node = map[item.key] = new ListItem(iterable, item); list.append(node); return node; } insertBefore(item, reference) { let { map, list, iterable } = this; let node = map[item.key] = new ListItem(iterable, item); node.retained = true; list.insertBefore(node, reference); return node; } move(item, reference) { let { list } = this; item.retained = true; list.remove(item); list.insertBefore(item, reference); } remove(item) { let { list } = this; list.remove(item); delete this.map[item.key]; } nextNode(item) { return this.list.nextNode(item); } head() { return this.list.head(); } } exports.IterationArtifacts = IterationArtifacts; class ReferenceIterator { // if anyone needs to construct this object with something other than // an iterable, let @wycats know. constructor(iterable) { this.iterator = null; let artifacts = new IterationArtifacts(iterable); this.artifacts = artifacts; } next() { let { artifacts } = this; let iterator = this.iterator = this.iterator || artifacts.iterate(); let item = iterator.next(); if (!item) return null; return artifacts.append(item); } } exports.ReferenceIterator = ReferenceIterator; var Phase; (function (Phase) { Phase[Phase["Append"] = 0] = "Append"; Phase[Phase["Prune"] = 1] = "Prune"; Phase[Phase["Done"] = 2] = "Done"; })(Phase || (Phase = {})); class IteratorSynchronizer { constructor({ target, artifacts }) { this.target = target; this.artifacts = artifacts; this.iterator = artifacts.iterate(); this.current = artifacts.head(); } sync() { let 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; } } } advanceToKey(key) { let { current, artifacts } = this; let seek = current; while (seek && seek.key !== key) { seek.seen = true; seek = artifacts.nextNode(seek); } this.current = seek && artifacts.nextNode(seek); } nextAppend() { let { iterator, current, artifacts } = this; let item = iterator.next(); if (item === null) { return this.startPrune(); } let { key } = item; if (current && current.key === key) { this.nextRetain(item); } else if (artifacts.has(key)) { this.nextMove(item); } else { this.nextInsert(item); } return Phase.Append; } nextRetain(item) { let { artifacts, current } = this; current = (0, _util.expect)(current, 'BUG: current is empty'); current.update(item); this.current = artifacts.nextNode(current); this.target.retain(item.key, current.value, current.memo); } nextMove(item) { let { current, artifacts, target } = this; let { key } = item; let 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); } } nextInsert(item) { let { artifacts, target, current } = this; let node = artifacts.insertBefore(item, current); target.insert(node.key, node.value, node.memo, current ? current.key : null); } startPrune() { this.current = this.artifacts.head(); return Phase.Prune; } nextPrune() { let { artifacts, target, current } = this; if (current === null) { return Phase.Done; } let node = current; this.current = artifacts.nextNode(node); if (node.shouldRemove()) { artifacts.remove(node); target.delete(node.key); } else { node.reset(); } return Phase.Prune; } nextDone() { this.target.done(); } } exports.IteratorSynchronizer = IteratorSynchronizer; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["lib/iterable.js"],"names":["ListItem","constructor","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}"]}