UNPKG

3.8 kBJavaScriptView Raw
1"use strict";
2
3Object.defineProperty(exports, "__esModule", {
4 value: true
5});
6exports.default = traverse;
7Object.defineProperty(exports, "NodePath", {
8 enumerable: true,
9 get: function () {
10 return _path.default;
11 }
12});
13Object.defineProperty(exports, "Scope", {
14 enumerable: true,
15 get: function () {
16 return _scope.default;
17 }
18});
19Object.defineProperty(exports, "Hub", {
20 enumerable: true,
21 get: function () {
22 return _hub.default;
23 }
24});
25exports.visitors = void 0;
26
27var _context = _interopRequireDefault(require("./context"));
28
29var visitors = _interopRequireWildcard(require("./visitors"));
30
31exports.visitors = visitors;
32
33var t = _interopRequireWildcard(require("@babel/types"));
34
35var cache = _interopRequireWildcard(require("./cache"));
36
37var _path = _interopRequireDefault(require("./path"));
38
39var _scope = _interopRequireDefault(require("./scope"));
40
41var _hub = _interopRequireDefault(require("./hub"));
42
43function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function () { return cache; }; return cache; }
44
45function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
46
47function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
48
49function traverse(parent, opts, scope, state, parentPath) {
50 if (!parent) return;
51 if (!opts) opts = {};
52
53 if (!opts.noScope && !scope) {
54 if (parent.type !== "Program" && parent.type !== "File") {
55 throw new Error("You must pass a scope and parentPath unless traversing a Program/File. " + `Instead of that you tried to traverse a ${parent.type} node without ` + "passing scope and parentPath.");
56 }
57 }
58
59 if (!t.VISITOR_KEYS[parent.type]) {
60 return;
61 }
62
63 visitors.explode(opts);
64 traverse.node(parent, opts, scope, state, parentPath);
65}
66
67traverse.visitors = visitors;
68traverse.verify = visitors.verify;
69traverse.explode = visitors.explode;
70
71traverse.cheap = function (node, enter) {
72 return t.traverseFast(node, enter);
73};
74
75traverse.node = function (node, opts, scope, state, parentPath, skipKeys) {
76 const keys = t.VISITOR_KEYS[node.type];
77 if (!keys) return;
78 const context = new _context.default(scope, opts, state, parentPath);
79
80 for (const key of keys) {
81 if (skipKeys && skipKeys[key]) continue;
82 if (context.visit(node, key)) return;
83 }
84};
85
86traverse.clearNode = function (node, opts) {
87 t.removeProperties(node, opts);
88 cache.path.delete(node);
89};
90
91traverse.removeProperties = function (tree, opts) {
92 t.traverseFast(tree, traverse.clearNode, opts);
93 return tree;
94};
95
96function hasDenylistedType(path, state) {
97 if (path.node.type === state.type) {
98 state.has = true;
99 path.stop();
100 }
101}
102
103traverse.hasType = function (tree, type, denylistTypes) {
104 if (denylistTypes == null ? void 0 : denylistTypes.includes(tree.type)) return false;
105 if (tree.type === type) return true;
106 const state = {
107 has: false,
108 type: type
109 };
110 traverse(tree, {
111 noScope: true,
112 denylist: denylistTypes,
113 enter: hasDenylistedType
114 }, null, state);
115 return state.has;
116};
117
118traverse.cache = cache;
\No newline at end of file