Packets: added GenericTLVParserRegistry
[senf.git] / senf / Packets / DefaultBundle / ICMPv6TypePacket.cc
index a995c38..c7f18c0 100644 (file)
@@ -23,7 +23,6 @@
 // Definition of non-inline non-template functions
 
 // Custom includes
-#include <boost/io/ios_state.hpp>
 #include <senf/Packets/Packets.hh>
 #include "ICMPv6Packet.hh"
 #include "ICMPv6TypePacket.hh"
 #define prefix_
 ///////////////////////////////cc.p////////////////////////////////////////
 
-#ifndef DOXYGEN
-
-SENF_PACKET_REGISTRY_REGISTER( senf::ICMPTypes, 1,   senf::ICMPv6ErrDestUnreachable );
-SENF_PACKET_REGISTRY_REGISTER( senf::ICMPTypes, 2,   senf::ICMPv6ErrTooBig          );
-SENF_PACKET_REGISTRY_REGISTER( senf::ICMPTypes, 3,   senf::ICMPv6ErrTimeExceeded    );
-SENF_PACKET_REGISTRY_REGISTER( senf::ICMPTypes, 4,   senf::ICMPv6ErrParamProblem    );
-SENF_PACKET_REGISTRY_REGISTER( senf::ICMPTypes, 128, senf::ICMPv6EchoRequest        );
-SENF_PACKET_REGISTRY_REGISTER( senf::ICMPTypes, 129, senf::ICMPv6EchoReply          );
-SENF_PACKET_REGISTRY_REGISTER( senf::ICMPTypes, 130, senf::MLDv2ListenerQuery       );
-SENF_PACKET_REGISTRY_REGISTER( senf::ICMPTypes, 143, senf::MLDv2ListenerReport      );
-
-#endif
+namespace {
+    SENF_PACKET_REGISTRY_REGISTER( senf::ICMPTypes, 1,   senf::ICMPv6ErrDestUnreachable );
+    SENF_PACKET_REGISTRY_REGISTER( senf::ICMPTypes, 2,   senf::ICMPv6ErrTooBig          );
+    SENF_PACKET_REGISTRY_REGISTER( senf::ICMPTypes, 3,   senf::ICMPv6ErrTimeExceeded    );
+    SENF_PACKET_REGISTRY_REGISTER( senf::ICMPTypes, 4,   senf::ICMPv6ErrParamProblem    );
+    SENF_PACKET_REGISTRY_REGISTER( senf::ICMPTypes, 128, senf::ICMPv6EchoRequest        );
+    SENF_PACKET_REGISTRY_REGISTER( senf::ICMPTypes, 129, senf::ICMPv6EchoReply          );
+    SENF_PACKET_REGISTRY_REGISTER( senf::ICMPTypes, 130, senf::MLDv2ListenerQuery       );
+    SENF_PACKET_REGISTRY_REGISTER( senf::ICMPTypes, 143, senf::MLDv2ListenerReport      );
+}
 
 prefix_ void senf::ICMPv6EchoRequestType::dump(packet p, std::ostream & os)
 {
-    boost::io::ios_all_saver ias(os);
     os << "ICMPv6 Echo Request:\n"
-       <<     "  identifier              : " << p->identifier() << "\n"
-       <<     "  sequence nr.            : " << p->seqNr() << "\n";
+       << senf::fieldName("Identifier")         << unsigned(p->identifier()) << "\n"
+       << senf::fieldName("SequenceNumber")     << unsigned(p->seqNr() ) << "\n";
 }
 
-///////////////////////////////cc.e////////////////////////////////////////
-#undef prefix_
+prefix_ void senf::ICMPv6EchoReplyType::dump(packet p, std::ostream & os)
+{
+    os << "ICMPv6 Echo Reply:\n"
+       << senf::fieldName("Identifier")         << unsigned(p->identifier()) << "\n"
+       << senf::fieldName("SequenceNumber")     << unsigned(p->seqNr()) << "\n";
+}
+
+prefix_ void senf::ICMPv6ErrDestUnreachableType::dump(packet p, std::ostream & os)
+{
+    os << "ICMPv6 Error Destination Unreachable (no further fields available here)\n";    
+}
+
+prefix_ void senf::ICMPv6ErrTooBigType::dump(packet p, std::ostream & os)
+{
+    os << "ICMPv6 Error Packet Too Big:\n"
+       << senf::fieldName("MTU")            << unsigned(p->mtu() ) << "\n";    
+}
 
