diff options
| author | Paul Buetow <paul@buetow.org> | 2026-03-06 16:45:07 +0200 |
|---|---|---|
| committer | Paul Buetow <paul@buetow.org> | 2026-03-06 16:45:07 +0200 |
| commit | a639ed055e540d57fc2de6a9e90eac30555515f8 (patch) | |
| tree | c22bc37fceb0c869ae20747ef1ee60ca2bfbc248 /internal/flamegraph/trie_insert.go | |
| parent | 3791264d60df194f144f8b55eeca8f7aa9ea0a6b (diff) | |
refactor: share trie insertion path logic (task 382)
Diffstat (limited to 'internal/flamegraph/trie_insert.go')
| -rw-r--r-- | internal/flamegraph/trie_insert.go | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/internal/flamegraph/trie_insert.go b/internal/flamegraph/trie_insert.go new file mode 100644 index 0000000..7748b4a --- /dev/null +++ b/internal/flamegraph/trie_insert.go @@ -0,0 +1,22 @@ +package flamegraph + +// insertTriePath follows or creates nodes for frames and adds value at the leaf. +func insertTriePath(root *trieNode, frames []string, value uint64) { + node := root + for _, frame := range frames { + if node.childMap == nil { + node.childMap = make(map[string]*trieNode) + } + child, ok := node.childMap[frame] + if !ok { + child = &trieNode{ + name: frame, + childMap: make(map[string]*trieNode), + } + node.children = append(node.children, child) + node.childMap[frame] = child + } + node = child + } + node.value += value +} |
