From cdd121bfa4a66d5b2cf72a444f35e82daf81d11e Mon Sep 17 00:00:00 2001 From: Cameron Clark Date: Thu, 26 Dec 2024 19:10:19 +0000 Subject: [PATCH] fix(semantic): reference flags not correctly resolved when after an export stmt --- .../src/rules/typescript/consistent_type_imports.rs | 8 ++++++++ crates/oxc_semantic/src/builder.rs | 1 + 2 files changed, 9 insertions(+) diff --git a/crates/oxc_linter/src/rules/typescript/consistent_type_imports.rs b/crates/oxc_linter/src/rules/typescript/consistent_type_imports.rs index 607643b279a458..0c29635f85a5b3 100644 --- a/crates/oxc_linter/src/rules/typescript/consistent_type_imports.rs +++ b/crates/oxc_linter/src/rules/typescript/consistent_type_imports.rs @@ -1517,6 +1517,14 @@ fn test() { // ", // None, // ), + ( + "import { Bar } from './bar'; +export type { Baz } from './baz'; + +export class Foo extends Bar {} +", + None, + ), ]; let fail = vec![ diff --git a/crates/oxc_semantic/src/builder.rs b/crates/oxc_semantic/src/builder.rs index 9503630f0f2ff4..8652d13aa4af1a 100644 --- a/crates/oxc_semantic/src/builder.rs +++ b/crates/oxc_semantic/src/builder.rs @@ -1880,6 +1880,7 @@ impl<'a> Visit<'a> for SemanticBuilder<'a> { if let Some(with_clause) = &it.with_clause { self.visit_with_clause(with_clause); } + self.current_reference_flags = ReferenceFlags::None; self.leave_node(kind); }