From 14043ddbe44ebe6e0de3caff6f21e9c3e3bae48c Mon Sep 17 00:00:00 2001 From: rzvxa Date: Tue, 28 May 2024 16:39:12 +0330 Subject: [PATCH] improvement(semantic/cfg): better control flow for `ForStatement`s. --- crates/oxc_semantic/src/builder.rs | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/crates/oxc_semantic/src/builder.rs b/crates/oxc_semantic/src/builder.rs index 5c8e1705395b4c..f9694d1617f602 100644 --- a/crates/oxc_semantic/src/builder.rs +++ b/crates/oxc_semantic/src/builder.rs @@ -848,7 +848,7 @@ impl<'a> Visit<'a> for SemanticBuilder<'a> { } /* cfg */ - let body_graph_ix = self.cfg.new_basic_block(); + let before_body_graph_ix = self.cfg.new_basic_block(); let statement_state = self.cfg.preserve_state(self.current_node_id, StatementControlFlowType::UsesContinue); /* cfg */ @@ -856,10 +856,11 @@ impl<'a> Visit<'a> for SemanticBuilder<'a> { self.visit_statement(&stmt.body); /* cfg */ + let after_body_graph_ix = self.cfg.current_node_ix; let after_for_stmt = self.cfg.new_basic_block(); self.cfg.add_edge(before_for_graph_ix, test_graph_ix, EdgeType::Normal); - self.cfg.add_edge(after_test_graph_ix, body_graph_ix, EdgeType::Normal); - self.cfg.add_edge(body_graph_ix, update_graph_ix, EdgeType::Backedge); + self.cfg.add_edge(after_test_graph_ix, before_body_graph_ix, EdgeType::Normal); + self.cfg.add_edge(after_body_graph_ix, update_graph_ix, EdgeType::Backedge); self.cfg.add_edge(update_graph_ix, test_graph_ix, EdgeType::Backedge); self.cfg.add_edge(after_test_graph_ix, after_for_stmt, EdgeType::Normal);