X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Fpackage.cpp;h=165145f2e5e67b5d5285bf1454368afa0c4b5456;hb=cc38849384cc6d7b55c0d785ef44f03708d765ae;hp=3f994913dc36e9638def69883863d29bb2e567a2;hpb=63ea8aedbfd7dc56ab28dbc82c38b4458dcecb68;p=metaproxy-moved-to-github.git diff --git a/src/package.cpp b/src/package.cpp index 3f99491..165145f 100644 --- a/src/package.cpp +++ b/src/package.cpp @@ -1,4 +1,4 @@ -/* $Id: package.cpp,v 1.2 2006-01-04 11:19:04 adam Exp $ +/* $Id: package.cpp,v 1.5 2006-01-09 13:53:13 adam Exp $ Copyright (c) 2005, Index Data. %LICENSE% @@ -9,29 +9,36 @@ #include "package.hpp" yp2::Package::Package() - : m_filter(0), m_router(0), m_data(0) + : m_route_pos(0), m_data(0) { } +yp2::Package::~Package() +{ + delete m_route_pos; +} + yp2::Package::Package(yp2::Session &session, yp2::Origin &origin) : m_session(session), m_origin(origin), - m_filter(0), m_router(0), m_data(0) + m_route_pos(0), m_data(0) { } yp2::Package & yp2::Package::copy_filter(const Package &p) { - m_router = p.m_router; - m_filter = p.m_filter; + m_route_pos = p.m_route_pos->clone(); return *this; } void yp2::Package::move() { - m_filter = m_router->move(m_filter, this); - if (m_filter) - m_filter->process(*this); + if (m_route_pos) + { + const filter::Base *next_filter = m_route_pos->move(); + if (next_filter) + next_filter->process(*this); + } } yp2::Session & yp2::Package::session() @@ -74,8 +81,7 @@ yp2::Package & yp2::Package::origin(const Origin & origin) yp2::Package & yp2::Package::router(const yp2::Router &router) { - m_filter = 0; - m_router = &router; + m_route_pos = router.createpos(); return *this; } @@ -87,7 +93,7 @@ yazpp_1::GDU &yp2::Package::request() yazpp_1::GDU &yp2::Package::response() { - return m_response_gdu; + return m_response_gdu; } yp2::Session yp2::Package::session() const