X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Packets%2FPacketImpl.cti;h=e3ec1eaf16fd7995add8f6c1bab119b55bc5e0fd;hb=6fecbc9f068fc7c391f5f23d2c7ff37f61f1ff2d;hp=21956f18c3c105298179e0d5abdebf987aa188ce;hpb=9348e1098d66ac2684c8e280abf8d7143c887982;p=senf.git diff --git a/Packets/PacketImpl.cti b/Packets/PacketImpl.cti index 21956f1..e3ec1ea 100644 --- a/Packets/PacketImpl.cti +++ b/Packets/PacketImpl.cti @@ -38,6 +38,21 @@ prefix_ senf::detail::AnnotationIndexer::AnnotationIndexer() : index_ (maxAnnotations++) { small().push_back(Small); + registry().push_back(this); +} + +/////////////////////////////////////////////////////////////////////////// +// senf::detail::AnnotationIndexer + + +template +prefix_ void senf::detail::AnnotationIndexer::v_dump(PacketImpl * p, + std::ostream & os) +{ + + os << " " << senf::prettyName(typeid(Annotation)) << ": "; + p->dumpAnnotation(os); + os << "\n"; } template @@ -50,20 +65,33 @@ prefix_ unsigned senf::detail::AnnotationIndexer::index() // senf::detail::GetAnnotation template -prefix_ Annotation & senf::detail::GetAnnotation::get(AnnotationP * & p) +prefix_ Annotation & senf::detail::GetAnnotation::get(AnnotationEntry & e) { - if (!p) - p = new TAnnotationP(); - return static_cast< TAnnotationP* >(p)->annotation; + if (!e.p) + e.p = new TAnnotationP(); + return static_cast< TAnnotationP* >(e.p)->annotation; +} + +template +prefix_ void senf::detail::GetAnnotation::dump(AnnotationEntry & e, + std::ostream & os) +{ + if (!e.p) os << "no value"; + else os << get(e); +} + +template +prefix_ Annotation & senf::detail::GetAnnotation::get(AnnotationEntry & e) +{ + return * static_cast(static_cast(& e.i)); } -/* template -prefix_ Annotation & senf::detail::GetAnnotation::get(AnnotationP * & p) +prefix_ void senf::detail::GetAnnotation::dump(AnnotationEntry & e, + std::ostream & os) { - return * reinterpret_cast(p); + os << get(e); } -*/ /////////////////////////////////////////////////////////////////////////// // senf::detail::PacketImpl @@ -81,7 +109,7 @@ prefix_ void senf::detail::PacketImpl::insert(PacketData * self, iterator pos, F template prefix_ senf::detail::PacketImpl::PacketImpl(InputIterator first, InputIterator last) - : refcount_(0), data_(first,last), annotations_(AnnotationIndexerBase::maxAnnotations, 0) + : refcount_(0), data_(first,last), annotations_(AnnotationIndexerBase::maxAnnotations) {} // Annotations @@ -93,6 +121,13 @@ prefix_ Annotation & senf::detail::PacketImpl::annotation() annotations_[AnnotationIndexer::index()]); } +template +prefix_ void senf::detail::PacketImpl::dumpAnnotation(std::ostream & os) +{ + GetAnnotation::dump( + annotations_[AnnotationIndexer::index()], os); +} + ///////////////////////////////cti.e/////////////////////////////////////// #undef prefix_