/** * src/common/visitor/translation_unit_visitor.h * * Copyright (c) 2021-2023 Bartek Kryza * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #pragma once #include "comment/comment_visitor.h" #include "config/config.h" #include #include #include #include #include #include #include namespace clanguml::common::visitor { using found_relationships_t = std::vector>; /** * @brief Diagram translation unit visitor base class * * This class provides common interface for diagram translation unit * visitors. */ class translation_unit_visitor { public: /** * @brief Constructor * * @param sm Reference to @link clang::SourceManager instance * @param config Reference to @link clanguml::config::diagram configuration * instance */ explicit translation_unit_visitor( clang::SourceManager &sm, const clanguml::config::diagram &config); virtual ~translation_unit_visitor() = default; /** * @brief Get clang::SourceManager * @return Reference to @link clang::SourceManager used by this translation * unit visitor */ clang::SourceManager &source_manager() const; protected: /** * @brief Set source location in diagram element * * @param decl Reference to @link clang::Decl * @param element Reference to element to be updated */ void set_source_location(const clang::Decl &decl, clanguml::common::model::source_location &element); /** * @brief Set source location in diagram element * * @param expr Reference to @link clang::Expr * @param element Reference to element to be updated */ void set_source_location(const clang::Expr &expr, clanguml::common::model::source_location &element); void set_source_location(const clang::Stmt &stmt, clanguml::common::model::source_location &element); /** * @brief Set source location in diagram element * * @param location Reference to @link clang::SourceLocation * @param element Reference to element to be updated */ void set_source_location(const clang::SourceLocation &location, clanguml::common::model::source_location &element); /** * @brief Set source location in diagram element * * @param decl Reference to @link clang::NamedDecl * @param element Reference to element to be updated */ void process_comment(const clang::NamedDecl &decl, clanguml::common::model::decorated_element &e); private: clang::SourceManager &source_manager_; std::unique_ptr comment_visitor_; std::filesystem::path relative_to_path_; }; } // namespace clanguml::common::visitor