Skip to content

Commit

Permalink
fix(semantic): remove inherting ScopeFlags::Modifier from parent scope
Browse files Browse the repository at this point in the history
  • Loading branch information
Dunqing committed Dec 16, 2024
1 parent 10a86b9 commit f5da19a
Show file tree
Hide file tree
Showing 4 changed files with 8 additions and 35 deletions.
2 changes: 2 additions & 0 deletions crates/oxc_semantic/examples/semantic.rs
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,8 @@ fn main() -> std::io::Result<()> {
.with_check_syntax_error(true)
.build(&program);

println!("{:?}", semantic.semantic.scopes());

if !semantic.errors.is_empty() {
let error_message: String = semantic
.errors
Expand Down
16 changes: 2 additions & 14 deletions crates/oxc_semantic/src/scope.rs
Original file line number Diff line number Diff line change
Expand Up @@ -143,21 +143,9 @@ impl ScopeTree {
}

/// Get [`ScopeFlags`] for a new child scope under `parent_scope_id`.
pub fn get_new_scope_flags(
&self,
mut flags: ScopeFlags,
parent_scope_id: ScopeId,
) -> ScopeFlags {
pub fn get_new_scope_flags(&self, flags: ScopeFlags, parent_scope_id: ScopeId) -> ScopeFlags {
// https://tc39.es/ecma262/#sec-strict-mode-code
let parent_scope_flags = self.get_flags(parent_scope_id);
flags |= parent_scope_flags & ScopeFlags::StrictMode;

// inherit flags for non-function scopes
if !flags.contains(ScopeFlags::Function) {
flags |= parent_scope_flags & ScopeFlags::Modifiers;
}

flags
flags | self.get_flags(parent_scope_id) & ScopeFlags::StrictMode
}

#[inline]
Expand Down
4 changes: 2 additions & 2 deletions tasks/coverage/snapshots/semantic_typescript.snap
Original file line number Diff line number Diff line change
Expand Up @@ -54773,7 +54773,7 @@ Bindings mismatch:
after transform: ScopeId(32): ["A", "B", "C", "E"]
rebuilt : ScopeId(24): ["E"]
Scope flags mismatch:
after transform: ScopeId(32): ScopeFlags(StrictMode | Constructor)
after transform: ScopeId(32): ScopeFlags(StrictMode)
rebuilt : ScopeId(24): ScopeFlags(StrictMode | Function)
Bindings mismatch:
after transform: ScopeId(34): ["C", "E"]
Expand All @@ -54791,7 +54791,7 @@ Bindings mismatch:
after transform: ScopeId(38): ["A", "B", "C", "E"]
rebuilt : ScopeId(30): ["E"]
Scope flags mismatch:
after transform: ScopeId(38): ScopeFlags(StrictMode | GetAccessor)
after transform: ScopeId(38): ScopeFlags(StrictMode)
rebuilt : ScopeId(30): ScopeFlags(StrictMode | Function)
Symbol flags mismatch for "E":
after transform: SymbolId(1): SymbolFlags(RegularEnum)
Expand Down
21 changes: 2 additions & 19 deletions tasks/transform_conformance/snapshots/oxc.snap.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
commit: 54a8389f

Passed: 110/125
Passed: 111/125

# All Passed:
* babel-plugin-transform-class-static-block
Expand All @@ -16,24 +16,7 @@ Passed: 110/125
* regexp


# babel-plugin-transform-class-properties (11/14)
* instance-prop-initializer-no-existing-constructor/input.js
Scope flags mismatch:
after transform: ScopeId(12): ScopeFlags(StrictMode)
rebuilt : ScopeId(13): ScopeFlags(StrictMode | Constructor)
Scope flags mismatch:
after transform: ScopeId(13): ScopeFlags(StrictMode)
rebuilt : ScopeId(14): ScopeFlags(StrictMode | Constructor)
Scope flags mismatch:
after transform: ScopeId(14): ScopeFlags(StrictMode)
rebuilt : ScopeId(15): ScopeFlags(StrictMode | Constructor)
Scope flags mismatch:
after transform: ScopeId(15): ScopeFlags(StrictMode)
rebuilt : ScopeId(16): ScopeFlags(StrictMode | Constructor)
Scope flags mismatch:
after transform: ScopeId(20): ScopeFlags(StrictMode)
rebuilt : ScopeId(21): ScopeFlags(StrictMode | Constructor)

# babel-plugin-transform-class-properties (12/14)
* typescript/optional-call/input.ts
Symbol reference IDs mismatch for "X":
after transform: SymbolId(0): [ReferenceId(0), ReferenceId(2), ReferenceId(6), ReferenceId(11), ReferenceId(16)]
Expand Down

0 comments on commit f5da19a

Please sign in to comment.