//===-- SBTypeFilter.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/SBTypeFilter.h" #include "lldb/API/SBStream.h" #include "lldb/DataFormatters/DataVisualization.h" using namespace lldb; using namespace lldb_private; SBTypeFilter::SBTypeFilter() : m_opaque_sp() {} SBTypeFilter::SBTypeFilter(uint32_t options) : m_opaque_sp(TypeFilterImplSP(new TypeFilterImpl(options))) {} SBTypeFilter::SBTypeFilter(const lldb::SBTypeFilter &rhs) : m_opaque_sp(rhs.m_opaque_sp) {} SBTypeFilter::~SBTypeFilter() {} bool SBTypeFilter::IsValid() const { return m_opaque_sp.get() != NULL; } uint32_t SBTypeFilter::GetOptions() { if (IsValid()) return m_opaque_sp->GetOptions(); return 0; } void SBTypeFilter::SetOptions(uint32_t value) { if (CopyOnWrite_Impl()) m_opaque_sp->SetOptions(value); } bool SBTypeFilter::GetDescription(lldb::SBStream &description, lldb::DescriptionLevel description_level) { if (!IsValid()) return false; else { description.Printf("%s\n", m_opaque_sp->GetDescription().c_str()); return true; } } void SBTypeFilter::Clear() { if (CopyOnWrite_Impl()) m_opaque_sp->Clear(); } uint32_t SBTypeFilter::GetNumberOfExpressionPaths() { if (IsValid()) return m_opaque_sp->GetCount(); return 0; } const char *SBTypeFilter::GetExpressionPathAtIndex(uint32_t i) { if (IsValid()) { const char *item = m_opaque_sp->GetExpressionPathAtIndex(i); if (item && *item == '.') item++; return item; } return NULL; } bool SBTypeFilter::ReplaceExpressionPathAtIndex(uint32_t i, const char *item) { if (CopyOnWrite_Impl()) return m_opaque_sp->SetExpressionPathAtIndex(i, item); else return false; } void SBTypeFilter::AppendExpressionPath(const char *item) { if (CopyOnWrite_Impl()) m_opaque_sp->AddExpressionPath(item); } lldb::SBTypeFilter &SBTypeFilter::operator=(const lldb::SBTypeFilter &rhs) { if (this != &rhs) { m_opaque_sp = rhs.m_opaque_sp; } return *this; } bool SBTypeFilter::operator==(lldb::SBTypeFilter &rhs) { if (IsValid() == false) return !rhs.IsValid(); return m_opaque_sp == rhs.m_opaque_sp; } bool SBTypeFilter::IsEqualTo(lldb::SBTypeFilter &rhs) { if (IsValid() == false) return !rhs.IsValid(); if (GetNumberOfExpressionPaths() != rhs.GetNumberOfExpressionPaths()) return false; for (uint32_t j = 0; j < GetNumberOfExpressionPaths(); j++) if (strcmp(GetExpressionPathAtIndex(j), rhs.GetExpressionPathAtIndex(j)) != 0) return false; return GetOptions() == rhs.GetOptions(); } bool SBTypeFilter::operator!=(lldb::SBTypeFilter &rhs) { if (IsValid() == false) return !rhs.IsValid(); return m_opaque_sp != rhs.m_opaque_sp; } lldb::TypeFilterImplSP SBTypeFilter::GetSP() { return m_opaque_sp; } void SBTypeFilter::SetSP(const lldb::TypeFilterImplSP &typefilter_impl_sp) { m_opaque_sp = typefilter_impl_sp; } SBTypeFilter::SBTypeFilter(const lldb::TypeFilterImplSP &typefilter_impl_sp) : m_opaque_sp(typefilter_impl_sp) {} bool SBTypeFilter::CopyOnWrite_Impl() { if (!IsValid()) return false; if (m_opaque_sp.unique()) return true; TypeFilterImplSP new_sp(new TypeFilterImpl(GetOptions())); for (uint32_t j = 0; j < GetNumberOfExpressionPaths(); j++) new_sp->AddExpressionPath(GetExpressionPathAtIndex(j)); SetSP(new_sp); return true; }