From 152c6bed75598a6ca5efb7914701157270155833 Mon Sep 17 00:00:00 2001 From: Vincent Richard Date: Sun, 29 Dec 2013 10:02:12 +0100 Subject: Merged source and header files in directory structure. Got rid of SConstruct build. --- src/net/serviceFactory.cpp | 145 --------------------------------------------- 1 file changed, 145 deletions(-) delete mode 100644 src/net/serviceFactory.cpp (limited to 'src/net/serviceFactory.cpp') diff --git a/src/net/serviceFactory.cpp b/src/net/serviceFactory.cpp deleted file mode 100644 index 98aee646..00000000 --- a/src/net/serviceFactory.cpp +++ /dev/null @@ -1,145 +0,0 @@ -// -// VMime library (http://www.vmime.org) -// Copyright (C) 2002-2013 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 3 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. -// - -#include "vmime/config.hpp" - - -#if VMIME_HAVE_MESSAGING_FEATURES - - -#include "vmime/net/serviceFactory.hpp" -#include "vmime/net/service.hpp" - -#include "vmime/exception.hpp" - -#include "src/net/builtinServices.inl" - - -namespace vmime { -namespace net { - - -serviceFactory::serviceFactory() -{ -} - - -serviceFactory::~serviceFactory() -{ -} - - -shared_ptr serviceFactory::getInstance() -{ - static serviceFactory instance; - return shared_ptr (&instance, noop_shared_ptr_deleter ()); -} - - -shared_ptr serviceFactory::create - (shared_ptr sess, const string& protocol, - shared_ptr auth) -{ - return (getServiceByProtocol(protocol)->create(sess, auth)); -} - - -shared_ptr serviceFactory::create - (shared_ptr sess, const utility::url& u, - shared_ptr auth) -{ - shared_ptr serv = create(sess, u.getProtocol(), auth); - - sess->getProperties()[serv->getInfos().getPropertyPrefix() + "server.address"] = u.getHost(); - - if (u.getPort() != utility::url::UNSPECIFIED_PORT) - sess->getProperties()[serv->getInfos().getPropertyPrefix() + "server.port"] = u.getPort(); - - // Path portion of the URL is used to point a specific folder (empty = root). - // In maildir, this is used to point to the root of the message repository. - if (!u.getPath().empty()) - sess->getProperties()[serv->getInfos().getPropertyPrefix() + "server.rootpath"] = u.getPath(); - - if (!u.getUsername().empty()) - { - sess->getProperties()[serv->getInfos().getPropertyPrefix() + "auth.username"] = u.getUsername(); - sess->getProperties()[serv->getInfos().getPropertyPrefix() + "auth.password"] = u.getPassword(); - } - - return (serv); -} - - -shared_ptr serviceFactory::getServiceByProtocol(const string& protocol) const -{ - const string name(utility::stringUtils::toLower(protocol)); - - for (std::vector >::const_iterator it = m_services.begin() ; - it != m_services.end() ; ++it) - { - if ((*it)->getName() == name) - return (*it); - } - - return null; -} - - -size_t serviceFactory::getServiceCount() const -{ - return (m_services.size()); -} - - -shared_ptr serviceFactory::getServiceAt(const size_t pos) const -{ - return (m_services[pos]); -} - - -const std::vector > serviceFactory::getServiceList() const -{ - std::vector > res; - - for (std::vector >::const_iterator it = m_services.begin() ; - it != m_services.end() ; ++it) - { - res.push_back(*it); - } - - return (res); -} - - -void serviceFactory::registerService(shared_ptr reg) -{ - m_services.push_back(reg); -} - - -} // net -} // vmime - - -#endif // VMIME_HAVE_MESSAGING_FEATURES - -- cgit v1.2.3