0.6.0
C++ to UML diagram generator based on Clang
Loading...
Searching...
No Matches
package_diagram_generator.h
Go to the documentation of this file.
1/**
2 * @file src/package_diagram/generators/mermaid/package_diagram_generator.h
3 *
4 * Copyright (c) 2021-2025 Bartek Kryza <bkryza@gmail.com>
5 *
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
17 */
18#pragma once
19
24#include "config/config.h"
27#include "util/util.h"
28
29#include <filesystem>
30#include <fstream>
31#include <iostream>
32#include <sstream>
33
34namespace clanguml {
35namespace package_diagram {
36namespace generators {
37namespace mermaid {
38
41
42template <typename C, typename D>
44
48using namespace clanguml::util;
49
50/**
51 * @brief Package diagram MermaidJS generator
52 */
53class generator : public common_generator<diagram_config, diagram_model> {
54public:
56
58
59 /**
60 * @brief Main generator method.
61 *
62 * This method is called first and coordinates the entire diagram
63 * generation.
64 *
65 * @param ostr Output stream.
66 */
67 void generate_diagram(std::ostream &ostr) const override;
68
69 /**
70 * @brief Generate the diagram type
71 *
72 * @param ostr Output stream
73 */
74 void generate_diagram_type(std::ostream &ostr) const override;
75
76 /**
77 * @brief Generate relationships originating from package `p`
78 *
79 * @param p Diagram element
80 * @param parent Output stream
81 */
82 void generate_relationships(const package &p, std::ostream &ostr) const;
83
84 /**
85 * @brief Generate diagram package element
86 *
87 * @param p Package diagram element
88 * @param parent Output stream
89 */
90 void generate(const package &e, std::ostream &ostr) const;
91
92 /**
93 * @brief Generate package elements grouped using `together` MermaidJS tag
94 *
95 * @param ostr Output stream
96 */
97 void generate_groups(std::ostream &ostr) const;
98
99 /**
100 * @brief Generate notes attached to packages
101 *
102 * @param ostr Output stream
103 * @param element Element with a note
104 */
105 void generate_notes(std::ostream &ostr,
106 const common::model::diagram_element &element) const override;
107
108private:
109 mutable uint64_t note_id_{0UL};
112};
113
114} // namespace mermaid
115} // namespace generators
116} // namespace package_diagram
117} // namespace clanguml