Add access specifier to visitor_info
This commit is contained in:
parent
0c4de49234
commit
bb4527ff93
2 changed files with 46 additions and 21 deletions
|
|
@ -5,8 +5,6 @@
|
|||
#include <cppast/visitor.hpp>
|
||||
|
||||
#include <cppast/cpp_alias_template.hpp>
|
||||
#include <cppast/cpp_entity.hpp>
|
||||
#include <cppast/cpp_entity_kind.hpp>
|
||||
#include <cppast/cpp_class.hpp>
|
||||
#include <cppast/cpp_class_template.hpp>
|
||||
#include <cppast/cpp_enum.hpp>
|
||||
|
|
@ -20,56 +18,78 @@ using namespace cppast;
|
|||
|
||||
namespace
|
||||
{
|
||||
cpp_access_specifier_kind get_initial_access(const cpp_entity& e)
|
||||
{
|
||||
if (e.kind() == cpp_class::kind())
|
||||
return static_cast<const cpp_class&>(e).class_kind() == cpp_class_kind::class_t ?
|
||||
cpp_private :
|
||||
cpp_public;
|
||||
return cpp_public;
|
||||
}
|
||||
|
||||
void update_access(cpp_access_specifier_kind& child_access, const cpp_entity& child)
|
||||
{
|
||||
if (child.kind() == cpp_access_specifier::kind())
|
||||
child_access = static_cast<const cpp_access_specifier&>(child).access_specifier();
|
||||
}
|
||||
|
||||
template <typename T>
|
||||
bool handle_container(const cpp_entity& e, detail::visitor_callback_t cb, void* functor,
|
||||
bool last_child)
|
||||
cpp_access_specifier_kind cur_access, bool last_child)
|
||||
{
|
||||
auto& container = static_cast<const T&>(e);
|
||||
|
||||
auto handle_children =
|
||||
cb(functor, container, {visitor_info::container_entity_enter, last_child});
|
||||
cb(functor, container, {visitor_info::container_entity_enter, cur_access, last_child});
|
||||
if (handle_children)
|
||||
{
|
||||
auto child_access = get_initial_access(e);
|
||||
for (auto iter = container.begin(); iter != container.end();)
|
||||
{
|
||||
auto& cur = *iter;
|
||||
++iter;
|
||||
if (!detail::visit(cur, cb, functor, iter == container.end()))
|
||||
|
||||
update_access(child_access, cur);
|
||||
|
||||
if (!detail::visit(cur, cb, functor, child_access, iter == container.end()))
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
return cb(functor, container, {visitor_info::container_entity_exit, last_child});
|
||||
return cb(functor, container,
|
||||
{visitor_info::container_entity_exit, cur_access, last_child});
|
||||
}
|
||||
}
|
||||
|
||||
bool detail::visit(const cpp_entity& e, detail::visitor_callback_t cb, void* functor,
|
||||
bool last_child)
|
||||
cpp_access_specifier_kind cur_access, bool last_child)
|
||||
{
|
||||
switch (e.kind())
|
||||
{
|
||||
case cpp_entity_kind::file_t:
|
||||
return handle_container<cpp_file>(e, cb, functor, last_child);
|
||||
return handle_container<cpp_file>(e, cb, functor, cur_access, last_child);
|
||||
case cpp_entity_kind::language_linkage_t:
|
||||
return handle_container<cpp_language_linkage>(e, cb, functor, last_child);
|
||||
return handle_container<cpp_language_linkage>(e, cb, functor, cur_access, last_child);
|
||||
case cpp_entity_kind::namespace_t:
|
||||
return handle_container<cpp_namespace>(e, cb, functor, last_child);
|
||||
return handle_container<cpp_namespace>(e, cb, functor, cur_access, last_child);
|
||||
case cpp_entity_kind::enum_t:
|
||||
return handle_container<cpp_enum>(e, cb, functor, last_child);
|
||||
return handle_container<cpp_enum>(e, cb, functor, cur_access, last_child);
|
||||
case cpp_entity_kind::class_t:
|
||||
return handle_container<cpp_class>(e, cb, functor, last_child);
|
||||
return handle_container<cpp_class>(e, cb, functor, cur_access, last_child);
|
||||
case cpp_entity_kind::alias_template_t:
|
||||
return handle_container<cpp_alias_template>(e, cb, functor, last_child);
|
||||
return handle_container<cpp_alias_template>(e, cb, functor, cur_access, last_child);
|
||||
case cpp_entity_kind::variable_template_t:
|
||||
return handle_container<cpp_variable_template>(e, cb, functor, last_child);
|
||||
return handle_container<cpp_variable_template>(e, cb, functor, cur_access, last_child);
|
||||
case cpp_entity_kind::function_template_t:
|
||||
return handle_container<cpp_function_template>(e, cb, functor, last_child);
|
||||
return handle_container<cpp_function_template>(e, cb, functor, cur_access, last_child);
|
||||
case cpp_entity_kind::function_template_specialization_t:
|
||||
return handle_container<cpp_function_template_specialization>(e, cb, functor, last_child);
|
||||
return handle_container<cpp_function_template_specialization>(e, cb, functor, cur_access,
|
||||
last_child);
|
||||
case cpp_entity_kind::class_template_t:
|
||||
return handle_container<cpp_class_template>(e, cb, functor, last_child);
|
||||
return handle_container<cpp_class_template>(e, cb, functor, cur_access, last_child);
|
||||
case cpp_entity_kind::class_template_specialization_t:
|
||||
return handle_container<cpp_class_template_specialization>(e, cb, functor, last_child);
|
||||
return handle_container<cpp_class_template_specialization>(e, cb, functor, cur_access,
|
||||
last_child);
|
||||
|
||||
case cpp_entity_kind::macro_definition_t:
|
||||
case cpp_entity_kind::include_directive_t:
|
||||
|
|
@ -95,7 +115,7 @@ bool detail::visit(const cpp_entity& e, detail::visitor_callback_t cb, void* fun
|
|||
case cpp_entity_kind::template_template_parameter_t:
|
||||
case cpp_entity_kind::static_assert_t:
|
||||
case cpp_entity_kind::unexposed_t:
|
||||
return cb(functor, e, {visitor_info::leaf_entity, last_child});
|
||||
return cb(functor, e, {visitor_info::leaf_entity, cur_access, last_child});
|
||||
|
||||
case cpp_entity_kind::count:
|
||||
break;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue