// // VMime library (http://www.vmime.org) // Copyright (C) 2002-2006 Vincent Richard // // This program 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 2 of // the License, or (at your option) any later version. // // This program 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. // // You should have received a copy of the GNU General Public License along // with this program; if not, write to the Free Software Foundation, Inc., // 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. // // Linking this library statically or dynamically with other modules is making // a combined work based on this library. Thus, the terms and conditions of // the GNU General Public License cover the whole combination. // #ifndef VMIME_ENCODERFACTORY_HPP_INCLUDED #define VMIME_ENCODERFACTORY_HPP_INCLUDED #include "vmime/encoder.hpp" #include "vmime/utility/stringUtils.hpp" namespace vmime { /** A factory to create 'encoder' objects for the specified encoding. */ class encoderFactory { private: encoderFactory(); ~encoderFactory(); public: static encoderFactory* getInstance(); /** Information about a registered encoder. */ class registeredEncoder : public object { protected: virtual ~registeredEncoder() { } public: virtual ref create() const = 0; virtual const string& getName() const = 0; }; private: template class registeredEncoderImpl : public registeredEncoder { friend class vmime::creator; protected: registeredEncoderImpl(const string& name) : m_name(name) { } public: ref create() const { return vmime::create (); } const string& getName() const { return (m_name); } private: const string m_name; }; std::vector > m_encoders; public: /** Register a new encoder by its encoding name. * * @param name encoding name */ template void registerName(const string& name) { m_encoders.push_back(vmime::create >(utility::stringUtils::toLower(name))); } /** Create a new encoder instance from an encoding name. * * @param name encoding name (eg. "base64") * @return a new encoder instance for the specified encoding * @throw exceptions::no_encoder_available if no encoder is registered * for this encoding */ ref create(const string& name); /** Return information about a registered encoder. * * @param name encoding name * @return information about this encoder * @throw exceptions::no_encoder_available if no encoder is registered * for this encoding */ const ref getEncoderByName(const string& name) const; /** Return the number of registered encoders. * * @return number of registered encoders */ const int getEncoderCount() const; /** Return the registered encoder at the specified position. * * @param pos position of the registered encoder to return * @return registered encoder at the specified position */ const ref getEncoderAt(const int pos) const; /** Return a list of all registered encoders. * * @return list of registered encoders */ const std::vector > getEncoderList() const; }; } // vmime #endif // VMIME_ENCODERFACTORY_HPP_INCLUDED