0.5.4
C++ to UML diagram generator based on Clang
Loading...
Searching...
No Matches
clang_visitor.h
Go to the documentation of this file.
1/**
2 * @file src/common/visitor/comment/clang_visitor.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
20#include <clang/AST/ASTContext.h>
21#include <clang/AST/Comment.h>
22#include <clang/Basic/SourceManager.h>
23
24#include "comment_visitor.h"
25
27
28/**
29 * @brief Uses Clang's comment parser to extract Doxygen-style comment blocks.
30 */
32public:
33 clang_visitor(clang::SourceManager &source_manager);
34
35 /**
36 * Extracts Doxygen style comment blocks from the comment.
37 *
38 * @param decl Clang's named declaration
39 * @param e Diagram element
40 */
41 void visit(const clang::NamedDecl &decl,
43
44private:
46 const clang::comments::BlockCommandComment *command,
47 const clang::comments::CommandTraits &traits,
49
51 const clang::comments::ParamCommandComment *command,
52 const clang::comments::CommandTraits &traits,
54
56 const clang::comments::TParamCommandComment *command,
57 const clang::comments::CommandTraits &traits,
59
60 void visit_paragraph(const clang::comments::ParagraphComment *paragraph,
61 const clang::comments::CommandTraits &traits, std::string &text);
62};
63} // namespace clanguml::common::visitor::comment