diff options
author | Dimitry Andric <dim@FreeBSD.org> | 2015-12-30 11:55:28 +0000 |
---|---|---|
committer | Dimitry Andric <dim@FreeBSD.org> | 2015-12-30 11:55:28 +0000 |
commit | e81d9d49145e432d917eea3a70d2ae74dcad1d89 (patch) | |
tree | 9ed5e1a91f242e2cb5911577356e487a55c01b78 /source/Symbol/CompilerDeclContext.cpp | |
parent | 85d8ef8f1f0e0e063a8571944302be2d2026f823 (diff) |
Notes
Diffstat (limited to 'source/Symbol/CompilerDeclContext.cpp')
-rw-r--r-- | source/Symbol/CompilerDeclContext.cpp | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/source/Symbol/CompilerDeclContext.cpp b/source/Symbol/CompilerDeclContext.cpp new file mode 100644 index 0000000000000..e44cee67284c0 --- /dev/null +++ b/source/Symbol/CompilerDeclContext.cpp @@ -0,0 +1,75 @@ +//===-- CompilerDeclContext.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/Symbol/CompilerDeclContext.h" +#include "lldb/Symbol/CompilerDecl.h" +#include "lldb/Symbol/TypeSystem.h" +#include <vector> + +using namespace lldb_private; + +std::vector<CompilerDecl> +CompilerDeclContext::FindDeclByName (ConstString name) +{ + if (IsValid()) + return m_type_system->DeclContextFindDeclByName(m_opaque_decl_ctx, name); + else + return std::vector<CompilerDecl>(); +} + +bool +CompilerDeclContext::IsClang () const +{ + return IsValid() && m_type_system->getKind() == TypeSystem::eKindClang; +} + +ConstString +CompilerDeclContext::GetName () const +{ + if (IsValid()) + return m_type_system->DeclContextGetName(m_opaque_decl_ctx); + else + return ConstString(); +} + +bool +CompilerDeclContext::IsStructUnionOrClass () const +{ + if (IsValid()) + return m_type_system->DeclContextIsStructUnionOrClass(m_opaque_decl_ctx); + else + return false; +} + +bool +CompilerDeclContext::IsClassMethod (lldb::LanguageType *language_ptr, + bool *is_instance_method_ptr, + ConstString *language_object_name_ptr) +{ + if (IsValid()) + return m_type_system->DeclContextIsClassMethod (m_opaque_decl_ctx, + language_ptr, + is_instance_method_ptr, + language_object_name_ptr); + else + return false; +} + +bool +lldb_private::operator == (const lldb_private::CompilerDeclContext &lhs, const lldb_private::CompilerDeclContext &rhs) +{ + return lhs.GetTypeSystem() == rhs.GetTypeSystem() && lhs.GetOpaqueDeclContext() == rhs.GetOpaqueDeclContext(); +} + + +bool +lldb_private::operator != (const lldb_private::CompilerDeclContext &lhs, const lldb_private::CompilerDeclContext &rhs) +{ + return lhs.GetTypeSystem() != rhs.GetTypeSystem() || lhs.GetOpaqueDeclContext() != rhs.GetOpaqueDeclContext(); +} |