Files
clang-p2996/lldb/source/Symbol/CompilerDeclContext.cpp
Dave Lee c327f99254 [lldb] Refactor deduction of the instance variable's name (NFC)
Move responsibility of providing the instance variable name (`this`, `self`) from
`TypeSystem` to `Language`.

`Language` the natural place for this, but also has downstream benefits. Some languages
have multiple `TypeSystem` implementations (ex Swift), and by placing this logic in the
`Language`, redundancy is avoided.

This change relies on the tests from D145348 and D146320.

Differential Revision: https://reviews.llvm.org/D146548
2023-03-21 15:22:07 -07:00

73 lines
2.5 KiB
C++

//===-- CompilerDeclContext.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/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,
const bool ignore_using_decls) {
if (IsValid())
return m_type_system->DeclContextFindDeclByName(m_opaque_decl_ctx, name,
ignore_using_decls);
return std::vector<CompilerDecl>();
}
ConstString CompilerDeclContext::GetName() const {
if (IsValid())
return m_type_system->DeclContextGetName(m_opaque_decl_ctx);
return ConstString();
}
ConstString CompilerDeclContext::GetScopeQualifiedName() const {
if (IsValid())
return m_type_system->DeclContextGetScopeQualifiedName(m_opaque_decl_ctx);
return ConstString();
}
bool CompilerDeclContext::IsClassMethod() {
if (IsValid())
return m_type_system->DeclContextIsClassMethod(m_opaque_decl_ctx);
return false;
}
lldb::LanguageType CompilerDeclContext::GetLanguage() {
if (IsValid())
return m_type_system->DeclContextGetLanguage(m_opaque_decl_ctx);
return {};
}
bool CompilerDeclContext::IsContainedInLookup(CompilerDeclContext other) const {
if (!IsValid())
return false;
// If the other context is just the current context, we don't need to go
// over the type system to know that the lookup is identical.
if (this == &other)
return true;
return m_type_system->DeclContextIsContainedInLookup(m_opaque_decl_ctx,
other.m_opaque_decl_ctx);
}
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();
}