+prefix_ void senf::ICMPv6ErrTimeExceededType::dump(packet p, std::ostream & os)
+{
+    os << "ICMPv6 Error Time Exceeded:\n"
+       << senf::fieldName("Unused(32Bit)")  << unsigned(p->unused() ) << "\n";    
+}
 
-// Local Variables:
-// mode: c++
-// fill-column: 100
-// c-file-style: "senf"
-// indent-tabs-mode: nil
-// ispell-local-dictionary: "american"
-// compile-command: "scons -u test"
-// comment-column: 40
-// End:
+prefix_ void senf::ICMPv6ErrParamProblemType::dump(packet p, std::ostream & os)
+{
+    os << "ICMPv6 Error Parameter Problem:\n"
+       << senf::fieldName("Pointer")        << unsigned(p->pointer() ) << "\n";    
+}
+
+prefix_ void senf::MLDv2ListenerQueryType::dump(packet p, std::ostream & os)
+{
+    os << "ICMPv6 Multicast Listener Query:\n"
+       << senf::fieldName("Max. ResponseCode")         << unsigned(p->maxResponseCode()) << "\n"
+       << senf::fieldName("Reserved(16Bit)")           << unsigned(p->reserved()) << "\n"
+       << senf::fieldName("Multicast Address")         << p->mcAddress() << "\n"
+       << senf::fieldName("Reserver(4Bit)")            << unsigned(p->resv()) << "\n"
+       << senf::fieldName("Suppress Router-Side Processing") << unsigned(p->sFlag()) << "\n"
+       << senf::fieldName("Querier's Robustness Variable") << unsigned(p->qrv()) << "\n"
+       << senf::fieldName("Querier's Query Interval Code") << unsigned(p->qqic()) << "\n"
+       << "  Source Addresses:\n";
+    senf::MLDv2ListenerQuery::Parser::srcAddresses_t::container c (p->srcAddresses());
+    senf::MLDv2ListenerQuery::Parser::srcAddresses_t::container::iterator i (c.begin());
+    for (unsigned int nr =1; i != c.end(); ++i, ++nr)
+        os << "    " << nr << ".) " << *i << "\n";    
+    os << "\n";    
+}
+
+prefix_ void senf::MLDv2ListenerReportType::dump(packet p, std::ostream & os)
+{
+    os << "ICMPv6 Multicast Listener Report Message:\n"
+       << senf::fieldName("Reserved")              << unsigned(p->reserved() ) 
+       <<"\n  Multicast Address Records:\n";
+    
+    senf::MLDv2ListenerReport::Parser::mcastAddrRecords_t::container cAddrR (p->mcastAddrRecords() );
+    senf::MLDv2ListenerReport::Parser::mcastAddrRecords_t::container::iterator iAddrR (cAddrR.begin() );
+    for (; iAddrR != cAddrR.end(); ++iAddrR) {
+        os << senf::fieldName("  Record Type")         << unsigned(iAddrR->recordType()) << "\n"
+           << senf::fieldName("  Multicast Address")   << iAddrR->mcAddress() << "\n"
+           << "    Source Addresses\n:";
+        senf::MLDv2AddressRecordParser::srcAddresses_t::container cSrcAddr (iAddrR->srcAddresses());
+        senf::MLDv2AddressRecordParser::srcAddresses_t::container::iterator iSrcAddr (cSrcAddr.begin());
+        for (;iSrcAddr != cSrcAddr.end();++iSrcAddr)
+            os << "      " << *iSrcAddr << "\n";
+        os << "    Auxiliary Data:\n";
+        senf::MLDv2AddressRecordParser::auxData_t::container cAuxD ( iAddrR->auxData() );
+        senf::MLDv2AddressRecordParser::auxData_t::container::iterator iAuxD (cAuxD.begin() );
+        for (;iAuxD != cAuxD.end(); ++iAuxD)
+            os << "      " << *iAuxD << "\n";
+    }
+}
+
+///////////////////////////////cc.e////////////////////////////////////////
+#undef prefix_