2010-06-09 00:52:24 +08:00
|
|
|
//===-- SBDebugger.cpp ------------------------------------------*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2010-06-09 15:37:52 +08:00
|
|
|
#include "lldb/API/SBDebugger.h"
|
2010-06-09 00:52:24 +08:00
|
|
|
|
2011-03-25 05:19:54 +08:00
|
|
|
#include "lldb/lldb-private.h"
|
2010-06-09 00:52:24 +08:00
|
|
|
|
2010-06-09 15:37:52 +08:00
|
|
|
#include "lldb/API/SBListener.h"
|
|
|
|
#include "lldb/API/SBBroadcaster.h"
|
|
|
|
#include "lldb/API/SBCommandInterpreter.h"
|
|
|
|
#include "lldb/API/SBCommandReturnObject.h"
|
2011-04-30 09:09:13 +08:00
|
|
|
#include "lldb/API/SBError.h"
|
2010-06-09 15:37:52 +08:00
|
|
|
#include "lldb/API/SBEvent.h"
|
|
|
|
#include "lldb/API/SBFrame.h"
|
2010-09-04 08:03:46 +08:00
|
|
|
#include "lldb/API/SBInputReader.h"
|
2010-06-09 15:37:52 +08:00
|
|
|
#include "lldb/API/SBProcess.h"
|
|
|
|
#include "lldb/API/SBSourceManager.h"
|
2010-09-20 13:20:02 +08:00
|
|
|
#include "lldb/API/SBStream.h"
|
2010-09-04 08:03:46 +08:00
|
|
|
#include "lldb/API/SBStringList.h"
|
|
|
|
#include "lldb/API/SBTarget.h"
|
|
|
|
#include "lldb/API/SBThread.h"
|
2010-10-11 09:05:37 +08:00
|
|
|
#include "lldb/Core/Debugger.h"
|
|
|
|
#include "lldb/Core/State.h"
|
|
|
|
#include "lldb/Interpreter/Args.h"
|
|
|
|
#include "lldb/Interpreter/CommandInterpreter.h"
|
|
|
|
#include "lldb/Target/Process.h"
|
|
|
|
#include "lldb/Target/TargetList.h"
|
2010-06-09 00:52:24 +08:00
|
|
|
|
|
|
|
using namespace lldb;
|
|
|
|
using namespace lldb_private;
|
|
|
|
|
|
|
|
void
|
|
|
|
SBDebugger::Initialize ()
|
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
2010-10-26 11:11:13 +08:00
|
|
|
|
|
|
|
if (log)
|
|
|
|
log->Printf ("SBDebugger::Initialize ()");
|
|
|
|
|
2011-03-22 09:14:58 +08:00
|
|
|
SBCommandInterpreter::InitializeSWIG ();
|
|
|
|
|
2010-06-09 00:52:24 +08:00
|
|
|
Debugger::Initialize();
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
SBDebugger::Terminate ()
|
|
|
|
{
|
|
|
|
Debugger::Terminate();
|
|
|
|
}
|
|
|
|
|
2010-07-31 04:12:55 +08:00
|
|
|
void
|
|
|
|
SBDebugger::Clear ()
|
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
2010-10-26 11:11:13 +08:00
|
|
|
|
|
|
|
if (log)
|
2010-10-29 12:59:35 +08:00
|
|
|
log->Printf ("SBDebugger(%p)::Clear ()", m_opaque_sp.get());
|
2010-12-21 02:35:50 +08:00
|
|
|
|
|
|
|
if (m_opaque_sp)
|
|
|
|
m_opaque_sp->CleanUpInputReaders ();
|
2010-10-26 11:11:13 +08:00
|
|
|
|
2010-07-31 04:12:55 +08:00
|
|
|
m_opaque_sp.reset();
|
|
|
|
}
|
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
SBDebugger
|
|
|
|
SBDebugger::Create()
|
2010-06-09 00:52:24 +08:00
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
2010-10-26 11:11:13 +08:00
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
SBDebugger debugger;
|
|
|
|
debugger.reset(Debugger::CreateInstance());
|
2010-10-26 11:11:13 +08:00
|
|
|
|
|
|
|
if (log)
|
|
|
|
{
|
|
|
|
SBStream sstr;
|
|
|
|
debugger.GetDescription (sstr);
|
2010-10-29 12:59:35 +08:00
|
|
|
log->Printf ("SBDebugger::Create () => SBDebugger(%p): %s", debugger.m_opaque_sp.get(), sstr.GetData());
|
2010-10-26 11:11:13 +08:00
|
|
|
}
|
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
return debugger;
|
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
|
2011-01-22 09:02:07 +08:00
|
|
|
void
|
|
|
|
SBDebugger::Destroy (SBDebugger &debugger)
|
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
LogSP log (GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
2011-01-22 09:02:07 +08:00
|
|
|
|
|
|
|
if (log)
|
|
|
|
{
|
|
|
|
SBStream sstr;
|
|
|
|
debugger.GetDescription (sstr);
|
|
|
|
log->Printf ("SBDebugger::Destroy () => SBDebugger(%p): %s", debugger.m_opaque_sp.get(), sstr.GetData());
|
|
|
|
}
|
|
|
|
|
|
|
|
Debugger::Destroy (debugger.m_opaque_sp);
|
|
|
|
|
|
|
|
if (debugger.m_opaque_sp.get() != NULL)
|
|
|
|
debugger.m_opaque_sp.reset();
|
|
|
|
}
|
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
SBDebugger::SBDebugger () :
|
|
|
|
m_opaque_sp ()
|
|
|
|
{
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
2010-11-06 07:17:00 +08:00
|
|
|
SBDebugger::SBDebugger(const SBDebugger &rhs) :
|
|
|
|
m_opaque_sp (rhs.m_opaque_sp)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
SBDebugger &
|
|
|
|
SBDebugger::operator = (const SBDebugger &rhs)
|
|
|
|
{
|
|
|
|
if (this != &rhs)
|
|
|
|
{
|
|
|
|
m_opaque_sp = rhs.m_opaque_sp;
|
|
|
|
}
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
SBDebugger::~SBDebugger ()
|
2010-06-09 00:52:24 +08:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
bool
|
|
|
|
SBDebugger::IsValid() const
|
2010-06-09 00:52:24 +08:00
|
|
|
{
|
2010-06-23 09:19:29 +08:00
|
|
|
return m_opaque_sp.get() != NULL;
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
|
2010-06-09 00:52:24 +08:00
|
|
|
void
|
2010-06-23 09:19:29 +08:00
|
|
|
SBDebugger::SetAsync (bool b)
|
2010-06-09 00:52:24 +08:00
|
|
|
{
|
2010-06-23 09:19:29 +08:00
|
|
|
if (m_opaque_sp)
|
|
|
|
m_opaque_sp->SetAsyncExecution(b);
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
2010-10-11 09:05:37 +08:00
|
|
|
void
|
|
|
|
SBDebugger::SkipLLDBInitFiles (bool b)
|
|
|
|
{
|
|
|
|
if (m_opaque_sp)
|
|
|
|
m_opaque_sp->GetCommandInterpreter().SkipLLDBInitFiles (b);
|
|
|
|
}
|
|
|
|
|
2010-06-09 00:52:24 +08:00
|
|
|
// Shouldn't really be settable after initialization as this could cause lots of problems; don't want users
|
|
|
|
// trying to switch modes in the middle of a debugging session.
|
|
|
|
void
|
|
|
|
SBDebugger::SetInputFileHandle (FILE *fh, bool transfer_ownership)
|
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
2010-10-26 11:11:13 +08:00
|
|
|
|
|
|
|
if (log)
|
2010-10-31 11:01:06 +08:00
|
|
|
log->Printf ("SBDebugger(%p)::SetInputFileHandle (fh=%p, transfer_ownership=%i)", m_opaque_sp.get(),
|
|
|
|
fh, transfer_ownership);
|
2010-10-26 11:11:13 +08:00
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
if (m_opaque_sp)
|
|
|
|
m_opaque_sp->SetInputFileHandle (fh, transfer_ownership);
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
SBDebugger::SetOutputFileHandle (FILE *fh, bool transfer_ownership)
|
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
2010-10-26 11:11:13 +08:00
|
|
|
|
|
|
|
|
|
|
|
if (log)
|
2010-10-31 11:01:06 +08:00
|
|
|
log->Printf ("SBDebugger(%p)::SetOutputFileHandle (fh=%p, transfer_ownership=%i)", m_opaque_sp.get(),
|
|
|
|
fh, transfer_ownership);
|
2010-10-26 11:11:13 +08:00
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
if (m_opaque_sp)
|
|
|
|
m_opaque_sp->SetOutputFileHandle (fh, transfer_ownership);
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
SBDebugger::SetErrorFileHandle (FILE *fh, bool transfer_ownership)
|
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
2010-10-26 11:11:13 +08:00
|
|
|
|
|
|
|
|
|
|
|
if (log)
|
2010-10-31 11:01:06 +08:00
|
|
|
log->Printf ("SBDebugger(%p)::SetErrorFileHandle (fh=%p, transfer_ownership=%i)", m_opaque_sp.get(),
|
|
|
|
fh, transfer_ownership);
|
2010-10-26 11:11:13 +08:00
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
if (m_opaque_sp)
|
|
|
|
m_opaque_sp->SetErrorFileHandle (fh, transfer_ownership);
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
FILE *
|
|
|
|
SBDebugger::GetInputFileHandle ()
|
|
|
|
{
|
2010-06-23 09:19:29 +08:00
|
|
|
if (m_opaque_sp)
|
2011-02-09 09:08:52 +08:00
|
|
|
return m_opaque_sp->GetInputFile().GetStream();
|
2010-06-23 09:19:29 +08:00
|
|
|
return NULL;
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
FILE *
|
|
|
|
SBDebugger::GetOutputFileHandle ()
|
|
|
|
{
|
2010-06-23 09:19:29 +08:00
|
|
|
if (m_opaque_sp)
|
2011-02-09 09:08:52 +08:00
|
|
|
return m_opaque_sp->GetOutputFile().GetStream();
|
2010-06-23 09:19:29 +08:00
|
|
|
return NULL;
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
FILE *
|
|
|
|
SBDebugger::GetErrorFileHandle ()
|
|
|
|
{
|
2010-06-23 09:19:29 +08:00
|
|
|
if (m_opaque_sp)
|
2011-02-09 09:08:52 +08:00
|
|
|
return m_opaque_sp->GetErrorFile().GetStream();
|
2010-06-23 09:19:29 +08:00
|
|
|
return NULL;
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
SBCommandInterpreter
|
|
|
|
SBDebugger::GetCommandInterpreter ()
|
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
2010-10-26 11:11:13 +08:00
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
SBCommandInterpreter sb_interpreter;
|
|
|
|
if (m_opaque_sp)
|
|
|
|
sb_interpreter.reset (&m_opaque_sp->GetCommandInterpreter());
|
2010-10-26 11:11:13 +08:00
|
|
|
|
2010-10-27 07:49:36 +08:00
|
|
|
if (log)
|
2010-10-29 12:59:35 +08:00
|
|
|
log->Printf ("SBDebugger(%p)::GetCommandInterpreter () => SBCommandInterpreter(%p)",
|
2010-10-27 07:49:36 +08:00
|
|
|
m_opaque_sp.get(), sb_interpreter.get());
|
|
|
|
|
2010-06-09 00:52:24 +08:00
|
|
|
return sb_interpreter;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
SBDebugger::HandleCommand (const char *command)
|
|
|
|
{
|
2010-06-23 09:19:29 +08:00
|
|
|
if (m_opaque_sp)
|
|
|
|
{
|
2010-12-21 04:49:23 +08:00
|
|
|
TargetSP target_sp (m_opaque_sp->GetSelectedTarget());
|
|
|
|
Mutex::Locker api_locker;
|
|
|
|
if (target_sp)
|
|
|
|
api_locker.Reset(target_sp->GetAPIMutex().GetMutex());
|
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
SBCommandInterpreter sb_interpreter(GetCommandInterpreter ());
|
|
|
|
SBCommandReturnObject result;
|
2010-06-09 00:52:24 +08:00
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
sb_interpreter.HandleCommand (command, result, false);
|
2010-06-09 00:52:24 +08:00
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
if (GetErrorFileHandle() != NULL)
|
|
|
|
result.PutError (GetErrorFileHandle());
|
|
|
|
if (GetOutputFileHandle() != NULL)
|
|
|
|
result.PutOutput (GetOutputFileHandle());
|
2010-06-09 00:52:24 +08:00
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
if (m_opaque_sp->GetAsyncExecution() == false)
|
2010-06-09 00:52:24 +08:00
|
|
|
{
|
2010-06-23 09:19:29 +08:00
|
|
|
SBProcess process(GetCommandInterpreter().GetProcess ());
|
|
|
|
if (process.IsValid())
|
2010-06-09 00:52:24 +08:00
|
|
|
{
|
2010-06-23 09:19:29 +08:00
|
|
|
EventSP event_sp;
|
|
|
|
Listener &lldb_listener = m_opaque_sp->GetListener();
|
|
|
|
while (lldb_listener.GetNextEventForBroadcaster (process.get(), event_sp))
|
|
|
|
{
|
|
|
|
SBEvent event(event_sp);
|
|
|
|
HandleProcessEvent (process, event, GetOutputFileHandle(), GetErrorFileHandle());
|
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
SBListener
|
|
|
|
SBDebugger::GetListener ()
|
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
2010-10-26 11:11:13 +08:00
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
SBListener sb_listener;
|
|
|
|
if (m_opaque_sp)
|
|
|
|
sb_listener.reset(&m_opaque_sp->GetListener(), false);
|
2010-10-26 11:11:13 +08:00
|
|
|
|
2010-10-27 07:49:36 +08:00
|
|
|
if (log)
|
2010-10-29 12:59:35 +08:00
|
|
|
log->Printf ("SBDebugger(%p)::GetListener () => SBListener(%p)", m_opaque_sp.get(),
|
2010-10-27 07:49:36 +08:00
|
|
|
sb_listener.get());
|
|
|
|
|
2010-06-09 00:52:24 +08:00
|
|
|
return sb_listener;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
SBDebugger::HandleProcessEvent (const SBProcess &process, const SBEvent &event, FILE *out, FILE *err)
|
|
|
|
{
|
2010-12-21 04:49:23 +08:00
|
|
|
if (!process.IsValid())
|
|
|
|
return;
|
2010-06-09 00:52:24 +08:00
|
|
|
|
2010-12-21 04:49:23 +08:00
|
|
|
const uint32_t event_type = event.GetType();
|
|
|
|
char stdio_buffer[1024];
|
|
|
|
size_t len;
|
2010-06-09 00:52:24 +08:00
|
|
|
|
2010-12-21 04:49:23 +08:00
|
|
|
Mutex::Locker api_locker (process.GetTarget()->GetAPIMutex());
|
|
|
|
|
|
|
|
if (event_type & (Process::eBroadcastBitSTDOUT | Process::eBroadcastBitStateChanged))
|
|
|
|
{
|
|
|
|
// Drain stdout when we stop just in case we have any bytes
|
|
|
|
while ((len = process.GetSTDOUT (stdio_buffer, sizeof (stdio_buffer))) > 0)
|
|
|
|
if (out != NULL)
|
|
|
|
::fwrite (stdio_buffer, 1, len, out);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (event_type & (Process::eBroadcastBitSTDERR | Process::eBroadcastBitStateChanged))
|
|
|
|
{
|
|
|
|
// Drain stderr when we stop just in case we have any bytes
|
|
|
|
while ((len = process.GetSTDERR (stdio_buffer, sizeof (stdio_buffer))) > 0)
|
|
|
|
if (err != NULL)
|
|
|
|
::fwrite (stdio_buffer, 1, len, err);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (event_type & Process::eBroadcastBitStateChanged)
|
|
|
|
{
|
|
|
|
StateType event_state = SBProcess::GetStateFromEvent (event);
|
|
|
|
|
|
|
|
if (event_state == eStateInvalid)
|
|
|
|
return;
|
|
|
|
|
|
|
|
bool is_stopped = StateIsStoppedState (event_state);
|
|
|
|
if (!is_stopped)
|
|
|
|
process.ReportEventState (event, out);
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
SBSourceManager &
|
|
|
|
SBDebugger::GetSourceManager ()
|
|
|
|
{
|
|
|
|
static SourceManager g_lldb_source_manager;
|
2010-11-06 07:17:00 +08:00
|
|
|
static SBSourceManager g_sb_source_manager (&g_lldb_source_manager);
|
2010-06-09 00:52:24 +08:00
|
|
|
return g_sb_source_manager;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool
|
|
|
|
SBDebugger::GetDefaultArchitecture (char *arch_name, size_t arch_name_len)
|
|
|
|
{
|
|
|
|
if (arch_name && arch_name_len)
|
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
ArchSpec default_arch = Target::GetDefaultArchitecture ();
|
2010-09-21 04:44:43 +08:00
|
|
|
|
2010-06-09 00:52:24 +08:00
|
|
|
if (default_arch.IsValid())
|
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
const std::string &triple_str = default_arch.GetTriple().str();
|
|
|
|
if (!triple_str.empty())
|
|
|
|
::snprintf (arch_name, arch_name_len, "%s", triple_str.c_str());
|
|
|
|
else
|
|
|
|
::snprintf (arch_name, arch_name_len, "%s", default_arch.GetArchitectureName());
|
2010-06-09 00:52:24 +08:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (arch_name && arch_name_len)
|
|
|
|
arch_name[0] = '\0';
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool
|
|
|
|
SBDebugger::SetDefaultArchitecture (const char *arch_name)
|
|
|
|
{
|
|
|
|
if (arch_name)
|
|
|
|
{
|
2011-04-08 06:46:35 +08:00
|
|
|
ArchSpec arch (arch_name, NULL);
|
2010-06-09 00:52:24 +08:00
|
|
|
if (arch.IsValid())
|
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
Target::SetDefaultArchitecture (arch);
|
2010-06-09 00:52:24 +08:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
ScriptLanguage
|
|
|
|
SBDebugger::GetScriptingLanguage (const char *script_language_name)
|
|
|
|
{
|
2010-12-21 04:49:23 +08:00
|
|
|
|
2010-06-09 00:52:24 +08:00
|
|
|
return Args::StringToScriptLanguage (script_language_name,
|
|
|
|
eScriptLanguageDefault,
|
|
|
|
NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
const char *
|
|
|
|
SBDebugger::GetVersionString ()
|
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
return GetVersion();
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
const char *
|
2011-04-19 07:15:17 +08:00
|
|
|
SBDebugger::StateAsCString (StateType state)
|
2010-06-09 00:52:24 +08:00
|
|
|
{
|
2011-04-26 06:05:51 +08:00
|
|
|
return lldb_private::StateAsCString (state);
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
2011-04-19 07:15:17 +08:00
|
|
|
SBDebugger::StateIsRunningState (StateType state)
|
2010-06-09 00:52:24 +08:00
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
2010-10-30 12:51:46 +08:00
|
|
|
|
2011-04-26 06:05:51 +08:00
|
|
|
const bool result = lldb_private::StateIsRunningState (state);
|
2010-10-30 12:51:46 +08:00
|
|
|
if (log)
|
|
|
|
log->Printf ("SBDebugger::StateIsRunningState (state=%s) => %i",
|
2011-04-19 07:15:17 +08:00
|
|
|
StateAsCString (state), result);
|
2010-10-30 12:51:46 +08:00
|
|
|
|
|
|
|
return result;
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
2011-04-19 07:15:17 +08:00
|
|
|
SBDebugger::StateIsStoppedState (StateType state)
|
2010-06-09 00:52:24 +08:00
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
2010-10-26 11:11:13 +08:00
|
|
|
|
2011-04-26 06:05:51 +08:00
|
|
|
const bool result = lldb_private::StateIsStoppedState (state);
|
2010-10-26 11:11:13 +08:00
|
|
|
if (log)
|
2010-10-30 12:51:46 +08:00
|
|
|
log->Printf ("SBDebugger::StateIsStoppedState (state=%s) => %i",
|
2011-04-19 07:15:17 +08:00
|
|
|
StateAsCString (state), result);
|
2010-10-26 11:11:13 +08:00
|
|
|
|
2010-10-30 12:51:46 +08:00
|
|
|
return result;
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
SBTarget
|
|
|
|
SBDebugger::CreateTargetWithFileAndTargetTriple (const char *filename,
|
|
|
|
const char *target_triple)
|
|
|
|
{
|
2010-06-23 09:19:29 +08:00
|
|
|
SBTarget target;
|
|
|
|
if (m_opaque_sp)
|
|
|
|
{
|
|
|
|
ArchSpec arch;
|
2010-10-21 04:54:39 +08:00
|
|
|
FileSpec file_spec (filename, true);
|
2011-04-08 06:46:35 +08:00
|
|
|
arch.SetTriple (target_triple, m_opaque_sp->GetPlatformList().GetSelectedPlatform().get());
|
2010-06-23 09:19:29 +08:00
|
|
|
TargetSP target_sp;
|
2011-03-09 06:40:15 +08:00
|
|
|
Error error (m_opaque_sp->GetTargetList().CreateTarget (*m_opaque_sp, file_spec, arch, true, target_sp));
|
2010-06-23 09:19:29 +08:00
|
|
|
target.reset (target_sp);
|
|
|
|
}
|
2010-10-30 12:51:46 +08:00
|
|
|
|
2011-04-19 07:15:17 +08:00
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
2010-10-30 12:51:46 +08:00
|
|
|
if (log)
|
|
|
|
{
|
2010-10-31 11:01:06 +08:00
|
|
|
log->Printf ("SBDebugger(%p)::CreateTargetWithFileAndTargetTriple (filename=\"%s\", triple=%s) => SBTarget(%p)",
|
2010-10-30 12:51:46 +08:00
|
|
|
m_opaque_sp.get(), filename, target_triple, target.get());
|
|
|
|
}
|
|
|
|
|
2010-06-09 00:52:24 +08:00
|
|
|
return target;
|
|
|
|
}
|
|
|
|
|
|
|
|
SBTarget
|
2011-02-23 08:35:02 +08:00
|
|
|
SBDebugger::CreateTargetWithFileAndArch (const char *filename, const char *arch_cstr)
|
2010-06-09 00:52:24 +08:00
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
2010-10-26 11:11:13 +08:00
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
SBTarget target;
|
|
|
|
if (m_opaque_sp)
|
2010-06-09 00:52:24 +08:00
|
|
|
{
|
2010-10-21 04:54:39 +08:00
|
|
|
FileSpec file (filename, true);
|
2011-02-23 08:35:02 +08:00
|
|
|
ArchSpec arch;
|
2010-06-23 09:19:29 +08:00
|
|
|
TargetSP target_sp;
|
|
|
|
Error error;
|
|
|
|
|
2011-02-23 08:35:02 +08:00
|
|
|
if (arch_cstr)
|
2011-04-08 06:46:35 +08:00
|
|
|
arch.SetTriple (arch_cstr, m_opaque_sp->GetPlatformList().GetSelectedPlatform().get());
|
2010-06-23 09:19:29 +08:00
|
|
|
|
2011-03-09 06:40:15 +08:00
|
|
|
error = m_opaque_sp->GetTargetList().CreateTarget (*m_opaque_sp, file, arch, true, target_sp);
|
2010-06-23 09:19:29 +08:00
|
|
|
|
|
|
|
if (error.Success())
|
|
|
|
{
|
2010-08-27 05:32:51 +08:00
|
|
|
m_opaque_sp->GetTargetList().SetSelectedTarget (target_sp.get());
|
2010-06-23 09:19:29 +08:00
|
|
|
target.reset(target_sp);
|
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
2010-10-26 11:11:13 +08:00
|
|
|
|
|
|
|
if (log)
|
|
|
|
{
|
2010-10-31 11:01:06 +08:00
|
|
|
log->Printf ("SBDebugger(%p)::CreateTargetWithFileAndArch (filename=\"%s\", arch=%s) => SBTarget(%p)",
|
2011-02-23 08:35:02 +08:00
|
|
|
m_opaque_sp.get(), filename, arch_cstr, target.get());
|
2010-10-26 11:11:13 +08:00
|
|
|
}
|
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
return target;
|
|
|
|
}
|
|
|
|
|
|
|
|
SBTarget
|
|
|
|
SBDebugger::CreateTarget (const char *filename)
|
|
|
|
{
|
|
|
|
SBTarget target;
|
|
|
|
if (m_opaque_sp)
|
2010-06-09 00:52:24 +08:00
|
|
|
{
|
2010-10-21 04:54:39 +08:00
|
|
|
FileSpec file (filename, true);
|
2011-04-19 07:15:17 +08:00
|
|
|
ArchSpec arch = Target::GetDefaultArchitecture ();
|
2010-06-23 09:19:29 +08:00
|
|
|
TargetSP target_sp;
|
|
|
|
Error error;
|
|
|
|
|
2011-03-09 06:40:15 +08:00
|
|
|
error = m_opaque_sp->GetTargetList().CreateTarget (*m_opaque_sp, file, arch, true, target_sp);
|
2010-06-09 00:52:24 +08:00
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
if (error.Success())
|
|
|
|
{
|
2010-08-27 05:32:51 +08:00
|
|
|
m_opaque_sp->GetTargetList().SetSelectedTarget (target_sp.get());
|
2010-06-23 09:19:29 +08:00
|
|
|
target.reset (target_sp);
|
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
2011-04-19 07:15:17 +08:00
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
2010-10-30 12:51:46 +08:00
|
|
|
if (log)
|
|
|
|
{
|
2010-10-31 11:01:06 +08:00
|
|
|
log->Printf ("SBDebugger(%p)::CreateTarget (filename=\"%s\") => SBTarget(%p)",
|
2010-10-30 12:51:46 +08:00
|
|
|
m_opaque_sp.get(), filename, target.get());
|
|
|
|
}
|
2010-06-23 09:19:29 +08:00
|
|
|
return target;
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
2011-06-16 05:24:24 +08:00
|
|
|
bool
|
|
|
|
SBDebugger::DeleteTarget (lldb::SBTarget &target)
|
|
|
|
{
|
|
|
|
bool result = false;
|
|
|
|
if (m_opaque_sp)
|
|
|
|
{
|
|
|
|
// No need to lock, the target list is thread safe
|
|
|
|
result = m_opaque_sp->GetTargetList().DeleteTarget (target.m_opaque_sp);
|
|
|
|
}
|
|
|
|
|
|
|
|
LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
|
|
|
if (log)
|
|
|
|
{
|
|
|
|
log->Printf ("SBDebugger(%p)::DeleteTarget (SBTarget(%p)) => %i", m_opaque_sp.get(), target.m_opaque_sp.get(), result);
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
SBTarget
|
|
|
|
SBDebugger::GetTargetAtIndex (uint32_t idx)
|
|
|
|
{
|
2010-06-23 09:19:29 +08:00
|
|
|
SBTarget sb_target;
|
|
|
|
if (m_opaque_sp)
|
2010-12-21 04:49:23 +08:00
|
|
|
{
|
|
|
|
// No need to lock, the target list is thread safe
|
2010-06-23 09:19:29 +08:00
|
|
|
sb_target.reset(m_opaque_sp->GetTargetList().GetTargetAtIndex (idx));
|
2010-12-21 04:49:23 +08:00
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
return sb_target;
|
|
|
|
}
|
|
|
|
|
|
|
|
SBTarget
|
|
|
|
SBDebugger::FindTargetWithProcessID (pid_t pid)
|
|
|
|
{
|
2010-06-23 09:19:29 +08:00
|
|
|
SBTarget sb_target;
|
|
|
|
if (m_opaque_sp)
|
2010-12-21 04:49:23 +08:00
|
|
|
{
|
|
|
|
// No need to lock, the target list is thread safe
|
2010-06-23 09:19:29 +08:00
|
|
|
sb_target.reset(m_opaque_sp->GetTargetList().FindTargetWithProcessID (pid));
|
2010-12-21 04:49:23 +08:00
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
return sb_target;
|
|
|
|
}
|
|
|
|
|
|
|
|
SBTarget
|
|
|
|
SBDebugger::FindTargetWithFileAndArch (const char *filename, const char *arch_name)
|
|
|
|
{
|
2010-06-23 09:19:29 +08:00
|
|
|
SBTarget sb_target;
|
|
|
|
if (m_opaque_sp && filename && filename[0])
|
|
|
|
{
|
2010-12-21 04:49:23 +08:00
|
|
|
// No need to lock, the target list is thread safe
|
2011-04-08 06:46:35 +08:00
|
|
|
ArchSpec arch (arch_name, m_opaque_sp->GetPlatformList().GetSelectedPlatform().get());
|
2010-10-21 04:54:39 +08:00
|
|
|
TargetSP target_sp (m_opaque_sp->GetTargetList().FindTargetWithExecutableAndArchitecture (FileSpec(filename, false), arch_name ? &arch : NULL));
|
2010-06-23 09:19:29 +08:00
|
|
|
sb_target.reset(target_sp);
|
|
|
|
}
|
|
|
|
return sb_target;
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
SBTarget
|
2011-04-19 07:15:17 +08:00
|
|
|
SBDebugger::FindTargetWithLLDBProcess (const ProcessSP &process_sp)
|
2010-06-09 00:52:24 +08:00
|
|
|
{
|
2010-06-23 09:19:29 +08:00
|
|
|
SBTarget sb_target;
|
|
|
|
if (m_opaque_sp)
|
2010-12-21 04:49:23 +08:00
|
|
|
{
|
|
|
|
// No need to lock, the target list is thread safe
|
2010-06-23 09:19:29 +08:00
|
|
|
sb_target.reset(m_opaque_sp->GetTargetList().FindTargetWithProcess (process_sp.get()));
|
2010-12-21 04:49:23 +08:00
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
return sb_target;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
uint32_t
|
|
|
|
SBDebugger::GetNumTargets ()
|
|
|
|
{
|
2010-06-23 09:19:29 +08:00
|
|
|
if (m_opaque_sp)
|
2010-12-21 04:49:23 +08:00
|
|
|
{
|
|
|
|
// No need to lock, the target list is thread safe
|
2010-06-23 09:19:29 +08:00
|
|
|
return m_opaque_sp->GetTargetList().GetNumTargets ();
|
2010-12-21 04:49:23 +08:00
|
|
|
}
|
2010-06-23 09:19:29 +08:00
|
|
|
return 0;
|
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
|
|
|
|
SBTarget
|
2010-08-27 05:32:51 +08:00
|
|
|
SBDebugger::GetSelectedTarget ()
|
2010-06-09 00:52:24 +08:00
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
2010-10-26 11:11:13 +08:00
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
SBTarget sb_target;
|
|
|
|
if (m_opaque_sp)
|
2010-12-21 04:49:23 +08:00
|
|
|
{
|
|
|
|
// No need to lock, the target list is thread safe
|
2010-08-27 05:32:51 +08:00
|
|
|
sb_target.reset(m_opaque_sp->GetTargetList().GetSelectedTarget ());
|
2010-12-21 04:49:23 +08:00
|
|
|
}
|
2010-10-26 11:11:13 +08:00
|
|
|
|
|
|
|
if (log)
|
|
|
|
{
|
|
|
|
SBStream sstr;
|
2011-04-19 07:15:17 +08:00
|
|
|
sb_target.GetDescription (sstr, eDescriptionLevelBrief);
|
2010-10-29 12:59:35 +08:00
|
|
|
log->Printf ("SBDebugger(%p)::GetSelectedTarget () => SBTarget(%p): %s", m_opaque_sp.get(),
|
2010-10-27 07:49:36 +08:00
|
|
|
sb_target.get(), sstr.GetData());
|
2010-10-26 11:11:13 +08:00
|
|
|
}
|
|
|
|
|
2010-06-09 00:52:24 +08:00
|
|
|
return sb_target;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
SBDebugger::DispatchInput (void *baton, const void *data, size_t data_len)
|
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
2010-10-26 11:11:13 +08:00
|
|
|
|
|
|
|
if (log)
|
2010-10-31 11:01:06 +08:00
|
|
|
log->Printf ("SBDebugger(%p)::DispatchInput (baton=%p, data=\"%.*s\", size_t=%zu)", m_opaque_sp.get(),
|
|
|
|
baton, (int) data_len, (const char *) data, data_len);
|
2010-10-26 11:11:13 +08:00
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
if (m_opaque_sp)
|
|
|
|
m_opaque_sp->DispatchInput ((const char *) data, data_len);
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
2010-11-20 04:47:54 +08:00
|
|
|
void
|
|
|
|
SBDebugger::DispatchInputInterrupt ()
|
|
|
|
{
|
|
|
|
if (m_opaque_sp)
|
|
|
|
m_opaque_sp->DispatchInputInterrupt ();
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
SBDebugger::DispatchInputEndOfFile ()
|
|
|
|
{
|
|
|
|
if (m_opaque_sp)
|
|
|
|
m_opaque_sp->DispatchInputEndOfFile ();
|
|
|
|
}
|
2011-05-10 07:06:58 +08:00
|
|
|
|
|
|
|
bool
|
|
|
|
SBDebugger::InputReaderIsTopReader (const lldb::SBInputReader &reader)
|
|
|
|
{
|
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
|
|
|
|
|
|
|
if (log)
|
|
|
|
log->Printf ("SBDebugger(%p)::InputReaderIsTopReader (SBInputReader(%p))", m_opaque_sp.get(), &reader);
|
|
|
|
|
|
|
|
if (m_opaque_sp && reader.IsValid())
|
|
|
|
{
|
|
|
|
InputReaderSP reader_sp (*reader);
|
|
|
|
return m_opaque_sp->InputReaderIsTopReader (reader_sp);
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2010-11-20 04:47:54 +08:00
|
|
|
|
2010-06-09 00:52:24 +08:00
|
|
|
void
|
|
|
|
SBDebugger::PushInputReader (SBInputReader &reader)
|
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
2010-10-26 11:11:13 +08:00
|
|
|
|
|
|
|
if (log)
|
2010-10-29 12:59:35 +08:00
|
|
|
log->Printf ("SBDebugger(%p)::PushInputReader (SBInputReader(%p))", m_opaque_sp.get(), &reader);
|
2010-10-26 11:11:13 +08:00
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
if (m_opaque_sp && reader.IsValid())
|
2010-06-09 00:52:24 +08:00
|
|
|
{
|
2010-12-21 04:49:23 +08:00
|
|
|
TargetSP target_sp (m_opaque_sp->GetSelectedTarget());
|
|
|
|
Mutex::Locker api_locker;
|
|
|
|
if (target_sp)
|
|
|
|
api_locker.Reset(target_sp->GetAPIMutex().GetMutex());
|
2010-06-09 00:52:24 +08:00
|
|
|
InputReaderSP reader_sp(*reader);
|
2010-06-23 09:19:29 +08:00
|
|
|
m_opaque_sp->PushInputReader (reader_sp);
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
}
|
2010-06-23 09:19:29 +08:00
|
|
|
|
This patch captures and serializes all output being written by the
command line driver, including the lldb prompt being output by
editline, the asynchronous process output & error messages, and
asynchronous messages written by target stop-hooks.
As part of this it introduces a new Stream class,
StreamAsynchronousIO. A StreamAsynchronousIO object is created with a
broadcaster, who will eventually broadcast the stream's data for a
listener to handle, and an event type indicating what type of event
the broadcaster will broadcast. When the Write method is called on a
StreamAsynchronousIO object, the data is appended to an internal
string. When the Flush method is called on a StreamAsynchronousIO
object, it broadcasts it's data string and clears the string.
Anything in lldb-core that needs to generate asynchronous output for
the end-user should use the StreamAsynchronousIO objects.
I have also added a new notification type for InputReaders, to let
them know that a asynchronous output has been written. This is to
allow the input readers to, for example, refresh their prompts and
lines, if desired. I added the case statements to all the input
readers to catch this notification, but I haven't added any code for
handling them yet (except to the IOChannel input reader).
llvm-svn: 130721
2011-05-03 04:41:46 +08:00
|
|
|
void
|
|
|
|
SBDebugger::NotifyTopInputReader (InputReaderAction notification)
|
|
|
|
{
|
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
|
|
|
|
|
|
|
if (log)
|
|
|
|
log->Printf ("SBDebugger(%p)::NotifyTopInputReader (%d)", m_opaque_sp.get(), notification);
|
|
|
|
|
|
|
|
if (m_opaque_sp)
|
|
|
|
m_opaque_sp->NotifyTopInputReader (notification);
|
|
|
|
}
|
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
void
|
2011-04-19 07:15:17 +08:00
|
|
|
SBDebugger::reset (const DebuggerSP &debugger_sp)
|
2010-06-23 09:19:29 +08:00
|
|
|
{
|
|
|
|
m_opaque_sp = debugger_sp;
|
|
|
|
}
|
|
|
|
|
|
|
|
Debugger *
|
|
|
|
SBDebugger::get () const
|
|
|
|
{
|
|
|
|
return m_opaque_sp.get();
|
|
|
|
}
|
|
|
|
|
|
|
|
Debugger &
|
|
|
|
SBDebugger::ref () const
|
|
|
|
{
|
|
|
|
assert (m_opaque_sp.get());
|
|
|
|
return *m_opaque_sp;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-07-01 00:22:25 +08:00
|
|
|
SBDebugger
|
|
|
|
SBDebugger::FindDebuggerWithID (int id)
|
|
|
|
{
|
2010-12-21 04:49:23 +08:00
|
|
|
// No need to lock, the debugger list is thread safe
|
2010-07-01 00:22:25 +08:00
|
|
|
SBDebugger sb_debugger;
|
2011-04-19 07:15:17 +08:00
|
|
|
DebuggerSP debugger_sp = Debugger::FindDebuggerWithID (id);
|
2010-07-01 00:22:25 +08:00
|
|
|
if (debugger_sp)
|
|
|
|
sb_debugger.reset (debugger_sp);
|
|
|
|
return sb_debugger;
|
|
|
|
}
|
2010-08-31 03:44:40 +08:00
|
|
|
|
2010-09-10 01:45:09 +08:00
|
|
|
const char *
|
|
|
|
SBDebugger::GetInstanceName()
|
2010-09-04 08:03:46 +08:00
|
|
|
{
|
2010-09-09 14:25:08 +08:00
|
|
|
if (m_opaque_sp)
|
2010-09-10 01:45:09 +08:00
|
|
|
return m_opaque_sp->GetInstanceName().AsCString();
|
2010-09-09 14:25:08 +08:00
|
|
|
else
|
2010-09-10 01:45:09 +08:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
SBError
|
|
|
|
SBDebugger::SetInternalVariable (const char *var_name, const char *value, const char *debugger_instance_name)
|
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
UserSettingsControllerSP root_settings_controller = Debugger::GetSettingsController();
|
2010-09-09 14:25:08 +08:00
|
|
|
|
2011-03-25 05:19:54 +08:00
|
|
|
Error err = root_settings_controller->SetVariable (var_name,
|
|
|
|
value,
|
|
|
|
eVarSetOperationAssign,
|
|
|
|
true,
|
2010-09-09 14:25:08 +08:00
|
|
|
debugger_instance_name);
|
2010-09-04 08:03:46 +08:00
|
|
|
SBError sb_error;
|
|
|
|
sb_error.SetError (err);
|
|
|
|
|
|
|
|
return sb_error;
|
|
|
|
}
|
|
|
|
|
2011-04-19 07:15:17 +08:00
|
|
|
SBStringList
|
2010-09-10 01:45:09 +08:00
|
|
|
SBDebugger::GetInternalVariableValue (const char *var_name, const char *debugger_instance_name)
|
2010-09-04 08:03:46 +08:00
|
|
|
{
|
|
|
|
SBStringList ret_value;
|
2011-03-25 05:19:54 +08:00
|
|
|
SettableVariableType var_type;
|
2011-04-19 07:15:17 +08:00
|
|
|
Error err;
|
2010-09-09 14:25:08 +08:00
|
|
|
|
2011-04-19 07:15:17 +08:00
|
|
|
UserSettingsControllerSP root_settings_controller = Debugger::GetSettingsController();
|
2010-09-04 08:03:46 +08:00
|
|
|
|
2010-09-21 04:44:43 +08:00
|
|
|
StringList value = root_settings_controller->GetVariable (var_name, var_type, debugger_instance_name, err);
|
|
|
|
|
|
|
|
if (err.Success())
|
|
|
|
{
|
|
|
|
for (unsigned i = 0; i != value.GetSize(); ++i)
|
|
|
|
ret_value.AppendString (value.GetStringAtIndex(i));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
ret_value.AppendString (err.AsCString());
|
|
|
|
}
|
|
|
|
|
2010-09-04 08:03:46 +08:00
|
|
|
|
|
|
|
return ret_value;
|
|
|
|
}
|
|
|
|
|
2010-09-18 09:14:36 +08:00
|
|
|
uint32_t
|
|
|
|
SBDebugger::GetTerminalWidth () const
|
|
|
|
{
|
|
|
|
if (m_opaque_sp)
|
|
|
|
return m_opaque_sp->GetTerminalWidth ();
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
SBDebugger::SetTerminalWidth (uint32_t term_width)
|
|
|
|
{
|
|
|
|
if (m_opaque_sp)
|
|
|
|
m_opaque_sp->SetTerminalWidth (term_width);
|
|
|
|
}
|
|
|
|
|
|
|
|
const char *
|
|
|
|
SBDebugger::GetPrompt() const
|
|
|
|
{
|
2011-04-19 07:15:17 +08:00
|
|
|
LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
|
2010-10-26 11:11:13 +08:00
|
|
|
|
|
|
|
if (log)
|
2010-10-31 11:01:06 +08:00
|
|
|
log->Printf ("SBDebugger(%p)::GetPrompt () => \"%s\"", m_opaque_sp.get(),
|
2010-10-27 07:49:36 +08:00
|
|
|
(m_opaque_sp ? m_opaque_sp->GetPrompt() : ""));
|
2010-10-26 11:11:13 +08:00
|
|
|
|
2010-09-18 09:14:36 +08:00
|
|
|
if (m_opaque_sp)
|
|
|
|
return m_opaque_sp->GetPrompt ();
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
SBDebugger::SetPrompt (const char *prompt)
|
|
|
|
{
|
|
|
|
if (m_opaque_sp)
|
|
|
|
m_opaque_sp->SetPrompt (prompt);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-04-19 07:15:17 +08:00
|
|
|
ScriptLanguage
|
2010-09-18 09:14:36 +08:00
|
|
|
SBDebugger::GetScriptLanguage() const
|
|
|
|
{
|
|
|
|
if (m_opaque_sp)
|
|
|
|
return m_opaque_sp->GetScriptLanguage ();
|
|
|
|
return eScriptLanguageNone;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2011-04-19 07:15:17 +08:00
|
|
|
SBDebugger::SetScriptLanguage (ScriptLanguage script_lang)
|
2010-09-18 09:14:36 +08:00
|
|
|
{
|
|
|
|
if (m_opaque_sp)
|
2010-12-21 04:49:23 +08:00
|
|
|
{
|
2010-09-18 09:14:36 +08:00
|
|
|
m_opaque_sp->SetScriptLanguage (script_lang);
|
2010-12-21 04:49:23 +08:00
|
|
|
}
|
2010-09-18 09:14:36 +08:00
|
|
|
}
|
|
|
|
|
2010-08-31 03:44:40 +08:00
|
|
|
bool
|
|
|
|
SBDebugger::SetUseExternalEditor (bool value)
|
|
|
|
{
|
|
|
|
if (m_opaque_sp)
|
|
|
|
return m_opaque_sp->SetUseExternalEditor (value);
|
2010-12-21 04:49:23 +08:00
|
|
|
return false;
|
2010-08-31 03:44:40 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
2010-09-21 04:44:43 +08:00
|
|
|
SBDebugger::GetUseExternalEditor ()
|
2010-08-31 03:44:40 +08:00
|
|
|
{
|
|
|
|
if (m_opaque_sp)
|
2010-09-21 04:44:43 +08:00
|
|
|
return m_opaque_sp->GetUseExternalEditor ();
|
2010-12-21 04:49:23 +08:00
|
|
|
return false;
|
2010-08-31 03:44:40 +08:00
|
|
|
}
|
|
|
|
|
2010-09-20 13:20:02 +08:00
|
|
|
bool
|
|
|
|
SBDebugger::GetDescription (SBStream &description)
|
|
|
|
{
|
|
|
|
if (m_opaque_sp)
|
|
|
|
{
|
|
|
|
const char *name = m_opaque_sp->GetInstanceName().AsCString();
|
2011-04-19 07:15:17 +08:00
|
|
|
user_id_t id = m_opaque_sp->GetID();
|
2010-10-31 11:01:06 +08:00
|
|
|
description.Printf ("Debugger (instance: \"%s\", id: %d)", name, id);
|
2010-09-20 13:20:02 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
description.Printf ("No value");
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
2010-11-20 04:47:54 +08:00
|
|
|
|
2011-04-19 07:15:17 +08:00
|
|
|
user_id_t
|
2010-11-20 04:47:54 +08:00
|
|
|
SBDebugger::GetID()
|
|
|
|
{
|
|
|
|
if (m_opaque_sp)
|
|
|
|
return m_opaque_sp->GetID();
|
|
|
|
return LLDB_INVALID_UID;
|
|
|
|
}
|
2011-04-30 09:09:13 +08:00
|
|
|
|
|
|
|
|
|
|
|
SBError
|
|
|
|
SBDebugger::SetCurrentPlatform (const char *platform_name)
|
|
|
|
{
|
|
|
|
SBError sb_error;
|
|
|
|
if (m_opaque_sp)
|
|
|
|
{
|
|
|
|
PlatformSP platform_sp (Platform::Create (platform_name, sb_error.ref()));
|
|
|
|
|
|
|
|
if (platform_sp)
|
|
|
|
{
|
|
|
|
bool make_selected = true;
|
|
|
|
m_opaque_sp->GetPlatformList().Append (platform_sp, make_selected);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return sb_error;
|
|
|
|
}
|
|
|
|
|
2011-06-17 11:31:01 +08:00
|
|
|
bool
|
|
|
|
SBDebugger::SetCurrentPlatformSDKRoot (const char *sysroot)
|
|
|
|
{
|
|
|
|
if (m_opaque_sp)
|
|
|
|
{
|
|
|
|
PlatformSP platform_sp (m_opaque_sp->GetPlatformList().GetSelectedPlatform());
|
|
|
|
|
|
|
|
if (platform_sp)
|
|
|
|
{
|
|
|
|
platform_sp->SetSDKRootDirectory (ConstString (sysroot));
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2011-05-29 12:06:55 +08:00
|
|
|
bool
|
|
|
|
SBDebugger::GetCloseInputOnEOF () const
|
|
|
|
{
|
|
|
|
if (m_opaque_sp)
|
|
|
|
return m_opaque_sp->GetCloseInputOnEOF ();
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
SBDebugger::SetCloseInputOnEOF (bool b)
|
|
|
|
{
|
|
|
|
if (m_opaque_sp)
|
|
|
|
m_opaque_sp->SetCloseInputOnEOF (b);
|
|
|
|
}
|