Register binding for newly created vars for commonjs transforms (#14097)

This commit is contained in:
Sneh Khatri
2022-01-06 23:07:05 +05:30
committed by GitHub
parent bee3e35851
commit ed3036d11c
5 changed files with 59 additions and 0 deletions

View File

@@ -0,0 +1,5 @@
import {x} from './foo.js';
var y = true;
function f() {
return [x, y, console];
}

View File

@@ -0,0 +1,4 @@
{
"sourceType": "module",
"plugins": ["transform-modules-commonjs", "./plugin"]
}

View File

@@ -0,0 +1,15 @@
"use strict";
var _foo = require("./foo.js");
var y = true;
function f() {
return [
/* _foo hasBinding, getBinding */
_foo.x,
/* y hasBinding, getBinding */
y,
/* console no hasBinding, no getBinding */
console];
}

View File

@@ -0,0 +1,29 @@
module.exports = function () {
return {
visitor: {
Program: {
exit(programPath) {
// Sub-traversal to ensure runs after ESM->CJS transform
programPath.traverse({
ReferencedIdentifier(path) {
if (!path.findParent(p => p.isFunction())) return;
const varName = path.node.name;
path.addComment(
"leading",
` ${varName} ${
path.scope.hasBinding(varName)
? "hasBinding"
: "no hasBinding"
}, ${
path.scope.getBinding(varName)
? "getBinding"
: "no getBinding"
} `
);
},
});
},
},
},
};
};