From df02c40fe83b9259f49a6f870ee0c634f41b098f Mon Sep 17 00:00:00 2001 From: Dunqing Date: Wed, 10 Jul 2024 13:59:01 +0800 Subject: [PATCH] refactor(semantic): add strict mode in scope flags for class definitions --- crates/oxc_semantic/src/builder.rs | 7 +++- tasks/coverage/parser_babel.snap | 9 +---- tasks/coverage/parser_typescript.snap | 53 +++------------------------ 3 files changed, 13 insertions(+), 56 deletions(-) diff --git a/crates/oxc_semantic/src/builder.rs b/crates/oxc_semantic/src/builder.rs index 3c4a01de765b03..08f4c31537291b 100644 --- a/crates/oxc_semantic/src/builder.rs +++ b/crates/oxc_semantic/src/builder.rs @@ -258,7 +258,6 @@ impl<'a> SemanticBuilder<'a> { pub fn strict_mode(&self) -> bool { self.current_scope_flags().is_strict_mode() - || self.current_node_flags.contains(NodeFlags::Class) } pub fn set_function_node_flag(&mut self, flag: NodeFlags) { @@ -421,6 +420,12 @@ impl<'a> Visit<'a> for SemanticBuilder<'a> { if flags.contains(ScopeFlags::Top) { None } else { Some(self.current_scope_id) }; let mut flags = flags; + + if !flags.is_strict_mode() && self.current_node_flags.has_class() { + // NOTE A class definition is always strict mode code. + flags |= ScopeFlags::StrictMode; + }; + if let Some(parent_scope_id) = parent_scope_id { flags = self.scope.get_new_scope_flags(flags, parent_scope_id); } diff --git a/tasks/coverage/parser_babel.snap b/tasks/coverage/parser_babel.snap index d5c9ea06ef336d..d5606ac719602b 100644 --- a/tasks/coverage/parser_babel.snap +++ b/tasks/coverage/parser_babel.snap @@ -3,7 +3,7 @@ commit: 12619ffe parser_babel Summary: AST Parsed : 2093/2101 (99.62%) Positive Passed: 2083/2101 (99.14%) -Negative Passed: 1380/1501 (91.94%) +Negative Passed: 1379/1501 (91.87%) Expect Syntax Error: "annex-b/disabled/1.1-html-comments-close/input.js" Expect Syntax Error: "annex-b/disabled/3.1-sloppy-labeled-functions/input.js" Expect Syntax Error: "annex-b/disabled/3.1-sloppy-labeled-functions-if-body/input.js" @@ -39,6 +39,7 @@ Expect Syntax Error: "esprima/es2015-arrow-function/invalid-param-strict-mode/in Expect Syntax Error: "esprima/es2015-generator/generator-parameter-binding-property-reserved/input.js" Expect Syntax Error: "esprima/invalid-syntax/migrated_0101/input.js" Expect Syntax Error: "esprima/invalid-syntax/migrated_0276/input.js" +Expect Syntax Error: "esprima/invalid-syntax/migrated_0278/input.js" Expect Syntax Error: "typescript/cast/satisfies-const-error/input.ts" Expect Syntax Error: "typescript/cast/unparenthesized-assert-and-assign/input.ts" Expect Syntax Error: "typescript/cast/unparenthesized-type-assertion-and-assign/input.ts" @@ -9688,12 +9689,6 @@ Expect to Parse: "typescript/types/const-type-parameters-babel-7/input.ts" · ──── ╰──── - × The keyword 'static' is reserved - ╭─[esprima/invalid-syntax/migrated_0278/input.js:1:18] - 1 │ class A {static [static](){};} - · ────── - ╰──── - × A 'set' accessor cannot have rest parameter. ╭─[esprima/rest-parameter/invalid-setter-rest/input.js:1:13] 1 │ x = { set f(...y) {} } diff --git a/tasks/coverage/parser_typescript.snap b/tasks/coverage/parser_typescript.snap index a354da75413ca2..4d1a4c031cbcbd 100644 --- a/tasks/coverage/parser_typescript.snap +++ b/tasks/coverage/parser_typescript.snap @@ -3,7 +3,7 @@ commit: d8086f14 parser_typescript Summary: AST Parsed : 5279/5283 (99.92%) Positive Passed: 5272/5283 (99.79%) -Negative Passed: 1094/4875 (22.44%) +Negative Passed: 1090/4875 (22.36%) Expect Syntax Error: "compiler/ClassDeclaration10.ts" Expect Syntax Error: "compiler/ClassDeclaration11.ts" Expect Syntax Error: "compiler/ClassDeclaration13.ts" @@ -2321,6 +2321,8 @@ Expect Syntax Error: "conformance/es6/computedProperties/computedPropertyNames38 Expect Syntax Error: "conformance/es6/computedProperties/computedPropertyNames38_ES6.ts" Expect Syntax Error: "conformance/es6/computedProperties/computedPropertyNames39_ES5.ts" Expect Syntax Error: "conformance/es6/computedProperties/computedPropertyNames39_ES6.ts" +Expect Syntax Error: "conformance/es6/computedProperties/computedPropertyNames3_ES5.ts" +Expect Syntax Error: "conformance/es6/computedProperties/computedPropertyNames3_ES6.ts" Expect Syntax Error: "conformance/es6/computedProperties/computedPropertyNames42_ES5.ts" Expect Syntax Error: "conformance/es6/computedProperties/computedPropertyNames42_ES6.ts" Expect Syntax Error: "conformance/es6/computedProperties/computedPropertyNames43_ES5.ts" @@ -3287,7 +3289,9 @@ Expect Syntax Error: "conformance/parser/ecmascript6/ComputedPropertyNames/parse Expect Syntax Error: "conformance/parser/ecmascript6/ComputedPropertyNames/parserComputedPropertyName31.ts" Expect Syntax Error: "conformance/parser/ecmascript6/ComputedPropertyNames/parserComputedPropertyName32.ts" Expect Syntax Error: "conformance/parser/ecmascript6/ComputedPropertyNames/parserComputedPropertyName34.ts" +Expect Syntax Error: "conformance/parser/ecmascript6/ComputedPropertyNames/parserComputedPropertyName36.ts" Expect Syntax Error: "conformance/parser/ecmascript6/ComputedPropertyNames/parserComputedPropertyName37.ts" +Expect Syntax Error: "conformance/parser/ecmascript6/ComputedPropertyNames/parserComputedPropertyName38.ts" Expect Syntax Error: "conformance/parser/ecmascript6/ComputedPropertyNames/parserComputedPropertyName4.ts" Expect Syntax Error: "conformance/parser/ecmascript6/ComputedPropertyNames/parserComputedPropertyName40.ts" Expect Syntax Error: "conformance/parser/ecmascript6/ComputedPropertyNames/parserComputedPropertyName41.ts" @@ -9690,21 +9694,6 @@ Expect to Parse: "conformance/salsa/plainJSRedeclare3.ts" 16 │ } ╰──── - × The keyword 'package' is reserved - ╭─[compiler/strictModeReservedWordInClassDeclaration.ts:27:17] - 26 │ class F1 implements public.private.implements { } - 27 │ class G extends package { } - · ─────── - 28 │ class H extends package.A { } - ╰──── - - × The keyword 'package' is reserved - ╭─[compiler/strictModeReservedWordInClassDeclaration.ts:28:17] - 27 │ class G extends package { } - 28 │ class H extends package.A { } - · ─────── - ╰──── - × The keyword 'public' is reserved ╭─[compiler/strictModeReservedWordInDestructuring.ts:2:6] 1 │ "use strict" @@ -13073,22 +13062,6 @@ Expect to Parse: "conformance/salsa/plainJSRedeclare3.ts" 5 │ } ╰──── - × Delete of an unqualified identifier in strict mode. - ╭─[conformance/es6/computedProperties/computedPropertyNames3_ES5.ts:5:17] - 4 │ static [() => { }]() { } - 5 │ get [delete id]() { } - · ── - 6 │ set [[0, 1]](v) { } - ╰──── - - × Delete of an unqualified identifier in strict mode. - ╭─[conformance/es6/computedProperties/computedPropertyNames3_ES6.ts:5:17] - 4 │ static [() => { }]() { } - 5 │ get [delete id]() { } - · ── - 6 │ set [[0, 1]](v) { } - ╰──── - × Identifier `` has already been declared ╭─[conformance/es6/computedProperties/computedPropertyNames40_ES5.ts:8:6] 7 │ // Computed properties @@ -19143,22 +19116,6 @@ Expect to Parse: "conformance/salsa/plainJSRedeclare3.ts" 3 │ } ╰──── - × The keyword 'public' is reserved - ╭─[conformance/parser/ecmascript6/ComputedPropertyNames/parserComputedPropertyName36.ts:2:6] - 1 │ class C { - 2 │ [public ]: string; - · ────── - 3 │ } - ╰──── - - × The keyword 'public' is reserved - ╭─[conformance/parser/ecmascript6/ComputedPropertyNames/parserComputedPropertyName38.ts:2:6] - 1 │ class C { - 2 │ [public]() { } - · ────── - 3 │ } - ╰──── - × The keyword 'public' is reserved ╭─[conformance/parser/ecmascript6/ComputedPropertyNames/parserComputedPropertyName39.ts:3:6] 2 │ class C {