blob: e485139d0b23c4262005f471bcba455765050276 [file] [log] [blame]
Chris Lattner24943d22010-06-08 16:52:24 +00001//===-- SBProcess.cpp -------------------------------------------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
Eli Friedman7a62c8b2010-06-09 07:44:37 +000010#include "lldb/API/SBProcess.h"
Chris Lattner24943d22010-06-08 16:52:24 +000011
12#include "lldb/lldb-defines.h"
13#include "lldb/lldb-types.h"
14
Jim Ingham84cdc152010-06-15 19:49:27 +000015#include "lldb/Interpreter/Args.h"
Chris Lattner24943d22010-06-08 16:52:24 +000016#include "lldb/Core/DataBufferHeap.h"
17#include "lldb/Core/DataExtractor.h"
Greg Clayton1a3083a2010-10-06 03:53:16 +000018#include "lldb/Core/Debugger.h"
Caroline Tice7826c882010-10-26 03:11:13 +000019#include "lldb/Core/Log.h"
Chris Lattner24943d22010-06-08 16:52:24 +000020#include "lldb/Core/State.h"
21#include "lldb/Core/Stream.h"
22#include "lldb/Core/StreamFile.h"
23#include "lldb/Target/Process.h"
Chris Lattner24943d22010-06-08 16:52:24 +000024#include "lldb/Target/RegisterContext.h"
Greg Clayton63094e02010-06-23 01:19:29 +000025#include "lldb/Target/Target.h"
26#include "lldb/Target/Thread.h"
Chris Lattner24943d22010-06-08 16:52:24 +000027
28// Project includes
29
Eli Friedman7a62c8b2010-06-09 07:44:37 +000030#include "lldb/API/SBBroadcaster.h"
31#include "lldb/API/SBDebugger.h"
32#include "lldb/API/SBCommandReturnObject.h"
33#include "lldb/API/SBEvent.h"
34#include "lldb/API/SBThread.h"
Caroline Tice98f930f2010-09-20 05:20:02 +000035#include "lldb/API/SBStream.h"
Eli Friedman7a62c8b2010-06-09 07:44:37 +000036#include "lldb/API/SBStringList.h"
Chris Lattner24943d22010-06-08 16:52:24 +000037
38using namespace lldb;
39using namespace lldb_private;
40
41
42
43SBProcess::SBProcess () :
Greg Clayton63094e02010-06-23 01:19:29 +000044 m_opaque_sp()
Chris Lattner24943d22010-06-08 16:52:24 +000045{
46}
47
48
49//----------------------------------------------------------------------
50// SBProcess constructor
51//----------------------------------------------------------------------
52
53SBProcess::SBProcess (const SBProcess& rhs) :
Greg Clayton63094e02010-06-23 01:19:29 +000054 m_opaque_sp (rhs.m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000055{
Caroline Tice61ba7ec2010-10-26 23:49:36 +000056 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
Caroline Tice7826c882010-10-26 03:11:13 +000057
58 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +000059 log->Printf ("SBProcess::SBProcess (rhs.sp=%p) => this.sp = %p", rhs.m_opaque_sp.get(), m_opaque_sp.get());
Chris Lattner24943d22010-06-08 16:52:24 +000060}
61
62
63SBProcess::SBProcess (const lldb::ProcessSP &process_sp) :
Greg Clayton63094e02010-06-23 01:19:29 +000064 m_opaque_sp (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000065{
Caroline Tice61ba7ec2010-10-26 23:49:36 +000066 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
Caroline Tice7826c882010-10-26 03:11:13 +000067
68 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +000069 log->Printf ("SBProcess::SBProcess (process_sp=%p) => this.sp = %p", process_sp.get(), m_opaque_sp.get());
Chris Lattner24943d22010-06-08 16:52:24 +000070}
71
72//----------------------------------------------------------------------
73// Destructor
74//----------------------------------------------------------------------
75SBProcess::~SBProcess()
76{
77}
78
79void
80SBProcess::SetProcess (const ProcessSP &process_sp)
81{
Greg Clayton63094e02010-06-23 01:19:29 +000082 m_opaque_sp = process_sp;
Chris Lattner24943d22010-06-08 16:52:24 +000083}
84
85void
86SBProcess::Clear ()
87{
Greg Clayton63094e02010-06-23 01:19:29 +000088 m_opaque_sp.reset();
Chris Lattner24943d22010-06-08 16:52:24 +000089}
90
91
92bool
93SBProcess::IsValid() const
94{
Greg Clayton63094e02010-06-23 01:19:29 +000095 return m_opaque_sp.get() != NULL;
Chris Lattner24943d22010-06-08 16:52:24 +000096}
97
98
99uint32_t
100SBProcess::GetNumThreads ()
101{
Caroline Tice7826c882010-10-26 03:11:13 +0000102 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
103
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000104 //if (log)
105 // log->Printf ("SBProcess::GetNumThreads ()");
Caroline Tice7826c882010-10-26 03:11:13 +0000106
107 uint32_t num_threads = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000108 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000109 {
110 const bool can_update = true;
Caroline Tice7826c882010-10-26 03:11:13 +0000111 num_threads = m_opaque_sp->GetThreadList().GetSize(can_update);
Chris Lattner24943d22010-06-08 16:52:24 +0000112 }
Caroline Tice7826c882010-10-26 03:11:13 +0000113
114 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000115 log->Printf ("SBProcess::GetNumThreads (this.sp=%p) => %d", m_opaque_sp.get(), num_threads);
Caroline Tice7826c882010-10-26 03:11:13 +0000116
117 return num_threads;
Chris Lattner24943d22010-06-08 16:52:24 +0000118}
119
120SBThread
Jim Inghamc8332952010-08-26 21:32:51 +0000121SBProcess::GetSelectedThread () const
Chris Lattner24943d22010-06-08 16:52:24 +0000122{
Caroline Tice7826c882010-10-26 03:11:13 +0000123 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
124
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000125 //if (log)
126 // log->Printf ("SBProcess::GetSelectedThread ()");
Caroline Tice7826c882010-10-26 03:11:13 +0000127
Chris Lattner24943d22010-06-08 16:52:24 +0000128 SBThread sb_thread;
Greg Clayton63094e02010-06-23 01:19:29 +0000129 if (m_opaque_sp)
Jim Inghamc8332952010-08-26 21:32:51 +0000130 sb_thread.SetThread (m_opaque_sp->GetThreadList().GetSelectedThread());
Caroline Tice7826c882010-10-26 03:11:13 +0000131
132 if (log)
133 {
134 SBStream sstr;
135 sb_thread.GetDescription (sstr);
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000136 log->Printf ("SBProcess::GetSelectedThread (this.sp=%p) => SBThread : this = %p, '%s'", m_opaque_sp.get(),
137 &sb_thread, sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000138 }
139
Chris Lattner24943d22010-06-08 16:52:24 +0000140 return sb_thread;
141}
142
143SBTarget
144SBProcess::GetTarget() const
145{
Caroline Tice7826c882010-10-26 03:11:13 +0000146 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
147
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000148 //if (log)
149 // log->Printf ("SBProcess::GetTarget ()");
Caroline Tice7826c882010-10-26 03:11:13 +0000150
Chris Lattner24943d22010-06-08 16:52:24 +0000151 SBTarget sb_target;
Greg Clayton63094e02010-06-23 01:19:29 +0000152 if (m_opaque_sp)
153 sb_target = m_opaque_sp->GetTarget().GetSP();
Caroline Tice7826c882010-10-26 03:11:13 +0000154
155 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000156 log->Printf ("SBProcess::GetTarget (this.sp=%p) => SBTarget (this.sp = %p)", m_opaque_sp.get(),
Caroline Tice7826c882010-10-26 03:11:13 +0000157 sb_target.get());
158
Chris Lattner24943d22010-06-08 16:52:24 +0000159 return sb_target;
160}
161
162
163size_t
164SBProcess::PutSTDIN (const char *src, size_t src_len)
165{
Caroline Tice7826c882010-10-26 03:11:13 +0000166 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
167
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000168 //if (log)
169 // log->Printf ("SBProcess::PutSTDIN (%s, %d)", src, src_len);
Caroline Tice7826c882010-10-26 03:11:13 +0000170
171 size_t ret_val = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000172 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000173 {
174 Error error;
Caroline Tice7826c882010-10-26 03:11:13 +0000175 ret_val = m_opaque_sp->PutSTDIN (src, src_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000176 }
Caroline Tice7826c882010-10-26 03:11:13 +0000177
178 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000179 log->Printf ("SBProcess::PutSTDIN (this.sp=%p, src='%s', src_len=%d) => %d", m_opaque_sp.get(), src,
180 (uint32_t) src_len, ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000181
182 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000183}
184
185size_t
186SBProcess::GetSTDOUT (char *dst, size_t dst_len) const
187{
Caroline Tice7826c882010-10-26 03:11:13 +0000188 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
189
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000190 //if (log)
191 // log->Printf ("SBProcess::GetSTDOUT (char *dst, size_t dst_Len)");
Caroline Tice7826c882010-10-26 03:11:13 +0000192
193 size_t ret_val = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000194 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000195 {
196 Error error;
Caroline Tice7826c882010-10-26 03:11:13 +0000197 ret_val = m_opaque_sp->GetSTDOUT (dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000198 }
Caroline Tice7826c882010-10-26 03:11:13 +0000199
200 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000201 log->Printf ("SBProcess::GetSTDOUT (this.sp=%p, dst='%s', dst_len=%d) => %d", m_opaque_sp.get(), dst,
202 (uint32_t) dst_len, (uint32_t) ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000203
204 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000205}
206
207size_t
208SBProcess::GetSTDERR (char *dst, size_t dst_len) const
209{
Caroline Tice7826c882010-10-26 03:11:13 +0000210 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
211
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000212 //if (log)
213 // log->Printf ("SBProcess::GetSTDERR (char *dst, size_t dst_len)");
Caroline Tice7826c882010-10-26 03:11:13 +0000214
215 size_t ret_val = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000216 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000217 {
218 Error error;
Caroline Tice7826c882010-10-26 03:11:13 +0000219 ret_val = m_opaque_sp->GetSTDERR (dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000220 }
Caroline Tice7826c882010-10-26 03:11:13 +0000221
222 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000223 log->Printf ("SBProcess::GetSTDERR (this.sp=%p, dst='%s', dst_len=%d) => %d", m_opaque_sp.get(), dst,
224 (uint32_t) dst_len, (uint32_t) ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000225
226 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000227}
228
229void
Jim Inghamc8332952010-08-26 21:32:51 +0000230SBProcess::ReportEventState (const SBEvent &event, FILE *out) const
Chris Lattner24943d22010-06-08 16:52:24 +0000231{
232 if (out == NULL)
233 return;
234
Greg Clayton63094e02010-06-23 01:19:29 +0000235 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000236 {
237 const StateType event_state = SBProcess::GetStateFromEvent (event);
238 char message[1024];
239 int message_len = ::snprintf (message,
240 sizeof (message),
241 "Process %d %s\n",
Greg Clayton63094e02010-06-23 01:19:29 +0000242 m_opaque_sp->GetID(),
Chris Lattner24943d22010-06-08 16:52:24 +0000243 SBDebugger::StateAsCString (event_state));
244
245 if (message_len > 0)
246 ::fwrite (message, 1, message_len, out);
247 }
248}
249
250void
Jim Inghamc8332952010-08-26 21:32:51 +0000251SBProcess::AppendEventStateReport (const SBEvent &event, SBCommandReturnObject &result)
Chris Lattner24943d22010-06-08 16:52:24 +0000252{
Greg Clayton63094e02010-06-23 01:19:29 +0000253 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000254 {
255 const StateType event_state = SBProcess::GetStateFromEvent (event);
256 char message[1024];
257 ::snprintf (message,
258 sizeof (message),
259 "Process %d %s\n",
Greg Clayton63094e02010-06-23 01:19:29 +0000260 m_opaque_sp->GetID(),
Chris Lattner24943d22010-06-08 16:52:24 +0000261 SBDebugger::StateAsCString (event_state));
262
263 result.AppendMessage (message);
264 }
265}
266
267bool
Jim Inghamc8332952010-08-26 21:32:51 +0000268SBProcess::SetSelectedThread (const SBThread &thread)
Chris Lattner24943d22010-06-08 16:52:24 +0000269{
Greg Clayton63094e02010-06-23 01:19:29 +0000270 if (m_opaque_sp != NULL)
Jim Inghamc8332952010-08-26 21:32:51 +0000271 return m_opaque_sp->GetThreadList().SetSelectedThreadByID (thread.GetThreadID());
Chris Lattner24943d22010-06-08 16:52:24 +0000272 return false;
273}
274
275bool
Jim Inghamc8332952010-08-26 21:32:51 +0000276SBProcess::SetSelectedThreadByID (uint32_t tid)
Chris Lattner24943d22010-06-08 16:52:24 +0000277{
Caroline Tice7826c882010-10-26 03:11:13 +0000278 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
279
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000280 //if (log)
281 // log->Printf ("SBProcess::SetSelectedThreadByID (%d)", tid);
Caroline Tice7826c882010-10-26 03:11:13 +0000282
283 bool ret_val = false;
Greg Clayton63094e02010-06-23 01:19:29 +0000284 if (m_opaque_sp != NULL)
Caroline Tice7826c882010-10-26 03:11:13 +0000285 ret_val = m_opaque_sp->GetThreadList().SetSelectedThreadByID (tid);
286
287 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000288 log->Printf ("SBProcess::SetSelectedThreadByID (this.sp=%p, tid=%d) => '%s'", m_opaque_sp.get(),
289 tid, (ret_val ? "true" : "false"));
Caroline Tice7826c882010-10-26 03:11:13 +0000290
291 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000292}
293
294SBThread
295SBProcess::GetThreadAtIndex (size_t index)
296{
Caroline Tice7826c882010-10-26 03:11:13 +0000297 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
298
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000299 //if (log)
300 // log->Printf ("SBProcess::GetThreadAtIndex (%d)");
Caroline Tice7826c882010-10-26 03:11:13 +0000301
Chris Lattner24943d22010-06-08 16:52:24 +0000302 SBThread thread;
Greg Clayton63094e02010-06-23 01:19:29 +0000303 if (m_opaque_sp)
304 thread.SetThread (m_opaque_sp->GetThreadList().GetThreadAtIndex(index));
Caroline Tice7826c882010-10-26 03:11:13 +0000305
306 if (log)
307 {
308 SBStream sstr;
309 thread.GetDescription (sstr);
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000310 log->Printf ("SBProcess::GetThreadAtIndex (this.sp=%p, index=%d) => SBThread : this.sp = %p, '%s'",
311 m_opaque_sp.get(), (uint32_t) index, thread.GetLLDBObjectPtr(), sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000312 }
313
Chris Lattner24943d22010-06-08 16:52:24 +0000314 return thread;
315}
316
317StateType
318SBProcess::GetState ()
319{
Caroline Tice7826c882010-10-26 03:11:13 +0000320 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
321
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000322 //if (log)
323 // log->Printf ("SBProcess::GetState ()");
Caroline Tice7826c882010-10-26 03:11:13 +0000324
325 StateType ret_val = eStateInvalid;
Greg Clayton63094e02010-06-23 01:19:29 +0000326 if (m_opaque_sp != NULL)
Caroline Tice7826c882010-10-26 03:11:13 +0000327 ret_val = m_opaque_sp->GetState();
328
329 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000330 log->Printf ("SBProcess::GetState (this.sp=%p) => '%s'", m_opaque_sp.get(),
331 lldb_private::StateAsCString (ret_val));
Caroline Tice7826c882010-10-26 03:11:13 +0000332
333 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000334}
335
336
337int
338SBProcess::GetExitStatus ()
339{
Greg Clayton63094e02010-06-23 01:19:29 +0000340 if (m_opaque_sp != NULL)
341 return m_opaque_sp->GetExitStatus ();
Chris Lattner24943d22010-06-08 16:52:24 +0000342 else
343 return 0;
344}
345
346const char *
347SBProcess::GetExitDescription ()
348{
Greg Clayton63094e02010-06-23 01:19:29 +0000349 if (m_opaque_sp != NULL)
350 return m_opaque_sp->GetExitDescription ();
Chris Lattner24943d22010-06-08 16:52:24 +0000351 else
352 return NULL;
353}
354
355lldb::pid_t
356SBProcess::GetProcessID ()
357{
Caroline Tice7826c882010-10-26 03:11:13 +0000358 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
359
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000360 //if (log)
361 // log->Printf ("SBProcess::GetProcessID ()");
Caroline Tice7826c882010-10-26 03:11:13 +0000362
363 lldb::pid_t ret_val = LLDB_INVALID_PROCESS_ID;
Greg Clayton63094e02010-06-23 01:19:29 +0000364 if (m_opaque_sp)
Caroline Tice7826c882010-10-26 03:11:13 +0000365 ret_val = m_opaque_sp->GetID();
366
367 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000368 log->Printf ("SBProcess::GetProcessID (this.sp=%p) => %d", m_opaque_sp.get(), ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000369
370 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000371}
372
373uint32_t
374SBProcess::GetAddressByteSize () const
375{
Caroline Tice7826c882010-10-26 03:11:13 +0000376 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
377
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000378 //if (log)
379 // log->Printf ("SBProcess::GetAddressByteSize()");
Caroline Tice7826c882010-10-26 03:11:13 +0000380
381 uint32_t size = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000382 if (m_opaque_sp)
Caroline Tice7826c882010-10-26 03:11:13 +0000383 size = m_opaque_sp->GetAddressByteSize();
384
385 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000386 log->Printf ("SBProcess::GetAddressByteSize (this.sp=%p) => %d", m_opaque_sp.get(), size);
Caroline Tice7826c882010-10-26 03:11:13 +0000387
388 return size;
Chris Lattner24943d22010-06-08 16:52:24 +0000389}
390
Chris Lattner24943d22010-06-08 16:52:24 +0000391bool
392SBProcess::WaitUntilProcessHasStopped (SBCommandReturnObject &result)
393{
394 bool state_changed = false;
395
396 if (IsValid())
397 {
398 EventSP event_sp;
Greg Clayton63094e02010-06-23 01:19:29 +0000399 StateType state = m_opaque_sp->WaitForStateChangedEvents (NULL, event_sp);
Chris Lattner24943d22010-06-08 16:52:24 +0000400
401 while (StateIsStoppedState (state))
402 {
Greg Clayton63094e02010-06-23 01:19:29 +0000403 state = m_opaque_sp->WaitForStateChangedEvents (NULL, event_sp);
Chris Lattner24943d22010-06-08 16:52:24 +0000404 SBEvent event (event_sp);
Jim Inghamc8332952010-08-26 21:32:51 +0000405 AppendEventStateReport (event, result);
Chris Lattner24943d22010-06-08 16:52:24 +0000406 state_changed = true;
407 }
408 }
409 return state_changed;
410}
411
412SBError
413SBProcess::Continue ()
414{
Caroline Tice7826c882010-10-26 03:11:13 +0000415 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
416
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000417 //if (log)
418 // log->Printf ("SBProcess::Continue ()");
Caroline Tice7826c882010-10-26 03:11:13 +0000419
Chris Lattner24943d22010-06-08 16:52:24 +0000420 SBError sb_error;
421 if (IsValid())
Greg Clayton1a3083a2010-10-06 03:53:16 +0000422 {
423 Error error (m_opaque_sp->Resume());
424 if (error.Success())
425 {
426 if (m_opaque_sp->GetTarget().GetDebugger().GetAsyncExecution () == false)
427 m_opaque_sp->WaitForProcessToStop (NULL);
428 }
429 sb_error.SetError(error);
430 }
Chris Lattner24943d22010-06-08 16:52:24 +0000431 else
432 sb_error.SetErrorString ("SBProcess is invalid");
433
Caroline Tice7826c882010-10-26 03:11:13 +0000434 if (log)
435 {
436 SBStream sstr;
437 sb_error.GetDescription (sstr);
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000438 log->Printf ("SBProcess::Continue (this.sp=%p) => SBError (this.ap = %p, '%s')", m_opaque_sp.get(),
439 sb_error.get(), sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000440 }
441
Chris Lattner24943d22010-06-08 16:52:24 +0000442 return sb_error;
443}
444
445
446SBError
447SBProcess::Destroy ()
448{
449 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000450 if (m_opaque_sp)
451 sb_error.SetError(m_opaque_sp->Destroy());
Chris Lattner24943d22010-06-08 16:52:24 +0000452 else
453 sb_error.SetErrorString ("SBProcess is invalid");
454
455 return sb_error;
456}
457
458
459SBError
460SBProcess::Stop ()
461{
Caroline Tice7826c882010-10-26 03:11:13 +0000462 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
463
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000464 //if (log)
465 // log->Printf ("SBProcess::Stop ()");
Caroline Tice7826c882010-10-26 03:11:13 +0000466
Chris Lattner24943d22010-06-08 16:52:24 +0000467 SBError sb_error;
468 if (IsValid())
Greg Clayton63094e02010-06-23 01:19:29 +0000469 sb_error.SetError (m_opaque_sp->Halt());
Chris Lattner24943d22010-06-08 16:52:24 +0000470 else
471 sb_error.SetErrorString ("SBProcess is invalid");
Caroline Tice7826c882010-10-26 03:11:13 +0000472
473 if (log)
474 {
475 SBStream sstr;
476 sb_error.GetDescription (sstr);
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000477 log->Printf ("SBProcess::Stop (this.sp=%p) => SBError (this.ap = %p, '%s')", m_opaque_sp.get(), sb_error.get(),
478 sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000479 }
480
Chris Lattner24943d22010-06-08 16:52:24 +0000481 return sb_error;
482}
483
484SBError
485SBProcess::Kill ()
486{
Caroline Tice7826c882010-10-26 03:11:13 +0000487 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
488
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000489 //if (log)
490 // log->Printf ("SBProcess::Kill ()");
Caroline Tice7826c882010-10-26 03:11:13 +0000491
Chris Lattner24943d22010-06-08 16:52:24 +0000492 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000493 if (m_opaque_sp)
494 sb_error.SetError (m_opaque_sp->Destroy());
Chris Lattner24943d22010-06-08 16:52:24 +0000495 else
496 sb_error.SetErrorString ("SBProcess is invalid");
Caroline Tice7826c882010-10-26 03:11:13 +0000497
498 if (log)
499 {
500 SBStream sstr;
501 sb_error.GetDescription (sstr);
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000502 log->Printf ("SBProcess::Kill (this.sp=%p) => SBError (this.ap = %p,'%s')", m_opaque_sp.get(), sb_error.get(),
503 sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000504 }
505
Chris Lattner24943d22010-06-08 16:52:24 +0000506 return sb_error;
507}
508
509
510SBError
511SBProcess::AttachByName (const char *name, bool wait_for_launch)
512{
513 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000514 if (m_opaque_sp)
515 sb_error.SetError (m_opaque_sp->Attach (name, wait_for_launch));
Chris Lattner24943d22010-06-08 16:52:24 +0000516 else
517 sb_error.SetErrorString ("SBProcess is invalid");
518 return sb_error;
519}
520
521lldb::pid_t
Caroline Ticedfc91c32010-09-15 18:29:06 +0000522SBProcess::AttachByPID (lldb::pid_t attach_pid) // DEPRECATED: will be removed in a few builds in favor of SBError AttachByPID(pid_t)
Chris Lattner24943d22010-06-08 16:52:24 +0000523{
524 Attach (attach_pid);
525 return GetProcessID();
526}
527
Caroline Ticedfc91c32010-09-15 18:29:06 +0000528
Chris Lattner24943d22010-06-08 16:52:24 +0000529SBError
530SBProcess::Attach (lldb::pid_t attach_pid)
531{
532 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000533 if (m_opaque_sp)
534 sb_error.SetError (m_opaque_sp->Attach (attach_pid));
Chris Lattner24943d22010-06-08 16:52:24 +0000535 else
536 sb_error.SetErrorString ("SBProcess is invalid");
537 return sb_error;
538}
539
540SBError
541SBProcess::Detach ()
542{
543 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000544 if (m_opaque_sp)
545 sb_error.SetError (m_opaque_sp->Detach());
Chris Lattner24943d22010-06-08 16:52:24 +0000546 else
547 sb_error.SetErrorString ("SBProcess is invalid");
548
549 return sb_error;
550}
551
552SBError
553SBProcess::Signal (int signal)
554{
555 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000556 if (m_opaque_sp)
557 sb_error.SetError (m_opaque_sp->Signal (signal));
Chris Lattner24943d22010-06-08 16:52:24 +0000558 else
559 sb_error.SetErrorString ("SBProcess is invalid");
560 return sb_error;
561}
562
Chris Lattner24943d22010-06-08 16:52:24 +0000563SBThread
564SBProcess::GetThreadByID (tid_t sb_thread_id)
565{
566 SBThread thread;
Greg Clayton63094e02010-06-23 01:19:29 +0000567 if (m_opaque_sp)
568 thread.SetThread (m_opaque_sp->GetThreadList().FindThreadByID ((tid_t) sb_thread_id));
Chris Lattner24943d22010-06-08 16:52:24 +0000569 return thread;
570}
571
Chris Lattner24943d22010-06-08 16:52:24 +0000572StateType
573SBProcess::GetStateFromEvent (const SBEvent &event)
574{
Caroline Tice7826c882010-10-26 03:11:13 +0000575 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
576
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000577 //if (log)
578 //{
579 // SBStream sstr;
580 // event.GetDescription (sstr);
581 // log->Printf ("SBProcess::GetStateFromEvent (%s)", sstr.GetData());
582 //}
Caroline Tice7826c882010-10-26 03:11:13 +0000583
584 StateType ret_val = Process::ProcessEventData::GetStateFromEvent (event.get());
585
586 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000587 log->Printf ("SBProcess::GetStateFromEvent (event.sp=%p) => '%s'", event.get(),
588 lldb_private::StateAsCString (ret_val));
Caroline Tice7826c882010-10-26 03:11:13 +0000589
590 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000591}
592
Chris Lattner24943d22010-06-08 16:52:24 +0000593bool
594SBProcess::GetRestartedFromEvent (const SBEvent &event)
595{
Greg Clayton63094e02010-06-23 01:19:29 +0000596 return Process::ProcessEventData::GetRestartedFromEvent (event.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000597}
598
599SBProcess
600SBProcess::GetProcessFromEvent (const SBEvent &event)
601{
Greg Clayton63094e02010-06-23 01:19:29 +0000602 SBProcess process(Process::ProcessEventData::GetProcessFromEvent (event.get()));
Chris Lattner24943d22010-06-08 16:52:24 +0000603 return process;
604}
605
606
607SBBroadcaster
608SBProcess::GetBroadcaster () const
609{
Caroline Tice7826c882010-10-26 03:11:13 +0000610 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
611
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000612 //if (log)
613 // log->Printf ("SBProcess::GetBroadcaster ()");
614
Greg Clayton63094e02010-06-23 01:19:29 +0000615 SBBroadcaster broadcaster(m_opaque_sp.get(), false);
Caroline Tice7826c882010-10-26 03:11:13 +0000616
617 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000618 log->Printf ("SBProcess::GetBroadcaster (this.sp=%p) => SBBroadcaster (this.obj = %p)", m_opaque_sp.get(),
619 broadcaster.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000620
Chris Lattner24943d22010-06-08 16:52:24 +0000621 return broadcaster;
622}
623
624lldb_private::Process *
625SBProcess::operator->() const
626{
Greg Clayton63094e02010-06-23 01:19:29 +0000627 return m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000628}
629
630size_t
631SBProcess::ReadMemory (addr_t addr, void *dst, size_t dst_len, SBError &sb_error)
632{
Caroline Tice7826c882010-10-26 03:11:13 +0000633 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
634
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000635 //if (log)
636 // log->Printf ("SBProcess::ReadMemory (%p, %p, %d, sb_error)", addr, dst, dst_len);
Caroline Tice7826c882010-10-26 03:11:13 +0000637
Chris Lattner24943d22010-06-08 16:52:24 +0000638 size_t bytes_read = 0;
639
640 if (IsValid())
641 {
642 Error error;
Greg Clayton63094e02010-06-23 01:19:29 +0000643 bytes_read = m_opaque_sp->ReadMemory (addr, dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000644 sb_error.SetError (error);
645 }
646 else
647 {
648 sb_error.SetErrorString ("SBProcess is invalid");
649 }
650
Caroline Tice7826c882010-10-26 03:11:13 +0000651 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000652 log->Printf ("SBProcess::ReadMemory (this.sp=%p, addr=%p, dst=%p, dst_len=%d, sb_error.ap=%p) => %d",
653 m_opaque_sp.get(), addr, dst, (uint32_t) dst_len, sb_error.get(), (uint32_t) bytes_read);
Caroline Tice7826c882010-10-26 03:11:13 +0000654
Chris Lattner24943d22010-06-08 16:52:24 +0000655 return bytes_read;
656}
657
658size_t
659SBProcess::WriteMemory (addr_t addr, const void *src, size_t src_len, SBError &sb_error)
660{
661 size_t bytes_written = 0;
662
663 if (IsValid())
664 {
665 Error error;
Greg Clayton63094e02010-06-23 01:19:29 +0000666 bytes_written = m_opaque_sp->WriteMemory (addr, src, src_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000667 sb_error.SetError (error);
668 }
669
670 return bytes_written;
671}
672
673// Mimic shared pointer...
674lldb_private::Process *
675SBProcess::get() const
676{
Greg Clayton63094e02010-06-23 01:19:29 +0000677 return m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000678}
679
Caroline Tice98f930f2010-09-20 05:20:02 +0000680bool
681SBProcess::GetDescription (SBStream &description)
682{
683 if (m_opaque_sp)
684 {
685 char path[PATH_MAX];
686 GetTarget().GetExecutable().GetPath (path, sizeof(path));
Greg Clayton5c4c7462010-10-06 03:09:58 +0000687 Module *exe_module = m_opaque_sp->GetTarget().GetExecutableModule ().get();
688 const char *exe_name = NULL;
689 if (exe_module)
690 exe_name = exe_module->GetFileSpec().GetFilename().AsCString();
691
Greg Claytond8c62532010-10-07 04:19:01 +0000692 description.Printf ("SBProcess: pid = %d, state = %s, threads = %d%s%s",
Greg Clayton5c4c7462010-10-06 03:09:58 +0000693 m_opaque_sp->GetID(),
Caroline Tice7826c882010-10-26 03:11:13 +0000694 lldb_private::StateAsCString (GetState()),
Greg Clayton5c4c7462010-10-06 03:09:58 +0000695 GetNumThreads(),
Greg Claytond8c62532010-10-07 04:19:01 +0000696 exe_name ? ", executable = " : "",
Greg Clayton5c4c7462010-10-06 03:09:58 +0000697 exe_name ? exe_name : "");
Caroline Tice98f930f2010-09-20 05:20:02 +0000698 }
699 else
700 description.Printf ("No value");
701
702 return true;
703}