New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

tag-tree

Package Overview
Dependencies
Maintainers
1
Versions
12
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

tag-tree - npm Package Compare versions

Comparing version 0.4.1 to 1.0.0

.circleci/config.yml

24

js/index.js

@@ -1,26 +0,24 @@

'use strict';
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
var _TagTree = require('./TagTree');
Object.defineProperty(exports, 'TagTree', {
Object.defineProperty(exports, "TagTree", {
enumerable: true,
get: function get() {
return _interopRequireDefault(_TagTree).default;
return _TagTree.default;
}
});
var _TagTreeNode = require('./TagTreeNode');
Object.defineProperty(exports, 'TagTreeNode', {
Object.defineProperty(exports, "TagTreeNode", {
enumerable: true,
get: function get() {
return _interopRequireDefault(_TagTreeNode).default;
return _TagTreeNode.default;
}
});
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6WyJkZWZhdWx0Il0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs0Q0FFUUEsTzs7Ozs7Ozs7O2dEQUdBQSxPIiwiZmlsZSI6ImluZGV4LmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogQGZsb3cgKi9cblxuZXhwb3J0IHtkZWZhdWx0IGFzIFRhZ1RyZWV9IGZyb20gJy4vVGFnVHJlZSc7XG5leHBvcnQgdHlwZSB7VGFnVHJlZUNvbnRyb2xsZXJ9IGZyb20gJy4vVGFnVHJlZSc7XG5cbmV4cG9ydCB7ZGVmYXVsdCBhcyBUYWdUcmVlTm9kZX0gZnJvbSAnLi9UYWdUcmVlTm9kZSc7XG5leHBvcnQgdHlwZSB7VGFnVHJlZU5vZGVDb250cm9sbGVyfSBmcm9tICcuL1RhZ1RyZWVOb2RlJztcbiJdfQ==
var _TagTree = _interopRequireDefault(require("./TagTree"));
var _TagTreeNode = _interopRequireDefault(require("./TagTreeNode"));
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVBOztBQUdBIiwic291cmNlc0NvbnRlbnQiOlsiLyogQGZsb3cgKi9cblxuZXhwb3J0IHtkZWZhdWx0IGFzIFRhZ1RyZWV9IGZyb20gJy4vVGFnVHJlZSc7XG5leHBvcnQgdHlwZSB7VGFnVHJlZUluaXQsIFRhZ1RyZWVDb250cm9sbGVyfSBmcm9tICcuL1RhZ1RyZWUnO1xuXG5leHBvcnQge2RlZmF1bHQgYXMgVGFnVHJlZU5vZGV9IGZyb20gJy4vVGFnVHJlZU5vZGUnO1xuIl19

@@ -1,63 +0,44 @@

'use strict';
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _map = require('babel-runtime/core-js/map');
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _map2 = _interopRequireDefault(_map);
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _set = require('babel-runtime/core-js/set');
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _set2 = _interopRequireDefault(_set);
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of');
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf);
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _liveSet = _interopRequireDefault(require("live-set"));
var _createClass2 = require('babel-runtime/helpers/createClass');
var _TagTreeNode2 = _interopRequireDefault(require("./TagTreeNode"));
var _createClass3 = _interopRequireDefault(_createClass2);
var EMPTY_ARRAY = Object.freeze([]);
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
var TagTree =
/*#__PURE__*/
function (_TagTreeNode) {
(0, _inherits2.default)(TagTree, _TagTreeNode);
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
var _inherits2 = require('babel-runtime/helpers/inherits');
var _inherits3 = _interopRequireDefault(_inherits2);
var _freeze = require('babel-runtime/core-js/object/freeze');
var _freeze2 = _interopRequireDefault(_freeze);
var _liveSet = require('live-set');
var _liveSet2 = _interopRequireDefault(_liveSet);
var _TagTreeNode2 = require('./TagTreeNode');
var _TagTreeNode3 = _interopRequireDefault(_TagTreeNode2);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var EMPTY_ARRAY = (0, _freeze2.default)([]);
var TagTree = function (_TagTreeNode) {
(0, _inherits3.default)(TagTree, _TagTreeNode);
function TagTree(init) {
(0, _classCallCheck3.default)(this, TagTree);
var _this;
var rootNodeController = void 0;
var _this = (0, _possibleConstructorReturn3.default)(this, (TagTree.__proto__ || (0, _getPrototypeOf2.default)(TagTree)).call(this, {
(0, _classCallCheck2.default)(this, TagTree);
var rootNodeController;
_this = (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(TagTree).call(this, {
value: init.root,
parent: null,
ownedTags: new _set2.default(init.tags.map(function (_ref) {
ownedTags: new Set(init.tags.map(function (_ref) {
var tag = _ref.tag;

@@ -70,15 +51,15 @@ return tag;

}));
_this._nodeControllers = new _map2.default();
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_nodeControllers", new Map());
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_lookupTable", void 0);
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_allByTag", void 0);
if (!rootNodeController) throw new Error();
_this._nodeControllers.set(_this, rootNodeController);
_this._lookupTable = new _map2.default([[init.root, [_this]]]);
_this._nodeControllers.set((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), rootNodeController);
_this._allByTag = new _map2.default();
_this._lookupTable = new Map([[init.root, [(0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this))]]]);
_this._allByTag = new Map();
init.tags.forEach(function (_ref2) {
var tag = _ref2.tag;
var _LiveSet$active = _liveSet2.default.active(),
var _LiveSet$active = _liveSet.default.active(),
liveSet = _LiveSet$active.liveSet,

@@ -88,25 +69,28 @@ controller = _LiveSet$active.controller;

if (_this._allByTag.has(tag)) throw new Error('Tag specified twice: ' + tag);
_this._allByTag.set(tag, { ownedTags: new _set2.default(), liveSet: liveSet, controller: controller });
_this._allByTag.set(tag, {
ownedTags: new Set(),
liveSet: liveSet,
controller: controller
});
});
init.tags.forEach(function (_ref3) {
var tag = _ref3.tag,
ownedBy = _ref3.ownedBy;
if (!ownedBy) return;
ownedBy.forEach(function (owningTag) {
var entry = _this._allByTag.get(owningTag);
if (!entry) throw new Error('unknown ownedBy value for ' + tag + ': ' + owningTag);
if (!entry) throw new Error("unknown ownedBy value for ".concat(tag, ": ").concat(owningTag));
entry.ownedTags.add(tag);
});
});
var controller = {
tree: _this,
tree: (0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)),
addTaggedValue: function addTaggedValue(parent, tag, value) {
var tagEntry = _this._allByTag.get(tag);
if (!tagEntry) throw new Error('unknown tag: ' + tag);
var controller = void 0;
var node = new _TagTreeNode3.default({
if (!tagEntry) throw new Error("unknown tag: ".concat(tag));
var controller;
var node = new _TagTreeNode2.default({
value: value,

@@ -120,2 +104,3 @@ parent: parent,

if (!controller) throw new Error();
_this._nodeControllers.set(node, controller);

@@ -126,2 +111,3 @@

var valueNodes = _this._lookupTable.get(value);
if (valueNodes) {

@@ -134,5 +120,5 @@ valueNodes.push(node);

var parentController = _this._nodeControllers.get(parent);
if (!parentController) throw new Error('parent is not part of TagTree');
parentController.addOwnedNode(tag, node);
return node;

@@ -142,10 +128,14 @@ },

var tagEntry = _this._allByTag.get(tag);
if (!tagEntry) throw new Error('unknown tag: ' + tag);
if (!tagEntry) throw new Error("unknown tag: ".concat(tag));
var parentController = _this._nodeControllers.get(parent);
if (!parentController) throw new Error('parent is not part of TagTree');
var value = node.getValue();
var value = node.getValue();
var nodes = _this._lookupTable.get(value);
if (!nodes) throw new Error('node was missing from lookup table before removal');
if (nodes.length > 1) {

@@ -164,5 +154,5 @@ var ix = nodes.indexOf(node);

});
tagEntry.controller.remove(node);
parentController.removeOwnedNode(tag, node);
_this._nodeControllers.delete(node);

@@ -174,5 +164,5 @@ },

});
_this._allByTag.forEach(function (_ref4) {
var controller = _ref4.controller;
controller.end();

@@ -183,28 +173,34 @@ });

init.executor(controller);
init.executor = function () {}; // release reference
return _this;
}
(0, _createClass3.default)(TagTree, [{
key: 'getNodesForValue',
(0, _createClass2.default)(TagTree, [{
key: "getNodesForValue",
value: function getNodesForValue(value) {
var l = this._lookupTable.get(value);
return l ? (0, _freeze2.default)(l.slice()) : EMPTY_ARRAY;
return l ? Object.freeze(l.slice()) : EMPTY_ARRAY;
}
}, {
key: 'getAllByTag',
key: "getAllByTag",
value: function getAllByTag(tag) {
var entry = this._allByTag.get(tag);
if (!entry) throw new Error('tag does not exist in TagTree: ' + tag);
if (!entry) throw new Error("tag does not exist in TagTree: ".concat(tag));
return entry.liveSet;
}
}, {
key: 'getAll',
key: "getAll",
value: function getAll() {
var m = new _map2.default();
var m = new Map();
this._allByTag.forEach(function (_ref5, tag) {
var liveSet = _ref5.liveSet;
m.set(tag, liveSet);
});
return m;

@@ -214,6 +210,7 @@ }

return TagTree;
}(_TagTreeNode3.default);
}(_TagTreeNode2.default);
exports.default = TagTree;
module.exports = exports['default'];
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/TagTree.js"],"names":["EMPTY_ARRAY","TagTree","init","rootNodeController","value","root","parent","ownedTags","tags","map","tag","executor","controller","_nodeControllers","Error","set","_lookupTable","_allByTag","forEach","active","liveSet","has","ownedBy","entry","get","owningTag","add","tree","addTaggedValue","tagEntry","node","_controller","valueNodes","push","parentController","addOwnedNode","removeTaggedNode","getValue","nodes","length","ix","indexOf","splice","delete","getOwned","values","childNode","remove","removeOwnedNode","end","l","slice","m"],"mappings":"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","file":"TagTree.js","sourcesContent":["/* @flow */\n\nimport LiveSet from 'live-set';\nimport type {LiveSetController} from 'live-set';\n\nimport TagTreeNode from './TagTreeNode';\nimport type {TagTreeNodeController} from './TagTreeNode';\n\nexport type TagTreeController<T> = {\n  tree: TagTree<T>;\n  addTaggedValue(parent: TagTreeNode<T>, tag: string, value: T): TagTreeNode<T>;\n  removeTaggedNode(parent: TagTreeNode<T>, tag: string, node: TagTreeNode<T>): void;\n  end(): void;\n};\n\nexport type TagTreeInit<T> = {|\n  root: T;\n  tags: Array<{| tag: string, ownedBy?: ?Array<string> |}>;\n  executor: (controller: TagTreeController<T>) => void;\n|};\n\nconst EMPTY_ARRAY: any[] = Object.freeze([]);\n\nexport default class TagTree<T> extends TagTreeNode<T> {\n  _nodeControllers: Map<TagTreeNode<T>, TagTreeNodeController<T>> = new Map();\n  _lookupTable: Map<T, Array<TagTreeNode<T>>>;\n  _allByTag: Map<string, {\n    ownedTags: Set<string>;\n    liveSet: LiveSet<TagTreeNode<T>>;\n    controller: LiveSetController<TagTreeNode<T>>;\n  }>;\n\n  constructor(init: TagTreeInit<T>) {\n    let rootNodeController;\n    super({\n      value: init.root,\n      parent: null,\n      ownedTags: new Set(init.tags.map(({tag}) => tag)),\n      executor: (controller) => {\n        rootNodeController = controller;\n      }\n    });\n    if (!rootNodeController) throw new Error();\n    this._nodeControllers.set(this, rootNodeController);\n\n    this._lookupTable = new Map([[init.root, [this]]]);\n\n    this._allByTag = new Map();\n    init.tags.forEach(({tag}) => {\n      const {liveSet, controller} = LiveSet.active();\n      if (this._allByTag.has(tag)) throw new Error('Tag specified twice: '+tag);\n      this._allByTag.set(tag, {ownedTags: new Set(), liveSet, controller});\n    });\n\n    init.tags.forEach(({tag, ownedBy}) => {\n      if (!ownedBy) return;\n      ownedBy.forEach(owningTag => {\n        const entry = this._allByTag.get(owningTag);\n        if (!entry) throw new Error(`unknown ownedBy value for ${tag}: ${owningTag}`);\n        entry.ownedTags.add(tag);\n      });\n    });\n\n    const controller = {\n      tree: this,\n      addTaggedValue: (parent, tag, value) => {\n        const tagEntry = this._allByTag.get(tag);\n        if (!tagEntry) throw new Error(`unknown tag: ${tag}`);\n\n        let controller;\n        const node = new TagTreeNode({\n          value,\n          parent,\n          ownedTags: tagEntry.ownedTags,\n          executor: (_controller) => {\n            controller = _controller;\n          }\n        });\n        if (!controller) throw new Error();\n        this._nodeControllers.set(node, controller);\n\n        tagEntry.controller.add(node);\n\n        const valueNodes = this._lookupTable.get(value);\n        if (valueNodes) {\n          valueNodes.push(node);\n        } else {\n          this._lookupTable.set(value, [node]);\n        }\n\n        const parentController = this._nodeControllers.get(parent);\n        if (!parentController) throw new Error('parent is not part of TagTree');\n        parentController.addOwnedNode(tag, node);\n\n        return node;\n      },\n      removeTaggedNode: (parent, tag, node) => {\n        const tagEntry = this._allByTag.get(tag);\n        if (!tagEntry) throw new Error(`unknown tag: ${tag}`);\n\n        const parentController = this._nodeControllers.get(parent);\n        if (!parentController) throw new Error('parent is not part of TagTree');\n\n        const value = node.getValue();\n        const nodes = this._lookupTable.get(value);\n        if (!nodes) throw new Error('node was missing from lookup table before removal');\n        if (nodes.length > 1) {\n          const ix = nodes.indexOf(node);\n          if (ix < 0) throw new Error('node was missing from list in lookup table before removal');\n          nodes.splice(ix, 1);\n        } else {\n          this._lookupTable.delete(value);\n        }\n\n        node.getOwned().forEach((liveSet, tag) => {\n          liveSet.values().forEach(childNode => {\n            controller.removeTaggedNode(node, tag, childNode);\n          });\n        });\n\n        tagEntry.controller.remove(node);\n        parentController.removeOwnedNode(tag, node);\n        this._nodeControllers.delete(node);\n      },\n      end: () => {\n        this._nodeControllers.forEach(controller => {\n          controller.end();\n        });\n        this._allByTag.forEach(({controller}) => {\n          controller.end();\n        });\n      }\n    };\n    init.executor(controller);\n    init.executor = () => {}; // release reference\n  }\n\n  getNodesForValue(value: T): Array<TagTreeNode<T>> {\n    const l = this._lookupTable.get(value);\n    return l ? Object.freeze(l.slice()) : EMPTY_ARRAY;\n  }\n\n  getAllByTag(tag: string): LiveSet<TagTreeNode<T>> {\n    const entry = this._allByTag.get(tag);\n    if (!entry) throw new Error(`tag does not exist in TagTree: ${tag}`);\n    return entry.liveSet;\n  }\n\n  getAll(): Map<string, LiveSet<TagTreeNode<T>>> {\n    const m = new Map();\n    this._allByTag.forEach(({liveSet}, tag) => {\n      m.set(tag, liveSet);\n    });\n    return m;\n  }\n}\n"]}
module.exports = exports.default;
module.exports.default = exports.default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/TagTree.js"],"names":["EMPTY_ARRAY","Object","freeze","TagTree","init","rootNodeController","value","root","parent","ownedTags","Set","tags","map","tag","executor","controller","Map","Error","_nodeControllers","set","_lookupTable","_allByTag","forEach","LiveSet","active","liveSet","has","ownedBy","owningTag","entry","get","add","tree","addTaggedValue","tagEntry","node","TagTreeNode","_controller","valueNodes","push","parentController","addOwnedNode","removeTaggedNode","getValue","nodes","length","ix","indexOf","splice","delete","getOwned","values","childNode","remove","removeOwnedNode","end","l","slice","m"],"mappings":"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","sourcesContent":["/* @flow */\n\nimport LiveSet from 'live-set';\nimport type {LiveSetController} from 'live-set';\n\nimport TagTreeNode from './TagTreeNode';\nimport type {TagTreeNodeController} from './TagTreeNode';\n\nexport type TagTreeController<T> = {\n  tree: TagTree<T>;\n  addTaggedValue(parent: TagTreeNode<T>, tag: string, value: T): TagTreeNode<T>;\n  removeTaggedNode(parent: TagTreeNode<T>, tag: string, node: TagTreeNode<T>): void;\n  end(): void;\n};\n\nexport type TagTreeInit<T> = {|\n  root: T;\n  tags: $ReadOnlyArray<{| tag: string, ownedBy?: ?$ReadOnlyArray<string> |}>;\n  executor: (controller: TagTreeController<T>) => void;\n|};\n\nconst EMPTY_ARRAY: any[] = Object.freeze([]);\n\nexport default class TagTree<T> extends TagTreeNode<T> {\n  _nodeControllers: Map<TagTreeNode<T>, TagTreeNodeController<T>> = new Map();\n  _lookupTable: Map<T, Array<TagTreeNode<T>>>;\n  _allByTag: Map<string, {\n    ownedTags: Set<string>;\n    liveSet: LiveSet<TagTreeNode<T>>;\n    controller: LiveSetController<TagTreeNode<T>>;\n  }>;\n\n  constructor(init: TagTreeInit<T>) {\n    let rootNodeController;\n    super({\n      value: init.root,\n      parent: null,\n      ownedTags: new Set(init.tags.map(({tag}) => tag)),\n      executor: (controller) => {\n        rootNodeController = controller;\n      }\n    });\n    if (!rootNodeController) throw new Error();\n    this._nodeControllers.set(this, rootNodeController);\n\n    this._lookupTable = new Map([[init.root, [this]]]);\n\n    this._allByTag = new Map();\n    init.tags.forEach(({tag}) => {\n      const {liveSet, controller} = LiveSet.active();\n      if (this._allByTag.has(tag)) throw new Error('Tag specified twice: '+tag);\n      this._allByTag.set(tag, {ownedTags: new Set(), liveSet, controller});\n    });\n\n    init.tags.forEach(({tag, ownedBy}) => {\n      if (!ownedBy) return;\n      ownedBy.forEach(owningTag => {\n        const entry = this._allByTag.get(owningTag);\n        if (!entry) throw new Error(`unknown ownedBy value for ${tag}: ${owningTag}`);\n        entry.ownedTags.add(tag);\n      });\n    });\n\n    const controller = {\n      tree: this,\n      addTaggedValue: (parent, tag, value) => {\n        const tagEntry = this._allByTag.get(tag);\n        if (!tagEntry) throw new Error(`unknown tag: ${tag}`);\n\n        let controller;\n        const node = new TagTreeNode({\n          value,\n          parent,\n          ownedTags: tagEntry.ownedTags,\n          executor: (_controller) => {\n            controller = _controller;\n          }\n        });\n        if (!controller) throw new Error();\n        this._nodeControllers.set(node, controller);\n\n        tagEntry.controller.add(node);\n\n        const valueNodes = this._lookupTable.get(value);\n        if (valueNodes) {\n          valueNodes.push(node);\n        } else {\n          this._lookupTable.set(value, [node]);\n        }\n\n        const parentController = this._nodeControllers.get(parent);\n        if (!parentController) throw new Error('parent is not part of TagTree');\n        parentController.addOwnedNode(tag, node);\n\n        return node;\n      },\n      removeTaggedNode: (parent, tag, node) => {\n        const tagEntry = this._allByTag.get(tag);\n        if (!tagEntry) throw new Error(`unknown tag: ${tag}`);\n\n        const parentController = this._nodeControllers.get(parent);\n        if (!parentController) throw new Error('parent is not part of TagTree');\n\n        const value = node.getValue();\n        const nodes = this._lookupTable.get(value);\n        if (!nodes) throw new Error('node was missing from lookup table before removal');\n        if (nodes.length > 1) {\n          const ix = nodes.indexOf(node);\n          if (ix < 0) throw new Error('node was missing from list in lookup table before removal');\n          nodes.splice(ix, 1);\n        } else {\n          this._lookupTable.delete(value);\n        }\n\n        node.getOwned().forEach((liveSet, tag) => {\n          liveSet.values().forEach(childNode => {\n            controller.removeTaggedNode(node, tag, childNode);\n          });\n        });\n\n        tagEntry.controller.remove(node);\n        parentController.removeOwnedNode(tag, node);\n        this._nodeControllers.delete(node);\n      },\n      end: () => {\n        this._nodeControllers.forEach(controller => {\n          controller.end();\n        });\n        this._allByTag.forEach(({controller}) => {\n          controller.end();\n        });\n      }\n    };\n    init.executor(controller);\n    init.executor = () => {}; // release reference\n  }\n\n  getNodesForValue(value: T): $ReadOnlyArray<TagTreeNode<T>> {\n    const l = this._lookupTable.get(value);\n    return l ? Object.freeze(l.slice()) : EMPTY_ARRAY;\n  }\n\n  getAllByTag(tag: string): LiveSet<TagTreeNode<T>> {\n    const entry = this._allByTag.get(tag);\n    if (!entry) throw new Error(`tag does not exist in TagTree: ${tag}`);\n    return entry.liveSet;\n  }\n\n  getAll(): Map<string, LiveSet<TagTreeNode<T>>> {\n    const m = new Map();\n    this._allByTag.forEach(({liveSet}, tag) => {\n      m.set(tag, liveSet);\n    });\n    return m;\n  }\n}\n"]}

@@ -1,34 +0,30 @@

'use strict';
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _map = require('babel-runtime/core-js/map');
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _map2 = _interopRequireDefault(_map);
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _liveSet = _interopRequireDefault(require("live-set"));
var _createClass2 = require('babel-runtime/helpers/createClass');
var _createClass3 = _interopRequireDefault(_createClass2);
var _liveSet = require('live-set');
var _liveSet2 = _interopRequireDefault(_liveSet);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var TagTreeNode = function () {
var TagTreeNode =
/*#__PURE__*/
function () {
function TagTreeNode(init) {
var _this = this;
(0, _classCallCheck3.default)(this, TagTreeNode);
this._ownedNodes = new _map2.default();
this._ownedByTag = new _map2.default();
(0, _classCallCheck2.default)(this, TagTreeNode);
(0, _defineProperty2.default)(this, "_init", void 0);
(0, _defineProperty2.default)(this, "_ownedNodes", new Map());
(0, _defineProperty2.default)(this, "_ownedByTag", new Map());
this._init = init;
this._init = init;
this._init.executor({

@@ -38,10 +34,13 @@ node: this,

_this._ownedNodes.set(node, tag);
var entry = _this._ownedByTag.get(tag);
if (!entry) {
entry = _this._createTagEntry();
_this._ownedByTag.set(tag, entry);
}
var _entry = entry,
controller = _entry.controller;
controller.add(node);

@@ -51,6 +50,7 @@ },

_this._ownedNodes.delete(node);
var entry = _this._ownedByTag.get(tag);
if (!entry) throw new Error('tag not owned');
var controller = entry.controller;
controller.remove(node);

@@ -61,3 +61,2 @@ },

var controller = _ref.controller;
controller.end();

@@ -67,12 +66,14 @@ });

});
this._init.executor = function () {}; // release reference
}
(0, _createClass3.default)(TagTreeNode, [{
key: '_createTagEntry',
(0, _createClass2.default)(TagTreeNode, [{
key: "_createTagEntry",
value: function _createTagEntry() {
return _liveSet2.default.active();
return _liveSet.default.active();
}
}, {
key: 'getValue',
key: "getValue",
value: function getValue() {

@@ -82,3 +83,3 @@ return this._init.value;

}, {
key: 'getParent',
key: "getParent",
value: function getParent() {

@@ -88,34 +89,38 @@ return this._init.parent || null;

}, {
key: 'getOwnedByTag',
key: "getOwnedByTag",
value: function getOwnedByTag(tag) {
var entry = this._ownedByTag.get(tag);
if (!entry) {
if (!this._init.ownedTags.has(tag)) {
throw new Error('tag not owned: ' + tag);
throw new Error("tag not owned: ".concat(tag));
}
entry = this._createTagEntry();
this._ownedByTag.set(tag, entry);
}
return entry.liveSet;
}
}, {
key: 'getOwned',
key: "getOwned",
value: function getOwned() {
var m = new _map2.default();
var m = new Map();
this._ownedByTag.forEach(function (_ref2, tag) {
var liveSet = _ref2.liveSet;
m.set(tag, liveSet);
});
return m;
}
}, {
key: 'getTag',
key: "getTag",
value: function getTag() {
var parent = this._init.parent;
return parent ? parent.getTagOfOwnedNode(this) : null;
}
}, {
key: 'ownsNode',
key: "ownsNode",
value: function ownsNode(node) {

@@ -125,5 +130,6 @@ return this._ownedNodes.has(node);

}, {
key: 'getTagOfOwnedNode',
key: "getTagOfOwnedNode",
value: function getTagOfOwnedNode(node) {
var tag = this._ownedNodes.get(node);
if (tag == null) throw new Error('node not owned');

@@ -137,3 +143,4 @@ return tag;

exports.default = TagTreeNode;
module.exports = exports['default'];
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9UYWdUcmVlTm9kZS5qcyJdLCJuYW1lcyI6WyJUYWdUcmVlTm9kZSIsImluaXQiLCJfb3duZWROb2RlcyIsIl9vd25lZEJ5VGFnIiwiX2luaXQiLCJleGVjdXRvciIsIm5vZGUiLCJhZGRPd25lZE5vZGUiLCJ0YWciLCJzZXQiLCJlbnRyeSIsImdldCIsIl9jcmVhdGVUYWdFbnRyeSIsImNvbnRyb2xsZXIiLCJhZGQiLCJyZW1vdmVPd25lZE5vZGUiLCJkZWxldGUiLCJFcnJvciIsInJlbW92ZSIsImVuZCIsImZvckVhY2giLCJhY3RpdmUiLCJ2YWx1ZSIsInBhcmVudCIsIm93bmVkVGFncyIsImhhcyIsImxpdmVTZXQiLCJtIiwiZ2V0VGFnT2ZPd25lZE5vZGUiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVBOzs7Ozs7SUFzQnFCQSxXO0FBS25CLHVCQUFZQyxJQUFaLEVBQXNDO0FBQUE7O0FBQUE7QUFBQSxTQUh0Q0MsV0FHc0MsR0FISyxtQkFHTDtBQUFBLFNBRnRDQyxXQUVzQyxHQUZFLG1CQUVGOztBQUNwQyxTQUFLQyxLQUFMLEdBQWFILElBQWI7QUFDQSxTQUFLRyxLQUFMLENBQVdDLFFBQVgsQ0FBb0I7QUFDbEJDLFlBQU0sSUFEWTtBQUVsQkMsb0JBQWMsc0JBQUNDLEdBQUQsRUFBTUYsSUFBTixFQUFlO0FBQzNCLGNBQUtKLFdBQUwsQ0FBaUJPLEdBQWpCLENBQXFCSCxJQUFyQixFQUEyQkUsR0FBM0I7QUFDQSxZQUFJRSxRQUFRLE1BQUtQLFdBQUwsQ0FBaUJRLEdBQWpCLENBQXFCSCxHQUFyQixDQUFaO0FBQ0EsWUFBSSxDQUFDRSxLQUFMLEVBQVk7QUFDVkEsa0JBQVEsTUFBS0UsZUFBTCxFQUFSO0FBQ0EsZ0JBQUtULFdBQUwsQ0FBaUJNLEdBQWpCLENBQXFCRCxHQUFyQixFQUEwQkUsS0FBMUI7QUFDRDtBQU4wQixxQkFPTkEsS0FQTTtBQUFBLFlBT3BCRyxVQVBvQixVQU9wQkEsVUFQb0I7O0FBUTNCQSxtQkFBV0MsR0FBWCxDQUFlUixJQUFmO0FBQ0QsT0FYaUI7QUFZbEJTLHVCQUFpQix5QkFBQ1AsR0FBRCxFQUFNRixJQUFOLEVBQWU7QUFDOUIsY0FBS0osV0FBTCxDQUFpQmMsTUFBakIsQ0FBd0JWLElBQXhCO0FBQ0EsWUFBTUksUUFBUSxNQUFLUCxXQUFMLENBQWlCUSxHQUFqQixDQUFxQkgsR0FBckIsQ0FBZDtBQUNBLFlBQUksQ0FBQ0UsS0FBTCxFQUFZLE1BQU0sSUFBSU8sS0FBSixDQUFVLGVBQVYsQ0FBTjtBQUhrQixZQUl2QkosVUFKdUIsR0FJVEgsS0FKUyxDQUl2QkcsVUFKdUI7O0FBSzlCQSxtQkFBV0ssTUFBWCxDQUFrQlosSUFBbEI7QUFDRCxPQWxCaUI7QUFtQmxCYSxXQUFLLGVBQU07QUFDVCxjQUFLaEIsV0FBTCxDQUFpQmlCLE9BQWpCLENBQXlCLGdCQUFrQjtBQUFBLGNBQWhCUCxVQUFnQixRQUFoQkEsVUFBZ0I7O0FBQ3pDQSxxQkFBV00sR0FBWDtBQUNELFNBRkQ7QUFHRDtBQXZCaUIsS0FBcEI7QUF5QkEsU0FBS2YsS0FBTCxDQUFXQyxRQUFYLEdBQXNCLFlBQU0sQ0FBRSxDQUE5QixDQTNCb0MsQ0EyQko7QUFDakM7Ozs7c0NBRThCO0FBQzdCLGFBQU8sa0JBQVFnQixNQUFSLEVBQVA7QUFDRDs7OytCQUVhO0FBQ1osYUFBTyxLQUFLakIsS0FBTCxDQUFXa0IsS0FBbEI7QUFDRDs7O2dDQUVnQztBQUMvQixhQUFPLEtBQUtsQixLQUFMLENBQVdtQixNQUFYLElBQXFCLElBQTVCO0FBQ0Q7OztrQ0FFYWYsRyxFQUFzQztBQUNsRCxVQUFJRSxRQUFRLEtBQUtQLFdBQUwsQ0FBaUJRLEdBQWpCLENBQXFCSCxHQUFyQixDQUFaO0FBQ0EsVUFBSSxDQUFDRSxLQUFMLEVBQVk7QUFDVixZQUFJLENBQUMsS0FBS04sS0FBTCxDQUFXb0IsU0FBWCxDQUFxQkMsR0FBckIsQ0FBeUJqQixHQUF6QixDQUFMLEVBQW9DO0FBQ2xDLGdCQUFNLElBQUlTLEtBQUoscUJBQTRCVCxHQUE1QixDQUFOO0FBQ0Q7QUFDREUsZ0JBQVEsS0FBS0UsZUFBTCxFQUFSO0FBQ0EsYUFBS1QsV0FBTCxDQUFpQk0sR0FBakIsQ0FBcUJELEdBQXJCLEVBQTBCRSxLQUExQjtBQUNEO0FBQ0QsYUFBT0EsTUFBTWdCLE9BQWI7QUFDRDs7OytCQUVnRDtBQUMvQyxVQUFNQyxJQUFJLG1CQUFWO0FBQ0EsV0FBS3hCLFdBQUwsQ0FBaUJpQixPQUFqQixDQUF5QixpQkFBWVosR0FBWixFQUFvQjtBQUFBLFlBQWxCa0IsT0FBa0IsU0FBbEJBLE9BQWtCOztBQUMzQ0MsVUFBRWxCLEdBQUYsQ0FBTUQsR0FBTixFQUFXa0IsT0FBWDtBQUNELE9BRkQ7QUFHQSxhQUFPQyxDQUFQO0FBQ0Q7Ozs2QkFFcUI7QUFBQSxVQUNiSixNQURhLEdBQ0gsS0FBS25CLEtBREYsQ0FDYm1CLE1BRGE7O0FBRXBCLGFBQU9BLFNBQVNBLE9BQU9LLGlCQUFQLENBQXlCLElBQXpCLENBQVQsR0FBMEMsSUFBakQ7QUFDRDs7OzZCQUVRdEIsSSxFQUErQjtBQUN0QyxhQUFPLEtBQUtKLFdBQUwsQ0FBaUJ1QixHQUFqQixDQUFxQm5CLElBQXJCLENBQVA7QUFDRDs7O3NDQUVpQkEsSSxFQUE4QjtBQUM5QyxVQUFNRSxNQUFNLEtBQUtOLFdBQUwsQ0FBaUJTLEdBQWpCLENBQXFCTCxJQUFyQixDQUFaO0FBQ0EsVUFBSUUsT0FBTyxJQUFYLEVBQWlCLE1BQU0sSUFBSVMsS0FBSixDQUFVLGdCQUFWLENBQU47QUFDakIsYUFBT1QsR0FBUDtBQUNEOzs7OztrQkFoRmtCUixXIiwiZmlsZSI6IlRhZ1RyZWVOb2RlLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogQGZsb3cgKi9cblxuaW1wb3J0IExpdmVTZXQgZnJvbSAnbGl2ZS1zZXQnO1xuaW1wb3J0IHR5cGUge0xpdmVTZXRDb250cm9sbGVyfSBmcm9tICdsaXZlLXNldCc7XG5cbmV4cG9ydCB0eXBlIFRhZ1RyZWVOb2RlQ29udHJvbGxlcjxUPiA9IHtcbiAgbm9kZTogVGFnVHJlZU5vZGU8VD47XG4gIGFkZE93bmVkTm9kZSh0YWc6IHN0cmluZywgbm9kZTogVGFnVHJlZU5vZGU8VD4pOiB2b2lkO1xuICByZW1vdmVPd25lZE5vZGUodGFnOiBzdHJpbmcsIG5vZGU6IFRhZ1RyZWVOb2RlPFQ+KTogdm9pZDtcbiAgZW5kKCk6IHZvaWQ7XG59O1xuXG5leHBvcnQgdHlwZSBUYWdUcmVlTm9kZUluaXQ8VD4gPSB7fFxuICB2YWx1ZTogVDtcbiAgcGFyZW50OiA/VGFnVHJlZU5vZGU8VD47XG4gIG93bmVkVGFnczogU2V0PHN0cmluZz47XG4gIGV4ZWN1dG9yOiAoY29udHJvbGxlcjogVGFnVHJlZU5vZGVDb250cm9sbGVyPFQ+KSA9PiB2b2lkO1xufH07XG5cbnR5cGUgVGFnRW50cnk8VD4gPSB7XG4gIGxpdmVTZXQ6IExpdmVTZXQ8VGFnVHJlZU5vZGU8VD4+O1xuICBjb250cm9sbGVyOiBMaXZlU2V0Q29udHJvbGxlcjxUYWdUcmVlTm9kZTxUPj47XG59O1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBUYWdUcmVlTm9kZTxUPiB7XG4gIF9pbml0OiBUYWdUcmVlTm9kZUluaXQ8VD47XG4gIF9vd25lZE5vZGVzOiBNYXA8VGFnVHJlZU5vZGU8VD4sIHN0cmluZz4gPSBuZXcgTWFwKCk7XG4gIF9vd25lZEJ5VGFnOiBNYXA8c3RyaW5nLCBUYWdFbnRyeTxUPj4gPSBuZXcgTWFwKCk7XG5cbiAgY29uc3RydWN0b3IoaW5pdDogVGFnVHJlZU5vZGVJbml0PFQ+KSB7XG4gICAgdGhpcy5faW5pdCA9IGluaXQ7XG4gICAgdGhpcy5faW5pdC5leGVjdXRvcih7XG4gICAgICBub2RlOiB0aGlzLFxuICAgICAgYWRkT3duZWROb2RlOiAodGFnLCBub2RlKSA9PiB7XG4gICAgICAgIHRoaXMuX293bmVkTm9kZXMuc2V0KG5vZGUsIHRhZyk7XG4gICAgICAgIGxldCBlbnRyeSA9IHRoaXMuX293bmVkQnlUYWcuZ2V0KHRhZyk7XG4gICAgICAgIGlmICghZW50cnkpIHtcbiAgICAgICAgICBlbnRyeSA9IHRoaXMuX2NyZWF0ZVRhZ0VudHJ5KCk7XG4gICAgICAgICAgdGhpcy5fb3duZWRCeVRhZy5zZXQodGFnLCBlbnRyeSk7XG4gICAgICAgIH1cbiAgICAgICAgY29uc3Qge2NvbnRyb2xsZXJ9ID0gZW50cnk7XG4gICAgICAgIGNvbnRyb2xsZXIuYWRkKG5vZGUpO1xuICAgICAgfSxcbiAgICAgIHJlbW92ZU93bmVkTm9kZTogKHRhZywgbm9kZSkgPT4ge1xuICAgICAgICB0aGlzLl9vd25lZE5vZGVzLmRlbGV0ZShub2RlKTtcbiAgICAgICAgY29uc3QgZW50cnkgPSB0aGlzLl9vd25lZEJ5VGFnLmdldCh0YWcpO1xuICAgICAgICBpZiAoIWVudHJ5KSB0aHJvdyBuZXcgRXJyb3IoJ3RhZyBub3Qgb3duZWQnKTtcbiAgICAgICAgY29uc3Qge2NvbnRyb2xsZXJ9ID0gZW50cnk7XG4gICAgICAgIGNvbnRyb2xsZXIucmVtb3ZlKG5vZGUpO1xuICAgICAgfSxcbiAgICAgIGVuZDogKCkgPT4ge1xuICAgICAgICB0aGlzLl9vd25lZEJ5VGFnLmZvckVhY2goKHtjb250cm9sbGVyfSkgPT4ge1xuICAgICAgICAgIGNvbnRyb2xsZXIuZW5kKCk7XG4gICAgICAgIH0pO1xuICAgICAgfVxuICAgIH0pO1xuICAgIHRoaXMuX2luaXQuZXhlY3V0b3IgPSAoKSA9PiB7fTsgLy8gcmVsZWFzZSByZWZlcmVuY2VcbiAgfVxuXG4gIF9jcmVhdGVUYWdFbnRyeSgpOiBUYWdFbnRyeTxUPiB7XG4gICAgcmV0dXJuIExpdmVTZXQuYWN0aXZlKCk7XG4gIH1cblxuICBnZXRWYWx1ZSgpOiBUIHtcbiAgICByZXR1cm4gdGhpcy5faW5pdC52YWx1ZTtcbiAgfVxuXG4gIGdldFBhcmVudCgpOiBudWxsfFRhZ1RyZWVOb2RlPFQ+IHtcbiAgICByZXR1cm4gdGhpcy5faW5pdC5wYXJlbnQgfHwgbnVsbDtcbiAgfVxuXG4gIGdldE93bmVkQnlUYWcodGFnOiBzdHJpbmcpOiBMaXZlU2V0PFRhZ1RyZWVOb2RlPFQ+PiB7XG4gICAgbGV0IGVudHJ5ID0gdGhpcy5fb3duZWRCeVRhZy5nZXQodGFnKTtcbiAgICBpZiAoIWVudHJ5KSB7XG4gICAgICBpZiAoIXRoaXMuX2luaXQub3duZWRUYWdzLmhhcyh0YWcpKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihgdGFnIG5vdCBvd25lZDogJHt0YWd9YCk7XG4gICAgICB9XG4gICAgICBlbnRyeSA9IHRoaXMuX2NyZWF0ZVRhZ0VudHJ5KCk7XG4gICAgICB0aGlzLl9vd25lZEJ5VGFnLnNldCh0YWcsIGVudHJ5KTtcbiAgICB9XG4gICAgcmV0dXJuIGVudHJ5LmxpdmVTZXQ7XG4gIH1cblxuICBnZXRPd25lZCgpOiBNYXA8c3RyaW5nLCBMaXZlU2V0PFRhZ1RyZWVOb2RlPFQ+Pj4ge1xuICAgIGNvbnN0IG0gPSBuZXcgTWFwKCk7XG4gICAgdGhpcy5fb3duZWRCeVRhZy5mb3JFYWNoKCh7bGl2ZVNldH0sIHRhZykgPT4ge1xuICAgICAgbS5zZXQodGFnLCBsaXZlU2V0KTtcbiAgICB9KTtcbiAgICByZXR1cm4gbTtcbiAgfVxuXG4gIGdldFRhZygpOiBudWxsfHN0cmluZyB7XG4gICAgY29uc3Qge3BhcmVudH0gPSB0aGlzLl9pbml0O1xuICAgIHJldHVybiBwYXJlbnQgPyBwYXJlbnQuZ2V0VGFnT2ZPd25lZE5vZGUodGhpcykgOiBudWxsO1xuICB9XG5cbiAgb3duc05vZGUobm9kZTogVGFnVHJlZU5vZGU8VD4pOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5fb3duZWROb2Rlcy5oYXMobm9kZSk7XG4gIH1cblxuICBnZXRUYWdPZk93bmVkTm9kZShub2RlOiBUYWdUcmVlTm9kZTxUPik6IHN0cmluZyB7XG4gICAgY29uc3QgdGFnID0gdGhpcy5fb3duZWROb2Rlcy5nZXQobm9kZSk7XG4gICAgaWYgKHRhZyA9PSBudWxsKSB0aHJvdyBuZXcgRXJyb3IoJ25vZGUgbm90IG93bmVkJyk7XG4gICAgcmV0dXJuIHRhZztcbiAgfVxufVxuIl19
module.exports = exports.default;
module.exports.default = exports.default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9UYWdUcmVlTm9kZS5qcyJdLCJuYW1lcyI6WyJUYWdUcmVlTm9kZSIsImluaXQiLCJNYXAiLCJfaW5pdCIsImV4ZWN1dG9yIiwibm9kZSIsImFkZE93bmVkTm9kZSIsInRhZyIsIl9vd25lZE5vZGVzIiwic2V0IiwiZW50cnkiLCJfb3duZWRCeVRhZyIsImdldCIsIl9jcmVhdGVUYWdFbnRyeSIsImNvbnRyb2xsZXIiLCJhZGQiLCJyZW1vdmVPd25lZE5vZGUiLCJkZWxldGUiLCJFcnJvciIsInJlbW92ZSIsImVuZCIsImZvckVhY2giLCJMaXZlU2V0IiwiYWN0aXZlIiwidmFsdWUiLCJwYXJlbnQiLCJvd25lZFRhZ3MiLCJoYXMiLCJsaXZlU2V0IiwibSIsImdldFRhZ09mT3duZWROb2RlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7QUFFQTs7SUFzQnFCQSxXOzs7QUFLbkIsdUJBQVlDLElBQVosRUFBc0M7QUFBQTs7QUFBQTtBQUFBO0FBQUEsdURBSEssSUFBSUMsR0FBSixFQUdMO0FBQUEsdURBRkUsSUFBSUEsR0FBSixFQUVGO0FBQ3BDLFNBQUtDLEtBQUwsR0FBYUYsSUFBYjs7QUFDQSxTQUFLRSxLQUFMLENBQVdDLFFBQVgsQ0FBb0I7QUFDbEJDLE1BQUFBLElBQUksRUFBRSxJQURZO0FBRWxCQyxNQUFBQSxZQUFZLEVBQUUsc0JBQUNDLEdBQUQsRUFBTUYsSUFBTixFQUFlO0FBQzNCLFFBQUEsS0FBSSxDQUFDRyxXQUFMLENBQWlCQyxHQUFqQixDQUFxQkosSUFBckIsRUFBMkJFLEdBQTNCOztBQUNBLFlBQUlHLEtBQUssR0FBRyxLQUFJLENBQUNDLFdBQUwsQ0FBaUJDLEdBQWpCLENBQXFCTCxHQUFyQixDQUFaOztBQUNBLFlBQUksQ0FBQ0csS0FBTCxFQUFZO0FBQ1ZBLFVBQUFBLEtBQUssR0FBRyxLQUFJLENBQUNHLGVBQUwsRUFBUjs7QUFDQSxVQUFBLEtBQUksQ0FBQ0YsV0FBTCxDQUFpQkYsR0FBakIsQ0FBcUJGLEdB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O0FBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAZmxvdyAqL1xuXG5pbXBvcnQgTGl2ZVNldCBmcm9tICdsaXZlLXNldCc7XG5pbXBvcnQgdHlwZSB7TGl2ZVNldENvbnRyb2xsZXJ9IGZyb20gJ2xpdmUtc2V0JztcblxuZXhwb3J0IHR5cGUgVGFnVHJlZU5vZGVDb250cm9sbGVyPFQ+ID0ge1xuICBub2RlOiBUYWdUcmVlTm9kZTxUPjtcbiAgYWRkT3duZWROb2RlKHRhZzogc3RyaW5nLCBub2RlOiBUYWdUcmVlTm9kZTxUPik6IHZvaWQ7XG4gIHJlbW92ZU93bmVkTm9kZSh0YWc6IHN0cmluZywgbm9kZTogVGFnVHJlZU5vZGU8VD4pOiB2b2lkO1xuICBlbmQoKTogdm9pZDtcbn07XG5cbmV4cG9ydCB0eXBlIFRhZ1RyZWVOb2RlSW5pdDxUPiA9IHt8XG4gIHZhbHVlOiBUO1xuICBwYXJlbnQ6ID9UYWdUcmVlTm9kZTxUPjtcbiAgb3duZWRUYWdzOiBTZXQ8c3RyaW5nPjtcbiAgZXhlY3V0b3I6IChjb250cm9sbGVyOiBUYWdUcmVlTm9kZUNvbnRyb2xsZXI8VD4pID0+IHZvaWQ7XG58fTtcblxudHlwZSBUYWdFbnRyeTxUPiA9IHtcbiAgbGl2ZVNldDogTGl2ZVNldDxUYWdUcmVlTm9kZTxUPj47XG4gIGNvbnRyb2xsZXI6IExpdmVTZXRDb250cm9sbGVyPFRhZ1RyZWVOb2RlPFQ+Pjtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFRhZ1RyZWVOb2RlPFQ+IHtcbiAgX2luaXQ6IFRhZ1RyZWVOb2RlSW5pdDxUPjtcbiAgX293bmVkTm9kZXM6IE1hcDxUYWdUcmVlTm9kZTxUPiwgc3RyaW5nPiA9IG5ldyBNYXAoKTtcbiAgX293bmVkQnlUYWc6IE1hcDxzdHJpbmcsIFRhZ0VudHJ5PFQ+PiA9IG5ldyBNYXAoKTtcblxuICBjb25zdHJ1Y3Rvcihpbml0OiBUYWdUcmVlTm9kZUluaXQ8VD4pIHtcbiAgICB0aGlzLl9pbml0ID0gaW5pdDtcbiAgICB0aGlzLl9pbml0LmV4ZWN1dG9yKHtcbiAgICAgIG5vZGU6IHRoaXMsXG4gICAgICBhZGRPd25lZE5vZGU6ICh0YWcsIG5vZGUpID0+IHtcbiAgICAgICAgdGhpcy5fb3duZWROb2Rlcy5zZXQobm9kZSwgdGFnKTtcbiAgICAgICAgbGV0IGVudHJ5ID0gdGhpcy5fb3duZWRCeVRhZy5nZXQodGFnKTtcbiAgICAgICAgaWYgKCFlbnRyeSkge1xuICAgICAgICAgIGVudHJ5ID0gdGhpcy5fY3JlYXRlVGFnRW50cnkoKTtcbiAgICAgICAgICB0aGlzLl9vd25lZEJ5VGFnLnNldCh0YWcsIGVudHJ5KTtcbiAgICAgICAgfVxuICAgICAgICBjb25zdCB7Y29udHJvbGxlcn0gPSBlbnRyeTtcbiAgICAgICAgY29udHJvbGxlci5hZGQobm9kZSk7XG4gICAgICB9LFxuICAgICAgcmVtb3ZlT3duZWROb2RlOiAodGFnLCBub2RlKSA9PiB7XG4gICAgICAgIHRoaXMuX293bmVkTm9kZXMuZGVsZXRlKG5vZGUpO1xuICAgICAgICBjb25zdCBlbnRyeSA9IHRoaXMuX293bmVkQnlUYWcuZ2V0KHRhZyk7XG4gICAgICAgIGlmICghZW50cnkpIHRocm93IG5ldyBFcnJvcigndGFnIG5vdCBvd25lZCcpO1xuICAgICAgICBjb25zdCB7Y29udHJvbGxlcn0gPSBlbnRyeTtcbiAgICAgICAgY29udHJvbGxlci5yZW1vdmUobm9kZSk7XG4gICAgICB9LFxuICAgICAgZW5kOiAoKSA9PiB7XG4gICAgICAgIHRoaXMuX293bmVkQnlUYWcuZm9yRWFjaCgoe2NvbnRyb2xsZXJ9KSA9PiB7XG4gICAgICAgICAgY29udHJvbGxlci5lbmQoKTtcbiAgICAgICAgfSk7XG4gICAgICB9XG4gICAgfSk7XG4gICAgdGhpcy5faW5pdC5leGVjdXRvciA9ICgpID0+IHt9OyAvLyByZWxlYXNlIHJlZmVyZW5jZVxuICB9XG5cbiAgX2NyZWF0ZVRhZ0VudHJ5KCk6IFRhZ0VudHJ5PFQ+IHtcbiAgICByZXR1cm4gTGl2ZVNldC5hY3RpdmUoKTtcbiAgfVxuXG4gIGdldFZhbHVlKCk6IFQge1xuICAgIHJldHVybiB0aGlzLl9pbml0LnZhbHVlO1xuICB9XG5cbiAgZ2V0UGFyZW50KCk6IG51bGx8VGFnVHJlZU5vZGU8VD4ge1xuICAgIHJldHVybiB0aGlzLl9pbml0LnBhcmVudCB8fCBudWxsO1xuICB9XG5cbiAgZ2V0T3duZWRCeVRhZyh0YWc6IHN0cmluZyk6IExpdmVTZXQ8VGFnVHJlZU5vZGU8VD4+IHtcbiAgICBsZXQgZW50cnkgPSB0aGlzLl9vd25lZEJ5VGFnLmdldCh0YWcpO1xuICAgIGlmICghZW50cnkpIHtcbiAgICAgIGlmICghdGhpcy5faW5pdC5vd25lZFRhZ3MuaGFzKHRhZykpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGB0YWcgbm90IG93bmVkOiAke3RhZ31gKTtcbiAgICAgIH1cbiAgICAgIGVudHJ5ID0gdGhpcy5fY3JlYXRlVGFnRW50cnkoKTtcbiAgICAgIHRoaXMuX293bmVkQnlUYWcuc2V0KHRhZywgZW50cnkpO1xuICAgIH1cbiAgICByZXR1cm4gZW50cnkubGl2ZVNldDtcbiAgfVxuXG4gIGdldE93bmVkKCk6IE1hcDxzdHJpbmcsIExpdmVTZXQ8VGFnVHJlZU5vZGU8VD4+PiB7XG4gICAgY29uc3QgbSA9IG5ldyBNYXAoKTtcbiAgICB0aGlzLl9vd25lZEJ5VGFnLmZvckVhY2goKHtsaXZlU2V0fSwgdGFnKSA9PiB7XG4gICAgICBtLnNldCh0YWcsIGxpdmVTZXQpO1xuICAgIH0pO1xuICAgIHJldHVybiBtO1xuICB9XG5cbiAgZ2V0VGFnKCk6IG51bGx8c3RyaW5nIHtcbiAgICBjb25zdCB7cGFyZW50fSA9IHRoaXMuX2luaXQ7XG4gICAgcmV0dXJuIHBhcmVudCA/IHBhcmVudC5nZXRUYWdPZk93bmVkTm9kZSh0aGlzKSA6IG51bGw7XG4gIH1cblxuICBvd25zTm9kZShub2RlOiBUYWdUcmVlTm9kZTxUPik6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLl9vd25lZE5vZGVzLmhhcyhub2RlKTtcbiAgfVxuXG4gIGdldFRhZ09mT3duZWROb2RlKG5vZGU6IFRhZ1RyZWVOb2RlPFQ+KTogc3RyaW5nIHtcbiAgICBjb25zdCB0YWcgPSB0aGlzLl9vd25lZE5vZGVzLmdldChub2RlKTtcbiAgICBpZiAodGFnID09IG51bGwpIHRocm93IG5ldyBFcnJvcignbm9kZSBub3Qgb3duZWQnKTtcbiAgICByZXR1cm4gdGFnO1xuICB9XG59XG4iXX0=
The MIT License (MIT)
Copyright (c) 2017 Rewardly, Inc.
Copyright (c) 2018 Rewardly, Inc.

@@ -5,0 +5,0 @@ Permission is hereby granted, free of charge, to any person obtaining a copy

{
"name": "tag-tree",
"version": "0.4.1",
"version": "1.0.0",
"description": "Class representing a changing tree of tagged items.",
"main": "js/index.js",
"sideEffects": false,
"scripts": {
"prepare": "babel -s inline -d js/ src/ --ignore '*.test.*' && flow-copy-source -v src js --ignore '*.test.*'",
"test": "npm run lint && npm run flow_check && jest",
"flow_check": "flow check",
"prepare": "rimraf js && babel -s inline -d js/ src/ --ignore '**/*.test.js' && flow-copy-source -v src js --ignore '*.test.*'",
"test": "yarn lint && flow check && jest && tsc",
"lint": "eslint .",

@@ -28,21 +28,25 @@ "lint-fix": "eslint . --fix"

"dependencies": {
"babel-runtime": "^6.22.0",
"live-set": "^0.4.0"
"@babel/runtime": "^7.0.0",
"live-set": "^1.0.0"
},
"devDependencies": {
"babel-cli": "^6.22.2",
"babel-eslint": "^7.1.1",
"babel-jest": "^20.0.3",
"babel-plugin-add-module-exports": "^0.2.1",
"babel-plugin-transform-flow-strip-types": "^6.22.0",
"babel-plugin-transform-runtime": "^6.22.0",
"babel-preset-es2015": "^6.22.0",
"babel-preset-stage-2": "^6.22.0",
"eslint": "^4.1.1",
"@babel/cli": "^7.0.0",
"@babel/core": "^7.0.0",
"@babel/plugin-proposal-class-properties": "^7.0.0",
"@babel/plugin-transform-runtime": "^7.0.0",
"@babel/preset-env": "^7.0.0",
"@babel/preset-flow": "^7.0.0",
"babel-core": "^7.0.0-bridge.0",
"babel-eslint": "^10.0.1",
"babel-jest": "^23.6.0",
"babel-plugin-add-module-exports": "^1.0.0",
"eslint": "^5.6.0",
"eslint-plugin-flowtype": "^2.30.0",
"flow-bin": "^0.49.1",
"flow-copy-source": "^1.1.0",
"jest": "^20.0.4",
"pdelay": "^1.0.0"
"flow-bin": "^0.82.0",
"flow-copy-source": "^2.0.2",
"jest": "^23.6.0",
"pdelay": "^2.0.0",
"rimraf": "^2.6.1",
"typescript": "^3.1.1"
}
}
# tag-tree
[![Circle CI](https://circleci.com/gh/StreakYC/tag-tree.svg?style=shield)](https://circleci.com/gh/StreakYC/tag-tree)
[![npm version](https://badge.fury.io/js/tag-tree.svg)](https://badge.fury.io/js/tag-tree)
[![GitHub license](https://img.shields.io/badge/license-MIT-blue.svg)](https://github.com/StreakYC/tag-tree/blob/master/LICENSE.txt) [![Circle CI](https://circleci.com/gh/StreakYC/tag-tree.svg?style=shield)](https://circleci.com/gh/StreakYC/tag-tree) [![npm version](https://badge.fury.io/js/tag-tree.svg)](https://badge.fury.io/js/tag-tree)

@@ -145,3 +144,4 @@ This class represents a hierarchical tree of tagged (named) values.

[Flow](https://flowtype.org/) type declarations for this module are included!
If you are using Flow, they won't require any configuration to use.
Both [TypeScript](https://www.typescriptlang.org/) and
[Flow](https://flowtype.org/) type definitions for this module are included!
The type definitions won't require any configuration to use.

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc