From 8bd496d86a464d631f27705585d8eb1d7632d72b Mon Sep 17 00:00:00 2001 From: overlookmotel Date: Mon, 19 Aug 2024 17:39:30 +0100 Subject: [PATCH] fix(transformer): remove an `AstBuilder::copy` call from TS module transform --- crates/oxc_transformer/src/typescript/module.rs | 13 +++++-------- 1 file changed, 5 insertions(+), 8 deletions(-) diff --git a/crates/oxc_transformer/src/typescript/module.rs b/crates/oxc_transformer/src/typescript/module.rs index faa3fb511ed82a..777f2a0057508a 100644 --- a/crates/oxc_transformer/src/typescript/module.rs +++ b/crates/oxc_transformer/src/typescript/module.rs @@ -85,15 +85,12 @@ impl<'a> TypeScript<'a> { ) -> Expression<'a> { match type_name { TSTypeName::IdentifierReference(ident) => { + let mut ident = ident.clone(); ident.reference_flag = ReferenceFlag::Read; - if let Some(reference_id) = ident.reference_id.get() { - let reference = ctx.symbols_mut().get_reference_mut(reference_id); - *reference.flag_mut() = ReferenceFlag::Read; - } else { - unreachable!() - } - // SAFETY: `ast.copy` is unsound! We need to fix. - self.ctx.ast.expression_from_identifier_reference(unsafe { ctx.ast.copy(ident) }) + let reference_id = ident.reference_id.get().unwrap(); + let reference = ctx.symbols_mut().get_reference_mut(reference_id); + *reference.flag_mut() = ReferenceFlag::Read; + self.ctx.ast.expression_from_identifier_reference(ident) } TSTypeName::QualifiedName(qualified_name) => self .ctx