X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FPackets%2FPacketInterpreter.ct;h=3499dd32f8b458a25c8108c5a66b066f2c2172cf;hb=HEAD;hp=57194b7e66595c983265a7dccca518780b5d091a;hpb=ab7ff164ab5ae711ec09ce2b24228510f1ffdcff;p=senf.git diff --git a/senf/Packets/PacketInterpreter.ct b/senf/Packets/PacketInterpreter.ct index 57194b7..3499dd3 100644 --- a/senf/Packets/PacketInterpreter.ct +++ b/senf/Packets/PacketInterpreter.ct @@ -78,15 +78,14 @@ prefix_ typename senf::PacketInterpreter::ptr senf::PacketInterpreter::create(size_type size, senf::NoInit_t) { detail::PacketImpl::Guard p (new detail::PacketImpl(size,0)); - ptr pi (create(p.p,p.p->begin(),p.p->end(),Append)); - return pi; + return create(p.p,p.p->begin(),p.p->end(),Append); } // Create packet as new packet after a given packet template prefix_ typename senf::PacketInterpreter::ptr -senf::PacketInterpreter::createAfter(PacketInterpreterBase::ptr packet, +senf::PacketInterpreter::createAfter(PacketInterpreterBase::ptr const & packet, size_type size) { if (size < initSize()) @@ -99,7 +98,7 @@ senf::PacketInterpreter::createAfter(PacketInterpreterBase::ptr pack template prefix_ typename senf::PacketInterpreter::ptr -senf::PacketInterpreter::createAfter(PacketInterpreterBase::ptr packet, +senf::PacketInterpreter::createAfter(PacketInterpreterBase::ptr const & packet, size_type size, senf::NoInit_t) { optional_range r (packet->nextPacketRange()); @@ -117,7 +116,7 @@ senf::PacketInterpreter::createAfter(PacketInterpreterBase::ptr pack template template prefix_ typename senf::PacketInterpreter::ptr -senf::PacketInterpreter::createAfter(PacketInterpreterBase::ptr packet, +senf::PacketInterpreter::createAfter(PacketInterpreterBase::ptr const & packet, ForwardReadableRange const & range) { optional_range r (packet->nextPacketRange()); @@ -137,7 +136,7 @@ senf::PacketInterpreter::createAfter(PacketInterpreterBase::ptr pack template prefix_ typename senf::PacketInterpreter::ptr -senf::PacketInterpreter::createBefore(PacketInterpreterBase::ptr packet) +senf::PacketInterpreter::createBefore(PacketInterpreterBase::ptr const & packet) { ptr pi (createBefore(packet, senf::noinit)); pi->data().insert(pi->data().begin(),initHeadSize(),byte(0x00u)); @@ -148,7 +147,7 @@ senf::PacketInterpreter::createBefore(PacketInterpreterBase::ptr pac template prefix_ typename senf::PacketInterpreter::ptr -senf::PacketInterpreter::createBefore(PacketInterpreterBase::ptr packet, senf::NoInit_t) +senf::PacketInterpreter::createBefore(PacketInterpreterBase::ptr const & packet, senf::NoInit_t) { if (packet->prev()) packet->impl().truncateInterpretersBackwards(packet->prev().get()); @@ -158,7 +157,7 @@ senf::PacketInterpreter::createBefore(PacketInterpreterBase::ptr pac template prefix_ typename senf::PacketInterpreter::ptr -senf::PacketInterpreter::createInsertBefore(PacketInterpreterBase::ptr packet) +senf::PacketInterpreter::createInsertBefore(PacketInterpreterBase::ptr const & packet) { ptr pi (createInsertBefore(packet, senf::noinit)); pi->data().insert(pi->data().begin(),initHeadSize(),byte(0x00u)); @@ -169,7 +168,7 @@ senf::PacketInterpreter::createInsertBefore(PacketInterpreterBase::p template prefix_ typename senf::PacketInterpreter::ptr -senf::PacketInterpreter::createInsertBefore(PacketInterpreterBase::ptr packet, +senf::PacketInterpreter::createInsertBefore(PacketInterpreterBase::ptr const & packet, senf::NoInit_t) { return create(&packet->impl(),packet->data().begin(),packet->data().end(),packet); @@ -181,7 +180,7 @@ senf::PacketInterpreter::createInsertBefore(PacketInterpreterBase::p // virtual interface template -prefix_ typename senf::PacketInterpreter::optional_range +prefix_ senf::PacketInterpreterBase::optional_range senf::PacketInterpreter::v_nextPacketRange() { return type::nextPacketRange(ConcretePacket(ptr(this))); @@ -224,14 +223,14 @@ prefix_ senf::TypeIdValue senf::PacketInterpreter::v_type() } template -prefix_ typename senf::PacketInterpreter::factory_t +prefix_ senf::PacketInterpreterBase::factory_t senf::PacketInterpreter::v_factory() { return factory(); } template -prefix_ typename senf::PacketInterpreter::factory_t +prefix_ senf::PacketInterpreterBase::factory_t senf::PacketInterpreter::v_nextPacketType() { return type::nextPacketType(ConcretePacket(ptr(this))); @@ -253,7 +252,7 @@ senf::PacketInterpreterBase::Factory::create(ForwardReadableRange const & range) template prefix_ senf::PacketInterpreterBase::ptr -senf::PacketInterpreterBase::Factory::createAfter(PacketInterpreterBase::ptr packet, +senf::PacketInterpreterBase::Factory::createAfter(PacketInterpreterBase::ptr const & packet, ForwardReadableRange const & range) const { @@ -303,7 +302,7 @@ senf::PacketInterpreter::FactoryImpl::create(size_type size, senf::N template prefix_ typename senf::PacketInterpreterBase::ptr -senf::PacketInterpreter::FactoryImpl::createAfter(PacketInterpreterBase::ptr packet) +senf::PacketInterpreter::FactoryImpl::createAfter(PacketInterpreterBase::ptr const & packet) const { return senf::PacketInterpreter::createAfter(packet); @@ -311,7 +310,7 @@ senf::PacketInterpreter::FactoryImpl::createAfter(PacketInterpreterB template prefix_ typename senf::PacketInterpreterBase::ptr -senf::PacketInterpreter::FactoryImpl::createAfter(PacketInterpreterBase::ptr packet, +senf::PacketInterpreter::FactoryImpl::createAfter(PacketInterpreterBase::ptr const & packet, senf::NoInit_t) const { @@ -320,7 +319,7 @@ senf::PacketInterpreter::FactoryImpl::createAfter(PacketInterpreterB template prefix_ typename senf::PacketInterpreterBase::ptr -senf::PacketInterpreter::FactoryImpl::createAfter(PacketInterpreterBase::ptr packet, +senf::PacketInterpreter::FactoryImpl::createAfter(PacketInterpreterBase::ptr const & packet, size_type size) const { @@ -329,7 +328,7 @@ senf::PacketInterpreter::FactoryImpl::createAfter(PacketInterpreterB template prefix_ typename senf::PacketInterpreterBase::ptr -senf::PacketInterpreter::FactoryImpl::createAfter(PacketInterpreterBase::ptr packet, +senf::PacketInterpreter::FactoryImpl::createAfter(PacketInterpreterBase::ptr const & packet, size_type size, senf::NoInit_t) const { @@ -341,7 +340,7 @@ senf::PacketInterpreter::FactoryImpl::createAfter(PacketInterpreterB template prefix_ typename senf::PacketInterpreterBase::ptr senf::PacketInterpreter::FactoryImpl:: -createBefore(PacketInterpreterBase::ptr packet) +createBefore(PacketInterpreterBase::ptr const & packet) const { return senf::PacketInterpreter::createBefore(packet); @@ -350,7 +349,7 @@ createBefore(PacketInterpreterBase::ptr packet) template prefix_ senf::PacketInterpreterBase::ptr senf::PacketInterpreter::FactoryImpl:: -createBefore(PacketInterpreterBase::ptr packet, senf::NoInit_t) +createBefore(PacketInterpreterBase::ptr const & packet, senf::NoInit_t) const { return senf::PacketInterpreter::createBefore(packet,senf::noinit); @@ -359,7 +358,7 @@ createBefore(PacketInterpreterBase::ptr packet, senf::NoInit_t) template prefix_ senf::PacketInterpreterBase::ptr senf::PacketInterpreter::FactoryImpl:: -createInsertBefore(PacketInterpreterBase::ptr packet) +createInsertBefore(PacketInterpreterBase::ptr const & packet) const { return senf::PacketInterpreter::createInsertBefore(packet); @@ -368,7 +367,7 @@ createInsertBefore(PacketInterpreterBase::ptr packet) template prefix_ senf::PacketInterpreterBase::ptr senf::PacketInterpreter::FactoryImpl:: -createInsertBefore(PacketInterpreterBase::ptr packet, senf::NoInit_t) +createInsertBefore(PacketInterpreterBase::ptr const & packet, senf::NoInit_t) const { return senf::PacketInterpreter::createInsertBefore(packet,senf::noinit); @@ -378,17 +377,16 @@ createInsertBefore(PacketInterpreterBase::ptr packet, senf::NoInit_t) template prefix_ typename senf::PacketInterpreterBase::ptr -senf::PacketInterpreter::FactoryImpl::parseNext(PacketInterpreterBase::ptr packet) +senf::PacketInterpreter::FactoryImpl::parseNext(PacketInterpreterBase::ptr const & packet, PacketInterpreterBase::optional_range const & range) const { - optional_range r (packet->nextPacketRange()); - if (!r) + if (!range) throw InvalidPacketChainException(); if (packet->next()) packet->impl().truncateInterpreters(packet->next().get()); - return senf::PacketInterpreter::create(&packet->impl(),r->begin(),r->end(),Append); + return senf::PacketInterpreter::create(&packet->impl(),range->begin(),range->end(),Append); } template