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 {
52750cd175SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
53ceb6b139SCaroline Tice 
54ceb6b139SCaroline Tice     if (log)
55750cd175SCaroline Tice     {
56750cd175SCaroline Tice         SBStream sstr;
57750cd175SCaroline Tice         GetDescription (sstr);
58*93aa84e8SGreg Clayton         log->Printf ("SBThread::SBThread (lldb_object_sp=%p) => SBThread(%p) :%s",
59750cd175SCaroline Tice                      lldb_object_sp.get(), m_opaque_sp.get(), sstr.GetData());
60750cd175SCaroline Tice     }
6130fdc8d8SChris Lattner }
6230fdc8d8SChris Lattner 
6330fdc8d8SChris Lattner SBThread::SBThread (const SBThread &rhs)
6430fdc8d8SChris Lattner {
65750cd175SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
66ceb6b139SCaroline Tice 
676611103cSGreg Clayton     m_opaque_sp = rhs.m_opaque_sp;
68750cd175SCaroline Tice 
69750cd175SCaroline Tice     if (log)
70*93aa84e8SGreg Clayton         log->Printf ("SBThread::SBThread (rhs.sp=%p) => SBThread(%p)",
71750cd175SCaroline Tice                      rhs.m_opaque_sp.get(), m_opaque_sp.get());
72750cd175SCaroline 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 
100ceb6b139SCaroline Tice     StopReason reason = eStopReasonInvalid;
1016611103cSGreg Clayton     if (m_opaque_sp)
10230fdc8d8SChris Lattner     {
103b15bfc75SJim Ingham         StopInfoSP stop_info_sp = m_opaque_sp->GetStopInfo ();
104b15bfc75SJim Ingham         if (stop_info_sp)
105ceb6b139SCaroline Tice             reason =  stop_info_sp->GetStopReason();
10630fdc8d8SChris Lattner     }
107ceb6b139SCaroline Tice 
108ceb6b139SCaroline Tice     if (log)
109*93aa84e8SGreg Clayton         log->Printf ("SBThread(%p)::GetStopReason () => '%s'", m_opaque_sp.get(),
110750cd175SCaroline Tice                      Thread::StopReasonAsCString (reason));
111ceb6b139SCaroline Tice 
112ceb6b139SCaroline Tice     return reason;
11330fdc8d8SChris Lattner }
11430fdc8d8SChris Lattner 
11530fdc8d8SChris Lattner size_t
11630fdc8d8SChris Lattner SBThread::GetStopDescription (char *dst, size_t dst_len)
11730fdc8d8SChris Lattner {
118ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
119ceb6b139SCaroline Tice 
1206611103cSGreg Clayton     if (m_opaque_sp)
12130fdc8d8SChris Lattner     {
122b15bfc75SJim Ingham         StopInfoSP stop_info_sp = m_opaque_sp->GetStopInfo ();
123b15bfc75SJim Ingham         if (stop_info_sp)
12430fdc8d8SChris Lattner         {
125b15bfc75SJim Ingham             const char *stop_desc = stop_info_sp->GetDescription();
12630fdc8d8SChris Lattner             if (stop_desc)
12730fdc8d8SChris Lattner             {
128ceb6b139SCaroline Tice                 if (log)
129*93aa84e8SGreg Clayton                     log->Printf ("SBThread(%p)::GetStopDescription (dst, dst_len) => '%s'",
130750cd175SCaroline Tice                                  m_opaque_sp.get(), stop_desc);
13130fdc8d8SChris Lattner                 if (dst)
13230fdc8d8SChris Lattner                     return ::snprintf (dst, dst_len, "%s", stop_desc);
13330fdc8d8SChris Lattner                 else
13430fdc8d8SChris Lattner                 {
13530fdc8d8SChris Lattner                     // NULL dst passed in, return the length needed to contain the description
13630fdc8d8SChris Lattner                     return ::strlen (stop_desc) + 1; // Include the NULL byte for size
13730fdc8d8SChris Lattner                 }
13830fdc8d8SChris Lattner             }
13930fdc8d8SChris Lattner             else
14030fdc8d8SChris Lattner             {
14130fdc8d8SChris Lattner                 size_t stop_desc_len = 0;
142b15bfc75SJim Ingham                 switch (stop_info_sp->GetStopReason())
14330fdc8d8SChris Lattner                 {
14430fdc8d8SChris Lattner                 case eStopReasonTrace:
14530fdc8d8SChris Lattner                 case eStopReasonPlanComplete:
14630fdc8d8SChris Lattner                     {
14730fdc8d8SChris Lattner                         static char trace_desc[] = "step";
14830fdc8d8SChris Lattner                         stop_desc = trace_desc;
14930fdc8d8SChris Lattner                         stop_desc_len = sizeof(trace_desc); // Include the NULL byte for size
15030fdc8d8SChris Lattner                     }
15130fdc8d8SChris Lattner                     break;
15230fdc8d8SChris Lattner 
15330fdc8d8SChris Lattner                 case eStopReasonBreakpoint:
15430fdc8d8SChris Lattner                     {
15530fdc8d8SChris Lattner                         static char bp_desc[] = "breakpoint hit";
15630fdc8d8SChris Lattner                         stop_desc = bp_desc;
15730fdc8d8SChris Lattner                         stop_desc_len = sizeof(bp_desc); // Include the NULL byte for size
15830fdc8d8SChris Lattner                     }
15930fdc8d8SChris Lattner                     break;
16030fdc8d8SChris Lattner 
16130fdc8d8SChris Lattner                 case eStopReasonWatchpoint:
16230fdc8d8SChris Lattner                     {
16330fdc8d8SChris Lattner                         static char wp_desc[] = "watchpoint hit";
16430fdc8d8SChris Lattner                         stop_desc = wp_desc;
16530fdc8d8SChris Lattner                         stop_desc_len = sizeof(wp_desc); // Include the NULL byte for size
16630fdc8d8SChris Lattner                     }
16730fdc8d8SChris Lattner                     break;
16830fdc8d8SChris Lattner 
16930fdc8d8SChris Lattner                 case eStopReasonSignal:
17030fdc8d8SChris Lattner                     {
171b15bfc75SJim Ingham                         stop_desc = m_opaque_sp->GetProcess().GetUnixSignals ().GetSignalAsCString (stop_info_sp->GetValue());
17230fdc8d8SChris Lattner                         if (stop_desc == NULL || stop_desc[0] == '\0')
17330fdc8d8SChris Lattner                         {
17430fdc8d8SChris Lattner                             static char signal_desc[] = "signal";
17530fdc8d8SChris Lattner                             stop_desc = signal_desc;
17630fdc8d8SChris Lattner                             stop_desc_len = sizeof(signal_desc); // Include the NULL byte for size
17730fdc8d8SChris Lattner                         }
17830fdc8d8SChris Lattner                     }
17930fdc8d8SChris Lattner                     break;
18030fdc8d8SChris Lattner 
18130fdc8d8SChris Lattner                 case eStopReasonException:
18230fdc8d8SChris Lattner                     {
18330fdc8d8SChris Lattner                         char exc_desc[] = "exception";
18430fdc8d8SChris Lattner                         stop_desc = exc_desc;
18530fdc8d8SChris Lattner                         stop_desc_len = sizeof(exc_desc); // Include the NULL byte for size
18630fdc8d8SChris Lattner                     }
18730fdc8d8SChris Lattner                     break;
188c982c768SGreg Clayton 
189c982c768SGreg Clayton                 default:
190c982c768SGreg Clayton                     break;
19130fdc8d8SChris Lattner                 }
19230fdc8d8SChris Lattner 
19330fdc8d8SChris Lattner                 if (stop_desc && stop_desc[0])
19430fdc8d8SChris Lattner                 {
195ceb6b139SCaroline Tice                     if (log)
196*93aa84e8SGreg Clayton                         log->Printf ("SBThread(%p)::GetStopDescription (dst, dst_len) => '%s'",
197750cd175SCaroline Tice                                      m_opaque_sp.get(), stop_desc);
198ceb6b139SCaroline Tice 
19930fdc8d8SChris Lattner                     if (dst)
20030fdc8d8SChris Lattner                         return ::snprintf (dst, dst_len, "%s", stop_desc) + 1; // Include the NULL byte
20130fdc8d8SChris Lattner 
20230fdc8d8SChris Lattner                     if (stop_desc_len == 0)
20330fdc8d8SChris Lattner                         stop_desc_len = ::strlen (stop_desc) + 1; // Include the NULL byte
20430fdc8d8SChris Lattner 
20530fdc8d8SChris Lattner                     return stop_desc_len;
20630fdc8d8SChris Lattner                 }
20730fdc8d8SChris Lattner             }
20830fdc8d8SChris Lattner         }
20930fdc8d8SChris Lattner     }
21030fdc8d8SChris Lattner     if (dst)
21130fdc8d8SChris Lattner         *dst = 0;
21230fdc8d8SChris Lattner     return 0;
21330fdc8d8SChris Lattner }
21430fdc8d8SChris Lattner 
21530fdc8d8SChris Lattner void
21630fdc8d8SChris Lattner SBThread::SetThread (const ThreadSP& lldb_object_sp)
21730fdc8d8SChris Lattner {
2186611103cSGreg Clayton     m_opaque_sp = lldb_object_sp;
21930fdc8d8SChris Lattner }
22030fdc8d8SChris Lattner 
22130fdc8d8SChris Lattner 
22230fdc8d8SChris Lattner lldb::tid_t
22330fdc8d8SChris Lattner SBThread::GetThreadID () const
22430fdc8d8SChris Lattner {
225ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
226ceb6b139SCaroline Tice 
227750cd175SCaroline Tice     //if (log)
228750cd175SCaroline Tice     //    log->Printf ("SBThread::GetThreadID()");
229ceb6b139SCaroline Tice 
230ceb6b139SCaroline Tice     lldb::tid_t id = LLDB_INVALID_THREAD_ID;
2316611103cSGreg Clayton     if (m_opaque_sp)
232ceb6b139SCaroline Tice         id = m_opaque_sp->GetID();
233ceb6b139SCaroline Tice 
234ceb6b139SCaroline Tice     if (log)
235750cd175SCaroline Tice         log->Printf ("SBThread::GetThreadID (this.sp=%p) => %d", m_opaque_sp.get(), (uint32_t) id);
236ceb6b139SCaroline Tice 
237ceb6b139SCaroline Tice     return id;
23830fdc8d8SChris Lattner }
23930fdc8d8SChris Lattner 
24030fdc8d8SChris Lattner uint32_t
24130fdc8d8SChris Lattner SBThread::GetIndexID () const
24230fdc8d8SChris Lattner {
2436611103cSGreg Clayton     if (m_opaque_sp)
2446611103cSGreg Clayton         return m_opaque_sp->GetIndexID();
24530fdc8d8SChris Lattner     return LLDB_INVALID_INDEX32;
24630fdc8d8SChris Lattner }
24730fdc8d8SChris Lattner const char *
24830fdc8d8SChris Lattner SBThread::GetName () const
24930fdc8d8SChris Lattner {
250ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
251ceb6b139SCaroline Tice 
252750cd175SCaroline Tice     //if (log)
253750cd175SCaroline Tice     //    log->Printf ("SBThread::GetName ()");
254ceb6b139SCaroline Tice 
2556611103cSGreg Clayton     if (m_opaque_sp)
256ceb6b139SCaroline Tice     {
257ceb6b139SCaroline Tice         if (log)
258750cd175SCaroline Tice             log->Printf ("SBThread::GetName (this.sp=%p) => '%s'", m_opaque_sp.get(), m_opaque_sp->GetName());
2596611103cSGreg Clayton         return m_opaque_sp->GetName();
260ceb6b139SCaroline Tice     }
261ceb6b139SCaroline Tice 
262ceb6b139SCaroline Tice     if (log)
263750cd175SCaroline Tice         log->Printf ("SBThread::GetName (this.sp=%p) => NULL", m_opaque_sp.get());
264ceb6b139SCaroline Tice 
26530fdc8d8SChris Lattner     return NULL;
26630fdc8d8SChris Lattner }
26730fdc8d8SChris Lattner 
26830fdc8d8SChris Lattner const char *
26930fdc8d8SChris Lattner SBThread::GetQueueName () const
27030fdc8d8SChris Lattner {
271ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
272ceb6b139SCaroline Tice 
273750cd175SCaroline Tice     //if (log)
274750cd175SCaroline Tice     //    log->Printf ("SBThread::GetQueueName ()");
275ceb6b139SCaroline Tice 
2766611103cSGreg Clayton     if (m_opaque_sp)
277ceb6b139SCaroline Tice     {
278ceb6b139SCaroline Tice         if (log)
279750cd175SCaroline Tice             log->Printf ("SBThread::GetQueueName (this.sp=%p) => '%s'", m_opaque_sp.get(),
280750cd175SCaroline Tice                          m_opaque_sp->GetQueueName());
2816611103cSGreg Clayton         return m_opaque_sp->GetQueueName();
282ceb6b139SCaroline Tice     }
283ceb6b139SCaroline Tice 
284ceb6b139SCaroline Tice     if (log)
285750cd175SCaroline Tice         log->Printf ("SBThread::GetQueueName (this.sp=%p) => NULL", m_opaque_sp.get());
286ceb6b139SCaroline Tice 
28730fdc8d8SChris Lattner     return NULL;
28830fdc8d8SChris Lattner }
28930fdc8d8SChris Lattner 
29030fdc8d8SChris Lattner 
29130fdc8d8SChris Lattner void
29230fdc8d8SChris Lattner SBThread::StepOver (lldb::RunMode stop_other_threads)
29330fdc8d8SChris Lattner {
294ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
295ceb6b139SCaroline Tice 
296ceb6b139SCaroline Tice     if (log)
297*93aa84e8SGreg Clayton         log->Printf ("SBThread(%p)::StepOver (stop_other_threads='%s')", m_opaque_sp.get(),
298ceb6b139SCaroline Tice                      Thread::RunModeAsCString (stop_other_threads));
299ceb6b139SCaroline Tice 
3006611103cSGreg Clayton     if (m_opaque_sp)
30130fdc8d8SChris Lattner     {
30230fdc8d8SChris Lattner         bool abort_other_plans = true;
3036611103cSGreg Clayton         StackFrameSP frame_sp(m_opaque_sp->GetStackFrameAtIndex (0));
30430fdc8d8SChris Lattner 
30530fdc8d8SChris Lattner         if (frame_sp)
30630fdc8d8SChris Lattner         {
30730fdc8d8SChris Lattner             if (frame_sp->HasDebugInformation ())
30830fdc8d8SChris Lattner             {
30930fdc8d8SChris Lattner                 SymbolContext sc(frame_sp->GetSymbolContext(eSymbolContextEverything));
3106611103cSGreg Clayton                 m_opaque_sp->QueueThreadPlanForStepRange (abort_other_plans,
31130fdc8d8SChris Lattner                                                           eStepTypeOver,
31230fdc8d8SChris Lattner                                                           sc.line_entry.range,
31330fdc8d8SChris Lattner                                                           sc,
314474966a4SGreg Clayton                                                           stop_other_threads,
315474966a4SGreg Clayton                                                           false);
31630fdc8d8SChris Lattner 
31730fdc8d8SChris Lattner             }
31830fdc8d8SChris Lattner             else
31930fdc8d8SChris Lattner             {
3206611103cSGreg Clayton                 m_opaque_sp->QueueThreadPlanForStepSingleInstruction (true,
32130fdc8d8SChris Lattner                                                                       abort_other_plans,
32230fdc8d8SChris Lattner                                                                       stop_other_threads);
32330fdc8d8SChris Lattner             }
32430fdc8d8SChris Lattner         }
32530fdc8d8SChris Lattner 
3266611103cSGreg Clayton         Process &process = m_opaque_sp->GetProcess();
32730fdc8d8SChris Lattner         // Why do we need to set the current thread by ID here???
3282976d00aSJim Ingham         process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID());
3295d5028b5SGreg Clayton         Error error (process.Resume());
3305d5028b5SGreg Clayton         if (error.Success())
3315d5028b5SGreg Clayton         {
3325d5028b5SGreg Clayton             // If we are doing synchronous mode, then wait for the
3335d5028b5SGreg Clayton             // process to stop yet again!
3345d5028b5SGreg Clayton             if (process.GetTarget().GetDebugger().GetAsyncExecution () == false)
3355d5028b5SGreg Clayton                 process.WaitForProcessToStop (NULL);
3365d5028b5SGreg Clayton         }
33730fdc8d8SChris Lattner     }
33830fdc8d8SChris Lattner }
33930fdc8d8SChris Lattner 
34030fdc8d8SChris Lattner void
34130fdc8d8SChris Lattner SBThread::StepInto (lldb::RunMode stop_other_threads)
34230fdc8d8SChris Lattner {
343ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
344ceb6b139SCaroline Tice 
345ceb6b139SCaroline Tice     if (log)
346*93aa84e8SGreg Clayton         log->Printf ("SBThread(%p)::StepInto (stop_other_threads='%s')", m_opaque_sp.get(),
347ceb6b139SCaroline Tice                      Thread::RunModeAsCString (stop_other_threads));
348ceb6b139SCaroline Tice 
3496611103cSGreg Clayton     if (m_opaque_sp)
35030fdc8d8SChris Lattner     {
35130fdc8d8SChris Lattner         bool abort_other_plans = true;
35230fdc8d8SChris Lattner 
3536611103cSGreg Clayton         StackFrameSP frame_sp(m_opaque_sp->GetStackFrameAtIndex (0));
35430fdc8d8SChris Lattner 
35530fdc8d8SChris Lattner         if (frame_sp && frame_sp->HasDebugInformation ())
35630fdc8d8SChris Lattner         {
357474966a4SGreg Clayton             bool avoid_code_without_debug_info = true;
35830fdc8d8SChris Lattner             SymbolContext sc(frame_sp->GetSymbolContext(eSymbolContextEverything));
3596611103cSGreg Clayton             m_opaque_sp->QueueThreadPlanForStepRange (abort_other_plans,
36030fdc8d8SChris Lattner                                                       eStepTypeInto,
36130fdc8d8SChris Lattner                                                       sc.line_entry.range,
36230fdc8d8SChris Lattner                                                       sc,
363474966a4SGreg Clayton                                                       stop_other_threads,
364474966a4SGreg Clayton                                                       avoid_code_without_debug_info);
36530fdc8d8SChris Lattner         }
36630fdc8d8SChris Lattner         else
36730fdc8d8SChris Lattner         {
3686611103cSGreg Clayton             m_opaque_sp->QueueThreadPlanForStepSingleInstruction (false,
36930fdc8d8SChris Lattner                                                                   abort_other_plans,
37030fdc8d8SChris Lattner                                                                   stop_other_threads);
37130fdc8d8SChris Lattner         }
37230fdc8d8SChris Lattner 
3736611103cSGreg Clayton         Process &process = m_opaque_sp->GetProcess();
37430fdc8d8SChris Lattner         // Why do we need to set the current thread by ID here???
3752976d00aSJim Ingham         process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID());
3765d5028b5SGreg Clayton         Error error (process.Resume());
3775d5028b5SGreg Clayton         if (error.Success())
3785d5028b5SGreg Clayton         {
3795d5028b5SGreg Clayton             // If we are doing synchronous mode, then wait for the
3805d5028b5SGreg Clayton             // process to stop yet again!
3815d5028b5SGreg Clayton             if (process.GetTarget().GetDebugger().GetAsyncExecution () == false)
3825d5028b5SGreg Clayton                 process.WaitForProcessToStop (NULL);
3835d5028b5SGreg Clayton         }
38430fdc8d8SChris Lattner     }
38530fdc8d8SChris Lattner }
38630fdc8d8SChris Lattner 
38730fdc8d8SChris Lattner void
38830fdc8d8SChris Lattner SBThread::StepOut ()
38930fdc8d8SChris Lattner {
390ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
391ceb6b139SCaroline Tice 
392ceb6b139SCaroline Tice     if (log)
393750cd175SCaroline Tice         log->Printf ("SBThread::StepOut (this.sp=%p)", m_opaque_sp.get());
394ceb6b139SCaroline Tice 
3956611103cSGreg Clayton     if (m_opaque_sp)
39630fdc8d8SChris Lattner     {
39730fdc8d8SChris Lattner         bool abort_other_plans = true;
39830fdc8d8SChris Lattner         bool stop_other_threads = true;
39930fdc8d8SChris Lattner 
4006611103cSGreg Clayton         m_opaque_sp->QueueThreadPlanForStepOut (abort_other_plans, NULL, false, stop_other_threads, eVoteYes, eVoteNoOpinion);
40130fdc8d8SChris Lattner 
4026611103cSGreg Clayton         Process &process = m_opaque_sp->GetProcess();
4032976d00aSJim Ingham         process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID());
4045d5028b5SGreg Clayton         Error error (process.Resume());
4055d5028b5SGreg Clayton         if (error.Success())
4065d5028b5SGreg Clayton         {
4075d5028b5SGreg Clayton             // If we are doing synchronous mode, then wait for the
4085d5028b5SGreg Clayton             // process to stop yet again!
4095d5028b5SGreg Clayton             if (process.GetTarget().GetDebugger().GetAsyncExecution () == false)
4105d5028b5SGreg Clayton                 process.WaitForProcessToStop (NULL);
4115d5028b5SGreg Clayton         }
41230fdc8d8SChris Lattner     }
41330fdc8d8SChris Lattner }
41430fdc8d8SChris Lattner 
41530fdc8d8SChris Lattner void
41630fdc8d8SChris Lattner SBThread::StepInstruction (bool step_over)
41730fdc8d8SChris Lattner {
418ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
419ceb6b139SCaroline Tice 
420ceb6b139SCaroline Tice     if (log)
421*93aa84e8SGreg Clayton         log->Printf ("SBThread(%p)::StepInstruction (step_over=%i)", m_opaque_sp.get(), step_over);
422ceb6b139SCaroline Tice 
4236611103cSGreg Clayton     if (m_opaque_sp)
42430fdc8d8SChris Lattner     {
4256611103cSGreg Clayton         m_opaque_sp->QueueThreadPlanForStepSingleInstruction (step_over, true, true);
4266611103cSGreg Clayton         Process &process = m_opaque_sp->GetProcess();
4272976d00aSJim Ingham         process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID());
4285d5028b5SGreg Clayton         Error error (process.Resume());
4295d5028b5SGreg Clayton         if (error.Success())
4305d5028b5SGreg Clayton         {
4315d5028b5SGreg Clayton             // If we are doing synchronous mode, then wait for the
4325d5028b5SGreg Clayton             // process to stop yet again!
4335d5028b5SGreg Clayton             if (process.GetTarget().GetDebugger().GetAsyncExecution () == false)
4345d5028b5SGreg Clayton                 process.WaitForProcessToStop (NULL);
4355d5028b5SGreg Clayton         }
43630fdc8d8SChris Lattner     }
43730fdc8d8SChris Lattner }
43830fdc8d8SChris Lattner 
43930fdc8d8SChris Lattner void
44030fdc8d8SChris Lattner SBThread::RunToAddress (lldb::addr_t addr)
44130fdc8d8SChris Lattner {
442ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
443ceb6b139SCaroline Tice 
444ceb6b139SCaroline Tice     if (log)
445*93aa84e8SGreg Clayton         log->Printf ("SBThread(%p)::RunToAddress (addr=0x%llx)", m_opaque_sp.get(), addr);
446ceb6b139SCaroline Tice 
4476611103cSGreg Clayton     if (m_opaque_sp)
44830fdc8d8SChris Lattner     {
44930fdc8d8SChris Lattner         bool abort_other_plans = true;
45030fdc8d8SChris Lattner         bool stop_other_threads = true;
45130fdc8d8SChris Lattner 
45230fdc8d8SChris Lattner         Address target_addr (NULL, addr);
45330fdc8d8SChris Lattner 
4546611103cSGreg Clayton         m_opaque_sp->QueueThreadPlanForRunToAddress (abort_other_plans, target_addr, stop_other_threads);
4556611103cSGreg Clayton         Process &process = m_opaque_sp->GetProcess();
4562976d00aSJim Ingham         process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID());
4575d5028b5SGreg Clayton         Error error (process.Resume());
4585d5028b5SGreg Clayton         if (error.Success())
4595d5028b5SGreg Clayton         {
4605d5028b5SGreg Clayton             // If we are doing synchronous mode, then wait for the
4615d5028b5SGreg Clayton             // process to stop yet again!
4625d5028b5SGreg Clayton             if (process.GetTarget().GetDebugger().GetAsyncExecution () == false)
4635d5028b5SGreg Clayton                 process.WaitForProcessToStop (NULL);
4645d5028b5SGreg Clayton         }
46530fdc8d8SChris Lattner     }
46630fdc8d8SChris Lattner 
46730fdc8d8SChris Lattner }
46830fdc8d8SChris Lattner 
46930fdc8d8SChris Lattner SBProcess
47030fdc8d8SChris Lattner SBThread::GetProcess ()
47130fdc8d8SChris Lattner {
472ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
473ceb6b139SCaroline Tice 
47430fdc8d8SChris Lattner     SBProcess process;
4756611103cSGreg Clayton     if (m_opaque_sp)
47630fdc8d8SChris Lattner     {
47730fdc8d8SChris Lattner         // Have to go up to the target so we can get a shared pointer to our process...
4786611103cSGreg Clayton         process.SetProcess(m_opaque_sp->GetProcess().GetTarget().GetProcessSP());
47930fdc8d8SChris Lattner     }
480ceb6b139SCaroline Tice 
481ceb6b139SCaroline Tice     if (log)
482ceb6b139SCaroline Tice     {
483ceb6b139SCaroline Tice         SBStream sstr;
484ceb6b139SCaroline Tice         process.GetDescription (sstr);
485750cd175SCaroline Tice         log->Printf ("SBThread::GetProcess (this.sp=%p) => SBProcess : this.sp = %p, '%s'", m_opaque_sp.get(),
486750cd175SCaroline Tice                      process.get(), sstr.GetData());
487ceb6b139SCaroline Tice     }
488ceb6b139SCaroline Tice 
48930fdc8d8SChris Lattner     return process;
49030fdc8d8SChris Lattner }
49130fdc8d8SChris Lattner 
49230fdc8d8SChris Lattner uint32_t
49330fdc8d8SChris Lattner SBThread::GetNumFrames ()
49430fdc8d8SChris Lattner {
495ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
496ceb6b139SCaroline Tice 
497ceb6b139SCaroline Tice     uint32_t num_frames = 0;
4986611103cSGreg Clayton     if (m_opaque_sp)
499ceb6b139SCaroline Tice         num_frames = m_opaque_sp->GetStackFrameCount();
500ceb6b139SCaroline Tice 
501ceb6b139SCaroline Tice     if (log)
502750cd175SCaroline Tice         log->Printf ("SBThread::GetNumFrames (this.sp=%p) => %d", m_opaque_sp.get(), num_frames);
503ceb6b139SCaroline Tice 
504ceb6b139SCaroline Tice     return num_frames;
50530fdc8d8SChris Lattner }
50630fdc8d8SChris Lattner 
50730fdc8d8SChris Lattner SBFrame
50830fdc8d8SChris Lattner SBThread::GetFrameAtIndex (uint32_t idx)
50930fdc8d8SChris Lattner {
510ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
511ceb6b139SCaroline Tice 
51230fdc8d8SChris Lattner     SBFrame sb_frame;
5136611103cSGreg Clayton     if (m_opaque_sp)
5146611103cSGreg Clayton         sb_frame.SetFrame (m_opaque_sp->GetStackFrameAtIndex (idx));
515ceb6b139SCaroline Tice 
516ceb6b139SCaroline Tice     if (log)
517ceb6b139SCaroline Tice     {
518ceb6b139SCaroline Tice         SBStream sstr;
519ceb6b139SCaroline Tice         sb_frame.GetDescription (sstr);
520*93aa84e8SGreg Clayton         log->Printf ("SBThread(%p)::GetFrameAtIndex (idx=%d) => SBFrame.sp : this = %p, '%s'",
521750cd175SCaroline Tice                      m_opaque_sp.get(), idx, sb_frame.get(), sstr.GetData());
522ceb6b139SCaroline Tice     }
523ceb6b139SCaroline Tice 
52430fdc8d8SChris Lattner     return sb_frame;
52530fdc8d8SChris Lattner }
52630fdc8d8SChris Lattner 
52730fdc8d8SChris Lattner const lldb::SBThread &
52830fdc8d8SChris Lattner SBThread::operator = (const lldb::SBThread &rhs)
52930fdc8d8SChris Lattner {
530ceb6b139SCaroline Tice     Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
531ceb6b139SCaroline Tice 
532ceb6b139SCaroline Tice     if (log)
533*93aa84e8SGreg Clayton         log->Printf ("SBThread(%p)::operator= (rhs.sp=%p)", m_opaque_sp.get(), rhs.m_opaque_sp.get());
534ceb6b139SCaroline Tice 
5356611103cSGreg Clayton     m_opaque_sp = rhs.m_opaque_sp;
53630fdc8d8SChris Lattner     return *this;
53730fdc8d8SChris Lattner }
53830fdc8d8SChris Lattner 
53930fdc8d8SChris Lattner bool
54030fdc8d8SChris Lattner SBThread::operator == (const SBThread &rhs) const
54130fdc8d8SChris Lattner {
5426611103cSGreg Clayton     return m_opaque_sp.get() == rhs.m_opaque_sp.get();
54330fdc8d8SChris Lattner }
54430fdc8d8SChris Lattner 
54530fdc8d8SChris Lattner bool
54630fdc8d8SChris Lattner SBThread::operator != (const SBThread &rhs) const
54730fdc8d8SChris Lattner {
5486611103cSGreg Clayton     return m_opaque_sp.get() != rhs.m_opaque_sp.get();
54930fdc8d8SChris Lattner }
55030fdc8d8SChris Lattner 
55130fdc8d8SChris Lattner lldb_private::Thread *
55230fdc8d8SChris Lattner SBThread::GetLLDBObjectPtr ()
55330fdc8d8SChris Lattner {
5546611103cSGreg Clayton     return m_opaque_sp.get();
55530fdc8d8SChris Lattner }
55630fdc8d8SChris Lattner 
55730fdc8d8SChris Lattner const lldb_private::Thread *
55830fdc8d8SChris Lattner SBThread::operator->() const
55930fdc8d8SChris Lattner {
5606611103cSGreg Clayton     return m_opaque_sp.get();
56130fdc8d8SChris Lattner }
56230fdc8d8SChris Lattner 
56330fdc8d8SChris Lattner const lldb_private::Thread &
56430fdc8d8SChris Lattner SBThread::operator*() const
56530fdc8d8SChris Lattner {
5666611103cSGreg Clayton     return *m_opaque_sp;
56730fdc8d8SChris Lattner }
56830fdc8d8SChris Lattner 
56930fdc8d8SChris Lattner lldb_private::Thread *
57030fdc8d8SChris Lattner SBThread::operator->()
57130fdc8d8SChris Lattner {
5726611103cSGreg Clayton     return m_opaque_sp.get();
57330fdc8d8SChris Lattner }
57430fdc8d8SChris Lattner 
57530fdc8d8SChris Lattner lldb_private::Thread &
57630fdc8d8SChris Lattner SBThread::operator*()
57730fdc8d8SChris Lattner {
5786611103cSGreg Clayton     return *m_opaque_sp;
57930fdc8d8SChris Lattner }
580dde9cff3SCaroline Tice 
581dde9cff3SCaroline Tice bool
582dde9cff3SCaroline Tice SBThread::GetDescription (SBStream &description)
583dde9cff3SCaroline Tice {
584dde9cff3SCaroline Tice     if (m_opaque_sp)
58505faeb71SGreg Clayton     {
58605faeb71SGreg Clayton         StreamString strm;
58705faeb71SGreg Clayton         description.Printf("SBThread: tid = 0x%4.4x", m_opaque_sp->GetID());
58805faeb71SGreg Clayton     }
589dde9cff3SCaroline Tice     else
590dde9cff3SCaroline Tice         description.Printf ("No value");
591dde9cff3SCaroline Tice 
592dde9cff3SCaroline Tice     return true;
593dde9cff3SCaroline Tice }
594ceb6b139SCaroline Tice 
595ceb6b139SCaroline Tice bool
596ceb6b139SCaroline Tice SBThread::GetDescription (SBStream &description) const
597ceb6b139SCaroline Tice {
598ceb6b139SCaroline Tice     if (m_opaque_sp)
599ceb6b139SCaroline Tice     {
600ceb6b139SCaroline Tice         StreamString strm;
601ceb6b139SCaroline Tice         description.Printf("SBThread: tid = 0x%4.4x", m_opaque_sp->GetID());
602ceb6b139SCaroline Tice     }
603ceb6b139SCaroline Tice     else
604ceb6b139SCaroline Tice         description.Printf ("No value");
605ceb6b139SCaroline Tice 
606ceb6b139SCaroline Tice     return true;
607ceb6b139SCaroline Tice }
608