Added option to skip redundant dependency relationships

This commit is contained in:
Bartek Kryza
2023-08-05 17:52:30 +02:00
parent f6efb7941f
commit 2e1013c12f
15 changed files with 108 additions and 34 deletions

View File

@@ -208,6 +208,33 @@ inja::json diagram::context() const
return ctx;
}
void diagram::remove_redundant_dependencies()
{
using common::id_t;
using common::model::relationship;
using common::model::relationship_t;
for (auto &c : element_view<class_>::view()) {
std::set<id_t> dependency_relationships_to_remove;
for (auto &r : c.get().relationships()) {
if (r.type() != relationship_t::kDependency)
dependency_relationships_to_remove.emplace(r.destination());
}
for (const auto &base : c.get().parents()) {
dependency_relationships_to_remove.emplace(base.id());
}
util::erase_if(c.get().relationships(),
[&dependency_relationships_to_remove](const auto &r) {
return r.type() == relationship_t::kDependency &&
dependency_relationships_to_remove.count(r.destination()) >
0;
});
}
}
} // namespace clanguml::class_diagram::model
namespace clanguml::common::model {

View File

@@ -227,6 +227,11 @@ public:
*/
bool has_element(diagram_element::id_t id) const override;
/**
* @brief Remove redundant dependency relationships
*/
void remove_redundant_dependencies();
/**
* @brief Return the elements JSON context for inja templates.
*

View File

@@ -2061,6 +2061,9 @@ void translation_unit_visitor::finalize()
{
add_incomplete_forward_declarations();
resolve_local_to_global_ids();
if (config().skip_redundant_dependencies()) {
diagram().remove_redundant_dependencies();
}
}
void translation_unit_visitor::extract_constrained_template_param_name(