forked from M3-Academy/challenge-algorithms-v2.0
58 lines
1.2 KiB
JavaScript
58 lines
1.2 KiB
JavaScript
"use strict";
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports.default = hoistVariables;
|
|
|
|
var _t = require("@babel/types");
|
|
|
|
const {
|
|
assignmentExpression,
|
|
expressionStatement,
|
|
identifier
|
|
} = _t;
|
|
const visitor = {
|
|
Scope(path, state) {
|
|
if (state.kind === "let") path.skip();
|
|
},
|
|
|
|
FunctionParent(path) {
|
|
path.skip();
|
|
},
|
|
|
|
VariableDeclaration(path, state) {
|
|
if (state.kind && path.node.kind !== state.kind) return;
|
|
const nodes = [];
|
|
const declarations = path.get("declarations");
|
|
let firstId;
|
|
|
|
for (const declar of declarations) {
|
|
firstId = declar.node.id;
|
|
|
|
if (declar.node.init) {
|
|
nodes.push(expressionStatement(assignmentExpression("=", declar.node.id, declar.node.init)));
|
|
}
|
|
|
|
for (const name of Object.keys(declar.getBindingIdentifiers())) {
|
|
state.emit(identifier(name), name, declar.node.init !== null);
|
|
}
|
|
}
|
|
|
|
if (path.parentPath.isFor({
|
|
left: path.node
|
|
})) {
|
|
path.replaceWith(firstId);
|
|
} else {
|
|
path.replaceWithMultiple(nodes);
|
|
}
|
|
}
|
|
|
|
};
|
|
|
|
function hoistVariables(path, emit, kind = "var") {
|
|
path.traverse(visitor, {
|
|
kind,
|
|
emit
|
|
});
|
|
} |