From 7513fb7d4dce94e998feff8bbdb7d2cc5f650f83 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Nicol=C3=B2=20Ribaudo?= Date: Mon, 5 Aug 2024 14:35:54 +0200 Subject: [PATCH] Update the Babel plugin to remove empty static blocks This commit updates the Babel plugin to: - apply the same flattening logic that we already have for blocks, to flatten blocks nested inside class static blocks - remove class static blocks when, after flattening all the blocks they contain, they are empty. Before this commit, the transform output was the same as the input. --- external/builder/babel-plugin-pdfjs-preprocessor.mjs | 6 +++++- external/builder/fixtures_babel/staticblock-expected.js | 5 +++++ external/builder/fixtures_babel/staticblock.js | 9 +++++++++ 3 files changed, 19 insertions(+), 1 deletion(-) create mode 100644 external/builder/fixtures_babel/staticblock-expected.js create mode 100644 external/builder/fixtures_babel/staticblock.js diff --git a/external/builder/babel-plugin-pdfjs-preprocessor.mjs b/external/builder/babel-plugin-pdfjs-preprocessor.mjs index 8c5254e7374c86..8f8be7a724e750 100644 --- a/external/builder/babel-plugin-pdfjs-preprocessor.mjs +++ b/external/builder/babel-plugin-pdfjs-preprocessor.mjs @@ -184,7 +184,7 @@ function babelPluginPDFJSPreprocessor(babel, ctx) { path.replaceWith(t.importExpression(source)); } }, - BlockStatement: { + "BlockStatement|StaticBlock": { // Visit node in post-order so that recursive flattening // of blocks works correctly. exit(path) { @@ -215,6 +215,10 @@ function babelPluginPDFJSPreprocessor(babel, ctx) { } subExpressionIndex++; } + + if (node.type === "StaticBlock" && node.body.length === 0) { + path.remove(); + } }, }, Function: { diff --git a/external/builder/fixtures_babel/staticblock-expected.js b/external/builder/fixtures_babel/staticblock-expected.js new file mode 100644 index 00000000000000..059f844aadeb4d --- /dev/null +++ b/external/builder/fixtures_babel/staticblock-expected.js @@ -0,0 +1,5 @@ +class A { + static { + foo(); + } +} diff --git a/external/builder/fixtures_babel/staticblock.js b/external/builder/fixtures_babel/staticblock.js new file mode 100644 index 00000000000000..0dc197df381a12 --- /dev/null +++ b/external/builder/fixtures_babel/staticblock.js @@ -0,0 +1,9 @@ +class A { + static {} + static { + { foo() } + } + static { + {;} + } +} \ No newline at end of file