From ff73c7ffde7ea95ec8385928bb1416cb90725014 Mon Sep 17 00:00:00 2001 From: Dunqing <29533304+Dunqing@users.noreply.github.com> Date: Thu, 5 Dec 2024 13:41:43 +0000 Subject: [PATCH] feat(traverse): add `TraverseCtx::generate_uid_in_current_hoist_scope_based_on_node` (#7642) We have a lot of usage for this API in `class-properties` --- crates/oxc_traverse/src/context/mod.rs | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/crates/oxc_traverse/src/context/mod.rs b/crates/oxc_traverse/src/context/mod.rs index 18b5ed65a3d10..710ac8723d617 100644 --- a/crates/oxc_traverse/src/context/mod.rs +++ b/crates/oxc_traverse/src/context/mod.rs @@ -427,6 +427,19 @@ impl<'a> TraverseCtx<'a> { self.generate_uid(name, self.current_hoist_scope_id(), SymbolFlags::FunctionScopedVariable) } + /// Generate UID in current hoist scope based on node. + /// + /// See also comments on [`TraverseScoping::generate_uid_name`] for important information + /// on how UIDs are generated. There are some potential "gotchas". + #[inline] + pub fn generate_uid_in_current_hoist_scope_based_on_node>( + &mut self, + node: &N, + ) -> BoundIdentifier<'a> { + let name = get_var_name_from_node(node); + self.generate_uid_in_current_hoist_scope(&name) + } + /// Create a reference bound to a `SymbolId`. /// /// This is a shortcut for `ctx.scoping.create_bound_reference`.