diff options
Diffstat (limited to 'lldb/source/API/SBModule.cpp')
| -rw-r--r-- | lldb/source/API/SBModule.cpp | 767 | 
1 files changed, 767 insertions, 0 deletions
diff --git a/lldb/source/API/SBModule.cpp b/lldb/source/API/SBModule.cpp new file mode 100644 index 0000000000000..6cc6d2628ace0 --- /dev/null +++ b/lldb/source/API/SBModule.cpp @@ -0,0 +1,767 @@ +//===-- SBModule.cpp --------------------------------------------*- C++ -*-===// +// +// 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/SBModule.h" +#include "SBReproducerPrivate.h" +#include "lldb/API/SBAddress.h" +#include "lldb/API/SBFileSpec.h" +#include "lldb/API/SBModuleSpec.h" +#include "lldb/API/SBProcess.h" +#include "lldb/API/SBStream.h" +#include "lldb/API/SBSymbolContextList.h" +#include "lldb/Core/Module.h" +#include "lldb/Core/Section.h" +#include "lldb/Core/ValueObjectList.h" +#include "lldb/Core/ValueObjectVariable.h" +#include "lldb/Symbol/ObjectFile.h" +#include "lldb/Symbol/SymbolFile.h" +#include "lldb/Symbol/Symtab.h" +#include "lldb/Symbol/TypeSystem.h" +#include "lldb/Symbol/VariableList.h" +#include "lldb/Target/Target.h" +#include "lldb/Utility/StreamString.h" + +using namespace lldb; +using namespace lldb_private; + +SBModule::SBModule() : m_opaque_sp() { +  LLDB_RECORD_CONSTRUCTOR_NO_ARGS(SBModule); +} + +SBModule::SBModule(const lldb::ModuleSP &module_sp) : m_opaque_sp(module_sp) {} + +SBModule::SBModule(const SBModuleSpec &module_spec) : m_opaque_sp() { +  LLDB_RECORD_CONSTRUCTOR(SBModule, (const lldb::SBModuleSpec &), module_spec); + +  ModuleSP module_sp; +  Status error = ModuleList::GetSharedModule( +      *module_spec.m_opaque_up, module_sp, nullptr, nullptr, nullptr); +  if (module_sp) +    SetSP(module_sp); +} + +SBModule::SBModule(const SBModule &rhs) : m_opaque_sp(rhs.m_opaque_sp) { +  LLDB_RECORD_CONSTRUCTOR(SBModule, (const lldb::SBModule &), rhs); +} + +SBModule::SBModule(lldb::SBProcess &process, lldb::addr_t header_addr) +    : m_opaque_sp() { +  LLDB_RECORD_CONSTRUCTOR(SBModule, (lldb::SBProcess &, lldb::addr_t), process, +                          header_addr); + +  ProcessSP process_sp(process.GetSP()); +  if (process_sp) { +    m_opaque_sp = process_sp->ReadModuleFromMemory(FileSpec(), header_addr); +    if (m_opaque_sp) { +      Target &target = process_sp->GetTarget(); +      bool changed = false; +      m_opaque_sp->SetLoadAddress(target, 0, true, changed); +      target.GetImages().Append(m_opaque_sp); +    } +  } +} + +const SBModule &SBModule::operator=(const SBModule &rhs) { +  LLDB_RECORD_METHOD(const lldb::SBModule &, +                     SBModule, operator=,(const lldb::SBModule &), rhs); + +  if (this != &rhs) +    m_opaque_sp = rhs.m_opaque_sp; +  return LLDB_RECORD_RESULT(*this); +} + +SBModule::~SBModule() {} + +bool SBModule::IsValid() const { +  LLDB_RECORD_METHOD_CONST_NO_ARGS(bool, SBModule, IsValid); +  return this->operator bool(); +} +SBModule::operator bool() const { +  LLDB_RECORD_METHOD_CONST_NO_ARGS(bool, SBModule, operator bool); + +  return m_opaque_sp.get() != nullptr; +} + +void SBModule::Clear() { +  LLDB_RECORD_METHOD_NO_ARGS(void, SBModule, Clear); + +  m_opaque_sp.reset(); +} + +SBFileSpec SBModule::GetFileSpec() const { +  LLDB_RECORD_METHOD_CONST_NO_ARGS(lldb::SBFileSpec, SBModule, GetFileSpec); + +  SBFileSpec file_spec; +  ModuleSP module_sp(GetSP()); +  if (module_sp) +    file_spec.SetFileSpec(module_sp->GetFileSpec()); + +  return LLDB_RECORD_RESULT(file_spec); +} + +lldb::SBFileSpec SBModule::GetPlatformFileSpec() const { +  LLDB_RECORD_METHOD_CONST_NO_ARGS(lldb::SBFileSpec, SBModule, +                                   GetPlatformFileSpec); + + +  SBFileSpec file_spec; +  ModuleSP module_sp(GetSP()); +  if (module_sp) +    file_spec.SetFileSpec(module_sp->GetPlatformFileSpec()); + +  return LLDB_RECORD_RESULT(file_spec); +} + +bool SBModule::SetPlatformFileSpec(const lldb::SBFileSpec &platform_file) { +  LLDB_RECORD_METHOD(bool, SBModule, SetPlatformFileSpec, +                     (const lldb::SBFileSpec &), platform_file); + +  bool result = false; + +  ModuleSP module_sp(GetSP()); +  if (module_sp) { +    module_sp->SetPlatformFileSpec(*platform_file); +    result = true; +  } + +  return result; +} + +lldb::SBFileSpec SBModule::GetRemoteInstallFileSpec() { +  LLDB_RECORD_METHOD_NO_ARGS(lldb::SBFileSpec, SBModule, +                             GetRemoteInstallFileSpec); + +  SBFileSpec sb_file_spec; +  ModuleSP module_sp(GetSP()); +  if (module_sp) +    sb_file_spec.SetFileSpec(module_sp->GetRemoteInstallFileSpec()); +  return LLDB_RECORD_RESULT(sb_file_spec); +} + +bool SBModule::SetRemoteInstallFileSpec(lldb::SBFileSpec &file) { +  LLDB_RECORD_METHOD(bool, SBModule, SetRemoteInstallFileSpec, +                     (lldb::SBFileSpec &), file); + +  ModuleSP module_sp(GetSP()); +  if (module_sp) { +    module_sp->SetRemoteInstallFileSpec(file.ref()); +    return true; +  } +  return false; +} + +const uint8_t *SBModule::GetUUIDBytes() const { +  LLDB_RECORD_METHOD_CONST_NO_ARGS(const uint8_t *, SBModule, GetUUIDBytes); + +  const uint8_t *uuid_bytes = nullptr; +  ModuleSP module_sp(GetSP()); +  if (module_sp) +    uuid_bytes = module_sp->GetUUID().GetBytes().data(); + +  return uuid_bytes; +} + +const char *SBModule::GetUUIDString() const { +  LLDB_RECORD_METHOD_CONST_NO_ARGS(const char *, SBModule, GetUUIDString); + +  const char *uuid_cstr = nullptr; +  ModuleSP module_sp(GetSP()); +  if (module_sp) { +    // We are going to return a "const char *" value through the public API, so +    // we need to constify it so it gets added permanently the string pool and +    // then we don't need to worry about the lifetime of the string as it will +    // never go away once it has been put into the ConstString string pool +    uuid_cstr = ConstString(module_sp->GetUUID().GetAsString()).GetCString(); +  } + +  if (uuid_cstr && uuid_cstr[0]) { +    return uuid_cstr; +  } + +  return nullptr; +} + +bool SBModule::operator==(const SBModule &rhs) const { +  LLDB_RECORD_METHOD_CONST(bool, SBModule, operator==,(const lldb::SBModule &), +                           rhs); + +  if (m_opaque_sp) +    return m_opaque_sp.get() == rhs.m_opaque_sp.get(); +  return false; +} + +bool SBModule::operator!=(const SBModule &rhs) const { +  LLDB_RECORD_METHOD_CONST(bool, SBModule, operator!=,(const lldb::SBModule &), +                           rhs); + +  if (m_opaque_sp) +    return m_opaque_sp.get() != rhs.m_opaque_sp.get(); +  return false; +} + +ModuleSP SBModule::GetSP() const { return m_opaque_sp; } + +void SBModule::SetSP(const ModuleSP &module_sp) { m_opaque_sp = module_sp; } + +SBAddress SBModule::ResolveFileAddress(lldb::addr_t vm_addr) { +  LLDB_RECORD_METHOD(lldb::SBAddress, SBModule, ResolveFileAddress, +                     (lldb::addr_t), vm_addr); + +  lldb::SBAddress sb_addr; +  ModuleSP module_sp(GetSP()); +  if (module_sp) { +    Address addr; +    if (module_sp->ResolveFileAddress(vm_addr, addr)) +      sb_addr.ref() = addr; +  } +  return LLDB_RECORD_RESULT(sb_addr); +} + +SBSymbolContext +SBModule::ResolveSymbolContextForAddress(const SBAddress &addr, +                                         uint32_t resolve_scope) { +  LLDB_RECORD_METHOD(lldb::SBSymbolContext, SBModule, +                     ResolveSymbolContextForAddress, +                     (const lldb::SBAddress &, uint32_t), addr, resolve_scope); + +  SBSymbolContext sb_sc; +  ModuleSP module_sp(GetSP()); +  SymbolContextItem scope = static_cast<SymbolContextItem>(resolve_scope); +  if (module_sp && addr.IsValid()) +    module_sp->ResolveSymbolContextForAddress(addr.ref(), scope, *sb_sc); +  return LLDB_RECORD_RESULT(sb_sc); +} + +bool SBModule::GetDescription(SBStream &description) { +  LLDB_RECORD_METHOD(bool, SBModule, GetDescription, (lldb::SBStream &), +                     description); + +  Stream &strm = description.ref(); + +  ModuleSP module_sp(GetSP()); +  if (module_sp) { +    module_sp->GetDescription(&strm); +  } else +    strm.PutCString("No value"); + +  return true; +} + +uint32_t SBModule::GetNumCompileUnits() { +  LLDB_RECORD_METHOD_NO_ARGS(uint32_t, SBModule, GetNumCompileUnits); + +  ModuleSP module_sp(GetSP()); +  if (module_sp) { +    return module_sp->GetNumCompileUnits(); +  } +  return 0; +} + +SBCompileUnit SBModule::GetCompileUnitAtIndex(uint32_t index) { +  LLDB_RECORD_METHOD(lldb::SBCompileUnit, SBModule, GetCompileUnitAtIndex, +                     (uint32_t), index); + +  SBCompileUnit sb_cu; +  ModuleSP module_sp(GetSP()); +  if (module_sp) { +    CompUnitSP cu_sp = module_sp->GetCompileUnitAtIndex(index); +    sb_cu.reset(cu_sp.get()); +  } +  return LLDB_RECORD_RESULT(sb_cu); +} + +SBSymbolContextList SBModule::FindCompileUnits(const SBFileSpec &sb_file_spec) { +  LLDB_RECORD_METHOD(lldb::SBSymbolContextList, SBModule, FindCompileUnits, +                     (const lldb::SBFileSpec &), sb_file_spec); + +  SBSymbolContextList sb_sc_list; +  const ModuleSP module_sp(GetSP()); +  if (sb_file_spec.IsValid() && module_sp) { +    module_sp->FindCompileUnits(*sb_file_spec, *sb_sc_list); +  } +  return LLDB_RECORD_RESULT(sb_sc_list); +} + +static Symtab *GetUnifiedSymbolTable(const lldb::ModuleSP &module_sp) { +  if (module_sp) +    return module_sp->GetSymtab(); +  return nullptr; +} + +size_t SBModule::GetNumSymbols() { +  LLDB_RECORD_METHOD_NO_ARGS(size_t, SBModule, GetNumSymbols); + +  ModuleSP module_sp(GetSP()); +  if (Symtab *symtab = GetUnifiedSymbolTable(module_sp)) +    return symtab->GetNumSymbols(); +  return 0; +} + +SBSymbol SBModule::GetSymbolAtIndex(size_t idx) { +  LLDB_RECORD_METHOD(lldb::SBSymbol, SBModule, GetSymbolAtIndex, (size_t), idx); + +  SBSymbol sb_symbol; +  ModuleSP module_sp(GetSP()); +  Symtab *symtab = GetUnifiedSymbolTable(module_sp); +  if (symtab) +    sb_symbol.SetSymbol(symtab->SymbolAtIndex(idx)); +  return LLDB_RECORD_RESULT(sb_symbol); +} + +lldb::SBSymbol SBModule::FindSymbol(const char *name, +                                    lldb::SymbolType symbol_type) { +  LLDB_RECORD_METHOD(lldb::SBSymbol, SBModule, FindSymbol, +                     (const char *, lldb::SymbolType), name, symbol_type); + +  SBSymbol sb_symbol; +  if (name && name[0]) { +    ModuleSP module_sp(GetSP()); +    Symtab *symtab = GetUnifiedSymbolTable(module_sp); +    if (symtab) +      sb_symbol.SetSymbol(symtab->FindFirstSymbolWithNameAndType( +          ConstString(name), symbol_type, Symtab::eDebugAny, +          Symtab::eVisibilityAny)); +  } +  return LLDB_RECORD_RESULT(sb_symbol); +} + +lldb::SBSymbolContextList SBModule::FindSymbols(const char *name, +                                                lldb::SymbolType symbol_type) { +  LLDB_RECORD_METHOD(lldb::SBSymbolContextList, SBModule, FindSymbols, +                     (const char *, lldb::SymbolType), name, symbol_type); + +  SBSymbolContextList sb_sc_list; +  if (name && name[0]) { +    ModuleSP module_sp(GetSP()); +    Symtab *symtab = GetUnifiedSymbolTable(module_sp); +    if (symtab) { +      std::vector<uint32_t> matching_symbol_indexes; +      symtab->FindAllSymbolsWithNameAndType(ConstString(name), symbol_type, +                                            matching_symbol_indexes); +      const size_t num_matches = matching_symbol_indexes.size(); +      if (num_matches) { +        SymbolContext sc; +        sc.module_sp = module_sp; +        SymbolContextList &sc_list = *sb_sc_list; +        for (size_t i = 0; i < num_matches; ++i) { +          sc.symbol = symtab->SymbolAtIndex(matching_symbol_indexes[i]); +          if (sc.symbol) +            sc_list.Append(sc); +        } +      } +    } +  } +  return LLDB_RECORD_RESULT(sb_sc_list); +} + +size_t SBModule::GetNumSections() { +  LLDB_RECORD_METHOD_NO_ARGS(size_t, SBModule, GetNumSections); + +  ModuleSP module_sp(GetSP()); +  if (module_sp) { +    // Give the symbol vendor a chance to add to the unified section list. +    module_sp->GetSymbolFile(); +    SectionList *section_list = module_sp->GetSectionList(); +    if (section_list) +      return section_list->GetSize(); +  } +  return 0; +} + +SBSection SBModule::GetSectionAtIndex(size_t idx) { +  LLDB_RECORD_METHOD(lldb::SBSection, SBModule, GetSectionAtIndex, (size_t), +                     idx); + +  SBSection sb_section; +  ModuleSP module_sp(GetSP()); +  if (module_sp) { +    // Give the symbol vendor a chance to add to the unified section list. +    module_sp->GetSymbolFile(); +    SectionList *section_list = module_sp->GetSectionList(); + +    if (section_list) +      sb_section.SetSP(section_list->GetSectionAtIndex(idx)); +  } +  return LLDB_RECORD_RESULT(sb_section); +} + +lldb::SBSymbolContextList SBModule::FindFunctions(const char *name, +                                                  uint32_t name_type_mask) { +  LLDB_RECORD_METHOD(lldb::SBSymbolContextList, SBModule, FindFunctions, +                     (const char *, uint32_t), name, name_type_mask); + +  lldb::SBSymbolContextList sb_sc_list; +  ModuleSP module_sp(GetSP()); +  if (name && module_sp) { +    const bool symbols_ok = true; +    const bool inlines_ok = true; +    FunctionNameType type = static_cast<FunctionNameType>(name_type_mask); +    module_sp->FindFunctions(ConstString(name), nullptr, type, symbols_ok, +                             inlines_ok, *sb_sc_list); +  } +  return LLDB_RECORD_RESULT(sb_sc_list); +} + +SBValueList SBModule::FindGlobalVariables(SBTarget &target, const char *name, +                                          uint32_t max_matches) { +  LLDB_RECORD_METHOD(lldb::SBValueList, SBModule, FindGlobalVariables, +                     (lldb::SBTarget &, const char *, uint32_t), target, name, +                     max_matches); + +  SBValueList sb_value_list; +  ModuleSP module_sp(GetSP()); +  if (name && module_sp) { +    VariableList variable_list; +    module_sp->FindGlobalVariables(ConstString(name), nullptr, max_matches, +                                   variable_list); +    const uint32_t match_count = variable_list.GetSize(); +    if (match_count > 0) { +      for (uint32_t i = 0; i < match_count; ++i) { +        lldb::ValueObjectSP valobj_sp; +        TargetSP target_sp(target.GetSP()); +        valobj_sp = ValueObjectVariable::Create( +            target_sp.get(), variable_list.GetVariableAtIndex(i)); +        if (valobj_sp) +          sb_value_list.Append(SBValue(valobj_sp)); +      } +    } +  } + +  return LLDB_RECORD_RESULT(sb_value_list); +} + +lldb::SBValue SBModule::FindFirstGlobalVariable(lldb::SBTarget &target, +                                                const char *name) { +  LLDB_RECORD_METHOD(lldb::SBValue, SBModule, FindFirstGlobalVariable, +                     (lldb::SBTarget &, const char *), target, name); + +  SBValueList sb_value_list(FindGlobalVariables(target, name, 1)); +  if (sb_value_list.IsValid() && sb_value_list.GetSize() > 0) +    return LLDB_RECORD_RESULT(sb_value_list.GetValueAtIndex(0)); +  return LLDB_RECORD_RESULT(SBValue()); +} + +lldb::SBType SBModule::FindFirstType(const char *name_cstr) { +  LLDB_RECORD_METHOD(lldb::SBType, SBModule, FindFirstType, (const char *), +                     name_cstr); + +  SBType sb_type; +  ModuleSP module_sp(GetSP()); +  if (name_cstr && module_sp) { +    SymbolContext sc; +    const bool exact_match = false; +    ConstString name(name_cstr); + +    sb_type = SBType(module_sp->FindFirstType(sc, name, exact_match)); + +    if (!sb_type.IsValid()) { +      auto type_system_or_err = +          module_sp->GetTypeSystemForLanguage(eLanguageTypeC); +      if (auto err = type_system_or_err.takeError()) { +        llvm::consumeError(std::move(err)); +        return LLDB_RECORD_RESULT(SBType()); +      } +      sb_type = SBType(type_system_or_err->GetBuiltinTypeByName(name)); +    } +  } +  return LLDB_RECORD_RESULT(sb_type); +} + +lldb::SBType SBModule::GetBasicType(lldb::BasicType type) { +  LLDB_RECORD_METHOD(lldb::SBType, SBModule, GetBasicType, (lldb::BasicType), +                     type); + +  ModuleSP module_sp(GetSP()); +  if (module_sp) { +    auto type_system_or_err = +        module_sp->GetTypeSystemForLanguage(eLanguageTypeC); +    if (auto err = type_system_or_err.takeError()) { +      llvm::consumeError(std::move(err)); +    } else { +      return LLDB_RECORD_RESULT( +          SBType(type_system_or_err->GetBasicTypeFromAST(type))); +    } +  } +  return LLDB_RECORD_RESULT(SBType()); +} + +lldb::SBTypeList SBModule::FindTypes(const char *type) { +  LLDB_RECORD_METHOD(lldb::SBTypeList, SBModule, FindTypes, (const char *), +                     type); + +  SBTypeList retval; + +  ModuleSP module_sp(GetSP()); +  if (type && module_sp) { +    TypeList type_list; +    const bool exact_match = false; +    ConstString name(type); +    llvm::DenseSet<SymbolFile *> searched_symbol_files; +    module_sp->FindTypes(name, exact_match, UINT32_MAX, searched_symbol_files, +                         type_list); + +    if (type_list.Empty()) { +      auto type_system_or_err = +          module_sp->GetTypeSystemForLanguage(eLanguageTypeC); +      if (auto err = type_system_or_err.takeError()) { +        llvm::consumeError(std::move(err)); +      } else { +        CompilerType compiler_type = +            type_system_or_err->GetBuiltinTypeByName(name); +        if (compiler_type) +          retval.Append(SBType(compiler_type)); +      } +    } else { +      for (size_t idx = 0; idx < type_list.GetSize(); idx++) { +        TypeSP type_sp(type_list.GetTypeAtIndex(idx)); +        if (type_sp) +          retval.Append(SBType(type_sp)); +      } +    } +  } +  return LLDB_RECORD_RESULT(retval); +} + +lldb::SBType SBModule::GetTypeByID(lldb::user_id_t uid) { +  LLDB_RECORD_METHOD(lldb::SBType, SBModule, GetTypeByID, (lldb::user_id_t), +                     uid); + +  ModuleSP module_sp(GetSP()); +  if (module_sp) { +    if (SymbolFile *symfile = module_sp->GetSymbolFile()) { +      Type *type_ptr = symfile->ResolveTypeUID(uid); +      if (type_ptr) +        return LLDB_RECORD_RESULT(SBType(type_ptr->shared_from_this())); +    } +  } +  return LLDB_RECORD_RESULT(SBType()); +} + +lldb::SBTypeList SBModule::GetTypes(uint32_t type_mask) { +  LLDB_RECORD_METHOD(lldb::SBTypeList, SBModule, GetTypes, (uint32_t), +                     type_mask); + +  SBTypeList sb_type_list; + +  ModuleSP module_sp(GetSP()); +  if (!module_sp) +    return LLDB_RECORD_RESULT(sb_type_list); +  SymbolFile *symfile = module_sp->GetSymbolFile(); +  if (!symfile) +    return LLDB_RECORD_RESULT(sb_type_list); + +  TypeClass type_class = static_cast<TypeClass>(type_mask); +  TypeList type_list; +  symfile->GetTypes(nullptr, type_class, type_list); +  sb_type_list.m_opaque_up->Append(type_list); +  return LLDB_RECORD_RESULT(sb_type_list); +} + +SBSection SBModule::FindSection(const char *sect_name) { +  LLDB_RECORD_METHOD(lldb::SBSection, SBModule, FindSection, (const char *), +                     sect_name); + +  SBSection sb_section; + +  ModuleSP module_sp(GetSP()); +  if (sect_name && module_sp) { +    // Give the symbol vendor a chance to add to the unified section list. +    module_sp->GetSymbolFile(); +    SectionList *section_list = module_sp->GetSectionList(); +    if (section_list) { +      ConstString const_sect_name(sect_name); +      SectionSP section_sp(section_list->FindSectionByName(const_sect_name)); +      if (section_sp) { +        sb_section.SetSP(section_sp); +      } +    } +  } +  return LLDB_RECORD_RESULT(sb_section); +} + +lldb::ByteOrder SBModule::GetByteOrder() { +  LLDB_RECORD_METHOD_NO_ARGS(lldb::ByteOrder, SBModule, GetByteOrder); + +  ModuleSP module_sp(GetSP()); +  if (module_sp) +    return module_sp->GetArchitecture().GetByteOrder(); +  return eByteOrderInvalid; +} + +const char *SBModule::GetTriple() { +  LLDB_RECORD_METHOD_NO_ARGS(const char *, SBModule, GetTriple); + +  ModuleSP module_sp(GetSP()); +  if (module_sp) { +    std::string triple(module_sp->GetArchitecture().GetTriple().str()); +    // Unique the string so we don't run into ownership issues since the const +    // strings put the string into the string pool once and the strings never +    // comes out +    ConstString const_triple(triple.c_str()); +    return const_triple.GetCString(); +  } +  return nullptr; +} + +uint32_t SBModule::GetAddressByteSize() { +  LLDB_RECORD_METHOD_NO_ARGS(uint32_t, SBModule, GetAddressByteSize); + +  ModuleSP module_sp(GetSP()); +  if (module_sp) +    return module_sp->GetArchitecture().GetAddressByteSize(); +  return sizeof(void *); +} + +uint32_t SBModule::GetVersion(uint32_t *versions, uint32_t num_versions) { +  LLDB_RECORD_METHOD(uint32_t, SBModule, GetVersion, (uint32_t *, uint32_t), +                     versions, num_versions); + +  llvm::VersionTuple version; +  if (ModuleSP module_sp = GetSP()) +    version = module_sp->GetVersion(); +  uint32_t result = 0; +  if (!version.empty()) +    ++result; +  if (version.getMinor()) +    ++result; +  if(version.getSubminor()) +    ++result; + +  if (!versions) +    return result; + +  if (num_versions > 0) +    versions[0] = version.empty() ? UINT32_MAX : version.getMajor(); +  if (num_versions > 1) +    versions[1] = version.getMinor().getValueOr(UINT32_MAX); +  if (num_versions > 2) +    versions[2] = version.getSubminor().getValueOr(UINT32_MAX); +  for (uint32_t i = 3; i < num_versions; ++i) +    versions[i] = UINT32_MAX; +  return result; +} + +lldb::SBFileSpec SBModule::GetSymbolFileSpec() const { +  LLDB_RECORD_METHOD_CONST_NO_ARGS(lldb::SBFileSpec, SBModule, +                                   GetSymbolFileSpec); + +  lldb::SBFileSpec sb_file_spec; +  ModuleSP module_sp(GetSP()); +  if (module_sp) { +    if (SymbolFile *symfile = module_sp->GetSymbolFile()) +      sb_file_spec.SetFileSpec(symfile->GetObjectFile()->GetFileSpec()); +  } +  return LLDB_RECORD_RESULT(sb_file_spec); +} + +lldb::SBAddress SBModule::GetObjectFileHeaderAddress() const { +  LLDB_RECORD_METHOD_CONST_NO_ARGS(lldb::SBAddress, SBModule, +                                   GetObjectFileHeaderAddress); + +  lldb::SBAddress sb_addr; +  ModuleSP module_sp(GetSP()); +  if (module_sp) { +    ObjectFile *objfile_ptr = module_sp->GetObjectFile(); +    if (objfile_ptr) +      sb_addr.ref() = objfile_ptr->GetBaseAddress(); +  } +  return LLDB_RECORD_RESULT(sb_addr); +} + +lldb::SBAddress SBModule::GetObjectFileEntryPointAddress() const { +  LLDB_RECORD_METHOD_CONST_NO_ARGS(lldb::SBAddress, SBModule, +                                   GetObjectFileEntryPointAddress); + +  lldb::SBAddress sb_addr; +  ModuleSP module_sp(GetSP()); +  if (module_sp) { +    ObjectFile *objfile_ptr = module_sp->GetObjectFile(); +    if (objfile_ptr) +      sb_addr.ref() = objfile_ptr->GetEntryPointAddress(); +  } +  return LLDB_RECORD_RESULT(sb_addr); +} + +namespace lldb_private { +namespace repro { + +template <> +void RegisterMethods<SBModule>(Registry &R) { +  LLDB_REGISTER_CONSTRUCTOR(SBModule, ()); +  LLDB_REGISTER_CONSTRUCTOR(SBModule, (const lldb::SBModuleSpec &)); +  LLDB_REGISTER_CONSTRUCTOR(SBModule, (const lldb::SBModule &)); +  LLDB_REGISTER_CONSTRUCTOR(SBModule, (lldb::SBProcess &, lldb::addr_t)); +  LLDB_REGISTER_METHOD(const lldb::SBModule &, +                       SBModule, operator=,(const lldb::SBModule &)); +  LLDB_REGISTER_METHOD_CONST(bool, SBModule, IsValid, ()); +  LLDB_REGISTER_METHOD_CONST(bool, SBModule, operator bool, ()); +  LLDB_REGISTER_METHOD(void, SBModule, Clear, ()); +  LLDB_REGISTER_METHOD_CONST(lldb::SBFileSpec, SBModule, GetFileSpec, ()); +  LLDB_REGISTER_METHOD_CONST(lldb::SBFileSpec, SBModule, GetPlatformFileSpec, +                             ()); +  LLDB_REGISTER_METHOD(bool, SBModule, SetPlatformFileSpec, +                       (const lldb::SBFileSpec &)); +  LLDB_REGISTER_METHOD(lldb::SBFileSpec, SBModule, GetRemoteInstallFileSpec, +                       ()); +  LLDB_REGISTER_METHOD(bool, SBModule, SetRemoteInstallFileSpec, +                       (lldb::SBFileSpec &)); +  LLDB_REGISTER_METHOD_CONST(const char *, SBModule, GetUUIDString, ()); +  LLDB_REGISTER_METHOD_CONST(bool, +                             SBModule, operator==,(const lldb::SBModule &)); +  LLDB_REGISTER_METHOD_CONST(bool, +                             SBModule, operator!=,(const lldb::SBModule &)); +  LLDB_REGISTER_METHOD(lldb::SBAddress, SBModule, ResolveFileAddress, +                       (lldb::addr_t)); +  LLDB_REGISTER_METHOD(lldb::SBSymbolContext, SBModule, +                       ResolveSymbolContextForAddress, +                       (const lldb::SBAddress &, uint32_t)); +  LLDB_REGISTER_METHOD(bool, SBModule, GetDescription, (lldb::SBStream &)); +  LLDB_REGISTER_METHOD(uint32_t, SBModule, GetNumCompileUnits, ()); +  LLDB_REGISTER_METHOD(lldb::SBCompileUnit, SBModule, GetCompileUnitAtIndex, +                       (uint32_t)); +  LLDB_REGISTER_METHOD(lldb::SBSymbolContextList, SBModule, FindCompileUnits, +                       (const lldb::SBFileSpec &)); +  LLDB_REGISTER_METHOD(size_t, SBModule, GetNumSymbols, ()); +  LLDB_REGISTER_METHOD(lldb::SBSymbol, SBModule, GetSymbolAtIndex, (size_t)); +  LLDB_REGISTER_METHOD(lldb::SBSymbol, SBModule, FindSymbol, +                       (const char *, lldb::SymbolType)); +  LLDB_REGISTER_METHOD(lldb::SBSymbolContextList, SBModule, FindSymbols, +                       (const char *, lldb::SymbolType)); +  LLDB_REGISTER_METHOD(size_t, SBModule, GetNumSections, ()); +  LLDB_REGISTER_METHOD(lldb::SBSection, SBModule, GetSectionAtIndex, +                       (size_t)); +  LLDB_REGISTER_METHOD(lldb::SBSymbolContextList, SBModule, FindFunctions, +                       (const char *, uint32_t)); +  LLDB_REGISTER_METHOD(lldb::SBValueList, SBModule, FindGlobalVariables, +                       (lldb::SBTarget &, const char *, uint32_t)); +  LLDB_REGISTER_METHOD(lldb::SBValue, SBModule, FindFirstGlobalVariable, +                       (lldb::SBTarget &, const char *)); +  LLDB_REGISTER_METHOD(lldb::SBType, SBModule, FindFirstType, (const char *)); +  LLDB_REGISTER_METHOD(lldb::SBType, SBModule, GetBasicType, +                       (lldb::BasicType)); +  LLDB_REGISTER_METHOD(lldb::SBTypeList, SBModule, FindTypes, (const char *)); +  LLDB_REGISTER_METHOD(lldb::SBType, SBModule, GetTypeByID, +                       (lldb::user_id_t)); +  LLDB_REGISTER_METHOD(lldb::SBTypeList, SBModule, GetTypes, (uint32_t)); +  LLDB_REGISTER_METHOD(lldb::SBSection, SBModule, FindSection, +                       (const char *)); +  LLDB_REGISTER_METHOD(lldb::ByteOrder, SBModule, GetByteOrder, ()); +  LLDB_REGISTER_METHOD(const char *, SBModule, GetTriple, ()); +  LLDB_REGISTER_METHOD(uint32_t, SBModule, GetAddressByteSize, ()); +  LLDB_REGISTER_METHOD(uint32_t, SBModule, GetVersion, +                       (uint32_t *, uint32_t)); +  LLDB_REGISTER_METHOD_CONST(lldb::SBFileSpec, SBModule, GetSymbolFileSpec, +                             ()); +  LLDB_REGISTER_METHOD_CONST(lldb::SBAddress, SBModule, +                             GetObjectFileHeaderAddress, ()); +  LLDB_REGISTER_METHOD_CONST(lldb::SBAddress, SBModule, +                             GetObjectFileEntryPointAddress, ()); +} + +} +}  | 
