/*************************************************************************** * This file is part of the Lime Report project * * Copyright (C) 2021 by Alexander Arin * * arin_a@bk.ru * * * ** GNU General Public License Usage ** * * * This library is free software: you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation, either version 3 of the License, or * * (at your option) any later version. * * You should have received a copy of the GNU General Public License * * along with this program. If not, see . * * * ** GNU Lesser General Public License ** * * * This library is free software: you can redistribute it and/or modify * * it under the terms of the GNU Lesser General Public License as * * published by the Free Software Foundation, either version 3 of the * * License, or (at your option) any later version. * * You should have received a copy of the GNU Lesser General Public * * License along with this library. * * If not, see . * * * * This library is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * * GNU General Public License for more details. * ****************************************************************************/ #ifndef LRSIMPLEABSTRACTFACTORY_H #define LRSIMPLEABSTRACTFACTORY_H #include "lrsingleton.h" #include "lrglobal.h" #include #include #include #include namespace LimeReport{ template < typename AbstractProduct, typename IdentifierType, typename ProductCreator > class SimpleAbstractFactory : public Singleton< SimpleAbstractFactory< AbstractProduct,IdentifierType,ProductCreator > > { private: typedef QHash FactoryMap; friend class Singleton< SimpleAbstractFactory< AbstractProduct,IdentifierType,ProductCreator > >; public: bool registerCreator(const IdentifierType& id, ProductCreator creator){ return (m_factoryMap.insert(id,creator).value()==creator); } bool unregisterCreator(const IdentifierType& id){ return (m_factoryMap.remove(id)==1); } ProductCreator objectCreator(const IdentifierType& id){ if (m_factoryMap.contains(id)){ return m_factoryMap[id]; } else { return 0; } } const FactoryMap& map(){return m_factoryMap;} int mapElementCount(){return m_factoryMap.count();} private: FactoryMap m_factoryMap; }; template < typename AbstractProduct, typename IdentifierType, typename ProductCreator, typename Attribs > class AttribAbstractFactory : public SimpleAbstractFactory< AbstractProduct,IdentifierType,ProductCreator >{ typedef SimpleAbstractFactory< AbstractProduct,IdentifierType,ProductCreator > SimpleFactory; typedef QMap AliasMap; friend class Singleton >; public : bool registerCreator(const IdentifierType &id, Attribs attribs, ProductCreator creator){ return SimpleFactory::registerCreator(id,creator) && (m_attribsMap.insert(id,attribs).value()==attribs); } bool unregisterCreator(const IdentifierType &id){ return SimpleFactory::unregisterCreator(id)&&(m_attribsMap.remove(id)==1); } QString attribs(const IdentifierType& id){ if (m_attribsMap.contains(id)){ return m_attribsMap.value(id); } else return ""; } const AliasMap& attribsMap(){return m_attribsMap;} private: AliasMap m_attribsMap; }; } #endif //LRSIMPLEABSTRACTFACTORY_H