aboutsummaryrefslogtreecommitdiff
path: root/contrib/llvm-project/lldb/source/API/SBFileSpecList.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'contrib/llvm-project/lldb/source/API/SBFileSpecList.cpp')
-rw-r--r--contrib/llvm-project/lldb/source/API/SBFileSpecList.cpp116
1 files changed, 116 insertions, 0 deletions
diff --git a/contrib/llvm-project/lldb/source/API/SBFileSpecList.cpp b/contrib/llvm-project/lldb/source/API/SBFileSpecList.cpp
new file mode 100644
index 000000000000..74a368a3cabe
--- /dev/null
+++ b/contrib/llvm-project/lldb/source/API/SBFileSpecList.cpp
@@ -0,0 +1,116 @@
+//===-- SBFileSpecList.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/SBFileSpecList.h"
+#include "Utils.h"
+#include "lldb/API/SBFileSpec.h"
+#include "lldb/API/SBStream.h"
+#include "lldb/Host/PosixApi.h"
+#include "lldb/Utility/FileSpec.h"
+#include "lldb/Utility/FileSpecList.h"
+#include "lldb/Utility/Instrumentation.h"
+#include "lldb/Utility/Stream.h"
+
+#include <climits>
+
+using namespace lldb;
+using namespace lldb_private;
+
+SBFileSpecList::SBFileSpecList() : m_opaque_up(new FileSpecList()) {
+ LLDB_INSTRUMENT_VA(this);
+}
+
+SBFileSpecList::SBFileSpecList(const SBFileSpecList &rhs) {
+ LLDB_INSTRUMENT_VA(this, rhs);
+
+ m_opaque_up = clone(rhs.m_opaque_up);
+}
+
+SBFileSpecList::~SBFileSpecList() = default;
+
+const SBFileSpecList &SBFileSpecList::operator=(const SBFileSpecList &rhs) {
+ LLDB_INSTRUMENT_VA(this, rhs);
+
+ if (this != &rhs)
+ m_opaque_up = clone(rhs.m_opaque_up);
+ return *this;
+}
+
+uint32_t SBFileSpecList::GetSize() const {
+ LLDB_INSTRUMENT_VA(this);
+
+ return m_opaque_up->GetSize();
+}
+
+void SBFileSpecList::Append(const SBFileSpec &sb_file) {
+ LLDB_INSTRUMENT_VA(this, sb_file);
+
+ m_opaque_up->Append(sb_file.ref());
+}
+
+bool SBFileSpecList::AppendIfUnique(const SBFileSpec &sb_file) {
+ LLDB_INSTRUMENT_VA(this, sb_file);
+
+ return m_opaque_up->AppendIfUnique(sb_file.ref());
+}
+
+void SBFileSpecList::Clear() {
+ LLDB_INSTRUMENT_VA(this);
+
+ m_opaque_up->Clear();
+}
+
+uint32_t SBFileSpecList::FindFileIndex(uint32_t idx, const SBFileSpec &sb_file,
+ bool full) {
+ LLDB_INSTRUMENT_VA(this, idx, sb_file, full);
+
+ return m_opaque_up->FindFileIndex(idx, sb_file.ref(), full);
+}
+
+const SBFileSpec SBFileSpecList::GetFileSpecAtIndex(uint32_t idx) const {
+ LLDB_INSTRUMENT_VA(this, idx);
+
+ SBFileSpec new_spec;
+ new_spec.SetFileSpec(m_opaque_up->GetFileSpecAtIndex(idx));
+ return new_spec;
+}
+
+const lldb_private::FileSpecList *SBFileSpecList::operator->() const {
+ return m_opaque_up.get();
+}
+
+const lldb_private::FileSpecList *SBFileSpecList::get() const {
+ return m_opaque_up.get();
+}
+
+const lldb_private::FileSpecList &SBFileSpecList::operator*() const {
+ return *m_opaque_up;
+}
+
+const lldb_private::FileSpecList &SBFileSpecList::ref() const {
+ return *m_opaque_up;
+}
+
+bool SBFileSpecList::GetDescription(SBStream &description) const {
+ LLDB_INSTRUMENT_VA(this, description);
+
+ Stream &strm = description.ref();
+
+ if (m_opaque_up) {
+ uint32_t num_files = m_opaque_up->GetSize();
+ strm.Printf("%d files: ", num_files);
+ for (uint32_t i = 0; i < num_files; i++) {
+ char path[PATH_MAX];
+ if (m_opaque_up->GetFileSpecAtIndex(i).GetPath(path, sizeof(path)))
+ strm.Printf("\n %s", path);
+ }
+ } else
+ strm.PutCString("No value");
+
+ return true;
+}