2010-06-09 00:52:24 +08:00
|
|
|
//===-- SBCompileUnit.cpp ---------------------------------------*- C++ -*-===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// 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
|
2010-06-09 00:52:24 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "lldb/API/SBCompileUnit.h"
|
2019-03-06 08:06:00 +08:00
|
|
|
#include "SBReproducerPrivate.h"
|
2010-06-09 00:52:24 +08:00
|
|
|
#include "lldb/API/SBLineEntry.h"
|
2010-09-20 13:20:02 +08:00
|
|
|
#include "lldb/API/SBStream.h"
|
2013-06-19 06:51:05 +08:00
|
|
|
#include "lldb/Core/Module.h"
|
2010-06-09 00:52:24 +08:00
|
|
|
#include "lldb/Symbol/CompileUnit.h"
|
|
|
|
#include "lldb/Symbol/LineEntry.h"
|
|
|
|
#include "lldb/Symbol/LineTable.h"
|
2019-08-06 17:12:42 +08:00
|
|
|
#include "lldb/Symbol/SymbolFile.h"
|
2013-06-19 06:51:05 +08:00
|
|
|
#include "lldb/Symbol/Type.h"
|
2019-07-25 16:22:05 +08:00
|
|
|
#include "lldb/Symbol/TypeList.h"
|
2010-06-09 00:52:24 +08:00
|
|
|
|
|
|
|
using namespace lldb;
|
|
|
|
using namespace lldb_private;
|
|
|
|
|
[lldb] NFC modernize codebase with modernize-use-nullptr
Summary:
NFC = [[ https://llvm.org/docs/Lexicon.html#nfc | Non functional change ]]
This commit is the result of modernizing the LLDB codebase by using
`nullptr` instread of `0` or `NULL`. See
https://clang.llvm.org/extra/clang-tidy/checks/modernize-use-nullptr.html
for more information.
This is the command I ran and I to fix and format the code base:
```
run-clang-tidy.py \
-header-filter='.*' \
-checks='-*,modernize-use-nullptr' \
-fix ~/dev/llvm-project/lldb/.* \
-format \
-style LLVM \
-p ~/llvm-builds/debug-ninja-gcc
```
NOTE: There were also changes to `llvm/utils/unittest` but I did not
include them because I felt that maybe this library shall be updated in
isolation somehow.
NOTE: I know this is a rather large commit but it is a nobrainer in most
parts.
Reviewers: martong, espindola, shafik, #lldb, JDevlieghere
Reviewed By: JDevlieghere
Subscribers: arsenm, jvesely, nhaehnle, hiraditya, JDevlieghere, teemperor, rnkovacs, emaste, kubamracek, nemanjai, ki.stfu, javed.absar, arichardson, kbarton, jrtc27, MaskRay, atanasyan, dexonsmith, arphaman, jfb, jsji, jdoerfert, lldb-commits, llvm-commits
Tags: #lldb, #llvm
Differential Revision: https://reviews.llvm.org/D61847
llvm-svn: 361484
2019-05-23 19:14:47 +08:00
|
|
|
SBCompileUnit::SBCompileUnit() : m_opaque_ptr(nullptr) {
|
2019-03-06 08:06:00 +08:00
|
|
|
LLDB_RECORD_CONSTRUCTOR_NO_ARGS(SBCompileUnit);
|
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
|
|
|
|
SBCompileUnit::SBCompileUnit(lldb_private::CompileUnit *lldb_object_ptr)
|
2010-06-23 09:19:29 +08:00
|
|
|
: m_opaque_ptr(lldb_object_ptr) {}
|
2010-06-09 00:52:24 +08:00
|
|
|
|
2010-11-06 07:17:00 +08:00
|
|
|
SBCompileUnit::SBCompileUnit(const SBCompileUnit &rhs)
|
2019-03-06 08:06:00 +08:00
|
|
|
: m_opaque_ptr(rhs.m_opaque_ptr) {
|
|
|
|
LLDB_RECORD_CONSTRUCTOR(SBCompileUnit, (const lldb::SBCompileUnit &), rhs);
|
|
|
|
}
|
2010-11-06 07:17:00 +08:00
|
|
|
|
|
|
|
const SBCompileUnit &SBCompileUnit::operator=(const SBCompileUnit &rhs) {
|
2019-03-06 08:06:00 +08:00
|
|
|
LLDB_RECORD_METHOD(const lldb::SBCompileUnit &,
|
|
|
|
SBCompileUnit, operator=,(const lldb::SBCompileUnit &),
|
|
|
|
rhs);
|
|
|
|
|
2010-11-06 07:17:00 +08:00
|
|
|
m_opaque_ptr = rhs.m_opaque_ptr;
|
2019-04-04 05:31:22 +08:00
|
|
|
return LLDB_RECORD_RESULT(*this);
|
2010-11-06 07:17:00 +08:00
|
|
|
}
|
|
|
|
|
[lldb] NFC modernize codebase with modernize-use-nullptr
Summary:
NFC = [[ https://llvm.org/docs/Lexicon.html#nfc | Non functional change ]]
This commit is the result of modernizing the LLDB codebase by using
`nullptr` instread of `0` or `NULL`. See
https://clang.llvm.org/extra/clang-tidy/checks/modernize-use-nullptr.html
for more information.
This is the command I ran and I to fix and format the code base:
```
run-clang-tidy.py \
-header-filter='.*' \
-checks='-*,modernize-use-nullptr' \
-fix ~/dev/llvm-project/lldb/.* \
-format \
-style LLVM \
-p ~/llvm-builds/debug-ninja-gcc
```
NOTE: There were also changes to `llvm/utils/unittest` but I did not
include them because I felt that maybe this library shall be updated in
isolation somehow.
NOTE: I know this is a rather large commit but it is a nobrainer in most
parts.
Reviewers: martong, espindola, shafik, #lldb, JDevlieghere
Reviewed By: JDevlieghere
Subscribers: arsenm, jvesely, nhaehnle, hiraditya, JDevlieghere, teemperor, rnkovacs, emaste, kubamracek, nemanjai, ki.stfu, javed.absar, arichardson, kbarton, jrtc27, MaskRay, atanasyan, dexonsmith, arphaman, jfb, jsji, jdoerfert, lldb-commits, llvm-commits
Tags: #lldb, #llvm
Differential Revision: https://reviews.llvm.org/D61847
llvm-svn: 361484
2019-05-23 19:14:47 +08:00
|
|
|
SBCompileUnit::~SBCompileUnit() { m_opaque_ptr = nullptr; }
|
2010-11-06 07:17:00 +08:00
|
|
|
|
2010-06-09 00:52:24 +08:00
|
|
|
SBFileSpec SBCompileUnit::GetFileSpec() const {
|
2019-03-06 08:06:00 +08:00
|
|
|
LLDB_RECORD_METHOD_CONST_NO_ARGS(lldb::SBFileSpec, SBCompileUnit,
|
|
|
|
GetFileSpec);
|
|
|
|
|
2010-06-09 00:52:24 +08:00
|
|
|
SBFileSpec file_spec;
|
|
|
|
if (m_opaque_ptr)
|
2010-06-23 09:19:29 +08:00
|
|
|
file_spec.SetFileSpec(*m_opaque_ptr);
|
2019-03-06 08:06:00 +08:00
|
|
|
return LLDB_RECORD_RESULT(file_spec);
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t SBCompileUnit::GetNumLineEntries() const {
|
2019-03-06 08:06:00 +08:00
|
|
|
LLDB_RECORD_METHOD_CONST_NO_ARGS(uint32_t, SBCompileUnit, GetNumLineEntries);
|
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
if (m_opaque_ptr) {
|
|
|
|
LineTable *line_table = m_opaque_ptr->GetLineTable();
|
2019-03-06 10:32:45 +08:00
|
|
|
if (line_table) {
|
2010-06-09 00:52:24 +08:00
|
|
|
return line_table->GetSize();
|
2019-03-06 10:32:45 +08:00
|
|
|
}
|
2016-09-07 04:57:50 +08:00
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
SBLineEntry SBCompileUnit::GetLineEntryAtIndex(uint32_t idx) const {
|
2019-03-06 08:06:00 +08:00
|
|
|
LLDB_RECORD_METHOD_CONST(lldb::SBLineEntry, SBCompileUnit,
|
|
|
|
GetLineEntryAtIndex, (uint32_t), idx);
|
|
|
|
|
2010-06-09 00:52:24 +08:00
|
|
|
SBLineEntry sb_line_entry;
|
2010-06-23 09:19:29 +08:00
|
|
|
if (m_opaque_ptr) {
|
|
|
|
LineTable *line_table = m_opaque_ptr->GetLineTable();
|
2010-06-09 00:52:24 +08:00
|
|
|
if (line_table) {
|
|
|
|
LineEntry line_entry;
|
|
|
|
if (line_table->GetLineEntryAtIndex(idx, line_entry))
|
|
|
|
sb_line_entry.SetLineEntry(line_entry);
|
|
|
|
}
|
2016-09-07 04:57:50 +08:00
|
|
|
}
|
2014-04-04 12:06:10 +08:00
|
|
|
|
2019-03-06 08:06:00 +08:00
|
|
|
return LLDB_RECORD_RESULT(sb_line_entry);
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t SBCompileUnit::FindLineEntryIndex(uint32_t start_idx, uint32_t line,
|
|
|
|
SBFileSpec *inline_file_spec) const {
|
2019-03-06 08:06:00 +08:00
|
|
|
LLDB_RECORD_METHOD_CONST(uint32_t, SBCompileUnit, FindLineEntryIndex,
|
|
|
|
(uint32_t, uint32_t, lldb::SBFileSpec *), start_idx,
|
|
|
|
line, inline_file_spec);
|
|
|
|
|
2011-09-23 08:54:11 +08:00
|
|
|
const bool exact = true;
|
|
|
|
return FindLineEntryIndex(start_idx, line, inline_file_spec, exact);
|
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t SBCompileUnit::FindLineEntryIndex(uint32_t start_idx, uint32_t line,
|
|
|
|
SBFileSpec *inline_file_spec,
|
|
|
|
bool exact) const {
|
2019-03-06 08:06:00 +08:00
|
|
|
LLDB_RECORD_METHOD_CONST(uint32_t, SBCompileUnit, FindLineEntryIndex,
|
|
|
|
(uint32_t, uint32_t, lldb::SBFileSpec *, bool),
|
|
|
|
start_idx, line, inline_file_spec, exact);
|
|
|
|
|
2010-10-31 11:01:06 +08:00
|
|
|
uint32_t index = UINT32_MAX;
|
2010-06-23 09:19:29 +08:00
|
|
|
if (m_opaque_ptr) {
|
2010-06-09 00:52:24 +08:00
|
|
|
FileSpec file_spec;
|
|
|
|
if (inline_file_spec && inline_file_spec->IsValid())
|
|
|
|
file_spec = inline_file_spec->ref();
|
2016-09-07 04:57:50 +08:00
|
|
|
else
|
2010-06-23 09:19:29 +08:00
|
|
|
file_spec = *m_opaque_ptr;
|
2016-09-07 04:57:50 +08:00
|
|
|
|
2010-10-31 11:01:06 +08:00
|
|
|
index = m_opaque_ptr->FindLineEntry(
|
[lldb] NFC modernize codebase with modernize-use-nullptr
Summary:
NFC = [[ https://llvm.org/docs/Lexicon.html#nfc | Non functional change ]]
This commit is the result of modernizing the LLDB codebase by using
`nullptr` instread of `0` or `NULL`. See
https://clang.llvm.org/extra/clang-tidy/checks/modernize-use-nullptr.html
for more information.
This is the command I ran and I to fix and format the code base:
```
run-clang-tidy.py \
-header-filter='.*' \
-checks='-*,modernize-use-nullptr' \
-fix ~/dev/llvm-project/lldb/.* \
-format \
-style LLVM \
-p ~/llvm-builds/debug-ninja-gcc
```
NOTE: There were also changes to `llvm/utils/unittest` but I did not
include them because I felt that maybe this library shall be updated in
isolation somehow.
NOTE: I know this is a rather large commit but it is a nobrainer in most
parts.
Reviewers: martong, espindola, shafik, #lldb, JDevlieghere
Reviewed By: JDevlieghere
Subscribers: arsenm, jvesely, nhaehnle, hiraditya, JDevlieghere, teemperor, rnkovacs, emaste, kubamracek, nemanjai, ki.stfu, javed.absar, arichardson, kbarton, jrtc27, MaskRay, atanasyan, dexonsmith, arphaman, jfb, jsji, jdoerfert, lldb-commits, llvm-commits
Tags: #lldb, #llvm
Differential Revision: https://reviews.llvm.org/D61847
llvm-svn: 361484
2019-05-23 19:14:47 +08:00
|
|
|
start_idx, line, inline_file_spec ? inline_file_spec->get() : nullptr,
|
|
|
|
exact, nullptr);
|
2016-09-07 04:57:50 +08:00
|
|
|
}
|
|
|
|
|
2010-10-31 11:01:06 +08:00
|
|
|
return index;
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
2012-03-17 04:46:10 +08:00
|
|
|
uint32_t SBCompileUnit::GetNumSupportFiles() const {
|
2019-03-06 08:06:00 +08:00
|
|
|
LLDB_RECORD_METHOD_CONST_NO_ARGS(uint32_t, SBCompileUnit, GetNumSupportFiles);
|
|
|
|
|
2019-05-30 16:21:25 +08:00
|
|
|
if (m_opaque_ptr)
|
|
|
|
return m_opaque_ptr->GetSupportFiles().GetSize();
|
|
|
|
|
2012-03-17 04:46:10 +08:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2013-06-19 06:51:05 +08:00
|
|
|
lldb::SBTypeList SBCompileUnit::GetTypes(uint32_t type_mask) {
|
2019-03-06 08:06:00 +08:00
|
|
|
LLDB_RECORD_METHOD(lldb::SBTypeList, SBCompileUnit, GetTypes, (uint32_t),
|
|
|
|
type_mask);
|
|
|
|
|
2013-06-19 06:51:05 +08:00
|
|
|
SBTypeList sb_type_list;
|
|
|
|
|
2018-10-26 04:45:40 +08:00
|
|
|
if (!m_opaque_ptr)
|
2019-03-06 08:06:00 +08:00
|
|
|
return LLDB_RECORD_RESULT(sb_type_list);
|
2018-10-26 04:45:40 +08:00
|
|
|
|
|
|
|
ModuleSP module_sp(m_opaque_ptr->GetModule());
|
|
|
|
if (!module_sp)
|
2019-03-06 08:06:00 +08:00
|
|
|
return LLDB_RECORD_RESULT(sb_type_list);
|
2018-10-26 04:45:40 +08:00
|
|
|
|
2019-08-06 17:12:42 +08:00
|
|
|
SymbolFile *symfile = module_sp->GetSymbolFile();
|
|
|
|
if (!symfile)
|
2019-03-06 08:06:00 +08:00
|
|
|
return LLDB_RECORD_RESULT(sb_type_list);
|
2018-10-26 04:45:40 +08:00
|
|
|
|
|
|
|
TypeClass type_class = static_cast<TypeClass>(type_mask);
|
|
|
|
TypeList type_list;
|
2019-08-06 17:12:42 +08:00
|
|
|
symfile->GetTypes(m_opaque_ptr, type_class, type_list);
|
2019-02-13 14:25:41 +08:00
|
|
|
sb_type_list.m_opaque_up->Append(type_list);
|
2019-03-06 08:06:00 +08:00
|
|
|
return LLDB_RECORD_RESULT(sb_type_list);
|
2013-06-19 06:51:05 +08:00
|
|
|
}
|
|
|
|
|
2012-03-17 04:46:10 +08:00
|
|
|
SBFileSpec SBCompileUnit::GetSupportFileAtIndex(uint32_t idx) const {
|
2019-03-06 08:06:00 +08:00
|
|
|
LLDB_RECORD_METHOD_CONST(lldb::SBFileSpec, SBCompileUnit,
|
|
|
|
GetSupportFileAtIndex, (uint32_t), idx);
|
|
|
|
|
2012-03-17 04:46:10 +08:00
|
|
|
SBFileSpec sb_file_spec;
|
2010-06-23 09:19:29 +08:00
|
|
|
if (m_opaque_ptr) {
|
2019-05-30 16:21:25 +08:00
|
|
|
FileSpec spec = m_opaque_ptr->GetSupportFiles().GetFileSpecAtIndex(idx);
|
|
|
|
sb_file_spec.SetFileSpec(spec);
|
2016-09-07 04:57:50 +08:00
|
|
|
}
|
2013-06-19 06:51:05 +08:00
|
|
|
|
|
|
|
|
2019-03-06 08:06:00 +08:00
|
|
|
return LLDB_RECORD_RESULT(sb_file_spec);
|
2012-03-17 04:46:10 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t SBCompileUnit::FindSupportFileIndex(uint32_t start_idx,
|
|
|
|
const SBFileSpec &sb_file,
|
|
|
|
bool full) {
|
2019-03-06 08:06:00 +08:00
|
|
|
LLDB_RECORD_METHOD(uint32_t, SBCompileUnit, FindSupportFileIndex,
|
|
|
|
(uint32_t, const lldb::SBFileSpec &, bool), start_idx,
|
|
|
|
sb_file, full);
|
|
|
|
|
2012-03-17 04:46:10 +08:00
|
|
|
if (m_opaque_ptr) {
|
2019-05-30 16:21:25 +08:00
|
|
|
const FileSpecList &support_files = m_opaque_ptr->GetSupportFiles();
|
2012-03-17 04:46:10 +08:00
|
|
|
return support_files.FindFileIndex(start_idx, sb_file.ref(), full);
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2014-11-18 07:06:20 +08:00
|
|
|
lldb::LanguageType SBCompileUnit::GetLanguage() {
|
2019-03-06 08:06:00 +08:00
|
|
|
LLDB_RECORD_METHOD_NO_ARGS(lldb::LanguageType, SBCompileUnit, GetLanguage);
|
|
|
|
|
2014-11-18 07:06:20 +08:00
|
|
|
if (m_opaque_ptr)
|
|
|
|
return m_opaque_ptr->GetLanguage();
|
|
|
|
return lldb::eLanguageTypeUnknown;
|
|
|
|
}
|
|
|
|
|
2019-03-06 08:06:00 +08:00
|
|
|
bool SBCompileUnit::IsValid() const {
|
|
|
|
LLDB_RECORD_METHOD_CONST_NO_ARGS(bool, SBCompileUnit, IsValid);
|
Add "operator bool" to SB APIs
Summary:
Our python version of the SB API has (the python equivalent of)
operator bool, but the C++ version doesn't.
This is because our python operators are added by modify-python-lldb.py,
which performs postprocessing on the swig-generated interface files.
In this patch, I add the "operator bool" to all SB classes which have an
IsValid method (which is the same logic used by modify-python-lldb.py).
This way, we make the two interfaces more constent, and it allows us to
rely on swig's automatic syntesis of python __nonzero__ methods instead
of doing manual fixups.
Reviewers: zturner, jingham, clayborg, jfb, serge-sans-paille
Subscribers: jdoerfert, lldb-commits
Differential Revision: https://reviews.llvm.org/D58792
llvm-svn: 355824
2019-03-11 21:58:46 +08:00
|
|
|
return this->operator bool();
|
|
|
|
}
|
|
|
|
SBCompileUnit::operator bool() const {
|
|
|
|
LLDB_RECORD_METHOD_CONST_NO_ARGS(bool, SBCompileUnit, operator bool);
|
2019-03-06 08:06:00 +08:00
|
|
|
|
[lldb] NFC modernize codebase with modernize-use-nullptr
Summary:
NFC = [[ https://llvm.org/docs/Lexicon.html#nfc | Non functional change ]]
This commit is the result of modernizing the LLDB codebase by using
`nullptr` instread of `0` or `NULL`. See
https://clang.llvm.org/extra/clang-tidy/checks/modernize-use-nullptr.html
for more information.
This is the command I ran and I to fix and format the code base:
```
run-clang-tidy.py \
-header-filter='.*' \
-checks='-*,modernize-use-nullptr' \
-fix ~/dev/llvm-project/lldb/.* \
-format \
-style LLVM \
-p ~/llvm-builds/debug-ninja-gcc
```
NOTE: There were also changes to `llvm/utils/unittest` but I did not
include them because I felt that maybe this library shall be updated in
isolation somehow.
NOTE: I know this is a rather large commit but it is a nobrainer in most
parts.
Reviewers: martong, espindola, shafik, #lldb, JDevlieghere
Reviewed By: JDevlieghere
Subscribers: arsenm, jvesely, nhaehnle, hiraditya, JDevlieghere, teemperor, rnkovacs, emaste, kubamracek, nemanjai, ki.stfu, javed.absar, arichardson, kbarton, jrtc27, MaskRay, atanasyan, dexonsmith, arphaman, jfb, jsji, jdoerfert, lldb-commits, llvm-commits
Tags: #lldb, #llvm
Differential Revision: https://reviews.llvm.org/D61847
llvm-svn: 361484
2019-05-23 19:14:47 +08:00
|
|
|
return m_opaque_ptr != nullptr;
|
2019-03-06 08:06:00 +08:00
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
|
|
|
|
bool SBCompileUnit::operator==(const SBCompileUnit &rhs) const {
|
2019-03-06 08:06:00 +08:00
|
|
|
LLDB_RECORD_METHOD_CONST(
|
|
|
|
bool, SBCompileUnit, operator==,(const lldb::SBCompileUnit &), rhs);
|
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
return m_opaque_ptr == rhs.m_opaque_ptr;
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
bool SBCompileUnit::operator!=(const SBCompileUnit &rhs) const {
|
2019-03-06 08:06:00 +08:00
|
|
|
LLDB_RECORD_METHOD_CONST(
|
|
|
|
bool, SBCompileUnit, operator!=,(const lldb::SBCompileUnit &), rhs);
|
|
|
|
|
2010-06-23 09:19:29 +08:00
|
|
|
return m_opaque_ptr != rhs.m_opaque_ptr;
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
const lldb_private::CompileUnit *SBCompileUnit::operator->() const {
|
2010-06-23 09:19:29 +08:00
|
|
|
return m_opaque_ptr;
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
const lldb_private::CompileUnit &SBCompileUnit::operator*() const {
|
2010-06-23 09:19:29 +08:00
|
|
|
return *m_opaque_ptr;
|
2010-06-09 00:52:24 +08:00
|
|
|
}
|
2010-09-20 13:20:02 +08:00
|
|
|
|
2011-09-26 15:11:27 +08:00
|
|
|
lldb_private::CompileUnit *SBCompileUnit::get() { return m_opaque_ptr; }
|
2010-12-14 12:58:53 +08:00
|
|
|
|
|
|
|
void SBCompileUnit::reset(lldb_private::CompileUnit *lldb_object_ptr) {
|
|
|
|
m_opaque_ptr = lldb_object_ptr;
|
|
|
|
}
|
|
|
|
|
2010-09-20 13:20:02 +08:00
|
|
|
bool SBCompileUnit::GetDescription(SBStream &description) {
|
2019-03-06 08:06:00 +08:00
|
|
|
LLDB_RECORD_METHOD(bool, SBCompileUnit, GetDescription, (lldb::SBStream &),
|
|
|
|
description);
|
|
|
|
|
2011-11-13 14:57:31 +08:00
|
|
|
Stream &strm = description.ref();
|
|
|
|
|
2010-09-20 13:20:02 +08:00
|
|
|
if (m_opaque_ptr) {
|
2011-11-13 14:57:31 +08:00
|
|
|
m_opaque_ptr->Dump(&strm, false);
|
2010-09-20 13:20:02 +08:00
|
|
|
} else
|
2011-11-13 14:57:31 +08:00
|
|
|
strm.PutCString("No value");
|
2016-09-07 04:57:50 +08:00
|
|
|
|
2010-09-20 13:20:02 +08:00
|
|
|
return true;
|
|
|
|
}
|
2019-03-20 01:13:13 +08:00
|
|
|
|
|
|
|
namespace lldb_private {
|
|
|
|
namespace repro {
|
|
|
|
|
|
|
|
template <>
|
|
|
|
void RegisterMethods<SBCompileUnit>(Registry &R) {
|
|
|
|
LLDB_REGISTER_CONSTRUCTOR(SBCompileUnit, ());
|
|
|
|
LLDB_REGISTER_CONSTRUCTOR(SBCompileUnit, (const lldb::SBCompileUnit &));
|
|
|
|
LLDB_REGISTER_METHOD(
|
|
|
|
const lldb::SBCompileUnit &,
|
|
|
|
SBCompileUnit, operator=,(const lldb::SBCompileUnit &));
|
|
|
|
LLDB_REGISTER_METHOD_CONST(lldb::SBFileSpec, SBCompileUnit, GetFileSpec,
|
|
|
|
());
|
|
|
|
LLDB_REGISTER_METHOD_CONST(uint32_t, SBCompileUnit, GetNumLineEntries, ());
|
|
|
|
LLDB_REGISTER_METHOD_CONST(lldb::SBLineEntry, SBCompileUnit,
|
|
|
|
GetLineEntryAtIndex, (uint32_t));
|
|
|
|
LLDB_REGISTER_METHOD_CONST(uint32_t, SBCompileUnit, FindLineEntryIndex,
|
|
|
|
(uint32_t, uint32_t, lldb::SBFileSpec *));
|
|
|
|
LLDB_REGISTER_METHOD_CONST(uint32_t, SBCompileUnit, FindLineEntryIndex,
|
|
|
|
(uint32_t, uint32_t, lldb::SBFileSpec *, bool));
|
|
|
|
LLDB_REGISTER_METHOD_CONST(uint32_t, SBCompileUnit, GetNumSupportFiles, ());
|
|
|
|
LLDB_REGISTER_METHOD(lldb::SBTypeList, SBCompileUnit, GetTypes, (uint32_t));
|
|
|
|
LLDB_REGISTER_METHOD_CONST(lldb::SBFileSpec, SBCompileUnit,
|
|
|
|
GetSupportFileAtIndex, (uint32_t));
|
|
|
|
LLDB_REGISTER_METHOD(uint32_t, SBCompileUnit, FindSupportFileIndex,
|
|
|
|
(uint32_t, const lldb::SBFileSpec &, bool));
|
|
|
|
LLDB_REGISTER_METHOD(lldb::LanguageType, SBCompileUnit, GetLanguage, ());
|
|
|
|
LLDB_REGISTER_METHOD_CONST(bool, SBCompileUnit, IsValid, ());
|
|
|
|
LLDB_REGISTER_METHOD_CONST(bool, SBCompileUnit, operator bool, ());
|
|
|
|
LLDB_REGISTER_METHOD_CONST(
|
|
|
|
bool, SBCompileUnit, operator==,(const lldb::SBCompileUnit &));
|
|
|
|
LLDB_REGISTER_METHOD_CONST(
|
|
|
|
bool, SBCompileUnit, operator!=,(const lldb::SBCompileUnit &));
|
|
|
|
LLDB_REGISTER_METHOD(bool, SBCompileUnit, GetDescription,
|
|
|
|
(lldb::SBStream &));
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|