| "use strict"; |
| |
| Object.defineProperty(exports, "__esModule", { |
| value: true |
| }); |
| exports._call = _call; |
| exports._getQueueContexts = _getQueueContexts; |
| exports._resyncKey = _resyncKey; |
| exports._resyncList = _resyncList; |
| exports._resyncParent = _resyncParent; |
| exports._resyncRemoved = _resyncRemoved; |
| exports.call = call; |
| exports.isDenylisted = isDenylisted; |
| exports.popContext = popContext; |
| exports.pushContext = pushContext; |
| exports.requeue = requeue; |
| exports.requeueComputedKeyAndDecorators = requeueComputedKeyAndDecorators; |
| exports.resync = resync; |
| exports.setContext = setContext; |
| exports.setKey = setKey; |
| exports.setScope = setScope; |
| exports.setup = setup; |
| exports.skip = skip; |
| exports.skipKey = skipKey; |
| exports.stop = stop; |
| exports.visit = visit; |
| var _traverseNode = require("../traverse-node.js"); |
| var _index = require("./index.js"); |
| var _removal = require("./removal.js"); |
| var t = require("@babel/types"); |
| function call(key) { |
| const opts = this.opts; |
| this.debug(key); |
| if (this.node) { |
| if (_call.call(this, opts[key])) return true; |
| } |
| if (this.node) { |
| var _opts$this$node$type; |
| return _call.call(this, (_opts$this$node$type = opts[this.node.type]) == null ? void 0 : _opts$this$node$type[key]); |
| } |
| return false; |
| } |
| function _call(fns) { |
| if (!fns) return false; |
| for (const fn of fns) { |
| if (!fn) continue; |
| const node = this.node; |
| if (!node) return true; |
| const ret = fn.call(this.state, this, this.state); |
| if (ret && typeof ret === "object" && typeof ret.then === "function") { |
| throw new Error(`You appear to be using a plugin with an async traversal visitor, ` + `which your current version of Babel does not support. ` + `If you're using a published plugin, you may need to upgrade ` + `your @babel/core version.`); |
| } |
| if (ret) { |
| throw new Error(`Unexpected return value from visitor method ${fn}`); |
| } |
| if (this.node !== node) return true; |
| if (this._traverseFlags > 0) return true; |
| } |
| return false; |
| } |
| function isDenylisted() { |
| var _this$opts$denylist; |
| const denylist = (_this$opts$denylist = this.opts.denylist) != null ? _this$opts$denylist : this.opts.blacklist; |
| return denylist == null ? void 0 : denylist.includes(this.node.type); |
| } |
| { |
| exports.isBlacklisted = isDenylisted; |
| } |
| function restoreContext(path, context) { |
| if (path.context !== context) { |
| path.context = context; |
| path.state = context.state; |
| path.opts = context.opts; |
| } |
| } |
| function visit() { |
| var _this$opts$shouldSkip, _this$opts; |
| if (!this.node) { |
| return false; |
| } |
| if (this.isDenylisted()) { |
| return false; |
| } |
| if ((_this$opts$shouldSkip = (_this$opts = this.opts).shouldSkip) != null && _this$opts$shouldSkip.call(_this$opts, this)) { |
| return false; |
| } |
| const currentContext = this.context; |
| if (this.shouldSkip || call.call(this, "enter")) { |
| this.debug("Skip..."); |
| return this.shouldStop; |
| } |
| restoreContext(this, currentContext); |
| this.debug("Recursing into..."); |
| this.shouldStop = (0, _traverseNode.traverseNode)(this.node, this.opts, this.scope, this.state, this, this.skipKeys); |
| restoreContext(this, currentContext); |
| call.call(this, "exit"); |
| return this.shouldStop; |
| } |
| function skip() { |
| this.shouldSkip = true; |
| } |
| function skipKey(key) { |
| if (this.skipKeys == null) { |
| this.skipKeys = {}; |
| } |
| this.skipKeys[key] = true; |
| } |
| function stop() { |
| this._traverseFlags |= _index.SHOULD_SKIP | _index.SHOULD_STOP; |
| } |
| function setScope() { |
| var _this$opts2, _this$scope; |
| if ((_this$opts2 = this.opts) != null && _this$opts2.noScope) return; |
| let path = this.parentPath; |
| if ((this.key === "key" || this.listKey === "decorators") && path.isMethod() || this.key === "discriminant" && path.isSwitchStatement()) { |
| path = path.parentPath; |
| } |
| let target; |
| while (path && !target) { |
| var _path$opts; |
| if ((_path$opts = path.opts) != null && _path$opts.noScope) return; |
| target = path.scope; |
| path = path.parentPath; |
| } |
| this.scope = this.getScope(target); |
| (_this$scope = this.scope) == null || _this$scope.init(); |
| } |
| function setContext(context) { |
| if (this.skipKeys != null) { |
| this.skipKeys = {}; |
| } |
| this._traverseFlags = 0; |
| if (context) { |
| this.context = context; |
| this.state = context.state; |
| this.opts = context.opts; |
| } |
| setScope.call(this); |
| return this; |
| } |
| function resync() { |
| if (this.removed) return; |
| _resyncParent.call(this); |
| _resyncList.call(this); |
| _resyncKey.call(this); |
| } |
| function _resyncParent() { |
| if (this.parentPath) { |
| this.parent = this.parentPath.node; |
| } |
| } |
| function _resyncKey() { |
| if (!this.container) return; |
| if (this.node === this.container[this.key]) { |
| return; |
| } |
| if (Array.isArray(this.container)) { |
| for (let i = 0; i < this.container.length; i++) { |
| if (this.container[i] === this.node) { |
| setKey.call(this, i); |
| return; |
| } |
| } |
| } else { |
| for (const key of Object.keys(this.container)) { |
| if (this.container[key] === this.node) { |
| setKey.call(this, key); |
| return; |
| } |
| } |
| } |
| this.key = null; |
| } |
| function _resyncList() { |
| if (!this.parent || !this.inList) return; |
| const newContainer = this.parent[this.listKey]; |
| if (this.container === newContainer) return; |
| this.container = newContainer || null; |
| } |
| function _resyncRemoved() { |
| if (this.key == null || !this.container || this.container[this.key] !== this.node) { |
| _removal._markRemoved.call(this); |
| } |
| } |
| function popContext() { |
| this.contexts.pop(); |
| if (this.contexts.length > 0) { |
| this.setContext(this.contexts[this.contexts.length - 1]); |
| } else { |
| this.setContext(undefined); |
| } |
| } |
| function pushContext(context) { |
| this.contexts.push(context); |
| this.setContext(context); |
| } |
| function setup(parentPath, container, listKey, key) { |
| this.listKey = listKey; |
| this.container = container; |
| this.parentPath = parentPath || this.parentPath; |
| setKey.call(this, key); |
| } |
| function setKey(key) { |
| var _this$node; |
| this.key = key; |
| this.node = this.container[this.key]; |
| this.type = (_this$node = this.node) == null ? void 0 : _this$node.type; |
| } |
| function requeue(pathToQueue = this) { |
| if (pathToQueue.removed) return; |
| ; |
| const contexts = this.contexts; |
| for (const context of contexts) { |
| context.maybeQueue(pathToQueue); |
| } |
| } |
| function requeueComputedKeyAndDecorators() { |
| const { |
| context, |
| node |
| } = this; |
| if (!t.isPrivate(node) && node.computed) { |
| context.maybeQueue(this.get("key")); |
| } |
| if (node.decorators) { |
| for (const decorator of this.get("decorators")) { |
| context.maybeQueue(decorator); |
| } |
| } |
| } |
| function _getQueueContexts() { |
| let path = this; |
| let contexts = this.contexts; |
| while (!contexts.length) { |
| path = path.parentPath; |
| if (!path) break; |
| contexts = path.contexts; |
| } |
| return contexts; |
| } |
| |
| //# sourceMappingURL=context.js.map |