added m_target member to keep track of target information. This is to
[metaproxy-moved-to-github.git] / src / package.cpp
index a008e45..d128f4f 100644 (file)
-/* $Id: package.cpp,v 1.3 2006-01-05 16:39:06 adam Exp $
-   Copyright (c) 2005, Index Data.
+/* $Id: package.cpp,v 1.12 2006-08-30 08:44:58 marc Exp $
+   Copyright (c) 2005-2006, Index Data.
 
-%LICENSE%
+   See the LICENSE file for details
  */
 
-#include "config.hpp"
 
+#include "config.hpp"
 #include "package.hpp"
 
-yp2::Package::Package() 
-    :  m_filter(0), m_router(0), m_data(0)
+#include <iostream>
+
+namespace mp = metaproxy_1;
+
+mp::Package::Package() 
+    : m_route_pos(0), m_data(0)
 {
 }
 
-yp2::Package::Package(yp2::Session &session, yp2::Origin &origin) 
+mp::Package::~Package()
+{
+    delete m_route_pos;
+}
+
+mp::Package::Package(mp::Session &session, const mp::Origin &origin) 
     : m_session(session), m_origin(origin),
-      m_filter(0), m_router(0), m_data(0)
+      m_route_pos(0), m_data(0)
+{
+}
+
+mp::Package::Package(mp::Session &session,
+                     const mp::Origin &origin, const mp::Origin &target) 
+    : m_session(session), m_origin(origin), m_target(target),
+      m_route_pos(0), m_data(0)
 {
 }
 
-yp2::Package & yp2::Package::copy_filter(const Package &p)
+mp::Package & mp::Package::copy_filter(const Package &p)
 {
-    m_router = p.m_router;
-    m_filter = p.m_filter;
+    delete m_route_pos;
+    m_route_pos = p.m_route_pos->clone();
     return *this;
 }
 
 
-void yp2::Package::move()
+void mp::Package::move()
+{
+    if (m_route_pos)
+    {
+        const filter::Base *next_filter = m_route_pos->move(0);
+        if (next_filter)
+            next_filter->process(*this);
+    }
+}
+
+void mp::Package::move(std::string route)
 {
-    m_filter = m_router->move(m_filter, this);
-    if (m_filter)
-        m_filter->process(*this);
+    if (m_route_pos)
+    {
+        const char *r_cstr = route.length() ? route.c_str() : 0;
+        const filter::Base *next_filter = m_route_pos->move(r_cstr);
+        if (next_filter)
+            next_filter->process(*this);
+    }
 }
 
-yp2::Session & yp2::Package::session()
+
+mp::Session & mp::Package::session()
 {
     return m_session;
 }
 
 
-int yp2::Package::data() const
+int mp::Package::data() const
 {
     return m_data;
 }
 
-int & yp2::Package::data()
+int & mp::Package::data()
 {
     return m_data;
 }
         
-yp2::Package & yp2::Package::data(const int & data)
+mp::Package & mp::Package::data(const int & data)
 {
     m_data = data;
     return *this;
 }
 
-yp2::Origin yp2::Package::origin() const 
+mp::Origin mp::Package::origin() const 
 {
     return m_origin;
 }
         
-yp2::Origin & yp2::Package::origin()
+mp::Origin & mp::Package::origin()
 {
     return m_origin;
 }
 
-yp2::Package & yp2::Package::origin(const Origin & origin)
+mp::Package & mp::Package::origin(const Origin & origin)
 {
     m_origin = origin;
     return *this;
 }
 
-yp2::Package & yp2::Package::router(const yp2::Router &router)
+mp::Origin mp::Package::target() const 
 {
-    m_filter = 0;
-    m_router = &router;
+    return m_target;
+}
+        
+mp::Origin & mp::Package::target()
+{
+    return m_target;
+}
+
+mp::Package & mp::Package::target(const Origin & target)
+{
+    m_target = target;
+    return *this;
+}
+
+mp::Package & mp::Package::router(const mp::Router &router)
+{
+    m_route_pos = router.createpos();
     return *this;
 }
 
-yazpp_1::GDU &yp2::Package::request()
+yazpp_1::GDU &mp::Package::request()
 {
     return m_request_gdu;
 }
 
 
-yazpp_1::GDU &yp2::Package::response()
+yazpp_1::GDU &mp::Package::response()
 {
-            return m_response_gdu;
+    return m_response_gdu;
 }
 
-yp2::Session yp2::Package::session() const
+mp::Session mp::Package::session() const
 {
     return m_session;
 }
+
+std::ostream& std::operator<<(std::ostream& os,  mp::Package& p)
+{
+    os << p.session().id() << " ";
+    os << p.origin();
+    return os;
+}
+
+std::ostream& std::operator<<(std::ostream& os,  mp::Origin& o)
+{
+    if (o.address != "")
+        os << o.address;
+    else
+        os << "0";
+    os << ":" << o.port;
+    return os;
+}
+
                 
 /*
  * Local variables: