0.6.0
C++ to UML diagram generator based on Clang
Loading...
Searching...
No Matches
Public Member Functions | Protected Member Functions | Private Attributes | Friends | List of all members
clanguml::common::model::diagram_element Class Reference

Base class for standalone diagram elements. More...

Detailed Description

Base class for standalone diagram elements.

This is a base cass of any standalone elements such as classes, structs, concepts, packages and so on participants and so on.

Definition at line 47 of file diagram_element.h.

#include <diagram_element.h>

Public Member Functions

 diagram_element ()
 
 ~diagram_element () override=default
 
const eid_tid () const
 Returns diagram element id.
 
void set_id (eid_t id)
 
std::optional< eid_tparent_element_id () const
 
void set_parent_element_id (eid_t id)
 
virtual std::string alias () const
 Return elements' diagram alias.
 
void set_name (const std::string &name)
 
void set_name (const std::string &parent, const std::string &name)
 
std::string name () const
 
virtual std::string type_name () const
 
std::string full_name (bool relative) const
 Return the elements fully qualified name.
 
std::vector< relationship > & relationships ()
 
const std::vector< relationship > & relationships () const
 
void add_relationship (relationship &&cr)
 
void append (const decorated_element &e)
 
bool is_nested () const
 
void nested (bool nested)
 
bool complete () const
 
void complete (bool completed)
 
void remove_duplicate_relationships ()
 
virtual void apply_filter (const diagram_filter &filter, const std::set< eid_t > &removed)
 
- Public Member Functions inherited from clanguml::common::model::decorated_element
virtual ~decorated_element ()=default
 
bool skip () const
 
bool skip_relationship () const
 
std::pair< relationship_t, std::string > get_relationship () const
 
std::string style_spec () const
 
const std::vector< std::shared_ptr< decorators::decorator > > & decorators () const
 
void add_decorators (const std::vector< std::shared_ptr< decorators::decorator > > &decorators)
 
void append (const decorated_element &de)
 
std::optional< comment_tcomment () const
 
void set_comment (const comment_t &c)
 
virtual std::optional< std::string > doxygen_link () const
 
- Public Member Functions inherited from clanguml::common::model::source_location
 source_location ()=default
 
 source_location (std::string f, unsigned int l)
 
const std::string & file () const
 
void set_file (const std::string &file)
 
const std::string & file_relative () const
 
void set_file_relative (const std::string &file)
 
const std::string & translation_unit () const
 
void set_translation_unit (const std::string &translation_unit)
 
unsigned int line () const
 
void set_line (const unsigned line)
 
unsigned int column () const
 
void set_column (const unsigned column)
 
unsigned int location_id () const
 
void set_location_id (unsigned int h)
 
- Public Member Functions inherited from clanguml::util::memoized< full_name_tag_t, std::string, bool >
auto memoize (bool is_complete, F &&f, Args... args) const
 
void invalidate (Args... args) const
 
- Public Member Functions inherited from clanguml::util::memoized< name_and_ns_tag, std::string >
auto memoize (bool is_complete, F &&f, Args... args) const
 
void invalidate (Args... args) const
 

Protected Member Functions

virtual std::string full_name_impl (bool) const
 

Private Attributes

eid_t id_ {}
 
std::optional< eid_tparent_element_id_ {}
 
std::string name_
 
std::vector< relationshiprelationships_
 
bool nested_ {false}
 
bool complete_ {false}
 

Friends

bool operator== (const diagram_element &l, const diagram_element &r)
 
std::ostream & operator<< (std::ostream &out, const diagram_element &rhs)
 

Additional Inherited Members

- Public Types inherited from clanguml::util::memoized< full_name_tag_t, std::string, bool >
using key_t = std::tuple< Args... >
 
using value_t = std::string
 
- Public Types inherited from clanguml::util::memoized< name_and_ns_tag, std::string >
using key_t = std::tuple< Args... >
 
using value_t = std::string
 

Constructor & Destructor Documentation

◆ diagram_element()

clanguml::common::model::diagram_element::diagram_element ( )
default

◆ ~diagram_element()

clanguml::common::model::diagram_element::~diagram_element ( )
overridedefault

Member Function Documentation

◆ add_relationship()

void clanguml::common::model::diagram_element::add_relationship ( relationship &&  cr)

Add relationships, whose source is this element.

Parameters
crRelationship to another diagram element.

Definition at line 52 of file diagram_element.cc.

53{
54 if ((cr.type() == relationship_t::kInstantiation) &&
55 (cr.destination() == id())) {
56 LOG_DBG("Skipping self instantiation relationship for {}",
57 cr.destination());
58 return;
59 }
60
62 LOG_DBG("Adding relationship from: '{}' ({}) - {} - '{}'", id(),
63 full_name(true), to_string(cr.type()), cr.destination());
64
65 relationships_.emplace_back(std::move(cr));
66 }
67}

◆ alias()

std::string clanguml::common::model::diagram_element::alias ( ) const
virtual

Return elements' diagram alias.

Todo:
This is a PlantUML specific method - it shouldn't be here.
Returns
PlantUML's diagram element alias.

Reimplemented in clanguml::sequence_diagram::model::method, and clanguml::sequence_diagram::model::objc_method.

Definition at line 44 of file diagram_element.cc.

45{
46 // Only generate alias for global id's
47 assert(id_.is_global());
48
49 return fmt::format("C_{:022}", id_.value());
50}

◆ append()

void clanguml::common::model::diagram_element::append ( const decorated_element e)

Add element to the diagram.

Parameters
eDiagram element.

Definition at line 79 of file diagram_element.cc.

80{
82}

◆ apply_filter()

void clanguml::common::model::diagram_element::apply_filter ( const diagram_filter filter,
const std::set< eid_t > &  removed 
)
virtual

Reimplemented in clanguml::class_diagram::model::class_.

Definition at line 105 of file diagram_element.cc.

107{
109
110 auto &rels = relationships();
111 rels.erase(std::remove_if(std::begin(rels), std::end(rels),
112 [&removed](auto &&r) {
113 return removed.count(r.destination()) > 0;
114 }),
115 std::end(rels));
116}

◆ complete() [1/2]

bool clanguml::common::model::diagram_element::complete ( ) const

Returns the diagrams completion status.

Returns
Whether the diagram is complete.

Definition at line 88 of file diagram_element.cc.

88{ return complete_; }

◆ complete() [2/2]

void clanguml::common::model::diagram_element::complete ( bool  completed)

Set the diagrams completion status.

Parameters
completed

Definition at line 90 of file diagram_element.cc.

90{ complete_ = completed; }

◆ full_name()

std::string clanguml::common::model::diagram_element::full_name ( bool  relative) const
inline

Return the elements fully qualified name.

This method should be implemented in each subclass, and ensure that for instance it includes fully qualified namespace, template params, etc.

Returns
Full elements name.

Definition at line 143 of file diagram_element.h.

144 {
146 complete(),
147 [this](bool relative) { return full_name_impl(relative); },
148 relative);
149 }

◆ full_name_impl()

virtual std::string clanguml::common::model::diagram_element::full_name_impl ( bool  ) const
inlineprotectedvirtual

◆ id()

const eid_t & clanguml::common::model::diagram_element::id ( ) const

Returns diagram element id.

Each element in the diagram is uniquely identified by id. The id is currently calculated from the full string representation of the element, in order to be uniquely identifiable among multiple translation units.

Returns
Elements id.

Definition at line 30 of file diagram_element.cc.

30{ return id_; }

◆ is_nested()

bool clanguml::common::model::diagram_element::is_nested ( ) const

Whether this element is nested in another element.

Returns

Definition at line 84 of file diagram_element.cc.

84{ return nested_; }

◆ name()

std::string clanguml::common::model::diagram_element::name ( ) const
inline

Return diagram element name.

Returns
Diagram element name.

Definition at line 126 of file diagram_element.h.

126{ return name_; }

◆ nested()

void clanguml::common::model::diagram_element::nested ( bool  nested)

Set element's nested status.

Parameters
nested

Definition at line 86 of file diagram_element.cc.

86{ nested_ = nested; }

◆ parent_element_id()

std::optional< eid_t > clanguml::common::model::diagram_element::parent_element_id ( ) const

Get elements parent package id.

Returns
Parent package id if element is nested.

Definition at line 34 of file diagram_element.cc.

35{
36 return parent_element_id_;
37}

◆ relationships() [1/2]

std::vector< relationship > & clanguml::common::model::diagram_element::relationships ( )

Return all relationships outgoing from this element.

Returns
List of relationships.

Definition at line 69 of file diagram_element.cc.

70{
71 return relationships_;
72}

◆ relationships() [2/2]

const std::vector< relationship > & clanguml::common::model::diagram_element::relationships ( ) const

Return all relationships outgoing from this element.

Returns
List of relationships.

Definition at line 74 of file diagram_element.cc.

75{
76 return relationships_;
77}

◆ remove_duplicate_relationships()

void clanguml::common::model::diagram_element::remove_duplicate_relationships ( )

Due to the fact that a relationship to the same element can be added once with local TU id and other time with global id, the relationship set can contain duplicates.

Definition at line 92 of file diagram_element.cc.

93{
94 std::vector<relationship> unique_relationships;
95
96 for (auto &r : relationships_) {
97 if (!util::contains(unique_relationships, r)) {
98 unique_relationships.emplace_back(r);
99 }
100 }
101
102 std::swap(relationships_, unique_relationships);
103}

◆ set_id()

void clanguml::common::model::diagram_element::set_id ( eid_t  id)

Set elements id.

Parameters
idElements id.

Definition at line 32 of file diagram_element.cc.

32{ id_ = id; }

◆ set_name() [1/2]

void clanguml::common::model::diagram_element::set_name ( const std::string &  name)
inline

Set diagram elements name.

Parameters
nameElements name.

Definition at line 104 of file diagram_element.h.

◆ set_name() [2/2]

void clanguml::common::model::diagram_element::set_name ( const std::string &  parent,
const std::string &  name 
)
inline

Set diagram elements name for nested elements.

Parameters
parentParents name.
nameElements name.

Definition at line 116 of file diagram_element.h.

117 {
118 set_name(fmt::format("{}##{}", parent, name));
119 }

◆ set_parent_element_id()

void clanguml::common::model::diagram_element::set_parent_element_id ( eid_t  id)

Set elements parent package id.

Parameters
idId of parent package.

Definition at line 39 of file diagram_element.cc.

40{
42}

◆ type_name()

virtual std::string clanguml::common::model::diagram_element::type_name ( ) const
inlinevirtual

Friends And Related Symbol Documentation

◆ operator<<

std::ostream & operator<< ( std::ostream &  out,
const diagram_element rhs 
)
friend

Definition at line 123 of file diagram_element.cc.

124{
125 out << "(" << rhs.name() << ", full_name=[" << rhs.full_name(false) << "])";
126
127 return out;
128}

◆ operator==

bool operator== ( const diagram_element l,
const diagram_element r 
)
friend

Definition at line 118 of file diagram_element.cc.

119{
120 return l.id() == r.id();
121}

Member Data Documentation

◆ complete_

bool clanguml::common::model::diagram_element::complete_ {false}
private

Definition at line 234 of file diagram_element.h.

◆ id_

eid_t clanguml::common::model::diagram_element::id_ {}
private

Definition at line 229 of file diagram_element.h.

◆ name_

std::string clanguml::common::model::diagram_element::name_
private

Definition at line 231 of file diagram_element.h.

◆ nested_

bool clanguml::common::model::diagram_element::nested_ {false}
private

Definition at line 233 of file diagram_element.h.

◆ parent_element_id_

std::optional<eid_t> clanguml::common::model::diagram_element::parent_element_id_ {}
private

Definition at line 230 of file diagram_element.h.

◆ relationships_

std::vector<relationship> clanguml::common::model::diagram_element::relationships_
private

Definition at line 232 of file diagram_element.h.


The documentation for this class was generated from the following files: