0.5.4
C++ to UML diagram generator based on Clang
Loading...
Searching...
No Matches
class_element.h
Go to the documentation of this file.
1/**
2 * @file src/class_diagram/model/class_element.h
3 *
4 * Copyright (c) 2021-2024 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
22
23#include <inja/inja.hpp>
24
25#include <string>
26
28
29/**
30 * @brief Base class for class elements (e.g. member or method).
31 */
34public:
36 common::model::access_t scope, std::string name, std::string type);
37
38 ~class_element() override = default;
39
40 /**
41 * @brief Get elements access scope.
42 *
43 * @return Elements access scope.
44 */
46
47 /**
48 * @brief Get elements name.
49 *
50 * @return Elements name.
51 */
52 std::string name() const;
53
54 /**
55 * @brief Set elements name.
56 *
57 * @param name Elements name.
58 */
59 void set_name(const std::string &name);
60
61 /**
62 * @brief Get elements type as string.
63 *
64 * @return Elements type as string.
65 */
66 std::string type() const;
67
68 /**
69 * @brief Set elements type as string.
70 *
71 * @param type Elements type as string.
72 */
73 void set_type(const std::string &type);
74
75 /**
76 * @brief Get elements inja context in JSON.
77 *
78 * @return Context in JSON
79 */
80 virtual inja::json context() const;
81
82private:
84 std::string name_;
85 std::string type_;
86};
87
88} // namespace clanguml::class_diagram::model