X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FPackets%2FPacketInterpreter.cc;h=62b912c7ffed0bb7f1d2cb18e76d8eea0631d881;hb=961cf85a6abf2b5f0a7958bbfcd8f72e7b32721b;hp=fcd67832e80af72ab642dfcc5f01e4c8c54165a6;hpb=601d1f509f5bb24df167a4dd5a20da67a0af9af8;p=senf.git diff --git a/senf/Packets/PacketInterpreter.cc b/senf/Packets/PacketInterpreter.cc index fcd6783..62b912c 100644 --- a/senf/Packets/PacketInterpreter.cc +++ b/senf/Packets/PacketInterpreter.cc @@ -55,11 +55,11 @@ prefix_ senf::PacketInterpreterBase::ptr senf::PacketInterpreterBase::append(ptr { if (next()) impl().truncateInterpreters(next().get()); - + optional_range r (nextPacketRange()); if (!r) throw InvalidPacketChainException(); - + ptr rv (packet->appendClone(&impl(), *r)); rv->data().resize(packet->data().size()); std::copy(packet->data().begin(), packet->data().end(), rv->data().begin()); @@ -74,13 +74,19 @@ prefix_ senf::PacketInterpreterBase::ptr senf::PacketInterpreterBase::append(ptr prefix_ void senf::PacketInterpreterBase::dump(std::ostream & os) { - if (detail::AnnotationIndexerBase::maxAnnotations > 0) { - os << "Annotations:\n"; - impl().dumpAnnotations(os); + try { + if (detail::AnnotationRegistry::instance().begin() + != detail::AnnotationRegistry::instance().end()) { + os << "Annotations:\n"; + impl().dumpAnnotations(os); + } + v_dump(os); + for (ptr i (next()); i; i = i->next()) + i->v_dump(os); + } + catch (senf::Exception & e) { + os << "[Exception: " << e.message() << "]\n"; } - v_dump(os); - for (ptr i (next()); i; i = i->next()) - i->v_dump(os); } prefix_ void senf::PacketInterpreterBase::finalizeThis()