130fdc8d8SChris Lattner //===-- SBThread.cpp --------------------------------------------*- C++ -*-===//
230fdc8d8SChris Lattner //
330fdc8d8SChris Lattner //                     The LLVM Compiler Infrastructure
430fdc8d8SChris Lattner //
530fdc8d8SChris Lattner // This file is distributed under the University of Illinois Open Source
630fdc8d8SChris Lattner // License. See LICENSE.TXT for details.
730fdc8d8SChris Lattner //
830fdc8d8SChris Lattner //===----------------------------------------------------------------------===//
930fdc8d8SChris Lattner 
104c5de699SEli Friedman #include "lldb/API/SBThread.h"
1130fdc8d8SChris Lattner 
1230fdc8d8SChris Lattner #include "lldb/API/SBSymbolContext.h"
1330fdc8d8SChris Lattner #include "lldb/API/SBFileSpec.h"
14dde9cff3SCaroline Tice #include "lldb/API/SBStream.h"
156611103cSGreg Clayton #include "lldb/Core/Debugger.h"
1630fdc8d8SChris Lattner #include "lldb/Core/Stream.h"
1730fdc8d8SChris Lattner #include "lldb/Core/StreamFile.h"
186611103cSGreg Clayton #include "lldb/Interpreter/CommandInterpreter.h"
1930fdc8d8SChris Lattner #include "lldb/Target/Thread.h"
2030fdc8d8SChris Lattner #include "lldb/Target/Process.h"
2130fdc8d8SChris Lattner #include "lldb/Symbol/SymbolContext.h"
2230fdc8d8SChris Lattner #include "lldb/Symbol/CompileUnit.h"
23f4b47e15SGreg Clayton #include "lldb/Target/StopInfo.h"
2430fdc8d8SChris Lattner #include "lldb/Target/Target.h"
2530fdc8d8SChris Lattner #include "lldb/Target/ThreadPlan.h"
2630fdc8d8SChris Lattner #include "lldb/Target/ThreadPlanStepInstruction.h"
2730fdc8d8SChris Lattner #include "lldb/Target/ThreadPlanStepOut.h"
2830fdc8d8SChris Lattner #include "lldb/Target/ThreadPlanStepRange.h"
2930fdc8d8SChris Lattner #include "lldb/Target/ThreadPlanStepInRange.h"
3030fdc8d8SChris Lattner 
3130fdc8d8SChris Lattner 
324c5de699SEli Friedman #include "lldb/API/SBAddress.h"
334c5de699SEli Friedman #include "lldb/API/SBFrame.h"
344c5de699SEli Friedman #include "lldb/API/SBSourceManager.h"
354c5de699SEli Friedman #include "lldb/API/SBDebugger.h"
364c5de699SEli Friedman #include "lldb/API/SBProcess.h"
3730fdc8d8SChris Lattner 
3830fdc8d8SChris Lattner using namespace lldb;
3930fdc8d8SChris Lattner using namespace lldb_private;
4030fdc8d8SChris Lattner 
4130fdc8d8SChris Lattner SBThread::SBThread () :
426611103cSGreg Clayton     m_opaque_sp ()
4330fdc8d8SChris Lattner {
4430fdc8d8SChris Lattner }
4530fdc8d8SChris Lattner 
4630fdc8d8SChris Lattner //----------------------------------------------------------------------
4730fdc8d8SChris Lattner // Thread constructor
4830fdc8d8SChris Lattner //----------------------------------------------------------------------
4930fdc8d8SChris Lattner SBThread::SBThread (const ThreadSP& lldb_object_sp) :
506611103cSGreg Clayton     m_opaque_sp (lldb_object_sp)
5130fdc8d8SChris Lattner {
52*750cd175SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
53ceb6b139SCaroline Tice 
54ceb6b139SCaroline Tice     if (log)
55*750cd175SCaroline Tice     {
56*750cd175SCaroline Tice         SBStream sstr;
57*750cd175SCaroline Tice         GetDescription (sstr);
58*750cd175SCaroline Tice         log->Printf ("SBThread::SBThread (lldb_object_sp=%p) => this.sp = %p (%s)",
59*750cd175SCaroline Tice                      lldb_object_sp.get(), m_opaque_sp.get(), sstr.GetData());
60*750cd175SCaroline Tice     }
6130fdc8d8SChris Lattner }
6230fdc8d8SChris Lattner 
6330fdc8d8SChris Lattner SBThread::SBThread (const SBThread &rhs)
6430fdc8d8SChris Lattner {
65*750cd175SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
66ceb6b139SCaroline Tice 
676611103cSGreg Clayton     m_opaque_sp = rhs.m_opaque_sp;
68*750cd175SCaroline Tice 
69*750cd175SCaroline Tice     if (log)
70*750cd175SCaroline Tice         log->Printf ("SBThread::SBThread (rhs.sp=%p) => this.sp = %p",
71*750cd175SCaroline Tice                      rhs.m_opaque_sp.get(), m_opaque_sp.get());
72*750cd175SCaroline Tice 
7330fdc8d8SChris Lattner }
7430fdc8d8SChris Lattner 
7530fdc8d8SChris Lattner //----------------------------------------------------------------------
7630fdc8d8SChris Lattner // Destructor
7730fdc8d8SChris Lattner //----------------------------------------------------------------------
7830fdc8d8SChris Lattner SBThread::~SBThread()
7930fdc8d8SChris Lattner {
8030fdc8d8SChris Lattner }
8130fdc8d8SChris Lattner 
8230fdc8d8SChris Lattner bool
8330fdc8d8SChris Lattner SBThread::IsValid() const
8430fdc8d8SChris Lattner {
856611103cSGreg Clayton     return m_opaque_sp != NULL;
8630fdc8d8SChris Lattner }
8730fdc8d8SChris Lattner 
8848e42549SGreg Clayton void
8948e42549SGreg Clayton SBThread::Clear ()
9048e42549SGreg Clayton {
9148e42549SGreg Clayton     m_opaque_sp.reset();
9248e42549SGreg Clayton }
9348e42549SGreg Clayton 
9448e42549SGreg Clayton 
9530fdc8d8SChris Lattner StopReason
9630fdc8d8SChris Lattner SBThread::GetStopReason()
9730fdc8d8SChris Lattner {
98ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
99ceb6b139SCaroline Tice 
100*750cd175SCaroline Tice     //if (log)
101*750cd175SCaroline Tice     //    log->Printf ("SBThread::GetStopReason ()");
102ceb6b139SCaroline Tice 
103ceb6b139SCaroline Tice     StopReason reason = eStopReasonInvalid;
1046611103cSGreg Clayton     if (m_opaque_sp)
10530fdc8d8SChris Lattner     {
106b15bfc75SJim Ingham         StopInfoSP stop_info_sp = m_opaque_sp->GetStopInfo ();
107b15bfc75SJim Ingham         if (stop_info_sp)
108ceb6b139SCaroline Tice             reason =  stop_info_sp->GetStopReason();
10930fdc8d8SChris Lattner     }
110ceb6b139SCaroline Tice 
111ceb6b139SCaroline Tice     if (log)
112*750cd175SCaroline Tice         log->Printf ("SBThread::GetStopReason (this.sp=%p) => '%s'", m_opaque_sp.get(),
113*750cd175SCaroline Tice                      Thread::StopReasonAsCString (reason));
114ceb6b139SCaroline Tice 
115ceb6b139SCaroline Tice     return reason;
11630fdc8d8SChris Lattner }
11730fdc8d8SChris Lattner 
11830fdc8d8SChris Lattner size_t
11930fdc8d8SChris Lattner SBThread::GetStopDescription (char *dst, size_t dst_len)
12030fdc8d8SChris Lattner {
121ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
122ceb6b139SCaroline Tice 
123*750cd175SCaroline Tice     //if (log)
124*750cd175SCaroline Tice     //    log->Printf ("SBThread::GetStopDescription (char *dst, size_t dst_len)");
125ceb6b139SCaroline Tice 
1266611103cSGreg Clayton     if (m_opaque_sp)
12730fdc8d8SChris Lattner     {
128b15bfc75SJim Ingham         StopInfoSP stop_info_sp = m_opaque_sp->GetStopInfo ();
129b15bfc75SJim Ingham         if (stop_info_sp)
13030fdc8d8SChris Lattner         {
131b15bfc75SJim Ingham             const char *stop_desc = stop_info_sp->GetDescription();
13230fdc8d8SChris Lattner             if (stop_desc)
13330fdc8d8SChris Lattner             {
134ceb6b139SCaroline Tice                 if (log)
135*750cd175SCaroline Tice                     log->Printf ("SBThread::GetStopDescription (this.sp=%p, dst, dst_len) => '%s'",
136*750cd175SCaroline Tice                                  m_opaque_sp.get(), stop_desc);
13730fdc8d8SChris Lattner                 if (dst)
13830fdc8d8SChris Lattner                     return ::snprintf (dst, dst_len, "%s", stop_desc);
13930fdc8d8SChris Lattner                 else
14030fdc8d8SChris Lattner                 {
14130fdc8d8SChris Lattner                     // NULL dst passed in, return the length needed to contain the description
14230fdc8d8SChris Lattner                     return ::strlen (stop_desc) + 1; // Include the NULL byte for size
14330fdc8d8SChris Lattner                 }
14430fdc8d8SChris Lattner             }
14530fdc8d8SChris Lattner             else
14630fdc8d8SChris Lattner             {
14730fdc8d8SChris Lattner                 size_t stop_desc_len = 0;
148b15bfc75SJim Ingham                 switch (stop_info_sp->GetStopReason())
14930fdc8d8SChris Lattner                 {
15030fdc8d8SChris Lattner                 case eStopReasonTrace:
15130fdc8d8SChris Lattner                 case eStopReasonPlanComplete:
15230fdc8d8SChris Lattner                     {
15330fdc8d8SChris Lattner                         static char trace_desc[] = "step";
15430fdc8d8SChris Lattner                         stop_desc = trace_desc;
15530fdc8d8SChris Lattner                         stop_desc_len = sizeof(trace_desc); // Include the NULL byte for size
15630fdc8d8SChris Lattner                     }
15730fdc8d8SChris Lattner                     break;
15830fdc8d8SChris Lattner 
15930fdc8d8SChris Lattner                 case eStopReasonBreakpoint:
16030fdc8d8SChris Lattner                     {
16130fdc8d8SChris Lattner                         static char bp_desc[] = "breakpoint hit";
16230fdc8d8SChris Lattner                         stop_desc = bp_desc;
16330fdc8d8SChris Lattner                         stop_desc_len = sizeof(bp_desc); // Include the NULL byte for size
16430fdc8d8SChris Lattner                     }
16530fdc8d8SChris Lattner                     break;
16630fdc8d8SChris Lattner 
16730fdc8d8SChris Lattner                 case eStopReasonWatchpoint:
16830fdc8d8SChris Lattner                     {
16930fdc8d8SChris Lattner                         static char wp_desc[] = "watchpoint hit";
17030fdc8d8SChris Lattner                         stop_desc = wp_desc;
17130fdc8d8SChris Lattner                         stop_desc_len = sizeof(wp_desc); // Include the NULL byte for size
17230fdc8d8SChris Lattner                     }
17330fdc8d8SChris Lattner                     break;
17430fdc8d8SChris Lattner 
17530fdc8d8SChris Lattner                 case eStopReasonSignal:
17630fdc8d8SChris Lattner                     {
177b15bfc75SJim Ingham                         stop_desc = m_opaque_sp->GetProcess().GetUnixSignals ().GetSignalAsCString (stop_info_sp->GetValue());
17830fdc8d8SChris Lattner                         if (stop_desc == NULL || stop_desc[0] == '\0')
17930fdc8d8SChris Lattner                         {
18030fdc8d8SChris Lattner                             static char signal_desc[] = "signal";
18130fdc8d8SChris Lattner                             stop_desc = signal_desc;
18230fdc8d8SChris Lattner                             stop_desc_len = sizeof(signal_desc); // Include the NULL byte for size
18330fdc8d8SChris Lattner                         }
18430fdc8d8SChris Lattner                     }
18530fdc8d8SChris Lattner                     break;
18630fdc8d8SChris Lattner 
18730fdc8d8SChris Lattner                 case eStopReasonException:
18830fdc8d8SChris Lattner                     {
18930fdc8d8SChris Lattner                         char exc_desc[] = "exception";
19030fdc8d8SChris Lattner                         stop_desc = exc_desc;
19130fdc8d8SChris Lattner                         stop_desc_len = sizeof(exc_desc); // Include the NULL byte for size
19230fdc8d8SChris Lattner                     }
19330fdc8d8SChris Lattner                     break;
194c982c768SGreg Clayton 
195c982c768SGreg Clayton                 default:
196c982c768SGreg Clayton                     break;
19730fdc8d8SChris Lattner                 }
19830fdc8d8SChris Lattner 
19930fdc8d8SChris Lattner                 if (stop_desc && stop_desc[0])
20030fdc8d8SChris Lattner                 {
201ceb6b139SCaroline Tice                     if (log)
202*750cd175SCaroline Tice                         log->Printf ("SBThread::GetStopDescription (this.sp=%p, dst, dst_len) => '%s'",
203*750cd175SCaroline Tice                                      m_opaque_sp.get(), stop_desc);
204ceb6b139SCaroline Tice 
20530fdc8d8SChris Lattner                     if (dst)
20630fdc8d8SChris Lattner                         return ::snprintf (dst, dst_len, "%s", stop_desc) + 1; // Include the NULL byte
20730fdc8d8SChris Lattner 
20830fdc8d8SChris Lattner                     if (stop_desc_len == 0)
20930fdc8d8SChris Lattner                         stop_desc_len = ::strlen (stop_desc) + 1; // Include the NULL byte
21030fdc8d8SChris Lattner 
21130fdc8d8SChris Lattner                     return stop_desc_len;
21230fdc8d8SChris Lattner                 }
21330fdc8d8SChris Lattner             }
21430fdc8d8SChris Lattner         }
21530fdc8d8SChris Lattner     }
21630fdc8d8SChris Lattner     if (dst)
21730fdc8d8SChris Lattner         *dst = 0;
21830fdc8d8SChris Lattner     return 0;
21930fdc8d8SChris Lattner }
22030fdc8d8SChris Lattner 
22130fdc8d8SChris Lattner void
22230fdc8d8SChris Lattner SBThread::SetThread (const ThreadSP& lldb_object_sp)
22330fdc8d8SChris Lattner {
2246611103cSGreg Clayton     m_opaque_sp = lldb_object_sp;
22530fdc8d8SChris Lattner }
22630fdc8d8SChris Lattner 
22730fdc8d8SChris Lattner 
22830fdc8d8SChris Lattner lldb::tid_t
22930fdc8d8SChris Lattner SBThread::GetThreadID () const
23030fdc8d8SChris Lattner {
231ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
232ceb6b139SCaroline Tice 
233*750cd175SCaroline Tice     //if (log)
234*750cd175SCaroline Tice     //    log->Printf ("SBThread::GetThreadID()");
235ceb6b139SCaroline Tice 
236ceb6b139SCaroline Tice     lldb::tid_t id = LLDB_INVALID_THREAD_ID;
2376611103cSGreg Clayton     if (m_opaque_sp)
238ceb6b139SCaroline Tice         id = m_opaque_sp->GetID();
239ceb6b139SCaroline Tice 
240ceb6b139SCaroline Tice     if (log)
241*750cd175SCaroline Tice         log->Printf ("SBThread::GetThreadID (this.sp=%p) => %d", m_opaque_sp.get(), (uint32_t) id);
242ceb6b139SCaroline Tice 
243ceb6b139SCaroline Tice     return id;
24430fdc8d8SChris Lattner }
24530fdc8d8SChris Lattner 
24630fdc8d8SChris Lattner uint32_t
24730fdc8d8SChris Lattner SBThread::GetIndexID () const
24830fdc8d8SChris Lattner {
2496611103cSGreg Clayton     if (m_opaque_sp)
2506611103cSGreg Clayton         return m_opaque_sp->GetIndexID();
25130fdc8d8SChris Lattner     return LLDB_INVALID_INDEX32;
25230fdc8d8SChris Lattner }
25330fdc8d8SChris Lattner const char *
25430fdc8d8SChris Lattner SBThread::GetName () const
25530fdc8d8SChris Lattner {
256ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
257ceb6b139SCaroline Tice 
258*750cd175SCaroline Tice     //if (log)
259*750cd175SCaroline Tice     //    log->Printf ("SBThread::GetName ()");
260ceb6b139SCaroline Tice 
2616611103cSGreg Clayton     if (m_opaque_sp)
262ceb6b139SCaroline Tice     {
263ceb6b139SCaroline Tice         if (log)
264*750cd175SCaroline Tice             log->Printf ("SBThread::GetName (this.sp=%p) => '%s'", m_opaque_sp.get(), m_opaque_sp->GetName());
2656611103cSGreg Clayton         return m_opaque_sp->GetName();
266ceb6b139SCaroline Tice     }
267ceb6b139SCaroline Tice 
268ceb6b139SCaroline Tice     if (log)
269*750cd175SCaroline Tice         log->Printf ("SBThread::GetName (this.sp=%p) => NULL", m_opaque_sp.get());
270ceb6b139SCaroline Tice 
27130fdc8d8SChris Lattner     return NULL;
27230fdc8d8SChris Lattner }
27330fdc8d8SChris Lattner 
27430fdc8d8SChris Lattner const char *
27530fdc8d8SChris Lattner SBThread::GetQueueName () const
27630fdc8d8SChris Lattner {
277ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
278ceb6b139SCaroline Tice 
279*750cd175SCaroline Tice     //if (log)
280*750cd175SCaroline Tice     //    log->Printf ("SBThread::GetQueueName ()");
281ceb6b139SCaroline Tice 
2826611103cSGreg Clayton     if (m_opaque_sp)
283ceb6b139SCaroline Tice     {
284ceb6b139SCaroline Tice         if (log)
285*750cd175SCaroline Tice             log->Printf ("SBThread::GetQueueName (this.sp=%p) => '%s'", m_opaque_sp.get(),
286*750cd175SCaroline Tice                          m_opaque_sp->GetQueueName());
2876611103cSGreg Clayton         return m_opaque_sp->GetQueueName();
288ceb6b139SCaroline Tice     }
289ceb6b139SCaroline Tice 
290ceb6b139SCaroline Tice     if (log)
291*750cd175SCaroline Tice         log->Printf ("SBThread::GetQueueName (this.sp=%p) => NULL", m_opaque_sp.get());
292ceb6b139SCaroline Tice 
29330fdc8d8SChris Lattner     return NULL;
29430fdc8d8SChris Lattner }
29530fdc8d8SChris Lattner 
29630fdc8d8SChris Lattner 
29730fdc8d8SChris Lattner void
29830fdc8d8SChris Lattner SBThread::StepOver (lldb::RunMode stop_other_threads)
29930fdc8d8SChris Lattner {
300ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
301ceb6b139SCaroline Tice 
302ceb6b139SCaroline Tice     if (log)
303*750cd175SCaroline Tice         log->Printf ("SBThread::StepOver (this.sp=%p, stop_other_threads='%s')", m_opaque_sp.get(),
304ceb6b139SCaroline Tice                      Thread::RunModeAsCString (stop_other_threads));
305ceb6b139SCaroline Tice 
3066611103cSGreg Clayton     if (m_opaque_sp)
30730fdc8d8SChris Lattner     {
30830fdc8d8SChris Lattner         bool abort_other_plans = true;
3096611103cSGreg Clayton         StackFrameSP frame_sp(m_opaque_sp->GetStackFrameAtIndex (0));
31030fdc8d8SChris Lattner 
31130fdc8d8SChris Lattner         if (frame_sp)
31230fdc8d8SChris Lattner         {
31330fdc8d8SChris Lattner             if (frame_sp->HasDebugInformation ())
31430fdc8d8SChris Lattner             {
31530fdc8d8SChris Lattner                 SymbolContext sc(frame_sp->GetSymbolContext(eSymbolContextEverything));
3166611103cSGreg Clayton                 m_opaque_sp->QueueThreadPlanForStepRange (abort_other_plans,
31730fdc8d8SChris Lattner                                                           eStepTypeOver,
31830fdc8d8SChris Lattner                                                           sc.line_entry.range,
31930fdc8d8SChris Lattner                                                           sc,
320474966a4SGreg Clayton                                                           stop_other_threads,
321474966a4SGreg Clayton                                                           false);
32230fdc8d8SChris Lattner 
32330fdc8d8SChris Lattner             }
32430fdc8d8SChris Lattner             else
32530fdc8d8SChris Lattner             {
3266611103cSGreg Clayton                 m_opaque_sp->QueueThreadPlanForStepSingleInstruction (true,
32730fdc8d8SChris Lattner                                                                       abort_other_plans,
32830fdc8d8SChris Lattner                                                                       stop_other_threads);
32930fdc8d8SChris Lattner             }
33030fdc8d8SChris Lattner         }
33130fdc8d8SChris Lattner 
3326611103cSGreg Clayton         Process &process = m_opaque_sp->GetProcess();
33330fdc8d8SChris Lattner         // Why do we need to set the current thread by ID here???
3342976d00aSJim Ingham         process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID());
3355d5028b5SGreg Clayton         Error error (process.Resume());
3365d5028b5SGreg Clayton         if (error.Success())
3375d5028b5SGreg Clayton         {
3385d5028b5SGreg Clayton             // If we are doing synchronous mode, then wait for the
3395d5028b5SGreg Clayton             // process to stop yet again!
3405d5028b5SGreg Clayton             if (process.GetTarget().GetDebugger().GetAsyncExecution () == false)
3415d5028b5SGreg Clayton                 process.WaitForProcessToStop (NULL);
3425d5028b5SGreg Clayton         }
34330fdc8d8SChris Lattner     }
34430fdc8d8SChris Lattner }
34530fdc8d8SChris Lattner 
34630fdc8d8SChris Lattner void
34730fdc8d8SChris Lattner SBThread::StepInto (lldb::RunMode stop_other_threads)
34830fdc8d8SChris Lattner {
349ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
350ceb6b139SCaroline Tice 
351ceb6b139SCaroline Tice     if (log)
352*750cd175SCaroline Tice         log->Printf ("SBThread::StepInto (this.sp=%p, stop_other_threads='%s')", m_opaque_sp.get(),
353ceb6b139SCaroline Tice                      Thread::RunModeAsCString (stop_other_threads));
354ceb6b139SCaroline Tice 
3556611103cSGreg Clayton     if (m_opaque_sp)
35630fdc8d8SChris Lattner     {
35730fdc8d8SChris Lattner         bool abort_other_plans = true;
35830fdc8d8SChris Lattner 
3596611103cSGreg Clayton         StackFrameSP frame_sp(m_opaque_sp->GetStackFrameAtIndex (0));
36030fdc8d8SChris Lattner 
36130fdc8d8SChris Lattner         if (frame_sp && frame_sp->HasDebugInformation ())
36230fdc8d8SChris Lattner         {
363474966a4SGreg Clayton             bool avoid_code_without_debug_info = true;
36430fdc8d8SChris Lattner             SymbolContext sc(frame_sp->GetSymbolContext(eSymbolContextEverything));
3656611103cSGreg Clayton             m_opaque_sp->QueueThreadPlanForStepRange (abort_other_plans,
36630fdc8d8SChris Lattner                                                       eStepTypeInto,
36730fdc8d8SChris Lattner                                                       sc.line_entry.range,
36830fdc8d8SChris Lattner                                                       sc,
369474966a4SGreg Clayton                                                       stop_other_threads,
370474966a4SGreg Clayton                                                       avoid_code_without_debug_info);
37130fdc8d8SChris Lattner         }
37230fdc8d8SChris Lattner         else
37330fdc8d8SChris Lattner         {
3746611103cSGreg Clayton             m_opaque_sp->QueueThreadPlanForStepSingleInstruction (false,
37530fdc8d8SChris Lattner                                                                   abort_other_plans,
37630fdc8d8SChris Lattner                                                                   stop_other_threads);
37730fdc8d8SChris Lattner         }
37830fdc8d8SChris Lattner 
3796611103cSGreg Clayton         Process &process = m_opaque_sp->GetProcess();
38030fdc8d8SChris Lattner         // Why do we need to set the current thread by ID here???
3812976d00aSJim Ingham         process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID());
3825d5028b5SGreg Clayton         Error error (process.Resume());
3835d5028b5SGreg Clayton         if (error.Success())
3845d5028b5SGreg Clayton         {
3855d5028b5SGreg Clayton             // If we are doing synchronous mode, then wait for the
3865d5028b5SGreg Clayton             // process to stop yet again!
3875d5028b5SGreg Clayton             if (process.GetTarget().GetDebugger().GetAsyncExecution () == false)
3885d5028b5SGreg Clayton                 process.WaitForProcessToStop (NULL);
3895d5028b5SGreg Clayton         }
39030fdc8d8SChris Lattner     }
39130fdc8d8SChris Lattner }
39230fdc8d8SChris Lattner 
39330fdc8d8SChris Lattner void
39430fdc8d8SChris Lattner SBThread::StepOut ()
39530fdc8d8SChris Lattner {
396ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
397ceb6b139SCaroline Tice 
398ceb6b139SCaroline Tice     if (log)
399*750cd175SCaroline Tice         log->Printf ("SBThread::StepOut (this.sp=%p)", m_opaque_sp.get());
400ceb6b139SCaroline Tice 
4016611103cSGreg Clayton     if (m_opaque_sp)
40230fdc8d8SChris Lattner     {
40330fdc8d8SChris Lattner         bool abort_other_plans = true;
40430fdc8d8SChris Lattner         bool stop_other_threads = true;
40530fdc8d8SChris Lattner 
4066611103cSGreg Clayton         m_opaque_sp->QueueThreadPlanForStepOut (abort_other_plans, NULL, false, stop_other_threads, eVoteYes, eVoteNoOpinion);
40730fdc8d8SChris Lattner 
4086611103cSGreg Clayton         Process &process = m_opaque_sp->GetProcess();
4092976d00aSJim Ingham         process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID());
4105d5028b5SGreg Clayton         Error error (process.Resume());
4115d5028b5SGreg Clayton         if (error.Success())
4125d5028b5SGreg Clayton         {
4135d5028b5SGreg Clayton             // If we are doing synchronous mode, then wait for the
4145d5028b5SGreg Clayton             // process to stop yet again!
4155d5028b5SGreg Clayton             if (process.GetTarget().GetDebugger().GetAsyncExecution () == false)
4165d5028b5SGreg Clayton                 process.WaitForProcessToStop (NULL);
4175d5028b5SGreg Clayton         }
41830fdc8d8SChris Lattner     }
41930fdc8d8SChris Lattner }
42030fdc8d8SChris Lattner 
42130fdc8d8SChris Lattner void
42230fdc8d8SChris Lattner SBThread::StepInstruction (bool step_over)
42330fdc8d8SChris Lattner {
424ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
425ceb6b139SCaroline Tice 
426ceb6b139SCaroline Tice     if (log)
427*750cd175SCaroline Tice         log->Printf ("SBThread::StepInstruction (this.sp=%p, step_over=%s)", m_opaque_sp.get(),
428*750cd175SCaroline Tice                      (step_over ? "true" : "false"));
429ceb6b139SCaroline Tice 
4306611103cSGreg Clayton     if (m_opaque_sp)
43130fdc8d8SChris Lattner     {
4326611103cSGreg Clayton         m_opaque_sp->QueueThreadPlanForStepSingleInstruction (step_over, true, true);
4336611103cSGreg Clayton         Process &process = m_opaque_sp->GetProcess();
4342976d00aSJim Ingham         process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID());
4355d5028b5SGreg Clayton         Error error (process.Resume());
4365d5028b5SGreg Clayton         if (error.Success())
4375d5028b5SGreg Clayton         {
4385d5028b5SGreg Clayton             // If we are doing synchronous mode, then wait for the
4395d5028b5SGreg Clayton             // process to stop yet again!
4405d5028b5SGreg Clayton             if (process.GetTarget().GetDebugger().GetAsyncExecution () == false)
4415d5028b5SGreg Clayton                 process.WaitForProcessToStop (NULL);
4425d5028b5SGreg Clayton         }
44330fdc8d8SChris Lattner     }
44430fdc8d8SChris Lattner }
44530fdc8d8SChris Lattner 
44630fdc8d8SChris Lattner void
44730fdc8d8SChris Lattner SBThread::RunToAddress (lldb::addr_t addr)
44830fdc8d8SChris Lattner {
449ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
450ceb6b139SCaroline Tice 
451ceb6b139SCaroline Tice     if (log)
452*750cd175SCaroline Tice         log->Printf ("SBThread::RunToAddress (this.sp=%p, addr=%p)", m_opaque_sp.get(), addr);
453ceb6b139SCaroline Tice 
4546611103cSGreg Clayton     if (m_opaque_sp)
45530fdc8d8SChris Lattner     {
45630fdc8d8SChris Lattner         bool abort_other_plans = true;
45730fdc8d8SChris Lattner         bool stop_other_threads = true;
45830fdc8d8SChris Lattner 
45930fdc8d8SChris Lattner         Address target_addr (NULL, addr);
46030fdc8d8SChris Lattner 
4616611103cSGreg Clayton         m_opaque_sp->QueueThreadPlanForRunToAddress (abort_other_plans, target_addr, stop_other_threads);
4626611103cSGreg Clayton         Process &process = m_opaque_sp->GetProcess();
4632976d00aSJim Ingham         process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID());
4645d5028b5SGreg Clayton         Error error (process.Resume());
4655d5028b5SGreg Clayton         if (error.Success())
4665d5028b5SGreg Clayton         {
4675d5028b5SGreg Clayton             // If we are doing synchronous mode, then wait for the
4685d5028b5SGreg Clayton             // process to stop yet again!
4695d5028b5SGreg Clayton             if (process.GetTarget().GetDebugger().GetAsyncExecution () == false)
4705d5028b5SGreg Clayton                 process.WaitForProcessToStop (NULL);
4715d5028b5SGreg Clayton         }
47230fdc8d8SChris Lattner     }
47330fdc8d8SChris Lattner 
47430fdc8d8SChris Lattner }
47530fdc8d8SChris Lattner 
47630fdc8d8SChris Lattner SBProcess
47730fdc8d8SChris Lattner SBThread::GetProcess ()
47830fdc8d8SChris Lattner {
479ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
480ceb6b139SCaroline Tice 
481*750cd175SCaroline Tice     //if (log)
482*750cd175SCaroline Tice     //    log->Printf ("SBThread::GetProcess ()");
483ceb6b139SCaroline Tice 
48430fdc8d8SChris Lattner     SBProcess process;
4856611103cSGreg Clayton     if (m_opaque_sp)
48630fdc8d8SChris Lattner     {
48730fdc8d8SChris Lattner         // Have to go up to the target so we can get a shared pointer to our process...
4886611103cSGreg Clayton         process.SetProcess(m_opaque_sp->GetProcess().GetTarget().GetProcessSP());
48930fdc8d8SChris Lattner     }
490ceb6b139SCaroline Tice 
491ceb6b139SCaroline Tice     if (log)
492ceb6b139SCaroline Tice     {
493ceb6b139SCaroline Tice         SBStream sstr;
494ceb6b139SCaroline Tice         process.GetDescription (sstr);
495*750cd175SCaroline Tice         log->Printf ("SBThread::GetProcess (this.sp=%p) => SBProcess : this.sp = %p, '%s'", m_opaque_sp.get(),
496*750cd175SCaroline Tice                      process.get(), sstr.GetData());
497ceb6b139SCaroline Tice     }
498ceb6b139SCaroline Tice 
49930fdc8d8SChris Lattner     return process;
50030fdc8d8SChris Lattner }
50130fdc8d8SChris Lattner 
50230fdc8d8SChris Lattner uint32_t
50330fdc8d8SChris Lattner SBThread::GetNumFrames ()
50430fdc8d8SChris Lattner {
505ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
506ceb6b139SCaroline Tice 
507*750cd175SCaroline Tice     //if (log)
508*750cd175SCaroline Tice     //    log->Printf ("SBThread::GetNumFrames ()");
509ceb6b139SCaroline Tice 
510ceb6b139SCaroline Tice     uint32_t num_frames = 0;
5116611103cSGreg Clayton     if (m_opaque_sp)
512ceb6b139SCaroline Tice         num_frames = m_opaque_sp->GetStackFrameCount();
513ceb6b139SCaroline Tice 
514ceb6b139SCaroline Tice     if (log)
515*750cd175SCaroline Tice         log->Printf ("SBThread::GetNumFrames (this.sp=%p) => %d", m_opaque_sp.get(), num_frames);
516ceb6b139SCaroline Tice 
517ceb6b139SCaroline Tice     return num_frames;
51830fdc8d8SChris Lattner }
51930fdc8d8SChris Lattner 
52030fdc8d8SChris Lattner SBFrame
52130fdc8d8SChris Lattner SBThread::GetFrameAtIndex (uint32_t idx)
52230fdc8d8SChris Lattner {
523ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
524ceb6b139SCaroline Tice 
525*750cd175SCaroline Tice     //if (log)
526*750cd175SCaroline Tice     //    log->Printf ("SBThread::GetFrameAtIndex (uint32_t idx) idx = %d", idx);
527ceb6b139SCaroline Tice 
52830fdc8d8SChris Lattner     SBFrame sb_frame;
5296611103cSGreg Clayton     if (m_opaque_sp)
5306611103cSGreg Clayton         sb_frame.SetFrame (m_opaque_sp->GetStackFrameAtIndex (idx));
531ceb6b139SCaroline Tice 
532ceb6b139SCaroline Tice     if (log)
533ceb6b139SCaroline Tice     {
534ceb6b139SCaroline Tice         SBStream sstr;
535ceb6b139SCaroline Tice         sb_frame.GetDescription (sstr);
536*750cd175SCaroline Tice         log->Printf ("SBThread::GetFrameAtIndex (this.sp=%p, idx=%d) => SBFrame.sp : this = %p, '%s'",
537*750cd175SCaroline Tice                      m_opaque_sp.get(), idx, sb_frame.get(), sstr.GetData());
538ceb6b139SCaroline Tice     }
539ceb6b139SCaroline Tice 
54030fdc8d8SChris Lattner     return sb_frame;
54130fdc8d8SChris Lattner }
54230fdc8d8SChris Lattner 
54330fdc8d8SChris Lattner const lldb::SBThread &
54430fdc8d8SChris Lattner SBThread::operator = (const lldb::SBThread &rhs)
54530fdc8d8SChris Lattner {
546ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
547ceb6b139SCaroline Tice 
548ceb6b139SCaroline Tice     if (log)
549*750cd175SCaroline Tice         log->Printf ("SBThread::operator= (this.sp=%p, rhs.sp=%p)", m_opaque_sp.get(), rhs.m_opaque_sp.get());
550ceb6b139SCaroline Tice 
5516611103cSGreg Clayton     m_opaque_sp = rhs.m_opaque_sp;
55230fdc8d8SChris Lattner     return *this;
55330fdc8d8SChris Lattner }
55430fdc8d8SChris Lattner 
55530fdc8d8SChris Lattner bool
55630fdc8d8SChris Lattner SBThread::operator == (const SBThread &rhs) const
55730fdc8d8SChris Lattner {
5586611103cSGreg Clayton     return m_opaque_sp.get() == rhs.m_opaque_sp.get();
55930fdc8d8SChris Lattner }
56030fdc8d8SChris Lattner 
56130fdc8d8SChris Lattner bool
56230fdc8d8SChris Lattner SBThread::operator != (const SBThread &rhs) const
56330fdc8d8SChris Lattner {
5646611103cSGreg Clayton     return m_opaque_sp.get() != rhs.m_opaque_sp.get();
56530fdc8d8SChris Lattner }
56630fdc8d8SChris Lattner 
56730fdc8d8SChris Lattner lldb_private::Thread *
56830fdc8d8SChris Lattner SBThread::GetLLDBObjectPtr ()
56930fdc8d8SChris Lattner {
5706611103cSGreg Clayton     return m_opaque_sp.get();
57130fdc8d8SChris Lattner }
57230fdc8d8SChris Lattner 
57330fdc8d8SChris Lattner const lldb_private::Thread *
57430fdc8d8SChris Lattner SBThread::operator->() const
57530fdc8d8SChris Lattner {
5766611103cSGreg Clayton     return m_opaque_sp.get();
57730fdc8d8SChris Lattner }
57830fdc8d8SChris Lattner 
57930fdc8d8SChris Lattner const lldb_private::Thread &
58030fdc8d8SChris Lattner SBThread::operator*() const
58130fdc8d8SChris Lattner {
5826611103cSGreg Clayton     return *m_opaque_sp;
58330fdc8d8SChris Lattner }
58430fdc8d8SChris Lattner 
58530fdc8d8SChris Lattner lldb_private::Thread *
58630fdc8d8SChris Lattner SBThread::operator->()
58730fdc8d8SChris Lattner {
5886611103cSGreg Clayton     return m_opaque_sp.get();
58930fdc8d8SChris Lattner }
59030fdc8d8SChris Lattner 
59130fdc8d8SChris Lattner lldb_private::Thread &
59230fdc8d8SChris Lattner SBThread::operator*()
59330fdc8d8SChris Lattner {
5946611103cSGreg Clayton     return *m_opaque_sp;
59530fdc8d8SChris Lattner }
596dde9cff3SCaroline Tice 
597dde9cff3SCaroline Tice bool
598dde9cff3SCaroline Tice SBThread::GetDescription (SBStream &description)
599dde9cff3SCaroline Tice {
600dde9cff3SCaroline Tice     if (m_opaque_sp)
60105faeb71SGreg Clayton     {
60205faeb71SGreg Clayton         StreamString strm;
60305faeb71SGreg Clayton         description.Printf("SBThread: tid = 0x%4.4x", m_opaque_sp->GetID());
60405faeb71SGreg Clayton     }
605dde9cff3SCaroline Tice     else
606dde9cff3SCaroline Tice         description.Printf ("No value");
607dde9cff3SCaroline Tice 
608dde9cff3SCaroline Tice     return true;
609dde9cff3SCaroline Tice }
610ceb6b139SCaroline Tice 
611ceb6b139SCaroline Tice bool
612ceb6b139SCaroline Tice SBThread::GetDescription (SBStream &description) const
613ceb6b139SCaroline Tice {
614ceb6b139SCaroline Tice     if (m_opaque_sp)
615ceb6b139SCaroline Tice     {
616ceb6b139SCaroline Tice         StreamString strm;
617ceb6b139SCaroline Tice         description.Printf("SBThread: tid = 0x%4.4x", m_opaque_sp->GetID());
618ceb6b139SCaroline Tice     }
619ceb6b139SCaroline Tice     else
620ceb6b139SCaroline Tice         description.Printf ("No value");
621ceb6b139SCaroline Tice 
622ceb6b139SCaroline Tice     return true;
623ceb6b139SCaroline Tice }
624