2010-06-09 00:52:24 +08:00
|
|
|
//===-- CommandReturnObject.cpp ---------------------------------*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "lldb/Interpreter/CommandReturnObject.h"
|
|
|
|
|
|
|
|
// C Includes
|
|
|
|
// C++ Includes
|
|
|
|
// Other libraries and framework includes
|
|
|
|
// Project includes
|
2011-11-15 11:53:30 +08:00
|
|
|
#include "lldb/Core/Error.h"
|
2010-06-09 00:52:24 +08:00
|
|
|
#include "lldb/Core/StreamString.h"
|
|
|
|
|
|
|
|
using namespace lldb;
|
|
|
|
using namespace lldb_private;
|
|
|
|
|
2011-07-03 05:07:54 +08:00
|
|
|
static void
|
|
|
|
DumpStringToStreamWithNewline (Stream &strm, const std::string &s, bool add_newline_if_empty)
|
|
|
|
{
|
|
|
|
bool add_newline = false;
|
|
|
|
if (s.empty())
|
|
|
|
{
|
|
|
|
add_newline = add_newline_if_empty;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// We already checked for empty above, now make sure there is a newline
|
|
|
|
// in the error, and if there isn't one, add one.
|
|
|
|
strm.Write(s.c_str(), s.size());
|
|
|
|
|
|
|
|
const char last_char = *s.rbegin();
|
|
|
|
add_newline = last_char != '\n' && last_char != '\r';
|
|
|
|
|
|
|
|
}
|
|
|
|
if (add_newline)
|
|
|
|
strm.EOL();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-06-09 00:52:24 +08:00
|
|
|
CommandReturnObject::CommandReturnObject () :
|
2011-02-20 10:15:07 +08:00
|
|
|
m_out_stream (),
|
|
|
|
m_err_stream (),
|
2010-06-09 00:52:24 +08:00
|
|
|
m_status (eReturnStatusStarted),
|
|
|
|
m_did_change_process_state (false)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
CommandReturnObject::~CommandReturnObject ()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
CommandReturnObject::AppendErrorWithFormat (const char *format, ...)
|
|
|
|
{
|
2011-12-20 05:36:23 +08:00
|
|
|
if (!format)
|
|
|
|
return;
|
2010-06-09 00:52:24 +08:00
|
|
|
va_list args;
|
|
|
|
va_start (args, format);
|
|
|
|
StreamString sstrm;
|
|
|
|
sstrm.PrintfVarArg(format, args);
|
|
|
|
va_end (args);
|
|
|
|
|
2011-07-03 05:07:54 +08:00
|
|
|
|
|
|
|
const std::string &s = sstrm.GetString();
|
|
|
|
if (!s.empty())
|
|
|
|
{
|
|
|
|
Stream &error_strm = GetErrorStream();
|
|
|
|
error_strm.PutCString ("error: ");
|
|
|
|
DumpStringToStreamWithNewline (error_strm, s, false);
|
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
CommandReturnObject::AppendMessageWithFormat (const char *format, ...)
|
|
|
|
{
|
2011-12-20 05:36:23 +08:00
|
|
|
if (!format)
|
|
|
|
return;
|
2010-06-09 00:52:24 +08:00
|
|
|
va_list args;
|
|
|
|
va_start (args, format);
|
|
|
|
StreamString sstrm;
|
|
|
|
sstrm.PrintfVarArg(format, args);
|
|
|
|
va_end (args);
|
|
|
|
|
2011-02-19 10:53:09 +08:00
|
|
|
GetOutputStream().Printf("%s", sstrm.GetData());
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
CommandReturnObject::AppendWarningWithFormat (const char *format, ...)
|
|
|
|
{
|
2011-12-20 05:36:23 +08:00
|
|
|
if (!format)
|
|
|
|
return;
|
2010-06-09 00:52:24 +08:00
|
|
|
va_list args;
|
|
|
|
va_start (args, format);
|
|
|
|
StreamString sstrm;
|
|
|
|
sstrm.PrintfVarArg(format, args);
|
|
|
|
va_end (args);
|
|
|
|
|
2011-02-19 10:53:09 +08:00
|
|
|
GetErrorStream().Printf("warning: %s", sstrm.GetData());
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
CommandReturnObject::AppendMessage (const char *in_string, int len)
|
|
|
|
{
|
2012-09-01 08:38:36 +08:00
|
|
|
if (!in_string || len == 0)
|
2011-12-20 05:36:23 +08:00
|
|
|
return;
|
2010-06-09 00:52:24 +08:00
|
|
|
if (len < 0)
|
2012-09-01 08:38:36 +08:00
|
|
|
GetOutputStream().Printf("%s\n", in_string);
|
|
|
|
else
|
|
|
|
GetOutputStream().Printf("%*.*s\n", len, len, in_string);
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
CommandReturnObject::AppendWarning (const char *in_string, int len)
|
|
|
|
{
|
2011-12-20 05:36:23 +08:00
|
|
|
if (!in_string)
|
|
|
|
return;
|
2010-06-09 00:52:24 +08:00
|
|
|
if (len < 0)
|
|
|
|
len = ::strlen (in_string);
|
2011-02-19 10:53:09 +08:00
|
|
|
GetErrorStream().Printf("warning: %*.*s\n", len, len, in_string);
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// Similar to AppendWarning, but do not prepend 'warning: ' to message, and
|
|
|
|
// don't append "\n" to the end of it.
|
|
|
|
|
|
|
|
void
|
|
|
|
CommandReturnObject::AppendRawWarning (const char *in_string, int len)
|
|
|
|
{
|
2011-12-20 05:36:23 +08:00
|
|
|
if (!in_string)
|
|
|
|
return;
|
2010-06-09 00:52:24 +08:00
|
|
|
if (len < 0)
|
|
|
|
len = ::strlen (in_string);
|
2011-02-19 10:53:09 +08:00
|
|
|
GetErrorStream().Printf("%*.*s", len, len, in_string);
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
CommandReturnObject::AppendError (const char *in_string, int len)
|
|
|
|
{
|
|
|
|
if (!in_string)
|
|
|
|
return;
|
|
|
|
if (len < 0)
|
|
|
|
len = ::strlen (in_string);
|
2011-02-19 10:53:09 +08:00
|
|
|
GetErrorStream().Printf ("error: %*.*s\n", len, len, in_string);
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
2011-11-15 11:53:30 +08:00
|
|
|
void
|
|
|
|
CommandReturnObject::SetError (const Error &error, const char *fallback_error_cstr)
|
|
|
|
{
|
|
|
|
const char *error_cstr = error.AsCString();
|
|
|
|
if (error_cstr == NULL)
|
|
|
|
error_cstr = fallback_error_cstr;
|
|
|
|
AppendError (error_cstr);
|
|
|
|
SetStatus (eReturnStatusFailed);
|
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
// Similar to AppendError, but do not prepend 'Error: ' to message, and
|
|
|
|
// don't append "\n" to the end of it.
|
|
|
|
|
|
|
|
void
|
|
|
|
CommandReturnObject::AppendRawError (const char *in_string, int len)
|
|
|
|
{
|
2011-12-20 05:36:23 +08:00
|
|
|
if (!in_string)
|
|
|
|
return;
|
2010-06-09 00:52:24 +08:00
|
|
|
if (len < 0)
|
|
|
|
len = ::strlen (in_string);
|
2011-02-19 10:53:09 +08:00
|
|
|
GetErrorStream().Printf ("%*.*s", len, len, in_string);
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
CommandReturnObject::SetStatus (ReturnStatus status)
|
|
|
|
{
|
|
|
|
m_status = status;
|
|
|
|
}
|
|
|
|
|
|
|
|
ReturnStatus
|
|
|
|
CommandReturnObject::GetStatus ()
|
|
|
|
{
|
|
|
|
return m_status;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
CommandReturnObject::Succeeded ()
|
|
|
|
{
|
|
|
|
return m_status <= eReturnStatusSuccessContinuingResult;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
CommandReturnObject::HasResult ()
|
|
|
|
{
|
|
|
|
return (m_status == eReturnStatusSuccessFinishResult ||
|
|
|
|
m_status == eReturnStatusSuccessContinuingResult);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
CommandReturnObject::Clear()
|
|
|
|
{
|
2011-02-20 10:15:07 +08:00
|
|
|
lldb::StreamSP stream_sp;
|
|
|
|
stream_sp = m_out_stream.GetStreamAtIndex (eStreamStringIndex);
|
|
|
|
if (stream_sp)
|
|
|
|
static_cast<StreamString *>(stream_sp.get())->Clear();
|
|
|
|
stream_sp = m_err_stream.GetStreamAtIndex (eStreamStringIndex);
|
|
|
|
if (stream_sp)
|
|
|
|
static_cast<StreamString *>(stream_sp.get())->Clear();
|
2010-06-09 00:52:24 +08:00
|
|
|
m_status = eReturnStatusStarted;
|
2011-02-20 10:15:07 +08:00
|
|
|
m_did_change_process_state = false;
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
CommandReturnObject::GetDidChangeProcessState ()
|
|
|
|
{
|
|
|
|
return m_did_change_process_state;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
CommandReturnObject::SetDidChangeProcessState (bool b)
|
|
|
|
{
|
|
|
|
m_did_change_process_state = b;
|
|
|
|
}
|
|
|
|
|