X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Frouter.hpp;h=72ee73e01d80bbdbc77a84b15b6d4d3e73e4ca4e;hb=cc631cd71d418decb1ebde093a9a89d5e007f585;hp=28279def628c3aab2e8dfdac3a7d18e8623db69a;hpb=5cc9145ea95e0a778bef7ad2a0ea9c1a4824bcc4;p=metaproxy-moved-to-github.git diff --git a/src/router.hpp b/src/router.hpp index 28279de..72ee73e 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.9 2006-01-09 13:53:13 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() = 0; + virtual RoutePos *clone() = 0; + virtual ~RoutePos() {}; }; } #endif