X-Git-Url: http://lists.indexdata.com/cgi-bin?a=blobdiff_plain;f=src%2Frouter.hpp;h=d59b741eeef105cb8c136e4be5bab58e9a907bd4;hb=1a8f4295eceae42c82160c88f50bb7d6fc7eadf0;hp=31836ae3b61dd31c5174421363780551e70c45ca;hpb=0e4bd2f722c9cf0a83e7e4ef3d936c60c9419add;p=metaproxy-moved-to-github.git diff --git a/src/router.hpp b/src/router.hpp index 31836ae..d59b741 100644 --- a/src/router.hpp +++ b/src/router.hpp @@ -1,5 +1,5 @@ -/* $Id: router.hpp,v 1.7 2006-01-05 16:39:37 adam Exp $ - Copyright (c) 2005, Index Data. +/* $Id: router.hpp,v 1.11 2006-03-16 10:40:59 adam Exp $ + Copyright (c) 2005-2006, Index Data. %LICENSE% */ @@ -11,12 +11,12 @@ #include #include -namespace yp2 +namespace metaproxy_1 { namespace filter { class Base; } - class Package; + class RoutePos; class RouterException : public std::runtime_error { public: @@ -29,9 +29,14 @@ namespace yp2 Router(){}; virtual ~Router(){}; - /// determines next Filter to use from current Filter and Package - virtual const filter::Base *move(const filter::Base *filter, - const Package *package) const = 0; + virtual RoutePos *createpos() const = 0; + }; + + class RoutePos : boost::noncopyable { + public: + virtual const filter::Base *move(const char *route) = 0; + virtual RoutePos *clone() = 0; + virtual ~RoutePos() {}; }; } #endif