X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Frouter_chain.cpp;h=7d7e7790ae77e4af0e42b8df1b3f4cd0602d77f4;hb=b87d59a4add20f61400cfb77a9256dd26c243fb7;hp=346028c1976a6a0f1ee4459f7cf6aa0e86530b1f;hpb=e9420d437bd61c8683058af046a8dd90c859b6bc;p=metaproxy-moved-to-github.git diff --git a/src/router_chain.cpp b/src/router_chain.cpp index 346028c..7d7e779 100644 --- a/src/router_chain.cpp +++ b/src/router_chain.cpp @@ -1,39 +1,75 @@ -/* $Id: router_chain.cpp,v 1.1 2005-10-26 10:55:26 marc Exp $ +/* $Id: router_chain.cpp,v 1.4 2006-01-09 13:53:13 adam Exp $ Copyright (c) 2005, Index Data. + + %LICENSE% +*/ -%LICENSE% - */ +#include "router_chain.hpp" +#include -#include "router_chain.hpp" +namespace yp2 +{ + class ChainPos; + + class RouterChain::Rep { + friend class RouterChain; + friend class RouterChain::Pos; + std::list m_filter_list; + }; + class RouterChain::Pos : public RoutePos { + public: + virtual const filter::Base *move(); + virtual RoutePos *clone(); + virtual ~Pos(); + std::list::const_iterator it; + yp2::RouterChain::Rep *m_p; + }; +} + +yp2::RouterChain::RouterChain() : m_p(new yp2::RouterChain::Rep) +{ +} + +yp2::RouterChain::~RouterChain() +{ +} + +const yp2::filter::Base *yp2::RouterChain::Pos::move() +{ + if (it == m_p->m_filter_list.end()) + return 0; + const yp2::filter::Base *f = *it; + it++; + return f; +} + +yp2::RoutePos *yp2::RouterChain::createpos() const +{ + yp2::RouterChain::Pos *p = new yp2::RouterChain::Pos; + p->it = m_p->m_filter_list.begin(); + p->m_p = m_p.get(); + return p; +} +yp2::RoutePos *yp2::RouterChain::Pos::clone() +{ + yp2::RouterChain::Pos *p = new yp2::RouterChain::Pos; + p->it = it; + p->m_p = m_p; + return p; +} -const yp2::filter::Base * yp2::RouterChain::move(const filter::Base *filter, const Package *package) const { - std::list::const_iterator it; - it = m_filter_list.begin(); - if (filter) - { - for (; it != m_filter_list.end(); it++) - if (*it == filter) - { - it++; - break; - } - } - if (it == m_filter_list.end()) - { - //throw RouterException("no routing rules known"); - return 0; - } - return *it; - }; - - yp2::RouterChain & yp2::RouterChain::append(const filter::Base &filter){ - m_filter_list.push_back(&filter); - return *this; - }; +yp2::RouterChain::Pos::~Pos() +{ +} +yp2::RouterChain & yp2::RouterChain::append(const filter::Base &filter) +{ + m_p->m_filter_list.push_back(&filter); + return *this; +} /*