X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Frouter.hpp;h=5c5ce07e114092121b189fd0c0c3dc70d2a924c9;hb=357884a3c428262e37911c9429dc122fb0243bcd;hp=28279def628c3aab2e8dfdac3a7d18e8623db69a;hpb=5cc9145ea95e0a778bef7ad2a0ea9c1a4824bcc4;p=metaproxy-moved-to-github.git diff --git a/src/router.hpp b/src/router.hpp index 28279de..5c5ce07 100644 --- a/src/router.hpp +++ b/src/router.hpp @@ -1,4 +1,4 @@ -/* $Id: router.hpp,v 1.6 2005-11-10 23:10:42 adam Exp $ +/* $Id: router.hpp,v 1.10 2006-01-11 11:51:50 adam Exp $ Copyright (c) 2005, Index Data. %LICENSE% @@ -16,31 +16,27 @@ namespace yp2 namespace filter { class Base; } - class Package; + class RoutePos; class RouterException : public std::runtime_error { public: RouterException(const std::string message) : std::runtime_error("RouterException: " + message){}; }; - - + class Router : boost::noncopyable { public: 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; - - /// re-read configuration of routing tables - //virtual void configure(){}; + virtual RoutePos *createpos() const = 0; + }; - /// add routing rule expressed as Filter to Router - //virtual Router & rule(const filter::Base &filter){ - // return *this; - //} + class RoutePos : boost::noncopyable { + public: + virtual const filter::Base *move(const char *route) = 0; + virtual RoutePos *clone() = 0; + virtual ~RoutePos() {}; }; } #endif