/* * MIT License * * Copyright (c) 2019 Alexey Edelev , Tatyana Borisova * * This file is part of QtProtobuf project https://git.semlanik.org/semlanik/qtprotobuf * * Permission is hereby granted, free of charge, to any person obtaining a copy of this * software and associated documentation files (the "Software"), to deal in the Software * without restriction, including without limitation the rights to use, copy, modify, * merge, publish, distribute, sublicense, and/or sell copies of the Software, and * to permit persons to whom the Software is furnished to do so, subject to the following * conditions: * * The above copyright notice and this permission notice shall be included in all copies * or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR * PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE * FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER * DEALINGS IN THE SOFTWARE. */ #pragma once #include "baseprinter.h" #include "utils.h" #include "templates.h" #include "generatoroptions.h" #include "generatorcommon.h" namespace QtProtobuf { namespace generator { using PropertyMap = std::map; /*! * \ingroup generator * \private * \brief The DescriptorPrinterBase class is base of source code generation */ template class DescriptorPrinterBase : public BasePrinter { public: DescriptorPrinterBase(const T* descriptor, const std::shared_ptr<::google::protobuf::io::Printer> &printer) : BasePrinter(printer) , mDescriptor(descriptor) , mName(utils::upperCaseName(descriptor->name()))// TODO: migrate to typemaps for the client and service generators {} virtual ~DescriptorPrinterBase() = default; public: void encloseClass() { mPrinter->Print(Templates::SemicolonBlockEnclosureTemplate); mPrinter->Print("\n"); } void printNamespaces() { auto namespaces = common::getNamespaces(mDescriptor); if (!GeneratorOptions::instance().extraNamespace().empty()) { namespaces.insert(namespaces.begin(), GeneratorOptions::instance().extraNamespace()); } mPrinter->Print("\n"); for (auto ns : namespaces) { mPrinter->Print({{"namespace", ns}}, Templates::NamespaceTemplate); } } void encloseNamespaces() { auto namespacesSize = common::getNamespaces(mDescriptor).size(); if (!GeneratorOptions::instance().extraNamespace().empty()) { namespacesSize++; } mPrinter->Print("\n"); for (size_t i = 0; i < namespacesSize; ++i) { mPrinter->Print(Templates::SimpleBlockEnclosureTemplate); } mPrinter->Print("\n"); } protected: const T* mDescriptor; std::string mName;// TODO: migrate to typemaps for the client and service generators TypeMap mTypeMap; }; } //namespace generator } //namespace QtProtobuf