From e3f78fba0b8baa492f4ad70b27cc510aa1ef775c Mon Sep 17 00:00:00 2001 From: Boshen <1430279+Boshen@users.noreply.github.com> Date: Mon, 23 Dec 2024 15:34:30 +0000 Subject: [PATCH] feat(codegen): `new Foo()` -> `new Foo` when minify (#8077) --- crates/oxc_codegen/src/gen.rs | 36 +++++++++++-------- .../oxc_codegen/tests/integration/esbuild.rs | 12 +++---- crates/oxc_codegen/tests/integration/unit.rs | 2 +- 3 files changed, 28 insertions(+), 22 deletions(-) diff --git a/crates/oxc_codegen/src/gen.rs b/crates/oxc_codegen/src/gen.rs index 85c03f9a5cbc0..49bf97c0317d0 100644 --- a/crates/oxc_codegen/src/gen.rs +++ b/crates/oxc_codegen/src/gen.rs @@ -1494,7 +1494,7 @@ impl GenExpr for StaticMemberExpression<'_> { impl GenExpr for PrivateFieldExpression<'_> { fn gen_expr(&self, p: &mut Codegen, _precedence: Precedence, ctx: Context) { - self.object.print_expr(p, Precedence::Prefix, ctx.intersection(Context::FORBID_CALL)); + self.object.print_expr(p, Precedence::Postfix, ctx.intersection(Context::FORBID_CALL)); if self.optional { p.print_str("?"); } @@ -2240,23 +2240,29 @@ impl GenExpr for NewExpression<'_> { p.print_annotation_comments(self.span.start); p.print_space_before_identifier(); p.add_source_mapping(self.span); - p.print_str("new "); + p.print_str("new"); + p.print_soft_space(); self.callee.print_expr(p, Precedence::New, Context::FORBID_CALL); - p.print_ascii_byte(b'('); - let has_comment = (self.span.end > 0 && p.has_comment(self.span.end - 1)) - || self.arguments.iter().any(|item| p.has_comment(item.span().start)); - if has_comment { - p.indent(); - p.print_list_with_comments(&self.arguments, ctx); - // Handle `/* comment */);` - if self.span.end > 0 && !p.print_expr_comments(self.span.end - 1) { - p.print_soft_newline(); + + // Omit the "()" when minifying, but only when safe to do so + if !p.options.minify || !self.arguments.is_empty() || precedence >= Precedence::Postfix + { + p.print_ascii_byte(b'('); + let has_comment = (self.span.end > 0 && p.has_comment(self.span.end - 1)) + || self.arguments.iter().any(|item| p.has_comment(item.span().start)); + if has_comment { + p.indent(); + p.print_list_with_comments(&self.arguments, ctx); + // Handle `/* comment */);` + if self.span.end > 0 && !p.print_expr_comments(self.span.end - 1) { + p.print_soft_newline(); + } + p.dedent(); + } else { + p.print_list(&self.arguments, ctx); } - p.dedent(); - } else { - p.print_list(&self.arguments, ctx); + p.print_ascii_byte(b')'); } - p.print_ascii_byte(b')'); }); } } diff --git a/crates/oxc_codegen/tests/integration/esbuild.rs b/crates/oxc_codegen/tests/integration/esbuild.rs index 189653afce97f..bfa3503cf266c 100644 --- a/crates/oxc_codegen/tests/integration/esbuild.rs +++ b/crates/oxc_codegen/tests/integration/esbuild.rs @@ -178,12 +178,12 @@ fn test_new() { test("new (import('foo')[bar])", "new (import(\"foo\"))[bar]();\n"); test("new (import('foo'))[bar]", "new (import(\"foo\"))[bar]();\n"); - // test_minify("new x", "new x;"); - // test_minify("new x.y", "new x.y;"); - // test_minify("(new x).y", "new x().y;"); - // test_minify("new x().y", "new x().y;"); - // test_minify("new x() + y", "new x+y;"); - // test_minify("new x() ** 2", "new x**2;"); + test_minify("new x", "new x;"); + test_minify("new x.y", "new x.y;"); + test_minify("(new x).y", "new x().y;"); + test_minify("new x().y", "new x().y;"); + test_minify("new x() + y", "new x+y;"); + test_minify("new x() ** 2", "new x**2;"); // Test preservation of Webpack-specific comments test( diff --git a/crates/oxc_codegen/tests/integration/unit.rs b/crates/oxc_codegen/tests/integration/unit.rs index 1dc91547b92e9..d8b4502a1ec51 100644 --- a/crates/oxc_codegen/tests/integration/unit.rs +++ b/crates/oxc_codegen/tests/integration/unit.rs @@ -13,7 +13,7 @@ fn module_decl() { #[test] fn expr() { test("new (foo()).bar();", "new (foo()).bar();\n"); - test_minify("x in new Error()", "x in new Error();"); + test_minify("x in new Error()", "x in new Error;"); test("1000000000000000128.0.toFixed(0)", "0xde0b6b3a7640080.toFixed(0);\n"); test_minify("1000000000000000128.0.toFixed(0)", "0xde0b6b3a7640080.toFixed(0);");