X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Frouter_chain.hpp;h=a05eb37284f81f68876fff37dfa65b0422758567;hb=f47e8cf4cde2ba5465106e219c803e6424a4f177;hp=a965dd087247b404c432b6d64c47a88c762e7816;hpb=d7b1186d1f020678b617e2368415485bffef93f9;p=metaproxy-moved-to-github.git diff --git a/src/router_chain.hpp b/src/router_chain.hpp index a965dd0..a05eb37 100644 --- a/src/router_chain.hpp +++ b/src/router_chain.hpp @@ -1,4 +1,4 @@ -/* $Id: router_chain.hpp,v 1.1 2005-10-26 10:21:03 marc Exp $ +/* $Id: router_chain.hpp,v 1.5 2006-01-09 13:53:13 adam Exp $ Copyright (c) 2005, Index Data. %LICENSE% @@ -7,60 +7,29 @@ #ifndef ROUTER_CHAIN_HPP #define ROUTER_CHAIN_HPP -#include -#include #include "router.hpp" +#include +#include namespace yp2 { - namespace filter { - class Base; - } - class Package; - - class RouterChain : public Router { + class Rep; + class Pos; public: - RouterChain(){}; - virtual ~RouterChain(){}; - virtual const filter::Base *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; - }; - virtual void configure(){}; - RouterChain & rule(const filter::Base &filter){ - m_filter_list.push_back(&filter); - return *this; - } - protected: - std::list m_filter_list; + RouterChain(); + virtual ~RouterChain(); + virtual RoutePos *createpos() const; + RouterChain & append(const filter::Base &filter); private: + boost::scoped_ptr m_p; /// disabled because class is singleton RouterChain(const RouterChain &); /// disabled because class is singleton RouterChain& operator=(const RouterChain &); }; - - - } #endif