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"
146611103cSGreg Clayton #include "lldb/Core/Debugger.h"
1530fdc8d8SChris Lattner #include "lldb/Core/Stream.h"
1630fdc8d8SChris Lattner #include "lldb/Core/StreamFile.h"
176611103cSGreg Clayton #include "lldb/Interpreter/CommandInterpreter.h"
1830fdc8d8SChris Lattner #include "lldb/Target/Thread.h"
1930fdc8d8SChris Lattner #include "lldb/Target/Process.h"
2030fdc8d8SChris Lattner #include "lldb/Symbol/SymbolContext.h"
2130fdc8d8SChris Lattner #include "lldb/Symbol/CompileUnit.h"
2230fdc8d8SChris Lattner #include "lldb/Target/Target.h"
2330fdc8d8SChris Lattner #include "lldb/Target/ThreadPlan.h"
2430fdc8d8SChris Lattner #include "lldb/Target/ThreadPlanStepInstruction.h"
2530fdc8d8SChris Lattner #include "lldb/Target/ThreadPlanStepOut.h"
2630fdc8d8SChris Lattner #include "lldb/Target/ThreadPlanStepRange.h"
2730fdc8d8SChris Lattner #include "lldb/Target/ThreadPlanStepInRange.h"
2830fdc8d8SChris Lattner 
2930fdc8d8SChris Lattner 
304c5de699SEli Friedman #include "lldb/API/SBAddress.h"
314c5de699SEli Friedman #include "lldb/API/SBFrame.h"
324c5de699SEli Friedman #include "lldb/API/SBSourceManager.h"
334c5de699SEli Friedman #include "lldb/API/SBDebugger.h"
344c5de699SEli Friedman #include "lldb/API/SBProcess.h"
3530fdc8d8SChris Lattner 
3630fdc8d8SChris Lattner using namespace lldb;
3730fdc8d8SChris Lattner using namespace lldb_private;
3830fdc8d8SChris Lattner 
3930fdc8d8SChris Lattner SBThread::SBThread () :
406611103cSGreg Clayton     m_opaque_sp ()
4130fdc8d8SChris Lattner {
4230fdc8d8SChris Lattner }
4330fdc8d8SChris Lattner 
4430fdc8d8SChris Lattner //----------------------------------------------------------------------
4530fdc8d8SChris Lattner // Thread constructor
4630fdc8d8SChris Lattner //----------------------------------------------------------------------
4730fdc8d8SChris Lattner SBThread::SBThread (const ThreadSP& lldb_object_sp) :
486611103cSGreg Clayton     m_opaque_sp (lldb_object_sp)
4930fdc8d8SChris Lattner {
5030fdc8d8SChris Lattner }
5130fdc8d8SChris Lattner 
5230fdc8d8SChris Lattner SBThread::SBThread (const SBThread &rhs)
5330fdc8d8SChris Lattner {
546611103cSGreg Clayton     m_opaque_sp = rhs.m_opaque_sp;
5530fdc8d8SChris Lattner }
5630fdc8d8SChris Lattner 
5730fdc8d8SChris Lattner //----------------------------------------------------------------------
5830fdc8d8SChris Lattner // Destructor
5930fdc8d8SChris Lattner //----------------------------------------------------------------------
6030fdc8d8SChris Lattner SBThread::~SBThread()
6130fdc8d8SChris Lattner {
6230fdc8d8SChris Lattner }
6330fdc8d8SChris Lattner 
6430fdc8d8SChris Lattner bool
6530fdc8d8SChris Lattner SBThread::IsValid() const
6630fdc8d8SChris Lattner {
676611103cSGreg Clayton     return m_opaque_sp != NULL;
6830fdc8d8SChris Lattner }
6930fdc8d8SChris Lattner 
70*48e42549SGreg Clayton void
71*48e42549SGreg Clayton SBThread::Clear ()
72*48e42549SGreg Clayton {
73*48e42549SGreg Clayton     m_opaque_sp.reset();
74*48e42549SGreg Clayton }
75*48e42549SGreg Clayton 
76*48e42549SGreg Clayton 
7730fdc8d8SChris Lattner StopReason
7830fdc8d8SChris Lattner SBThread::GetStopReason()
7930fdc8d8SChris Lattner {
806611103cSGreg Clayton     if (m_opaque_sp)
8130fdc8d8SChris Lattner     {
8230fdc8d8SChris Lattner         lldb_private::Thread::StopInfo thread_stop_info;
836611103cSGreg Clayton         if (m_opaque_sp->GetStopInfo(&thread_stop_info))
8430fdc8d8SChris Lattner             return thread_stop_info.GetStopReason();
8530fdc8d8SChris Lattner     }
8630fdc8d8SChris Lattner     return eStopReasonInvalid;
8730fdc8d8SChris Lattner }
8830fdc8d8SChris Lattner 
8930fdc8d8SChris Lattner size_t
9030fdc8d8SChris Lattner SBThread::GetStopDescription (char *dst, size_t dst_len)
9130fdc8d8SChris Lattner {
926611103cSGreg Clayton     if (m_opaque_sp)
9330fdc8d8SChris Lattner     {
9430fdc8d8SChris Lattner         lldb_private::Thread::StopInfo thread_stop_info;
956611103cSGreg Clayton         if (m_opaque_sp->GetStopInfo(&thread_stop_info))
9630fdc8d8SChris Lattner         {
9730fdc8d8SChris Lattner             const char *stop_desc = thread_stop_info.GetStopDescription();
9830fdc8d8SChris Lattner             if (stop_desc)
9930fdc8d8SChris Lattner             {
10030fdc8d8SChris Lattner                 if (dst)
10130fdc8d8SChris Lattner                     return ::snprintf (dst, dst_len, "%s", stop_desc);
10230fdc8d8SChris Lattner                 else
10330fdc8d8SChris Lattner                 {
10430fdc8d8SChris Lattner                     // NULL dst passed in, return the length needed to contain the description
10530fdc8d8SChris Lattner                     return ::strlen (stop_desc) + 1; // Include the NULL byte for size
10630fdc8d8SChris Lattner                 }
10730fdc8d8SChris Lattner             }
10830fdc8d8SChris Lattner             else
10930fdc8d8SChris Lattner             {
11030fdc8d8SChris Lattner                 size_t stop_desc_len = 0;
11130fdc8d8SChris Lattner                 switch (thread_stop_info.GetStopReason())
11230fdc8d8SChris Lattner                 {
11330fdc8d8SChris Lattner                 case eStopReasonTrace:
11430fdc8d8SChris Lattner                 case eStopReasonPlanComplete:
11530fdc8d8SChris Lattner                     {
11630fdc8d8SChris Lattner                         static char trace_desc[] = "step";
11730fdc8d8SChris Lattner                         stop_desc = trace_desc;
11830fdc8d8SChris Lattner                         stop_desc_len = sizeof(trace_desc); // Include the NULL byte for size
11930fdc8d8SChris Lattner                     }
12030fdc8d8SChris Lattner                     break;
12130fdc8d8SChris Lattner 
12230fdc8d8SChris Lattner                 case eStopReasonBreakpoint:
12330fdc8d8SChris Lattner                     {
12430fdc8d8SChris Lattner                         static char bp_desc[] = "breakpoint hit";
12530fdc8d8SChris Lattner                         stop_desc = bp_desc;
12630fdc8d8SChris Lattner                         stop_desc_len = sizeof(bp_desc); // Include the NULL byte for size
12730fdc8d8SChris Lattner                     }
12830fdc8d8SChris Lattner                     break;
12930fdc8d8SChris Lattner 
13030fdc8d8SChris Lattner                 case eStopReasonWatchpoint:
13130fdc8d8SChris Lattner                     {
13230fdc8d8SChris Lattner                         static char wp_desc[] = "watchpoint hit";
13330fdc8d8SChris Lattner                         stop_desc = wp_desc;
13430fdc8d8SChris Lattner                         stop_desc_len = sizeof(wp_desc); // Include the NULL byte for size
13530fdc8d8SChris Lattner                     }
13630fdc8d8SChris Lattner                     break;
13730fdc8d8SChris Lattner 
13830fdc8d8SChris Lattner                 case eStopReasonSignal:
13930fdc8d8SChris Lattner                     {
1406611103cSGreg Clayton                         stop_desc = m_opaque_sp->GetProcess().GetUnixSignals ().GetSignalAsCString (thread_stop_info.GetSignal());
14130fdc8d8SChris Lattner                         if (stop_desc == NULL || stop_desc[0] == '\0')
14230fdc8d8SChris Lattner                         {
14330fdc8d8SChris Lattner                             static char signal_desc[] = "signal";
14430fdc8d8SChris Lattner                             stop_desc = signal_desc;
14530fdc8d8SChris Lattner                             stop_desc_len = sizeof(signal_desc); // Include the NULL byte for size
14630fdc8d8SChris Lattner                         }
14730fdc8d8SChris Lattner                     }
14830fdc8d8SChris Lattner                     break;
14930fdc8d8SChris Lattner 
15030fdc8d8SChris Lattner                 case eStopReasonException:
15130fdc8d8SChris Lattner                     {
15230fdc8d8SChris Lattner                         char exc_desc[] = "exception";
15330fdc8d8SChris Lattner                         stop_desc = exc_desc;
15430fdc8d8SChris Lattner                         stop_desc_len = sizeof(exc_desc); // Include the NULL byte for size
15530fdc8d8SChris Lattner                     }
15630fdc8d8SChris Lattner                     break;
157c982c768SGreg Clayton 
158c982c768SGreg Clayton                 default:
159c982c768SGreg Clayton                     break;
16030fdc8d8SChris Lattner                 }
16130fdc8d8SChris Lattner 
16230fdc8d8SChris Lattner                 if (stop_desc && stop_desc[0])
16330fdc8d8SChris Lattner                 {
16430fdc8d8SChris Lattner                     if (dst)
16530fdc8d8SChris Lattner                         return ::snprintf (dst, dst_len, "%s", stop_desc) + 1; // Include the NULL byte
16630fdc8d8SChris Lattner 
16730fdc8d8SChris Lattner                     if (stop_desc_len == 0)
16830fdc8d8SChris Lattner                         stop_desc_len = ::strlen (stop_desc) + 1; // Include the NULL byte
16930fdc8d8SChris Lattner 
17030fdc8d8SChris Lattner                     return stop_desc_len;
17130fdc8d8SChris Lattner                 }
17230fdc8d8SChris Lattner             }
17330fdc8d8SChris Lattner         }
17430fdc8d8SChris Lattner     }
17530fdc8d8SChris Lattner     if (dst)
17630fdc8d8SChris Lattner         *dst = 0;
17730fdc8d8SChris Lattner     return 0;
17830fdc8d8SChris Lattner }
17930fdc8d8SChris Lattner 
18030fdc8d8SChris Lattner void
18130fdc8d8SChris Lattner SBThread::SetThread (const ThreadSP& lldb_object_sp)
18230fdc8d8SChris Lattner {
1836611103cSGreg Clayton     m_opaque_sp = lldb_object_sp;
18430fdc8d8SChris Lattner }
18530fdc8d8SChris Lattner 
18630fdc8d8SChris Lattner 
18730fdc8d8SChris Lattner lldb::tid_t
18830fdc8d8SChris Lattner SBThread::GetThreadID () const
18930fdc8d8SChris Lattner {
1906611103cSGreg Clayton     if (m_opaque_sp)
1916611103cSGreg Clayton         return m_opaque_sp->GetID();
19230fdc8d8SChris Lattner     else
19330fdc8d8SChris Lattner         return LLDB_INVALID_THREAD_ID;
19430fdc8d8SChris Lattner }
19530fdc8d8SChris Lattner 
19630fdc8d8SChris Lattner uint32_t
19730fdc8d8SChris Lattner SBThread::GetIndexID () const
19830fdc8d8SChris Lattner {
1996611103cSGreg Clayton     if (m_opaque_sp)
2006611103cSGreg Clayton         return m_opaque_sp->GetIndexID();
20130fdc8d8SChris Lattner     return LLDB_INVALID_INDEX32;
20230fdc8d8SChris Lattner }
20330fdc8d8SChris Lattner const char *
20430fdc8d8SChris Lattner SBThread::GetName () const
20530fdc8d8SChris Lattner {
2066611103cSGreg Clayton     if (m_opaque_sp)
2076611103cSGreg Clayton         return m_opaque_sp->GetName();
20830fdc8d8SChris Lattner     return NULL;
20930fdc8d8SChris Lattner }
21030fdc8d8SChris Lattner 
21130fdc8d8SChris Lattner const char *
21230fdc8d8SChris Lattner SBThread::GetQueueName () const
21330fdc8d8SChris Lattner {
2146611103cSGreg Clayton     if (m_opaque_sp)
2156611103cSGreg Clayton         return m_opaque_sp->GetQueueName();
21630fdc8d8SChris Lattner     return NULL;
21730fdc8d8SChris Lattner }
21830fdc8d8SChris Lattner 
21930fdc8d8SChris Lattner 
22030fdc8d8SChris Lattner void
22130fdc8d8SChris Lattner SBThread::DisplayFramesForCurrentContext (FILE *out,
22230fdc8d8SChris Lattner                                           FILE *err,
22330fdc8d8SChris Lattner                                           uint32_t first_frame,
22430fdc8d8SChris Lattner                                           uint32_t num_frames,
22530fdc8d8SChris Lattner                                           bool show_frame_info,
22630fdc8d8SChris Lattner                                           uint32_t num_frames_with_source,
22730fdc8d8SChris Lattner                                           uint32_t source_lines_before,
22830fdc8d8SChris Lattner                                           uint32_t source_lines_after)
22930fdc8d8SChris Lattner {
23030fdc8d8SChris Lattner     if ((out == NULL) || (err == NULL))
23130fdc8d8SChris Lattner         return;
23230fdc8d8SChris Lattner 
2336611103cSGreg Clayton     if (m_opaque_sp)
23430fdc8d8SChris Lattner     {
2356611103cSGreg Clayton         uint32_t num_stack_frames = m_opaque_sp->GetStackFrameCount ();
23630fdc8d8SChris Lattner         StackFrameSP frame_sp;
237c982c768SGreg Clayton         uint32_t frame_idx = 0;
23830fdc8d8SChris Lattner 
23930fdc8d8SChris Lattner         for (frame_idx = first_frame; frame_idx < first_frame + num_frames; ++frame_idx)
24030fdc8d8SChris Lattner         {
24130fdc8d8SChris Lattner             if (frame_idx >= num_stack_frames)
24230fdc8d8SChris Lattner                 break;
24330fdc8d8SChris Lattner 
2446611103cSGreg Clayton             frame_sp = m_opaque_sp->GetStackFrameAtIndex (frame_idx);
24530fdc8d8SChris Lattner             if (!frame_sp)
24630fdc8d8SChris Lattner                 break;
24730fdc8d8SChris Lattner 
24830fdc8d8SChris Lattner             SBFrame sb_frame (frame_sp);
24930fdc8d8SChris Lattner             if (DisplaySingleFrameForCurrentContext (out,
25030fdc8d8SChris Lattner                                                      err,
25130fdc8d8SChris Lattner                                                      sb_frame,
25230fdc8d8SChris Lattner                                                      show_frame_info,
25330fdc8d8SChris Lattner                                                      num_frames_with_source > first_frame - frame_idx,
25430fdc8d8SChris Lattner                                                      source_lines_before,
25530fdc8d8SChris Lattner                                                      source_lines_after) == false)
25630fdc8d8SChris Lattner                 break;
25730fdc8d8SChris Lattner         }
25830fdc8d8SChris Lattner     }
25930fdc8d8SChris Lattner }
26030fdc8d8SChris Lattner 
26130fdc8d8SChris Lattner bool
26230fdc8d8SChris Lattner SBThread::DisplaySingleFrameForCurrentContext (FILE *out,
26330fdc8d8SChris Lattner                                                FILE *err,
26430fdc8d8SChris Lattner                                                SBFrame &frame,
26530fdc8d8SChris Lattner                                                bool show_frame_info,
26630fdc8d8SChris Lattner                                                bool show_source,
26730fdc8d8SChris Lattner                                                uint32_t source_lines_after,
26830fdc8d8SChris Lattner                                                uint32_t source_lines_before)
26930fdc8d8SChris Lattner {
27030fdc8d8SChris Lattner     bool success = false;
27130fdc8d8SChris Lattner 
27230fdc8d8SChris Lattner     if ((out == NULL) || (err == NULL))
27330fdc8d8SChris Lattner         return false;
27430fdc8d8SChris Lattner 
2756611103cSGreg Clayton     if (m_opaque_sp && frame.IsValid())
27630fdc8d8SChris Lattner     {
27730fdc8d8SChris Lattner         StreamFile str (out);
27830fdc8d8SChris Lattner 
27930fdc8d8SChris Lattner         SBSymbolContext sc(frame.GetSymbolContext(eSymbolContextEverything));
28030fdc8d8SChris Lattner 
28130fdc8d8SChris Lattner         if (show_frame_info && sc.IsValid())
28230fdc8d8SChris Lattner         {
28330fdc8d8SChris Lattner             user_id_t frame_idx = (user_id_t) frame.GetFrameID();
28430fdc8d8SChris Lattner             lldb::addr_t pc = frame.GetPC();
28530fdc8d8SChris Lattner             ::fprintf (out,
28630fdc8d8SChris Lattner                        "     frame #%u: tid = 0x%4.4x, pc = 0x%llx ",
28730fdc8d8SChris Lattner                        frame_idx,
28830fdc8d8SChris Lattner                        GetThreadID(),
2898878f87fSEli Friedman                        (long long)pc);
2906611103cSGreg Clayton             sc->DumpStopContext (&str, &m_opaque_sp->GetProcess(), *frame.GetPCAddress());
29130fdc8d8SChris Lattner             fprintf (out, "\n");
29230fdc8d8SChris Lattner             success = true;
29330fdc8d8SChris Lattner         }
29430fdc8d8SChris Lattner 
29530fdc8d8SChris Lattner         SBCompileUnit comp_unit(sc.GetCompileUnit());
29630fdc8d8SChris Lattner         if (show_source && comp_unit.IsValid())
29730fdc8d8SChris Lattner         {
29830fdc8d8SChris Lattner             success = false;
29930fdc8d8SChris Lattner             SBLineEntry line_entry;
30030fdc8d8SChris Lattner             if (line_entry.IsValid())
30130fdc8d8SChris Lattner             {
3026611103cSGreg Clayton                 SourceManager& source_manager = m_opaque_sp->GetProcess().GetTarget().GetDebugger().GetSourceManager();
3036611103cSGreg Clayton                 SBFileSpec line_entry_file_spec (line_entry.GetFileSpec());
30430fdc8d8SChris Lattner 
30530fdc8d8SChris Lattner                 if (line_entry_file_spec.IsValid())
30630fdc8d8SChris Lattner                 {
3076611103cSGreg Clayton                     source_manager.DisplaySourceLinesWithLineNumbers (line_entry_file_spec.ref(),
30830fdc8d8SChris Lattner                                                                       line_entry.GetLine(),
30930fdc8d8SChris Lattner                                                                       source_lines_after,
31030fdc8d8SChris Lattner                                                                       source_lines_before, "->",
3116611103cSGreg Clayton                                                                       &str);
31230fdc8d8SChris Lattner                     success = true;
31330fdc8d8SChris Lattner                 }
31430fdc8d8SChris Lattner             }
31530fdc8d8SChris Lattner         }
31630fdc8d8SChris Lattner     }
31730fdc8d8SChris Lattner     return success;
31830fdc8d8SChris Lattner }
31930fdc8d8SChris Lattner 
32030fdc8d8SChris Lattner void
32130fdc8d8SChris Lattner SBThread::StepOver (lldb::RunMode stop_other_threads)
32230fdc8d8SChris Lattner {
3236611103cSGreg Clayton     if (m_opaque_sp)
32430fdc8d8SChris Lattner     {
32530fdc8d8SChris Lattner         bool abort_other_plans = true;
3266611103cSGreg Clayton         StackFrameSP frame_sp(m_opaque_sp->GetStackFrameAtIndex (0));
32730fdc8d8SChris Lattner 
32830fdc8d8SChris Lattner         if (frame_sp)
32930fdc8d8SChris Lattner         {
33030fdc8d8SChris Lattner             if (frame_sp->HasDebugInformation ())
33130fdc8d8SChris Lattner             {
33230fdc8d8SChris Lattner                 SymbolContext sc(frame_sp->GetSymbolContext(eSymbolContextEverything));
3336611103cSGreg Clayton                 m_opaque_sp->QueueThreadPlanForStepRange (abort_other_plans,
33430fdc8d8SChris Lattner                                                                eStepTypeOver,
33530fdc8d8SChris Lattner                                                                sc.line_entry.range,
33630fdc8d8SChris Lattner                                                                sc,
337474966a4SGreg Clayton                                                                stop_other_threads,
338474966a4SGreg Clayton                                                                false);
33930fdc8d8SChris Lattner 
34030fdc8d8SChris Lattner             }
34130fdc8d8SChris Lattner             else
34230fdc8d8SChris Lattner             {
3436611103cSGreg Clayton                 m_opaque_sp->QueueThreadPlanForStepSingleInstruction (true,
34430fdc8d8SChris Lattner                                                                            abort_other_plans,
34530fdc8d8SChris Lattner                                                                            stop_other_threads);
34630fdc8d8SChris Lattner             }
34730fdc8d8SChris Lattner         }
34830fdc8d8SChris Lattner 
3496611103cSGreg Clayton         Process &process = m_opaque_sp->GetProcess();
35030fdc8d8SChris Lattner         // Why do we need to set the current thread by ID here???
3516611103cSGreg Clayton         process.GetThreadList().SetCurrentThreadByID (m_opaque_sp->GetID());
35230fdc8d8SChris Lattner         process.Resume();
35330fdc8d8SChris Lattner     }
35430fdc8d8SChris Lattner }
35530fdc8d8SChris Lattner 
35630fdc8d8SChris Lattner void
35730fdc8d8SChris Lattner SBThread::StepInto (lldb::RunMode stop_other_threads)
35830fdc8d8SChris Lattner {
3596611103cSGreg Clayton     if (m_opaque_sp)
36030fdc8d8SChris Lattner     {
36130fdc8d8SChris Lattner         bool abort_other_plans = true;
36230fdc8d8SChris Lattner 
3636611103cSGreg Clayton         StackFrameSP frame_sp(m_opaque_sp->GetStackFrameAtIndex (0));
36430fdc8d8SChris Lattner 
36530fdc8d8SChris Lattner         if (frame_sp && frame_sp->HasDebugInformation ())
36630fdc8d8SChris Lattner         {
367474966a4SGreg Clayton             bool avoid_code_without_debug_info = true;
36830fdc8d8SChris Lattner             SymbolContext sc(frame_sp->GetSymbolContext(eSymbolContextEverything));
3696611103cSGreg Clayton             m_opaque_sp->QueueThreadPlanForStepRange (abort_other_plans,
37030fdc8d8SChris Lattner                                                            eStepTypeInto,
37130fdc8d8SChris Lattner                                                            sc.line_entry.range,
37230fdc8d8SChris Lattner                                                            sc,
373474966a4SGreg Clayton                                                            stop_other_threads,
374474966a4SGreg Clayton                                                            avoid_code_without_debug_info);
37530fdc8d8SChris Lattner         }
37630fdc8d8SChris Lattner         else
37730fdc8d8SChris Lattner         {
3786611103cSGreg Clayton             m_opaque_sp->QueueThreadPlanForStepSingleInstruction (false,
37930fdc8d8SChris Lattner                                                                        abort_other_plans,
38030fdc8d8SChris Lattner                                                                        stop_other_threads);
38130fdc8d8SChris Lattner         }
38230fdc8d8SChris Lattner 
3836611103cSGreg Clayton         Process &process = m_opaque_sp->GetProcess();
38430fdc8d8SChris Lattner         // Why do we need to set the current thread by ID here???
3856611103cSGreg Clayton         process.GetThreadList().SetCurrentThreadByID (m_opaque_sp->GetID());
38630fdc8d8SChris Lattner         process.Resume();
38730fdc8d8SChris Lattner 
38830fdc8d8SChris Lattner     }
38930fdc8d8SChris Lattner }
39030fdc8d8SChris Lattner 
39130fdc8d8SChris Lattner void
39230fdc8d8SChris Lattner SBThread::StepOut ()
39330fdc8d8SChris Lattner {
3946611103cSGreg Clayton     if (m_opaque_sp)
39530fdc8d8SChris Lattner     {
39630fdc8d8SChris Lattner         bool abort_other_plans = true;
39730fdc8d8SChris Lattner         bool stop_other_threads = true;
39830fdc8d8SChris Lattner 
3996611103cSGreg Clayton         m_opaque_sp->QueueThreadPlanForStepOut (abort_other_plans, NULL, false, stop_other_threads, eVoteYes, eVoteNoOpinion);
40030fdc8d8SChris Lattner 
4016611103cSGreg Clayton         Process &process = m_opaque_sp->GetProcess();
4026611103cSGreg Clayton         process.GetThreadList().SetCurrentThreadByID (m_opaque_sp->GetID());
40330fdc8d8SChris Lattner         process.Resume();
40430fdc8d8SChris Lattner     }
40530fdc8d8SChris Lattner }
40630fdc8d8SChris Lattner 
40730fdc8d8SChris Lattner void
40830fdc8d8SChris Lattner SBThread::StepInstruction (bool step_over)
40930fdc8d8SChris Lattner {
4106611103cSGreg Clayton     if (m_opaque_sp)
41130fdc8d8SChris Lattner     {
4126611103cSGreg Clayton         m_opaque_sp->QueueThreadPlanForStepSingleInstruction (step_over, true, true);
4136611103cSGreg Clayton         Process &process = m_opaque_sp->GetProcess();
4146611103cSGreg Clayton         process.GetThreadList().SetCurrentThreadByID (m_opaque_sp->GetID());
41530fdc8d8SChris Lattner         process.Resume();
41630fdc8d8SChris Lattner     }
41730fdc8d8SChris Lattner }
41830fdc8d8SChris Lattner 
41930fdc8d8SChris Lattner void
42030fdc8d8SChris Lattner SBThread::RunToAddress (lldb::addr_t addr)
42130fdc8d8SChris Lattner {
4226611103cSGreg Clayton     if (m_opaque_sp)
42330fdc8d8SChris Lattner     {
42430fdc8d8SChris Lattner         bool abort_other_plans = true;
42530fdc8d8SChris Lattner         bool stop_other_threads = true;
42630fdc8d8SChris Lattner 
42730fdc8d8SChris Lattner         Address target_addr (NULL, addr);
42830fdc8d8SChris Lattner 
4296611103cSGreg Clayton         m_opaque_sp->QueueThreadPlanForRunToAddress (abort_other_plans, target_addr, stop_other_threads);
4306611103cSGreg Clayton         Process &process = m_opaque_sp->GetProcess();
4316611103cSGreg Clayton         process.GetThreadList().SetCurrentThreadByID (m_opaque_sp->GetID());
43230fdc8d8SChris Lattner         process.Resume();
43330fdc8d8SChris Lattner     }
43430fdc8d8SChris Lattner 
43530fdc8d8SChris Lattner }
43630fdc8d8SChris Lattner 
43730fdc8d8SChris Lattner SBProcess
43830fdc8d8SChris Lattner SBThread::GetProcess ()
43930fdc8d8SChris Lattner {
44030fdc8d8SChris Lattner     SBProcess process;
4416611103cSGreg Clayton     if (m_opaque_sp)
44230fdc8d8SChris Lattner     {
44330fdc8d8SChris Lattner         // Have to go up to the target so we can get a shared pointer to our process...
4446611103cSGreg Clayton         process.SetProcess(m_opaque_sp->GetProcess().GetTarget().GetProcessSP());
44530fdc8d8SChris Lattner     }
44630fdc8d8SChris Lattner     return process;
44730fdc8d8SChris Lattner }
44830fdc8d8SChris Lattner 
44930fdc8d8SChris Lattner uint32_t
45030fdc8d8SChris Lattner SBThread::GetNumFrames ()
45130fdc8d8SChris Lattner {
4526611103cSGreg Clayton     if (m_opaque_sp)
4536611103cSGreg Clayton         return m_opaque_sp->GetStackFrameCount();
45430fdc8d8SChris Lattner     return 0;
45530fdc8d8SChris Lattner }
45630fdc8d8SChris Lattner 
45730fdc8d8SChris Lattner SBFrame
45830fdc8d8SChris Lattner SBThread::GetFrameAtIndex (uint32_t idx)
45930fdc8d8SChris Lattner {
46030fdc8d8SChris Lattner     SBFrame sb_frame;
4616611103cSGreg Clayton     if (m_opaque_sp)
4626611103cSGreg Clayton         sb_frame.SetFrame (m_opaque_sp->GetStackFrameAtIndex (idx));
46330fdc8d8SChris Lattner     return sb_frame;
46430fdc8d8SChris Lattner }
46530fdc8d8SChris Lattner 
46630fdc8d8SChris Lattner const lldb::SBThread &
46730fdc8d8SChris Lattner SBThread::operator = (const lldb::SBThread &rhs)
46830fdc8d8SChris Lattner {
4696611103cSGreg Clayton     m_opaque_sp = rhs.m_opaque_sp;
47030fdc8d8SChris Lattner     return *this;
47130fdc8d8SChris Lattner }
47230fdc8d8SChris Lattner 
47330fdc8d8SChris Lattner bool
47430fdc8d8SChris Lattner SBThread::operator == (const SBThread &rhs) const
47530fdc8d8SChris Lattner {
4766611103cSGreg Clayton     return m_opaque_sp.get() == rhs.m_opaque_sp.get();
47730fdc8d8SChris Lattner }
47830fdc8d8SChris Lattner 
47930fdc8d8SChris Lattner bool
48030fdc8d8SChris Lattner SBThread::operator != (const SBThread &rhs) const
48130fdc8d8SChris Lattner {
4826611103cSGreg Clayton     return m_opaque_sp.get() != rhs.m_opaque_sp.get();
48330fdc8d8SChris Lattner }
48430fdc8d8SChris Lattner 
48530fdc8d8SChris Lattner lldb_private::Thread *
48630fdc8d8SChris Lattner SBThread::GetLLDBObjectPtr ()
48730fdc8d8SChris Lattner {
4886611103cSGreg Clayton     return m_opaque_sp.get();
48930fdc8d8SChris Lattner }
49030fdc8d8SChris Lattner 
49130fdc8d8SChris Lattner const lldb_private::Thread *
49230fdc8d8SChris Lattner SBThread::operator->() const
49330fdc8d8SChris Lattner {
4946611103cSGreg Clayton     return m_opaque_sp.get();
49530fdc8d8SChris Lattner }
49630fdc8d8SChris Lattner 
49730fdc8d8SChris Lattner const lldb_private::Thread &
49830fdc8d8SChris Lattner SBThread::operator*() const
49930fdc8d8SChris Lattner {
5006611103cSGreg Clayton     return *m_opaque_sp;
50130fdc8d8SChris Lattner }
50230fdc8d8SChris Lattner 
50330fdc8d8SChris Lattner lldb_private::Thread *
50430fdc8d8SChris Lattner SBThread::operator->()
50530fdc8d8SChris Lattner {
5066611103cSGreg Clayton     return m_opaque_sp.get();
50730fdc8d8SChris Lattner }
50830fdc8d8SChris Lattner 
50930fdc8d8SChris Lattner lldb_private::Thread &
51030fdc8d8SChris Lattner SBThread::operator*()
51130fdc8d8SChris Lattner {
5126611103cSGreg Clayton     return *m_opaque_sp;
51330fdc8d8SChris Lattner }
514