diff --git a/crates/swc/tests/fixture/issues-8xxx/8705/input/.swcrc b/crates/swc/tests/fixture/issues-8xxx/8705/input/.swcrc new file mode 100644 index 000000000000..a35cd5524970 --- /dev/null +++ b/crates/swc/tests/fixture/issues-8xxx/8705/input/.swcrc @@ -0,0 +1,64 @@ +{ + "jsc": { + "parser": { + "syntax": "ecmascript", + "jsx": false + }, + "target": "es2022", + "loose": false, + "minify": { + "compress": { + "arguments": false, + "arrows": true, + "booleans": true, + "booleans_as_integers": false, + "collapse_vars": true, + "comparisons": true, + "computed_props": true, + "conditionals": true, + "dead_code": true, + "directives": true, + "drop_console": false, + "drop_debugger": true, + "evaluate": true, + "expression": false, + "hoist_funs": false, + "hoist_props": true, + "hoist_vars": false, + "if_return": true, + "join_vars": true, + "keep_classnames": false, + "keep_fargs": true, + "keep_fnames": false, + "keep_infinity": false, + "loops": true, + "negate_iife": true, + "properties": true, + "reduce_funcs": false, + "reduce_vars": false, + "side_effects": true, + "switches": true, + "typeofs": true, + "unsafe": false, + "unsafe_arrows": false, + "unsafe_comps": false, + "unsafe_Function": false, + "unsafe_math": false, + "unsafe_symbols": false, + "unsafe_methods": false, + "unsafe_proto": false, + "unsafe_regexp": false, + "unsafe_undefined": false, + "unused": true, + "const_to_let": true, + "pristine_globals": true + }, + "mangle": false + } + }, + "module": { + "type": "es6" + }, + "minify": false, + "isModule": true +} \ No newline at end of file diff --git a/crates/swc/tests/fixture/issues-8xxx/8705/input/1.js b/crates/swc/tests/fixture/issues-8xxx/8705/input/1.js new file mode 100644 index 000000000000..332255e2219f --- /dev/null +++ b/crates/swc/tests/fixture/issues-8xxx/8705/input/1.js @@ -0,0 +1 @@ +console.log(Math.pow({ valueOf() { return 42 } }, 1)) diff --git a/crates/swc/tests/fixture/issues-8xxx/8705/output/1.js b/crates/swc/tests/fixture/issues-8xxx/8705/output/1.js new file mode 100644 index 000000000000..8e81820cd976 --- /dev/null +++ b/crates/swc/tests/fixture/issues-8xxx/8705/output/1.js @@ -0,0 +1,3 @@ +console.log(Math.pow({ + valueOf: ()=>42 +}, 1)); diff --git a/crates/swc_ecma_minifier/tests/fixture/issues/8704/config.json b/crates/swc_ecma_minifier/tests/fixture/issues/8704/config.json new file mode 100644 index 000000000000..7e144b291fa7 --- /dev/null +++ b/crates/swc_ecma_minifier/tests/fixture/issues/8704/config.json @@ -0,0 +1,47 @@ +{ + "defaults": true, + "arguments": false, + "arrows": true, + "booleans": true, + "booleans_as_integers": false, + "collapse_vars": true, + "comparisons": true, + "computed_props": true, + "conditionals": true, + "dead_code": true, + "directives": true, + "drop_console": false, + "drop_debugger": true, + "evaluate": true, + "expression": false, + "hoist_funs": false, + "hoist_props": true, + "hoist_vars": false, + "if_return": true, + "join_vars": true, + "keep_classnames": false, + "keep_fargs": true, + "keep_fnames": false, + "keep_infinity": false, + "loops": true, + "negate_iife": true, + "properties": true, + "reduce_funcs": false, + "reduce_vars": false, + "side_effects": true, + "switches": true, + "typeofs": true, + "unsafe": false, + "unsafe_arrows": false, + "unsafe_comps": false, + "unsafe_Function": false, + "unsafe_math": false, + "unsafe_symbols": false, + "unsafe_methods": false, + "unsafe_proto": false, + "unsafe_regexp": false, + "unsafe_undefined": false, + "unused": true, + "const_to_let": true, + "pristine_globals": true +} diff --git a/crates/swc_ecma_minifier/tests/fixture/issues/8704/input.js b/crates/swc_ecma_minifier/tests/fixture/issues/8704/input.js new file mode 100644 index 000000000000..8cedf7ef50b3 --- /dev/null +++ b/crates/swc_ecma_minifier/tests/fixture/issues/8704/input.js @@ -0,0 +1 @@ +console.log({ toString() { return 'swc' } } + '') diff --git a/crates/swc_ecma_minifier/tests/fixture/issues/8704/output.js b/crates/swc_ecma_minifier/tests/fixture/issues/8704/output.js new file mode 100644 index 000000000000..d3c34ee65f73 --- /dev/null +++ b/crates/swc_ecma_minifier/tests/fixture/issues/8704/output.js @@ -0,0 +1,3 @@ +console.log({ + toString: ()=>'swc' +} + ''); diff --git a/crates/swc_ecma_minifier/tests/fixture/issues/8705/config.json b/crates/swc_ecma_minifier/tests/fixture/issues/8705/config.json new file mode 100644 index 000000000000..7e144b291fa7 --- /dev/null +++ b/crates/swc_ecma_minifier/tests/fixture/issues/8705/config.json @@ -0,0 +1,47 @@ +{ + "defaults": true, + "arguments": false, + "arrows": true, + "booleans": true, + "booleans_as_integers": false, + "collapse_vars": true, + "comparisons": true, + "computed_props": true, + "conditionals": true, + "dead_code": true, + "directives": true, + "drop_console": false, + "drop_debugger": true, + "evaluate": true, + "expression": false, + "hoist_funs": false, + "hoist_props": true, + "hoist_vars": false, + "if_return": true, + "join_vars": true, + "keep_classnames": false, + "keep_fargs": true, + "keep_fnames": false, + "keep_infinity": false, + "loops": true, + "negate_iife": true, + "properties": true, + "reduce_funcs": false, + "reduce_vars": false, + "side_effects": true, + "switches": true, + "typeofs": true, + "unsafe": false, + "unsafe_arrows": false, + "unsafe_comps": false, + "unsafe_Function": false, + "unsafe_math": false, + "unsafe_symbols": false, + "unsafe_methods": false, + "unsafe_proto": false, + "unsafe_regexp": false, + "unsafe_undefined": false, + "unused": true, + "const_to_let": true, + "pristine_globals": true +} diff --git a/crates/swc_ecma_minifier/tests/fixture/issues/8705/input.js b/crates/swc_ecma_minifier/tests/fixture/issues/8705/input.js new file mode 100644 index 000000000000..332255e2219f --- /dev/null +++ b/crates/swc_ecma_minifier/tests/fixture/issues/8705/input.js @@ -0,0 +1 @@ +console.log(Math.pow({ valueOf() { return 42 } }, 1)) diff --git a/crates/swc_ecma_minifier/tests/fixture/issues/8705/output.js b/crates/swc_ecma_minifier/tests/fixture/issues/8705/output.js new file mode 100644 index 000000000000..8e81820cd976 --- /dev/null +++ b/crates/swc_ecma_minifier/tests/fixture/issues/8705/output.js @@ -0,0 +1,3 @@ +console.log(Math.pow({ + valueOf: ()=>42 +}, 1)); diff --git a/crates/swc_ecma_transforms_optimization/src/simplify/expr/tests.rs b/crates/swc_ecma_transforms_optimization/src/simplify/expr/tests.rs index 472c4b3506bd..9b4b388a6c01 100644 --- a/crates/swc_ecma_transforms_optimization/src/simplify/expr/tests.rs +++ b/crates/swc_ecma_transforms_optimization/src/simplify/expr/tests.rs @@ -661,10 +661,6 @@ fn test_folding_mix_types_early() { fn test_folding_add1() { fold("x = null + true", "x=1"); fold_same("x = a + true"); - fold("x = '' + {}", "x = \"[object Object]\""); - fold("x = [] + {}", "x = \"[object Object]\""); - fold("x = {} + []", "x = \"[object Object]\""); - fold("x = {} + ''", "x = \"[object Object]\""); } #[test] diff --git a/crates/swc_ecma_utils/src/lib.rs b/crates/swc_ecma_utils/src/lib.rs index 2963edaca181..ac372cd97600 100644 --- a/crates/swc_ecma_utils/src/lib.rs +++ b/crates/swc_ecma_utils/src/lib.rs @@ -935,7 +935,7 @@ pub trait ExprExt { } } - Expr::Tpl(..) | Expr::Object(ObjectLit { .. }) | Expr::Array(ArrayLit { .. }) => { + Expr::Tpl(..) => { return ( Pure, num_from_str(&match self.as_pure_string(ctx) { @@ -1058,7 +1058,6 @@ pub trait ExprExt { } Known(buf.into()) } - Expr::Object(ObjectLit { .. }) => Known(Cow::Borrowed("[object Object]")), _ => Unknown, } }