X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Frouter_chain.hpp;h=21a423c1c69c26bc32c28df7c0b56ba7470fd571;hb=4c42fcd314fe52e0a896b08ed9d818bf6f323fe7;hp=a965dd087247b404c432b6d64c47a88c762e7816;hpb=d7b1186d1f020678b617e2368415485bffef93f9;p=metaproxy-moved-to-github.git diff --git a/src/router_chain.hpp b/src/router_chain.hpp index a965dd0..21a423c 100644 --- a/src/router_chain.hpp +++ b/src/router_chain.hpp @@ -1,5 +1,5 @@ -/* $Id: router_chain.hpp,v 1.1 2005-10-26 10:21:03 marc Exp $ - Copyright (c) 2005, Index Data. +/* $Id: router_chain.hpp,v 1.6 2006-03-16 10:40:59 adam Exp $ + Copyright (c) 2005-2006, 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; - - +namespace metaproxy_1 { 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