X-Git-Url: http://lists.indexdata.com/cgi-bin?a=blobdiff_plain;f=src%2Fpackage.hpp;h=466d7a0beb298aa1125698503936ed79530c2ced;hb=517e528f09d1f80ccc4948f9d38eeb79f8501975;hp=c5e63ff69b739bad293e55808c78f97111bcd8d0;hpb=ca452b141e9a32d98166f7e07fceb30d5185130a;p=metaproxy-moved-to-github.git diff --git a/src/package.hpp b/src/package.hpp index c5e63ff..466d7a0 100644 --- a/src/package.hpp +++ b/src/package.hpp @@ -1,57 +1,53 @@ -/* $Id: package.hpp,v 1.10 2005-11-11 15:00:25 adam Exp $ - Copyright (c) 2005, Index Data. +/* $Id: package.hpp,v 1.26 2007-01-25 14:05:54 adam Exp $ + Copyright (c) 2005-2007, Index Data. -%LICENSE% + See the LICENSE file for details */ #ifndef YP2_PACKAGE_HPP #define YP2_PACKAGE_HPP -#include -#include -#include +#include + +#include #include "router.hpp" #include "filter.hpp" #include "session.hpp" +#include "origin.hpp" + +namespace metaproxy_1 { + class Package; +} + + +namespace std +{ + std::ostream& operator<<(std::ostream& os, metaproxy_1::Package& p); +} + +namespace metaproxy_1 { -namespace yp2 { - - class Origin { - enum origin_t { - API, - UNIX, - TCPIP - } type; - std::string address; // UNIX+TCPIP - int port; // TCPIP only - public: - Origin() : type(API) {}; - }; - class Package { public: - Package() ; + Package(); + + ~Package(); - Package(yp2::Session &session, yp2::Origin &origin); + Package(metaproxy_1::Session &session, + const metaproxy_1::Origin &origin); + /// shallow copy constructor which only copies the filter chain info Package & copy_filter(const Package &p); /// send Package to it's next Filter defined in Router void move(); - - /// access session - left val in assignment - yp2::Session & session(); - - /// get function - right val in assignment - unsigned int data() const; + /// send Package to other route + void move(std::string route); - /// set function - left val in assignment - unsigned int & data(); - - /// set function - can be chained - Package & data(const unsigned int & data); + /// access session - left val in assignment + metaproxy_1::Session & session(); /// get function - right val in assignment Origin origin() const; @@ -62,6 +58,7 @@ namespace yp2 { /// set function - can be chained Package & origin(const Origin & origin); + /// set function - can be chained Package & router(const Router &router); yazpp_1::GDU &request(); @@ -74,16 +71,18 @@ namespace yp2 { private: Session m_session; Origin m_origin; - - const filter::Base *m_filter; - const Router *m_router; - unsigned int m_data; + + RoutePos *m_route_pos; + + //int m_data; yazpp_1::GDU m_request_gdu; yazpp_1::GDU m_response_gdu; }; } + + #endif /* * Local variables: