Add support for multiple namespace entities with the same name
This commit is contained in:
parent
08717b2ae7
commit
d21d017d8a
13 changed files with 207 additions and 203 deletions
74
src/cpp_entity_index.cpp
Normal file
74
src/cpp_entity_index.cpp
Normal file
|
|
@ -0,0 +1,74 @@
|
|||
// Copyright (C) 2017 Jonathan Müller <jonathanmueller.dev@gmail.com>
|
||||
// This file is subject to the license terms in the LICENSE file
|
||||
// found in the top-level directory of this distribution.
|
||||
|
||||
#include <cppast/cpp_entity_index.hpp>
|
||||
|
||||
#include <cppast/detail/assert.hpp>
|
||||
#include <cppast/cpp_entity.hpp>
|
||||
#include <cppast/cpp_entity_kind.hpp>
|
||||
|
||||
using namespace cppast;
|
||||
|
||||
void cpp_entity_index::register_definition(cpp_entity_id id,
|
||||
type_safe::object_ref<const cpp_entity> entity) const
|
||||
{
|
||||
DEBUG_ASSERT(entity->kind() != cpp_entity_kind::namespace_t,
|
||||
detail::precondition_error_handler{}, "must not be a namespace");
|
||||
std::lock_guard<std::mutex> lock(mutex_);
|
||||
auto result = map_.emplace(std::move(id), value(entity, true));
|
||||
if (!result.second)
|
||||
{
|
||||
// already in map, override declaration
|
||||
auto& value = result.first->second;
|
||||
DEBUG_ASSERT(!value.is_definition, detail::precondition_error_handler{},
|
||||
"duplicate entity registration");
|
||||
value.is_definition = true;
|
||||
value.entity = entity;
|
||||
}
|
||||
}
|
||||
|
||||
void cpp_entity_index::register_forward_declaration(
|
||||
cpp_entity_id id, type_safe::object_ref<const cpp_entity> entity) const
|
||||
{
|
||||
std::lock_guard<std::mutex> lock(mutex_);
|
||||
map_.emplace(std::move(id), value(entity, false));
|
||||
}
|
||||
|
||||
void cpp_entity_index::register_namespace(cpp_entity_id id,
|
||||
type_safe::object_ref<const cpp_namespace> ns) const
|
||||
{
|
||||
std::lock_guard<std::mutex> lock(mutex_);
|
||||
ns_[std::move(id)].push_back(ns);
|
||||
}
|
||||
|
||||
type_safe::optional_ref<const cpp_entity> cpp_entity_index::lookup(const cpp_entity_id& id) const
|
||||
noexcept
|
||||
{
|
||||
std::lock_guard<std::mutex> lock(mutex_);
|
||||
auto iter = map_.find(id);
|
||||
if (iter == map_.end())
|
||||
return {};
|
||||
return type_safe::ref(iter->second.entity.get());
|
||||
}
|
||||
|
||||
type_safe::optional_ref<const cpp_entity> cpp_entity_index::lookup_definition(
|
||||
const cpp_entity_id& id) const noexcept
|
||||
{
|
||||
std::lock_guard<std::mutex> lock(mutex_);
|
||||
auto iter = map_.find(id);
|
||||
if (iter == map_.end() || !iter->second.is_definition)
|
||||
return {};
|
||||
return type_safe::ref(iter->second.entity.get());
|
||||
}
|
||||
|
||||
auto cpp_entity_index::lookup_namespace(const cpp_entity_id& id) const noexcept
|
||||
-> type_safe::array_ref<type_safe::object_ref<const cpp_namespace>>
|
||||
{
|
||||
std::lock_guard<std::mutex> lock(mutex_);
|
||||
auto iter = ns_.find(id);
|
||||
if (iter == ns_.end())
|
||||
return nullptr;
|
||||
auto& vec = iter->second;
|
||||
return type_safe::ref(vec.data(), vec.size());
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue