X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Packets%2F80221Bundle%2FTLVPacket.cc;h=3bf20396de9f29e63d35be2a6b57dfea29c5a1c4;hb=eb89ea10c8c11d2ef12239cb037c958dec50f006;hp=177a2e1ca051b3e9af62d6b2c9c3d64cb7cab2bf;hpb=bd67664cb4ea1b36c9bb52a622e02341e4f0131f;p=senf.git diff --git a/Packets/80221Bundle/TLVPacket.cc b/Packets/80221Bundle/TLVPacket.cc index 177a2e1..3bf2039 100644 --- a/Packets/80221Bundle/TLVPacket.cc +++ b/Packets/80221Bundle/TLVPacket.cc @@ -127,25 +127,24 @@ prefix_ void senf::DynamicTLVLengthParser::shrink() } -prefix_ void senf::BaseTLVPacketParser:: maxLengthValue(DynamicTLVLengthParser::value_type v) - const +prefix_ void senf::DynamicTLVLengthParser:: maxValue(DynamicTLVLengthParser::value_type v) { if (v <= 127) return; - size_type b = senf::bytes( length_()); + size_type b = bytes(); if (v <= UInt8Parser::max_value) { - if (b < 2) length_().resize(2); + if (b < 2) resize(2); return; } if (v <= UInt16Parser::max_value) { - if (b < 3) length_().resize(3); + if (b < 3) resize(3); return; } if (v <= UInt24Parser::max_value) { - if (b < 4) length_().resize(4); + if (b < 4) resize(4); return; } - if (b < 5) length_().resize(5); + if (b < 5) resize(5); } @@ -164,11 +163,10 @@ prefix_ void senf::DynamicTLVLengthParser::resize(size_type size) size_type current_size (bytes()); SafePacketParserWrapper safeThis (*this); - safe_data_iterator si (data(), i()); if (current_size > size) - data().erase( si, boost::next(si, current_size-size)); + data().erase( i(), boost::next(i(), current_size-size)); else - data().insert( si, size-current_size, 0); + data().insert( i(), size-current_size, 0); if (size > 1) { safeThis->extended_length_flag() = true; @@ -176,7 +174,7 @@ prefix_ void senf::DynamicTLVLengthParser::resize(size_type size) } else { safeThis->extended_length_flag() = false; } - value(v); + safeThis->value(v); } @@ -186,7 +184,9 @@ prefix_ void senf::GenericTLVPacketType::dump(packet p, std::ostream & os) os << "GenericTLVPacket:\n" << std::dec << " type: " << unsigned( p->type()) << "\n" - << " length: " << unsigned( p->length()) << "\n"; + << " length: " << unsigned( p->length()) << "\n" + << " value\n:"; + senf::hexdump( p->value().begin(), p->value().end(), os); }