aboutsummaryrefslogtreecommitdiff
path: root/lldb/source/API/SBThread.cpp
diff options
context:
space:
mode:
authorAlex Langford <alangford@apple.com>2023-05-04 16:49:30 -0700
committerAlex Langford <alangford@apple.com>2023-05-04 16:49:30 -0700
commit3d6073a9c33005abf8c6fc074e434c90b36dccb9 (patch)
tree99bf2ad63bed6384dcc40cbbefeb12e2fe53de4d /lldb/source/API/SBThread.cpp
parent6f8b33f6dfd0a0f8d2522b6c832bd6298ae2f3f3 (diff)
downloadllvm-3d6073a9c33005abf8c6fc074e434c90b36dccb9.zip
llvm-3d6073a9c33005abf8c6fc074e434c90b36dccb9.tar.gz
llvm-3d6073a9c33005abf8c6fc074e434c90b36dccb9.tar.bz2
Revert "[lldb] Expose a const iterator for SymbolContextList"
This reverts commit 04aa943be8ed5c03092e2a90112ac638360ec253. This broke the debian buildbot and I'm not sure why. Reverting so I can investigate.
Diffstat (limited to 'lldb/source/API/SBThread.cpp')
-rw-r--r--lldb/source/API/SBThread.cpp22
1 files changed, 14 insertions, 8 deletions
diff --git a/lldb/source/API/SBThread.cpp b/lldb/source/API/SBThread.cpp
index 35cc45d..ef8a0ab 100644
--- a/lldb/source/API/SBThread.cpp
+++ b/lldb/source/API/SBThread.cpp
@@ -847,14 +847,20 @@ SBError SBThread::StepOverUntil(lldb::SBFrame &sb_frame,
SymbolContextList sc_list;
frame_sc.comp_unit->ResolveSymbolContext(location_spec,
eSymbolContextLineEntry, sc_list);
- for (const SymbolContext &sc : sc_list) {
- addr_t step_addr =
- sc.line_entry.range.GetBaseAddress().GetLoadAddress(target);
- if (step_addr != LLDB_INVALID_ADDRESS) {
- if (fun_range.ContainsLoadAddress(step_addr, target))
- step_over_until_addrs.push_back(step_addr);
- else
- all_in_function = false;
+ const uint32_t num_matches = sc_list.GetSize();
+ if (num_matches > 0) {
+ SymbolContext sc;
+ for (uint32_t i = 0; i < num_matches; ++i) {
+ if (sc_list.GetContextAtIndex(i, sc)) {
+ addr_t step_addr =
+ sc.line_entry.range.GetBaseAddress().GetLoadAddress(target);
+ if (step_addr != LLDB_INVALID_ADDRESS) {
+ if (fun_range.ContainsLoadAddress(step_addr, target))
+ step_over_until_addrs.push_back(step_addr);
+ else
+ all_in_function = false;
+ }
+ }
}
}