[llvm] [Support] Avoid repeated hash lookups (NFC) (PR #132517)
Kazu Hirata via llvm-commits
llvm-commits at lists.llvm.org
Fri Mar 21 21:10:27 PDT 2025
https://github.com/kazutakahirata created https://github.com/llvm/llvm-project/pull/132517
None
>From 86f40bb23c6b6e4707fceec2dcaf40db4867f334 Mon Sep 17 00:00:00 2001
From: Kazu Hirata <kazu at google.com>
Date: Fri, 21 Mar 2025 08:34:03 -0700
Subject: [PATCH] [Support] Avoid repeated hash lookups (NFC)
---
llvm/lib/Support/SuffixTree.cpp | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/llvm/lib/Support/SuffixTree.cpp b/llvm/lib/Support/SuffixTree.cpp
index 5e58310e1128b..5abcead5037f4 100644
--- a/llvm/lib/Support/SuffixTree.cpp
+++ b/llvm/lib/Support/SuffixTree.cpp
@@ -193,7 +193,8 @@ unsigned SuffixTree::extend(unsigned EndIdx, unsigned SuffixesToAdd) {
unsigned FirstChar = Str[Active.Idx];
// Have we inserted anything starting with FirstChar at the current node?
- if (Active.Node->Children.count(FirstChar) == 0) {
+ if (auto It = Active.Node->Children.find(FirstChar);
+ It == Active.Node->Children.end()) {
// If not, then we can just insert a leaf and move to the next step.
insertLeaf(*Active.Node, EndIdx, FirstChar);
@@ -206,7 +207,7 @@ unsigned SuffixTree::extend(unsigned EndIdx, unsigned SuffixesToAdd) {
} else {
// There's a match with FirstChar, so look for the point in the tree to
// insert a new node.
- SuffixTreeNode *NextNode = Active.Node->Children[FirstChar];
+ SuffixTreeNode *NextNode = It->second;
unsigned SubstringLen = numElementsInSubstring(NextNode);
More information about the llvm-commits
mailing list