Skip to content

Commit

Permalink
Register binding for newly created vars for commonjs transforms (#14097)
Browse files Browse the repository at this point in the history
  • Loading branch information
The-x-Theorist committed Jan 6, 2022
1 parent bee3e35 commit ed3036d
Show file tree
Hide file tree
Showing 5 changed files with 59 additions and 0 deletions.
6 changes: 6 additions & 0 deletions packages/babel-plugin-transform-modules-commonjs/src/index.ts
Expand Up @@ -235,6 +235,12 @@ export default declare((api, options) => {

ensureStatementsHoisted(headers);
path.unshiftContainer("body", headers);
path.get("body").forEach(path => {
if (headers.indexOf(path.node) === -1) return;
if (path.isVariableDeclaration()) {
path.scope.registerDeclaration(path);
}
});
},
},
},
Expand Down
@@ -0,0 +1,5 @@
import {x} from './foo.js';
var y = true;
function f() {
return [x, y, console];
}
@@ -0,0 +1,4 @@
{
"sourceType": "module",
"plugins": ["transform-modules-commonjs", "./plugin"]
}
@@ -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];
}
@@ -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"
} `
);
},
});
},
},
},
};
};

0 comments on commit ed3036d

Please sign in to comment.