003 File Manager
Current Path:
/usr/src/contrib/llvm-project/lldb/source/API
usr
/
src
/
contrib
/
llvm-project
/
lldb
/
source
/
API
/
📁
..
📄
SBAddress.cpp
(10.65 KB)
📄
SBAttachInfo.cpp
(10.17 KB)
📄
SBBlock.cpp
(12.18 KB)
📄
SBBreakpoint.cpp
(34.51 KB)
📄
SBBreakpointLocation.cpp
(17.54 KB)
📄
SBBreakpointName.cpp
(23.49 KB)
📄
SBBreakpointOptionCommon.cpp
(2.88 KB)
📄
SBBreakpointOptionCommon.h
(1.22 KB)
📄
SBBroadcaster.cpp
(7.11 KB)
📄
SBCommandInterpreter.cpp
(33.92 KB)
📄
SBCommandInterpreterRunOptions.cpp
(9.99 KB)
📄
SBCommandReturnObject.cpp
(14.87 KB)
📄
SBCommunication.cpp
(7.16 KB)
📄
SBCompileUnit.cpp
(9.25 KB)
📄
SBData.cpp
(23.68 KB)
📄
SBDebugger.cpp
(66.66 KB)
📄
SBDeclaration.cpp
(6.16 KB)
📄
SBEnvironment.cpp
(5.2 KB)
📄
SBError.cpp
(5.64 KB)
📄
SBEvent.cpp
(7.37 KB)
📄
SBExecutionContext.cpp
(5.26 KB)
📄
SBExpressionOptions.cpp
(12.71 KB)
📄
SBFile.cpp
(4.89 KB)
📄
SBFileSpec.cpp
(7.2 KB)
📄
SBFileSpecList.cpp
(4.81 KB)
📄
SBFrame.cpp
(45.55 KB)
📄
SBFunction.cpp
(9.03 KB)
📄
SBHostOS.cpp
(5.96 KB)
📄
SBInstruction.cpp
(12.79 KB)
📄
SBInstructionList.cpp
(7.64 KB)
📄
SBLanguageRuntime.cpp
(1.54 KB)
📄
SBLaunchInfo.cpp
(13.96 KB)
📄
SBLineEntry.cpp
(6.73 KB)
📄
SBListener.cpp
(13.13 KB)
📄
SBMemoryRegionInfo.cpp
(5.4 KB)
📄
SBMemoryRegionInfoList.cpp
(5.09 KB)
📄
SBModule.cpp
(25.85 KB)
📄
SBModuleSpec.cpp
(10.62 KB)
📄
SBPlatform.cpp
(25.5 KB)
📄
SBProcess.cpp
(49.03 KB)
📄
SBProcessInfo.cpp
(5.98 KB)
📄
SBQueue.cpp
(9.86 KB)
📄
SBQueueItem.cpp
(4.36 KB)
📄
SBReproducer.cpp
(7.57 KB)
📄
SBReproducerPrivate.h
(2.07 KB)
📄
SBSection.cpp
(10.38 KB)
📄
SBSourceManager.cpp
(5.84 KB)
📄
SBStream.cpp
(6.95 KB)
📄
SBStringList.cpp
(4.86 KB)
📄
SBStructuredData.cpp
(8.71 KB)
📄
SBSymbol.cpp
(7.6 KB)
📄
SBSymbolContext.cpp
(8.59 KB)
📄
SBSymbolContextList.cpp
(4.58 KB)
📄
SBTarget.cpp
(99.19 KB)
📄
SBThread.cpp
(47.63 KB)
📄
SBThreadCollection.cpp
(3.37 KB)
📄
SBThreadPlan.cpp
(17.19 KB)
📄
SBTrace.cpp
(4.21 KB)
📄
SBTraceOptions.cpp
(5.22 KB)
📄
SBType.cpp
(32.23 KB)
📄
SBTypeCategory.cpp
(24.5 KB)
📄
SBTypeEnumMember.cpp
(7.64 KB)
📄
SBTypeFilter.cpp
(6.8 KB)
📄
SBTypeFormat.cpp
(7.19 KB)
📄
SBTypeNameSpecifier.cpp
(6 KB)
📄
SBTypeSummary.cpp
(17.62 KB)
📄
SBTypeSynthetic.cpp
(7.87 KB)
📄
SBUnixSignals.cpp
(6.29 KB)
📄
SBValue.cpp
(52.5 KB)
📄
SBValueList.cpp
(6.43 KB)
📄
SBVariablesOptions.cpp
(9.41 KB)
📄
SBWatchpoint.cpp
(11.29 KB)
📄
SystemInitializerFull.cpp
(2.24 KB)
📄
SystemInitializerFull.h
(1.08 KB)
📄
Utils.h
(847 B)
📄
liblldb-private.exports
(84 B)
📄
liblldb.exports
(45 B)
📄
liblldb.xcode.exports
(34 B)
Editing: SBError.cpp
//===-- SBError.cpp -------------------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #include "lldb/API/SBError.h" #include "SBReproducerPrivate.h" #include "Utils.h" #include "lldb/API/SBStream.h" #include "lldb/Utility/Status.h" #include <stdarg.h> using namespace lldb; using namespace lldb_private; SBError::SBError() : m_opaque_up() { LLDB_RECORD_CONSTRUCTOR_NO_ARGS(SBError); } SBError::SBError(const SBError &rhs) : m_opaque_up() { LLDB_RECORD_CONSTRUCTOR(SBError, (const lldb::SBError &), rhs); m_opaque_up = clone(rhs.m_opaque_up); } SBError::~SBError() = default; const SBError &SBError::operator=(const SBError &rhs) { LLDB_RECORD_METHOD(const lldb::SBError &, SBError, operator=,(const lldb::SBError &), rhs); if (this != &rhs) m_opaque_up = clone(rhs.m_opaque_up); return LLDB_RECORD_RESULT(*this); } const char *SBError::GetCString() const { LLDB_RECORD_METHOD_CONST_NO_ARGS(const char *, SBError, GetCString); if (m_opaque_up) return m_opaque_up->AsCString(); return nullptr; } void SBError::Clear() { LLDB_RECORD_METHOD_NO_ARGS(void, SBError, Clear); if (m_opaque_up) m_opaque_up->Clear(); } bool SBError::Fail() const { LLDB_RECORD_METHOD_CONST_NO_ARGS(bool, SBError, Fail); bool ret_value = false; if (m_opaque_up) ret_value = m_opaque_up->Fail(); return ret_value; } bool SBError::Success() const { LLDB_RECORD_METHOD_CONST_NO_ARGS(bool, SBError, Success); bool ret_value = true; if (m_opaque_up) ret_value = m_opaque_up->Success(); return ret_value; } uint32_t SBError::GetError() const { LLDB_RECORD_METHOD_CONST_NO_ARGS(uint32_t, SBError, GetError); uint32_t err = 0; if (m_opaque_up) err = m_opaque_up->GetError(); return err; } ErrorType SBError::GetType() const { LLDB_RECORD_METHOD_CONST_NO_ARGS(lldb::ErrorType, SBError, GetType); ErrorType err_type = eErrorTypeInvalid; if (m_opaque_up) err_type = m_opaque_up->GetType(); return err_type; } void SBError::SetError(uint32_t err, ErrorType type) { LLDB_RECORD_METHOD(void, SBError, SetError, (uint32_t, lldb::ErrorType), err, type); CreateIfNeeded(); m_opaque_up->SetError(err, type); } void SBError::SetError(const Status &lldb_error) { CreateIfNeeded(); *m_opaque_up = lldb_error; } void SBError::SetErrorToErrno() { LLDB_RECORD_METHOD_NO_ARGS(void, SBError, SetErrorToErrno); CreateIfNeeded(); m_opaque_up->SetErrorToErrno(); } void SBError::SetErrorToGenericError() { LLDB_RECORD_METHOD_NO_ARGS(void, SBError, SetErrorToGenericError); CreateIfNeeded(); m_opaque_up->SetErrorToErrno(); } void SBError::SetErrorString(const char *err_str) { LLDB_RECORD_METHOD(void, SBError, SetErrorString, (const char *), err_str); CreateIfNeeded(); m_opaque_up->SetErrorString(err_str); } int SBError::SetErrorStringWithFormat(const char *format, ...) { CreateIfNeeded(); va_list args; va_start(args, format); int num_chars = m_opaque_up->SetErrorStringWithVarArg(format, args); va_end(args); return num_chars; } bool SBError::IsValid() const { LLDB_RECORD_METHOD_CONST_NO_ARGS(bool, SBError, IsValid); return this->operator bool(); } SBError::operator bool() const { LLDB_RECORD_METHOD_CONST_NO_ARGS(bool, SBError, operator bool); return m_opaque_up != nullptr; } void SBError::CreateIfNeeded() { if (m_opaque_up == nullptr) m_opaque_up = std::make_unique<Status>(); } lldb_private::Status *SBError::operator->() { return m_opaque_up.get(); } lldb_private::Status *SBError::get() { return m_opaque_up.get(); } lldb_private::Status &SBError::ref() { CreateIfNeeded(); return *m_opaque_up; } const lldb_private::Status &SBError::operator*() const { // Be sure to call "IsValid()" before calling this function or it will crash return *m_opaque_up; } bool SBError::GetDescription(SBStream &description) { LLDB_RECORD_METHOD(bool, SBError, GetDescription, (lldb::SBStream &), description); if (m_opaque_up) { if (m_opaque_up->Success()) description.Printf("success"); else { const char *err_string = GetCString(); description.Printf("error: %s", (err_string != nullptr ? err_string : "")); } } else description.Printf("error: <NULL>"); return true; } namespace lldb_private { namespace repro { template <> void RegisterMethods<SBError>(Registry &R) { LLDB_REGISTER_CONSTRUCTOR(SBError, ()); LLDB_REGISTER_CONSTRUCTOR(SBError, (const lldb::SBError &)); LLDB_REGISTER_METHOD(const lldb::SBError &, SBError, operator=,(const lldb::SBError &)); LLDB_REGISTER_METHOD_CONST(const char *, SBError, GetCString, ()); LLDB_REGISTER_METHOD(void, SBError, Clear, ()); LLDB_REGISTER_METHOD_CONST(bool, SBError, Fail, ()); LLDB_REGISTER_METHOD_CONST(bool, SBError, Success, ()); LLDB_REGISTER_METHOD_CONST(uint32_t, SBError, GetError, ()); LLDB_REGISTER_METHOD_CONST(lldb::ErrorType, SBError, GetType, ()); LLDB_REGISTER_METHOD(void, SBError, SetError, (uint32_t, lldb::ErrorType)); LLDB_REGISTER_METHOD(void, SBError, SetErrorToErrno, ()); LLDB_REGISTER_METHOD(void, SBError, SetErrorToGenericError, ()); LLDB_REGISTER_METHOD(void, SBError, SetErrorString, (const char *)); LLDB_REGISTER_METHOD_CONST(bool, SBError, IsValid, ()); LLDB_REGISTER_METHOD_CONST(bool, SBError, operator bool, ()); LLDB_REGISTER_METHOD(bool, SBError, GetDescription, (lldb::SBStream &)); } } }
Upload File
Create Folder