X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Frouter_chain.cpp;h=fe707c3a58996b5c04f44e7fba1175dee4854c9f;hb=586d78659d671683f33ec55f4a7d32b28e345ccd;hp=cf495443f32170f91d02f657b692e42dc7badd56;hpb=ec5548301e2549fc0f8d2f962aade24cb6f90d1b;p=metaproxy-moved-to-github.git diff --git a/src/router_chain.cpp b/src/router_chain.cpp index cf49544..fe707c3 100644 --- a/src/router_chain.cpp +++ b/src/router_chain.cpp @@ -1,14 +1,29 @@ -/* $Id: router_chain.cpp,v 1.3 2006-01-09 13:43:59 adam Exp $ - Copyright (c) 2005, Index Data. - - %LICENSE% +/* This file is part of Metaproxy. + Copyright (C) Index Data + +Metaproxy 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, or (at your option) any later +version. + +Metaproxy 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 St, Fifth Floor, Boston, MA 02110-1301 USA */ -#include "router_chain.hpp" +#include +#include #include -namespace yp2 +namespace mp = metaproxy_1; + +namespace metaproxy_1 { class ChainPos; @@ -17,81 +32,70 @@ namespace yp2 friend class RouterChain::Pos; std::list m_filter_list; }; - -#if ROUTE_POS class RouterChain::Pos : public RoutePos { public: - virtual const filter::Base *move(); + virtual const filter::Base *move(const char *route); virtual RoutePos *clone(); virtual ~Pos(); std::list::const_iterator it; - yp2::RouterChain::Rep *m_p; + mp::RouterChain::Rep *m_p; }; -#endif -}; +} + +mp::RouterChain::RouterChain() : m_p(new mp::RouterChain::Rep) +{ +} + +mp::RouterChain::~RouterChain() +{ +} -yp2::RouterChain::RouterChain() : m_p(new yp2::RouterChain::Rep) +void mp::RouterChain::start() { + std::list::const_iterator it; + + for (it = m_p->m_filter_list.begin(); it != m_p->m_filter_list.end(); it++) + (*it)->start(); } -yp2::RouterChain::~RouterChain() +void mp::RouterChain::stop(int signo) { + std::list::const_iterator it; + + for (it = m_p->m_filter_list.begin(); it != m_p->m_filter_list.end(); it++) + (*it)->stop(signo); } -#if ROUTE_POS -const yp2::filter::Base *yp2::RouterChain::Pos::move() +const mp::filter::Base *mp::RouterChain::Pos::move(const char *route) { if (it == m_p->m_filter_list.end()) return 0; - const yp2::filter::Base *f = *it; + const mp::filter::Base *f = *it; it++; return f; } -yp2::RoutePos *yp2::RouterChain::createpos() const +mp::RoutePos *mp::RouterChain::createpos() const { - yp2::RouterChain::Pos *p = new yp2::RouterChain::Pos; + mp::RouterChain::Pos *p = new mp::RouterChain::Pos; p->it = m_p->m_filter_list.begin(); p->m_p = m_p.get(); return p; } -yp2::RoutePos *yp2::RouterChain::Pos::clone() +mp::RoutePos *mp::RouterChain::Pos::clone() { - yp2::RouterChain::Pos *p = new yp2::RouterChain::Pos; + mp::RouterChain::Pos *p = new mp::RouterChain::Pos; p->it = it; p->m_p = m_p; return p; } - -yp2::RouterChain::Pos::~Pos() +mp::RouterChain::Pos::~Pos() { } -#else -const yp2::filter::Base *yp2::RouterChain::move(const filter::Base *filter, - const Package *package) const { - std::list::const_iterator it; - it = m_p->m_filter_list.begin(); - if (filter) - { - for (; it != m_p->m_filter_list.end(); it++) - if (*it == filter) - { - it++; - break; - } - } - if (it == m_p->m_filter_list.end()) - { - //throw RouterException("no routing rules known"); - return 0; - } - return *it; -} -#endif -yp2::RouterChain & yp2::RouterChain::append(const filter::Base &filter) +mp::RouterChain & mp::RouterChain::append(const filter::Base &filter) { m_p->m_filter_list.push_back(&filter); return *this; @@ -101,8 +105,9 @@ yp2::RouterChain & yp2::RouterChain::append(const filter::Base &filter) /* * Local variables: * c-basic-offset: 4 + * c-file-style: "Stroustrup" * indent-tabs-mode: nil - * c-file-style: "stroustrup" * End: * vim: shiftwidth=4 tabstop=8 expandtab */ +