1 //===-- SBThreadPlan.cpp ----------------------------------------*- C++ -*-===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 #include "lldb/API/SBThread.h"
12 #include "lldb/API/SBFileSpec.h"
13 #include "lldb/API/SBStream.h"
14 #include "lldb/API/SBSymbolContext.h"
15 #include "lldb/Breakpoint/BreakpointLocation.h"
16 #include "lldb/Core/Debugger.h"
17 #include "lldb/Core/StreamFile.h"
18 #include "lldb/Interpreter/CommandInterpreter.h"
19 #include "lldb/Symbol/CompileUnit.h"
20 #include "lldb/Symbol/SymbolContext.h"
21 #include "lldb/Target/Process.h"
22 #include "lldb/Target/Queue.h"
23 #include "lldb/Target/StopInfo.h"
24 #include "lldb/Target/SystemRuntime.h"
25 #include "lldb/Target/Target.h"
26 #include "lldb/Target/Thread.h"
27 #include "lldb/Target/ThreadPlan.h"
28 #include "lldb/Target/ThreadPlanPython.h"
29 #include "lldb/Target/ThreadPlanStepInRange.h"
30 #include "lldb/Target/ThreadPlanStepInstruction.h"
31 #include "lldb/Target/ThreadPlanStepOut.h"
32 #include "lldb/Target/ThreadPlanStepRange.h"
33 #include "lldb/Utility/State.h"
34 #include "lldb/Utility/Stream.h"
35 #include "lldb/Utility/StructuredData.h"
37 #include "lldb/API/SBAddress.h"
38 #include "lldb/API/SBDebugger.h"
39 #include "lldb/API/SBEvent.h"
40 #include "lldb/API/SBFrame.h"
41 #include "lldb/API/SBProcess.h"
42 #include "lldb/API/SBThreadPlan.h"
43 #include "lldb/API/SBValue.h"
46 using namespace lldb_private;
48 //----------------------------------------------------------------------
50 //----------------------------------------------------------------------
51 SBThreadPlan::SBThreadPlan() {}
53 SBThreadPlan::SBThreadPlan(const ThreadPlanSP &lldb_object_sp)
54 : m_opaque_sp(lldb_object_sp) {}
56 SBThreadPlan::SBThreadPlan(const SBThreadPlan &rhs)
57 : m_opaque_sp(rhs.m_opaque_sp) {}
59 SBThreadPlan::SBThreadPlan(lldb::SBThread &sb_thread, const char *class_name) {
60 Thread *thread = sb_thread.get();
62 m_opaque_sp.reset(new ThreadPlanPython(*thread, class_name));
65 //----------------------------------------------------------------------
66 // Assignment operator
67 //----------------------------------------------------------------------
69 const lldb::SBThreadPlan &SBThreadPlan::operator=(const SBThreadPlan &rhs) {
71 m_opaque_sp = rhs.m_opaque_sp;
74 //----------------------------------------------------------------------
76 //----------------------------------------------------------------------
77 SBThreadPlan::~SBThreadPlan() {}
79 lldb_private::ThreadPlan *SBThreadPlan::get() { return m_opaque_sp.get(); }
81 bool SBThreadPlan::IsValid() const { return m_opaque_sp.get() != NULL; }
83 void SBThreadPlan::Clear() { m_opaque_sp.reset(); }
85 lldb::StopReason SBThreadPlan::GetStopReason() { return eStopReasonNone; }
87 size_t SBThreadPlan::GetStopReasonDataCount() { return 0; }
89 uint64_t SBThreadPlan::GetStopReasonDataAtIndex(uint32_t idx) { return 0; }
91 SBThread SBThreadPlan::GetThread() const {
93 return SBThread(m_opaque_sp->GetThread().shared_from_this());
98 bool SBThreadPlan::GetDescription(lldb::SBStream &description) const {
100 m_opaque_sp->GetDescription(description.get(), eDescriptionLevelFull);
102 description.Printf("Empty SBThreadPlan");
107 void SBThreadPlan::SetThreadPlan(const ThreadPlanSP &lldb_object_sp) {
108 m_opaque_sp = lldb_object_sp;
111 void SBThreadPlan::SetPlanComplete(bool success) {
113 m_opaque_sp->SetPlanComplete(success);
116 bool SBThreadPlan::IsPlanComplete() {
118 return m_opaque_sp->IsPlanComplete();
123 bool SBThreadPlan::IsPlanStale() {
125 return m_opaque_sp->IsPlanStale();
130 bool SBThreadPlan::IsValid() {
132 return m_opaque_sp->ValidatePlan(nullptr);
137 // This section allows an SBThreadPlan to push another of the common types of
140 // FIXME, you should only be able to queue thread plans from inside the methods
141 // of a Scripted Thread Plan. Need a way to enforce that.
144 SBThreadPlan::QueueThreadPlanForStepOverRange(SBAddress &sb_start_address,
147 return QueueThreadPlanForStepOverRange(sb_start_address, size, error);
150 SBThreadPlan SBThreadPlan::QueueThreadPlanForStepOverRange(
151 SBAddress &sb_start_address, lldb::addr_t size, SBError &error) {
153 Address *start_address = sb_start_address.get();
154 if (!start_address) {
155 return SBThreadPlan();
158 AddressRange range(*start_address, size);
160 start_address->CalculateSymbolContext(&sc);
164 SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForStepOverRange(
165 false, range, sc, eAllThreads, plan_status));
167 if (plan_status.Fail())
168 error.SetErrorString(plan_status.AsCString());
172 return SBThreadPlan();
177 SBThreadPlan::QueueThreadPlanForStepInRange(SBAddress &sb_start_address,
180 return QueueThreadPlanForStepInRange(sb_start_address, size, error);
184 SBThreadPlan::QueueThreadPlanForStepInRange(SBAddress &sb_start_address,
185 lldb::addr_t size, SBError &error) {
187 Address *start_address = sb_start_address.get();
188 if (!start_address) {
189 return SBThreadPlan();
192 AddressRange range(*start_address, size);
194 start_address->CalculateSymbolContext(&sc);
198 SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForStepInRange(
199 false, range, sc, NULL, eAllThreads, plan_status));
201 if (plan_status.Fail())
202 error.SetErrorString(plan_status.AsCString());
206 return SBThreadPlan();
211 SBThreadPlan::QueueThreadPlanForStepOut(uint32_t frame_idx_to_step_to,
214 return QueueThreadPlanForStepOut(frame_idx_to_step_to, first_insn, error);
218 SBThreadPlan::QueueThreadPlanForStepOut(uint32_t frame_idx_to_step_to,
219 bool first_insn, SBError &error) {
222 sc = m_opaque_sp->GetThread().GetStackFrameAtIndex(0)->GetSymbolContext(
223 lldb::eSymbolContextEverything);
227 SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForStepOut(
228 false, &sc, first_insn, false, eVoteYes, eVoteNoOpinion,
229 frame_idx_to_step_to, plan_status));
231 if (plan_status.Fail())
232 error.SetErrorString(plan_status.AsCString());
236 return SBThreadPlan();
241 SBThreadPlan::QueueThreadPlanForRunToAddress(SBAddress sb_address) {
243 return QueueThreadPlanForRunToAddress(sb_address, error);
246 SBThreadPlan SBThreadPlan::QueueThreadPlanForRunToAddress(SBAddress sb_address,
249 Address *address = sb_address.get();
251 return SBThreadPlan();
255 SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForRunToAddress(
256 false, *address, false, plan_status));
258 if (plan_status.Fail())
259 error.SetErrorString(plan_status.AsCString());
263 return SBThreadPlan();
268 SBThreadPlan::QueueThreadPlanForStepScripted(const char *script_class_name) {
270 return QueueThreadPlanForStepScripted(script_class_name, error);
274 SBThreadPlan::QueueThreadPlanForStepScripted(const char *script_class_name,
279 SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForStepScripted(
280 false, script_class_name, false, plan_status));
282 if (plan_status.Fail())
283 error.SetErrorString(plan_status.AsCString());
287 return SBThreadPlan();