Fixes bug that would stop iterating inline site syms early

This fix reveals another bug--we need to display the inline site syms in
the reverse of the encoded order. The parent/child relationships are
actually encoded on the inline sites, but it's likely a bit fragile to
try to trace those, and also more complex. As long as there aren't
multiple matches this is fine, and if there are, tracing the parent/child
chain won't work anyway.
This commit is contained in:
Mason Remaley
2026-04-06 15:22:45 -07:00
parent 156f54d8f0
commit 5c6885be53
+2 -1
View File
@@ -62,7 +62,8 @@ pub const SymbolIterator = struct {
const pdb = if (di.pdb) |*pdb| pdb else unreachable;
// Get the next inlinee if it exists
if (info.inlinees.next(info.module)) |site| {
while (info.inlinees.next(info.module)) |site| {
const parent: *align(1) const std.pdb.RecordPrefix = @ptrCast(&info.module.symbols[site.parent - @sizeOf(u16) * 2]);
if (pdb.getInlineeInfo(info.module, site.inlinee) catch null) |loc| {
if (info.proc_sym) |proc_sym| {
const offset_in_func = info.addr - proc_sym.code_offset;