//===-- SBError.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/API/SBError.h" #include "lldb/API/SBStream.h" #include "lldb/Core/Error.h" #include "lldb/Core/Log.h" #include using namespace lldb; using namespace lldb_private; SBError::SBError () : m_opaque_ap () { } SBError::SBError (const SBError &rhs) : m_opaque_ap () { if (rhs.IsValid()) m_opaque_ap.reset (new Error(*rhs)); } SBError::~SBError() { } const SBError & SBError::operator = (const SBError &rhs) { if (rhs.IsValid()) { if (m_opaque_ap.get()) *m_opaque_ap = *rhs; else m_opaque_ap.reset (new Error(*rhs)); } else m_opaque_ap.reset(); return *this; } const char * SBError::GetCString () const { if (m_opaque_ap.get()) return m_opaque_ap->AsCString(); return NULL; } void SBError::Clear () { if (m_opaque_ap.get()) m_opaque_ap->Clear(); } bool SBError::Fail () const { Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); bool ret_value = false; if (m_opaque_ap.get()) ret_value = m_opaque_ap->Fail(); if (log) log->Printf ("SBError(%p)::Fail () => %i", m_opaque_ap.get(), ret_value); return ret_value; } bool SBError::Success () const { Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); bool ret_value = true; if (m_opaque_ap.get()) ret_value = m_opaque_ap->Success(); if (log) log->Printf ("SBError(%p)::Success () => %i", m_opaque_ap.get(), ret_value); return ret_value; } uint32_t SBError::GetError () const { Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); uint32_t err = 0; if (m_opaque_ap.get()) err = m_opaque_ap->GetError(); if (log) log->Printf ("SBError(%p)::GetError () => 0x%8.8x", m_opaque_ap.get(), err); return err; } ErrorType SBError::GetType () const { Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); ErrorType err_type = eErrorTypeInvalid; if (m_opaque_ap.get()) err_type = m_opaque_ap->GetType(); if (log) log->Printf ("SBError(%p)::GetType () => %i", m_opaque_ap.get(), err_type); return err_type; } void SBError::SetError (uint32_t err, ErrorType type) { CreateIfNeeded (); m_opaque_ap->SetError (err, type); } void SBError::SetError (const Error &lldb_error) { CreateIfNeeded (); *m_opaque_ap = lldb_error; } void SBError::SetErrorToErrno () { CreateIfNeeded (); m_opaque_ap->SetErrorToErrno (); } void SBError::SetErrorToGenericError () { CreateIfNeeded (); m_opaque_ap->SetErrorToErrno (); } void SBError::SetErrorString (const char *err_str) { CreateIfNeeded (); m_opaque_ap->SetErrorString (err_str); } int SBError::SetErrorStringWithFormat (const char *format, ...) { CreateIfNeeded (); va_list args; va_start (args, format); int num_chars = m_opaque_ap->SetErrorStringWithVarArg (format, args); va_end (args); return num_chars; } bool SBError::IsValid () const { return m_opaque_ap.get() != NULL; } void SBError::CreateIfNeeded () { if (m_opaque_ap.get() == NULL) m_opaque_ap.reset(new Error ()); } lldb_private::Error * SBError::operator->() { return m_opaque_ap.get(); } lldb_private::Error * SBError::get() { return m_opaque_ap.get(); } lldb_private::Error & SBError::ref() { CreateIfNeeded(); return *m_opaque_ap; } const lldb_private::Error & SBError::operator*() const { // Be sure to call "IsValid()" before calling this function or it will crash return *m_opaque_ap; } bool SBError::GetDescription (SBStream &description) { if (m_opaque_ap.get()) { if (m_opaque_ap->Success()) description.Printf ("success"); else { const char * err_string = GetCString(); description.Printf ("error: %s", (err_string != NULL ? err_string : "")); } } else description.Printf ("error: "); return true; }