blob: eb007fcfa773d11f8702e47c269a9b2ae54e5762 [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)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +000059 log->Printf ("SBProcess::SBProcess(%p)", rhs.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)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +000069 log->Printf ("SBProcess::SBProcess(%p)", process_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 Tice7826c882010-10-26 03:11:13 +0000104 uint32_t num_threads = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000105 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000106 {
107 const bool can_update = true;
Caroline Tice7826c882010-10-26 03:11:13 +0000108 num_threads = m_opaque_sp->GetThreadList().GetSize(can_update);
Chris Lattner24943d22010-06-08 16:52:24 +0000109 }
Caroline Tice7826c882010-10-26 03:11:13 +0000110
111 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000112 log->Printf ("SBProcess(%p)::GetNumThreads () => %d", m_opaque_sp.get(), num_threads);
Caroline Tice7826c882010-10-26 03:11:13 +0000113
114 return num_threads;
Chris Lattner24943d22010-06-08 16:52:24 +0000115}
116
117SBThread
Jim Inghamc8332952010-08-26 21:32:51 +0000118SBProcess::GetSelectedThread () const
Chris Lattner24943d22010-06-08 16:52:24 +0000119{
Caroline Tice7826c882010-10-26 03:11:13 +0000120 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
121
Chris Lattner24943d22010-06-08 16:52:24 +0000122 SBThread sb_thread;
Greg Clayton63094e02010-06-23 01:19:29 +0000123 if (m_opaque_sp)
Jim Inghamc8332952010-08-26 21:32:51 +0000124 sb_thread.SetThread (m_opaque_sp->GetThreadList().GetSelectedThread());
Caroline Tice7826c882010-10-26 03:11:13 +0000125
126 if (log)
127 {
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000128 log->Printf ("SBProcess(%p)::GetSelectedThread () => SBThread(%p)", m_opaque_sp.get(), sb_thread.GetLLDBObjectPtr());
Caroline Tice7826c882010-10-26 03:11:13 +0000129 }
130
Chris Lattner24943d22010-06-08 16:52:24 +0000131 return sb_thread;
132}
133
134SBTarget
135SBProcess::GetTarget() const
136{
Caroline Tice7826c882010-10-26 03:11:13 +0000137 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
138
Chris Lattner24943d22010-06-08 16:52:24 +0000139 SBTarget sb_target;
Greg Clayton63094e02010-06-23 01:19:29 +0000140 if (m_opaque_sp)
141 sb_target = m_opaque_sp->GetTarget().GetSP();
Caroline Tice7826c882010-10-26 03:11:13 +0000142
143 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000144 log->Printf ("SBProcess(%p)::GetTarget () => SBTarget(%p)", m_opaque_sp.get(), sb_target.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000145
Chris Lattner24943d22010-06-08 16:52:24 +0000146 return sb_target;
147}
148
149
150size_t
151SBProcess::PutSTDIN (const char *src, size_t src_len)
152{
Caroline Tice7826c882010-10-26 03:11:13 +0000153 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
154
Caroline Tice7826c882010-10-26 03:11:13 +0000155 size_t ret_val = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000156 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000157 {
158 Error error;
Caroline Tice7826c882010-10-26 03:11:13 +0000159 ret_val = m_opaque_sp->PutSTDIN (src, src_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000160 }
Caroline Tice7826c882010-10-26 03:11:13 +0000161
162 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000163 log->Printf ("SBProcess(%p)::PutSTDIN (src='%s', src_len=%d) => %d",
164 m_opaque_sp.get(),
165 src,
166 (uint32_t) src_len,
167 ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000168
169 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000170}
171
172size_t
173SBProcess::GetSTDOUT (char *dst, size_t dst_len) const
174{
Caroline Tice7826c882010-10-26 03:11:13 +0000175 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
176
Caroline Tice7826c882010-10-26 03:11:13 +0000177 size_t ret_val = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000178 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000179 {
180 Error error;
Caroline Tice7826c882010-10-26 03:11:13 +0000181 ret_val = m_opaque_sp->GetSTDOUT (dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000182 }
Caroline Tice7826c882010-10-26 03:11:13 +0000183
184 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000185 log->Printf ("SBProcess(%p)::GetSTDOUT (dst='%.*s', dst_len=%d) => %d",
186 m_opaque_sp.get(),
187 (uint32_t) dst_len,
188 dst,
189 (uint32_t) dst_len,
190 (uint32_t) ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000191
192 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000193}
194
195size_t
196SBProcess::GetSTDERR (char *dst, size_t dst_len) const
197{
Caroline Tice7826c882010-10-26 03:11:13 +0000198 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
199
Caroline Tice7826c882010-10-26 03:11:13 +0000200 size_t ret_val = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000201 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000202 {
203 Error error;
Caroline Tice7826c882010-10-26 03:11:13 +0000204 ret_val = m_opaque_sp->GetSTDERR (dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000205 }
Caroline Tice7826c882010-10-26 03:11:13 +0000206
207 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000208 log->Printf ("SBProcess(%p)::GetSTDERR (dst='%.*s', dst_len=%d) => %d",
209 m_opaque_sp.get(),
210 (uint32_t) dst_len,
211 dst,
212 (uint32_t) dst_len,
213 (uint32_t) ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000214
215 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000216}
217
218void
Jim Inghamc8332952010-08-26 21:32:51 +0000219SBProcess::ReportEventState (const SBEvent &event, FILE *out) const
Chris Lattner24943d22010-06-08 16:52:24 +0000220{
221 if (out == NULL)
222 return;
223
Greg Clayton63094e02010-06-23 01:19:29 +0000224 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000225 {
226 const StateType event_state = SBProcess::GetStateFromEvent (event);
227 char message[1024];
228 int message_len = ::snprintf (message,
229 sizeof (message),
230 "Process %d %s\n",
Greg Clayton63094e02010-06-23 01:19:29 +0000231 m_opaque_sp->GetID(),
Chris Lattner24943d22010-06-08 16:52:24 +0000232 SBDebugger::StateAsCString (event_state));
233
234 if (message_len > 0)
235 ::fwrite (message, 1, message_len, out);
236 }
237}
238
239void
Jim Inghamc8332952010-08-26 21:32:51 +0000240SBProcess::AppendEventStateReport (const SBEvent &event, SBCommandReturnObject &result)
Chris Lattner24943d22010-06-08 16:52:24 +0000241{
Greg Clayton63094e02010-06-23 01:19:29 +0000242 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000243 {
244 const StateType event_state = SBProcess::GetStateFromEvent (event);
245 char message[1024];
246 ::snprintf (message,
247 sizeof (message),
248 "Process %d %s\n",
Greg Clayton63094e02010-06-23 01:19:29 +0000249 m_opaque_sp->GetID(),
Chris Lattner24943d22010-06-08 16:52:24 +0000250 SBDebugger::StateAsCString (event_state));
251
252 result.AppendMessage (message);
253 }
254}
255
256bool
Jim Inghamc8332952010-08-26 21:32:51 +0000257SBProcess::SetSelectedThread (const SBThread &thread)
Chris Lattner24943d22010-06-08 16:52:24 +0000258{
Greg Clayton63094e02010-06-23 01:19:29 +0000259 if (m_opaque_sp != NULL)
Jim Inghamc8332952010-08-26 21:32:51 +0000260 return m_opaque_sp->GetThreadList().SetSelectedThreadByID (thread.GetThreadID());
Chris Lattner24943d22010-06-08 16:52:24 +0000261 return false;
262}
263
264bool
Jim Inghamc8332952010-08-26 21:32:51 +0000265SBProcess::SetSelectedThreadByID (uint32_t tid)
Chris Lattner24943d22010-06-08 16:52:24 +0000266{
Caroline Tice7826c882010-10-26 03:11:13 +0000267 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
268
Caroline Tice7826c882010-10-26 03:11:13 +0000269 bool ret_val = false;
Greg Clayton63094e02010-06-23 01:19:29 +0000270 if (m_opaque_sp != NULL)
Caroline Tice7826c882010-10-26 03:11:13 +0000271 ret_val = m_opaque_sp->GetThreadList().SetSelectedThreadByID (tid);
272
273 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000274 log->Printf ("SBProcess(%p)::SetSelectedThreadByID (tid=%d) => '%s'",
275 m_opaque_sp.get(), tid, (ret_val ? "true" : "false"));
Caroline Tice7826c882010-10-26 03:11:13 +0000276
277 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000278}
279
280SBThread
281SBProcess::GetThreadAtIndex (size_t index)
282{
Caroline Tice7826c882010-10-26 03:11:13 +0000283 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
284
Chris Lattner24943d22010-06-08 16:52:24 +0000285 SBThread thread;
Greg Clayton63094e02010-06-23 01:19:29 +0000286 if (m_opaque_sp)
287 thread.SetThread (m_opaque_sp->GetThreadList().GetThreadAtIndex(index));
Caroline Tice7826c882010-10-26 03:11:13 +0000288
289 if (log)
290 {
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000291 log->Printf ("SBProcess(%p)::GetThreadAtIndex (index=%d) => SBThread(%p)",
292 m_opaque_sp.get(), (uint32_t) index, thread.GetLLDBObjectPtr());
Caroline Tice7826c882010-10-26 03:11:13 +0000293 }
294
Chris Lattner24943d22010-06-08 16:52:24 +0000295 return thread;
296}
297
298StateType
299SBProcess::GetState ()
300{
Caroline Tice7826c882010-10-26 03:11:13 +0000301 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
302
Caroline Tice7826c882010-10-26 03:11:13 +0000303 StateType ret_val = eStateInvalid;
Greg Clayton63094e02010-06-23 01:19:29 +0000304 if (m_opaque_sp != NULL)
Caroline Tice7826c882010-10-26 03:11:13 +0000305 ret_val = m_opaque_sp->GetState();
306
307 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000308 log->Printf ("SBProcess(%p)::GetState () => '%s'",
309 m_opaque_sp.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000310 lldb_private::StateAsCString (ret_val));
Caroline Tice7826c882010-10-26 03:11:13 +0000311
312 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000313}
314
315
316int
317SBProcess::GetExitStatus ()
318{
Greg Clayton63094e02010-06-23 01:19:29 +0000319 if (m_opaque_sp != NULL)
320 return m_opaque_sp->GetExitStatus ();
Chris Lattner24943d22010-06-08 16:52:24 +0000321 else
322 return 0;
323}
324
325const char *
326SBProcess::GetExitDescription ()
327{
Greg Clayton63094e02010-06-23 01:19:29 +0000328 if (m_opaque_sp != NULL)
329 return m_opaque_sp->GetExitDescription ();
Chris Lattner24943d22010-06-08 16:52:24 +0000330 else
331 return NULL;
332}
333
334lldb::pid_t
335SBProcess::GetProcessID ()
336{
Caroline Tice7826c882010-10-26 03:11:13 +0000337 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
338
Caroline Tice7826c882010-10-26 03:11:13 +0000339 lldb::pid_t ret_val = LLDB_INVALID_PROCESS_ID;
Greg Clayton63094e02010-06-23 01:19:29 +0000340 if (m_opaque_sp)
Caroline Tice7826c882010-10-26 03:11:13 +0000341 ret_val = m_opaque_sp->GetID();
342
343 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000344 log->Printf ("SBProcess(%p)::GetProcessID () => %d", m_opaque_sp.get(), ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000345
346 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000347}
348
349uint32_t
350SBProcess::GetAddressByteSize () const
351{
Caroline Tice7826c882010-10-26 03:11:13 +0000352 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
353
Caroline Tice7826c882010-10-26 03:11:13 +0000354 uint32_t size = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000355 if (m_opaque_sp)
Caroline Tice7826c882010-10-26 03:11:13 +0000356 size = m_opaque_sp->GetAddressByteSize();
357
358 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000359 log->Printf ("SBProcess(%p)::GetAddressByteSize () => %d", m_opaque_sp.get(), size);
Caroline Tice7826c882010-10-26 03:11:13 +0000360
361 return size;
Chris Lattner24943d22010-06-08 16:52:24 +0000362}
363
Chris Lattner24943d22010-06-08 16:52:24 +0000364bool
365SBProcess::WaitUntilProcessHasStopped (SBCommandReturnObject &result)
366{
367 bool state_changed = false;
368
369 if (IsValid())
370 {
371 EventSP event_sp;
Greg Clayton63094e02010-06-23 01:19:29 +0000372 StateType state = m_opaque_sp->WaitForStateChangedEvents (NULL, event_sp);
Chris Lattner24943d22010-06-08 16:52:24 +0000373
374 while (StateIsStoppedState (state))
375 {
Greg Clayton63094e02010-06-23 01:19:29 +0000376 state = m_opaque_sp->WaitForStateChangedEvents (NULL, event_sp);
Chris Lattner24943d22010-06-08 16:52:24 +0000377 SBEvent event (event_sp);
Jim Inghamc8332952010-08-26 21:32:51 +0000378 AppendEventStateReport (event, result);
Chris Lattner24943d22010-06-08 16:52:24 +0000379 state_changed = true;
380 }
381 }
382 return state_changed;
383}
384
385SBError
386SBProcess::Continue ()
387{
Caroline Tice7826c882010-10-26 03:11:13 +0000388 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
389
Chris Lattner24943d22010-06-08 16:52:24 +0000390 SBError sb_error;
391 if (IsValid())
Greg Clayton1a3083a2010-10-06 03:53:16 +0000392 {
393 Error error (m_opaque_sp->Resume());
394 if (error.Success())
395 {
396 if (m_opaque_sp->GetTarget().GetDebugger().GetAsyncExecution () == false)
397 m_opaque_sp->WaitForProcessToStop (NULL);
398 }
399 sb_error.SetError(error);
400 }
Chris Lattner24943d22010-06-08 16:52:24 +0000401 else
402 sb_error.SetErrorString ("SBProcess is invalid");
403
Caroline Tice7826c882010-10-26 03:11:13 +0000404 if (log)
405 {
406 SBStream sstr;
407 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000408 log->Printf ("SBProcess(%p)::Continue () => SBError (%p): %s", m_opaque_sp.get(), sb_error.get(), sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000409 }
410
Chris Lattner24943d22010-06-08 16:52:24 +0000411 return sb_error;
412}
413
414
415SBError
416SBProcess::Destroy ()
417{
418 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000419 if (m_opaque_sp)
420 sb_error.SetError(m_opaque_sp->Destroy());
Chris Lattner24943d22010-06-08 16:52:24 +0000421 else
422 sb_error.SetErrorString ("SBProcess is invalid");
423
424 return sb_error;
425}
426
427
428SBError
429SBProcess::Stop ()
430{
Caroline Tice7826c882010-10-26 03:11:13 +0000431 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
432
Chris Lattner24943d22010-06-08 16:52:24 +0000433 SBError sb_error;
434 if (IsValid())
Greg Clayton63094e02010-06-23 01:19:29 +0000435 sb_error.SetError (m_opaque_sp->Halt());
Chris Lattner24943d22010-06-08 16:52:24 +0000436 else
437 sb_error.SetErrorString ("SBProcess is invalid");
Caroline Tice7826c882010-10-26 03:11:13 +0000438
439 if (log)
440 {
441 SBStream sstr;
442 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000443 log->Printf ("SBProcess(%p)::Stop () => SBError (%p): %s",
444 m_opaque_sp.get(),
445 sb_error.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000446 sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000447 }
448
Chris Lattner24943d22010-06-08 16:52:24 +0000449 return sb_error;
450}
451
452SBError
453SBProcess::Kill ()
454{
Caroline Tice7826c882010-10-26 03:11:13 +0000455 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
456
Chris Lattner24943d22010-06-08 16:52:24 +0000457 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000458 if (m_opaque_sp)
459 sb_error.SetError (m_opaque_sp->Destroy());
Chris Lattner24943d22010-06-08 16:52:24 +0000460 else
461 sb_error.SetErrorString ("SBProcess is invalid");
Caroline Tice7826c882010-10-26 03:11:13 +0000462
463 if (log)
464 {
465 SBStream sstr;
466 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000467 log->Printf ("SBProcess(%p)::Kill () => SBError (%p): %s",
468 m_opaque_sp.get(),
469 sb_error.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000470 sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000471 }
472
Chris Lattner24943d22010-06-08 16:52:24 +0000473 return sb_error;
474}
475
476
477SBError
478SBProcess::AttachByName (const char *name, bool wait_for_launch)
479{
480 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000481 if (m_opaque_sp)
482 sb_error.SetError (m_opaque_sp->Attach (name, wait_for_launch));
Chris Lattner24943d22010-06-08 16:52:24 +0000483 else
484 sb_error.SetErrorString ("SBProcess is invalid");
485 return sb_error;
486}
487
488lldb::pid_t
Caroline Ticedfc91c32010-09-15 18:29:06 +0000489SBProcess::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 +0000490{
491 Attach (attach_pid);
492 return GetProcessID();
493}
494
Caroline Ticedfc91c32010-09-15 18:29:06 +0000495
Chris Lattner24943d22010-06-08 16:52:24 +0000496SBError
497SBProcess::Attach (lldb::pid_t attach_pid)
498{
499 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000500 if (m_opaque_sp)
501 sb_error.SetError (m_opaque_sp->Attach (attach_pid));
Chris Lattner24943d22010-06-08 16:52:24 +0000502 else
503 sb_error.SetErrorString ("SBProcess is invalid");
504 return sb_error;
505}
506
507SBError
508SBProcess::Detach ()
509{
510 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000511 if (m_opaque_sp)
512 sb_error.SetError (m_opaque_sp->Detach());
Chris Lattner24943d22010-06-08 16:52:24 +0000513 else
514 sb_error.SetErrorString ("SBProcess is invalid");
515
516 return sb_error;
517}
518
519SBError
520SBProcess::Signal (int signal)
521{
522 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000523 if (m_opaque_sp)
524 sb_error.SetError (m_opaque_sp->Signal (signal));
Chris Lattner24943d22010-06-08 16:52:24 +0000525 else
526 sb_error.SetErrorString ("SBProcess is invalid");
527 return sb_error;
528}
529
Chris Lattner24943d22010-06-08 16:52:24 +0000530SBThread
531SBProcess::GetThreadByID (tid_t sb_thread_id)
532{
533 SBThread thread;
Greg Clayton63094e02010-06-23 01:19:29 +0000534 if (m_opaque_sp)
535 thread.SetThread (m_opaque_sp->GetThreadList().FindThreadByID ((tid_t) sb_thread_id));
Chris Lattner24943d22010-06-08 16:52:24 +0000536 return thread;
537}
538
Chris Lattner24943d22010-06-08 16:52:24 +0000539StateType
540SBProcess::GetStateFromEvent (const SBEvent &event)
541{
Caroline Tice7826c882010-10-26 03:11:13 +0000542 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
543
Caroline Tice7826c882010-10-26 03:11:13 +0000544 StateType ret_val = Process::ProcessEventData::GetStateFromEvent (event.get());
545
546 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000547 log->Printf ("SBProcess::GetStateFromEvent (event.sp=%p) => '%s'", event.get(),
548 lldb_private::StateAsCString (ret_val));
Caroline Tice7826c882010-10-26 03:11:13 +0000549
550 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000551}
552
Chris Lattner24943d22010-06-08 16:52:24 +0000553bool
554SBProcess::GetRestartedFromEvent (const SBEvent &event)
555{
Greg Clayton63094e02010-06-23 01:19:29 +0000556 return Process::ProcessEventData::GetRestartedFromEvent (event.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000557}
558
559SBProcess
560SBProcess::GetProcessFromEvent (const SBEvent &event)
561{
Greg Clayton63094e02010-06-23 01:19:29 +0000562 SBProcess process(Process::ProcessEventData::GetProcessFromEvent (event.get()));
Chris Lattner24943d22010-06-08 16:52:24 +0000563 return process;
564}
565
566
567SBBroadcaster
568SBProcess::GetBroadcaster () const
569{
Caroline Tice7826c882010-10-26 03:11:13 +0000570 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
571
Greg Clayton63094e02010-06-23 01:19:29 +0000572 SBBroadcaster broadcaster(m_opaque_sp.get(), false);
Caroline Tice7826c882010-10-26 03:11:13 +0000573
574 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000575 log->Printf ("SBProcess(%p)::GetBroadcaster () => SBBroadcaster (%p)", m_opaque_sp.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000576 broadcaster.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000577
Chris Lattner24943d22010-06-08 16:52:24 +0000578 return broadcaster;
579}
580
581lldb_private::Process *
582SBProcess::operator->() const
583{
Greg Clayton63094e02010-06-23 01:19:29 +0000584 return m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000585}
586
587size_t
588SBProcess::ReadMemory (addr_t addr, void *dst, size_t dst_len, SBError &sb_error)
589{
Caroline Tice7826c882010-10-26 03:11:13 +0000590 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
591
Chris Lattner24943d22010-06-08 16:52:24 +0000592 size_t bytes_read = 0;
593
594 if (IsValid())
595 {
596 Error error;
Greg Clayton63094e02010-06-23 01:19:29 +0000597 bytes_read = m_opaque_sp->ReadMemory (addr, dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000598 sb_error.SetError (error);
599 }
600 else
601 {
602 sb_error.SetErrorString ("SBProcess is invalid");
603 }
604
Caroline Tice7826c882010-10-26 03:11:13 +0000605 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000606 {
607 SBStream sstr;
608 sb_error.GetDescription (sstr);
609 log->Printf ("SBProcess(%p)::ReadMemory (addr=%llx, dst=%p, dst_len=%d, SBError (%p): %s) => %d",
610 m_opaque_sp.get(),
611 addr,
612 dst,
613 (uint32_t) dst_len,
614 sb_error.get(),
615 sstr.GetData(),
616 (uint32_t) bytes_read);
617 }
Caroline Tice7826c882010-10-26 03:11:13 +0000618
Chris Lattner24943d22010-06-08 16:52:24 +0000619 return bytes_read;
620}
621
622size_t
623SBProcess::WriteMemory (addr_t addr, const void *src, size_t src_len, SBError &sb_error)
624{
625 size_t bytes_written = 0;
626
627 if (IsValid())
628 {
629 Error error;
Greg Clayton63094e02010-06-23 01:19:29 +0000630 bytes_written = m_opaque_sp->WriteMemory (addr, src, src_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000631 sb_error.SetError (error);
632 }
633
634 return bytes_written;
635}
636
637// Mimic shared pointer...
638lldb_private::Process *
639SBProcess::get() const
640{
Greg Clayton63094e02010-06-23 01:19:29 +0000641 return m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000642}
643
Caroline Tice98f930f2010-09-20 05:20:02 +0000644bool
645SBProcess::GetDescription (SBStream &description)
646{
647 if (m_opaque_sp)
648 {
649 char path[PATH_MAX];
650 GetTarget().GetExecutable().GetPath (path, sizeof(path));
Greg Clayton5c4c7462010-10-06 03:09:58 +0000651 Module *exe_module = m_opaque_sp->GetTarget().GetExecutableModule ().get();
652 const char *exe_name = NULL;
653 if (exe_module)
654 exe_name = exe_module->GetFileSpec().GetFilename().AsCString();
655
Greg Claytond8c62532010-10-07 04:19:01 +0000656 description.Printf ("SBProcess: pid = %d, state = %s, threads = %d%s%s",
Greg Clayton5c4c7462010-10-06 03:09:58 +0000657 m_opaque_sp->GetID(),
Caroline Tice7826c882010-10-26 03:11:13 +0000658 lldb_private::StateAsCString (GetState()),
Greg Clayton5c4c7462010-10-06 03:09:58 +0000659 GetNumThreads(),
Greg Claytond8c62532010-10-07 04:19:01 +0000660 exe_name ? ", executable = " : "",
Greg Clayton5c4c7462010-10-06 03:09:58 +0000661 exe_name ? exe_name : "");
Caroline Tice98f930f2010-09-20 05:20:02 +0000662 }
663 else
664 description.Printf ("No value");
665
666 return true;
667}