#include <boost/io/ios_state.hpp>
#define prefix_
+///////////////////////////////cc.p////////////////////////////////////////
-prefix_ std::string senf::MIHFId_TLVParser::asString()
- const
-{
- return std::string( i(1+length_bytes()), i(1+length_bytes()+length()) );
-}
+
+///////////////////////////////////////////////////////////////////////////
+// MIHFId_TLVParser
prefix_ void senf::MIHFId_TLVParser::setString(std::string const &id)
{
// the maximum length of a MIHF_ID is 253 octets (see F.3.11 in 802.21)
if (str_size > 253)
throw std::length_error("maximum length of a MIHF_ID is 253 octets");
- safe_data_iterator si = resizeValue( str_size);
+ safe_data_iterator si = resizeValueField( str_size);
std::copy( id.begin(), id.end(), si);
}
-
-prefix_ senf::MACAddress senf::MIHFId_TLVParser::asMACAddress()
- const
-{
- return MACAddress::from_data(
- getNAIDecodedIterator( i(1+length_bytes()), i(1+length_bytes()+12) ));
-}
-
prefix_ void senf::MIHFId_TLVParser::setMACAddress(senf::MACAddress const &mac)
{
- safe_data_iterator si = resizeValue(12);
+ safe_data_iterator si = resizeValueField(12);
std::copy( mac.begin(), mac.end(), getNAIEncodedOutputIterator(si));
}
-
-prefix_ senf::INet4Address senf::MIHFId_TLVParser::asINet4Address()
- const
+prefix_ void senf::MIHFId_TLVParser::setINet4Address(senf::INet4Address const &addr)
{
- return INet4Address::from_data(
- getNAIDecodedIterator( i(1+length_bytes()), i(1+length_bytes()+8) ));
+ safe_data_iterator si = resizeValueField(8);
+ std::copy( addr.begin(), addr.end(), getNAIEncodedOutputIterator(si));
}
-prefix_ void senf::MIHFId_TLVParser::setINet4Address(senf::INet4Address const &addr)
+prefix_ void senf::MIHFId_TLVParser::setINet6Address(senf::INet6Address const &addr)
{
- safe_data_iterator si = resizeValue(8);
+ safe_data_iterator si = resizeValueField(32);
std::copy( addr.begin(), addr.end(), getNAIEncodedOutputIterator(si));
}
-prefix_ senf::INet6Address senf::MIHFId_TLVParser::asINet6Address()
- const
+prefix_ void senf::MIHFId_TLVParser::setEUI64(senf::EUI64 const &addr)
{
- return INet6Address::from_data(
- getNAIDecodedIterator( i(1+length_bytes()), i(1+length_bytes()+32) ));
+ safe_data_iterator si = resizeValueField(16);
+ std::copy( addr.begin(), addr.end(), getNAIEncodedOutputIterator(si));
}
-prefix_ void senf::MIHFId_TLVParser::setINet6Address(senf::INet6Address const &addr)
+prefix_ senf::MIHFId senf::MIHFId_TLVParser::valueAs(MIHFId::Type type)
+ const
{
- safe_data_iterator si = resizeValue(32);
- std::copy( addr.begin(), addr.end(), getNAIEncodedOutputIterator(si));
+ if (length() == 0) return MIHFId();
+ switch (type) {
+ case MIHFId::Empty:
+ return MIHFId();
+ case MIHFId::MACAddress:
+ return MIHFId( asMACAddress());
+ case MIHFId::INet4Address:
+ return MIHFId( asINet4Address());
+ case MIHFId::INet6Address:
+ return MIHFId( asINet6Address());
+ case MIHFId::String:
+ return MIHFId( asINet6Address());
+ case MIHFId::EUI64:
+ return MIHFId( asINet6Address());
+ }
+ return MIHFId();
}
+///////////////////////////////////////////////////////////////////////////
+// MIHPacketType
+
prefix_ void senf::MIHPacketType::dump(packet p, std::ostream &os)
{
boost::io::ios_all_saver ias(os);
os << "MIH Packet:\n"
- << " protocol header:\n"
- << " Version: " << unsigned( p->version()) << "\n"
- << " Ack-Request: " << p->ackRequest() << "\n"
- << " Ack-Response: " << p->ackResponse() << "\n"
- << " UIR: " << p->uir() << "\n"
- << " more fragment: " << p->moreFragment() << "\n"
- << " fragment number: " << p->fragmentNr() << "\n"
- << " message ID (MID):\n"
- << " SID: " << unsigned( p->sid()) << "\n"
- << " Opcode: " << unsigned( p->opcode()) << "\n"
- << " AID: " << unsigned( p->aid()) << "\n"
- << " Transaction ID: " << unsigned( p->transactionId()) << "\n"
- << " payload length: " << unsigned( p->payloadLength()) << "\n"
- << " source MIHF_Id TLV:\n"
- << " type: " << unsigned (p->src_mihfId().type()) << "\n"
- << " length: " << unsigned (p->src_mihfId().length()) << "\n"
- << " value:\n";
+ << " protocol header:\n"
+ << " version : " << unsigned( p->version()) << "\n"
+ << " ack request : " << p->ackRequest() << "\n"
+ << " ack response : " << p->ackResponse() << "\n"
+ << " UIR : " << p->uir() << "\n"
+ << " more fragments : " << p->moreFragment() << "\n"
+ << " fragment number : " << p->fragmentNr() << "\n"
+ << " message ID (MID) : " << unsigned( p->messageId()) << "\n"
+ << " sid : " << unsigned( p->sid()) << "\n"
+ << " opcode : " << unsigned( p->opcode()) << "\n"
+ << " aid : " << unsigned( p->aid()) << "\n"
+ << " transaction id : " << unsigned( p->transactionId()) << "\n"
+ << " payload length : " << unsigned( p->payloadLength()) << "\n"
+ << " source MIHF_Id TLV :\n"
+ << " type : " << unsigned (p->src_mihfId().type()) << "\n"
+ << " length : " << unsigned (p->src_mihfId().length()) << "\n"
+ << " value :\n";
std::string src_mihfId (p->src_mihfId().asString());
hexdump(src_mihfId.begin(), src_mihfId.end(), os);
- os << " destination MIHF_Id TLV:\n"
- << " type: " << unsigned (p->dst_mihfId().type()) << "\n"
- << " length: " << unsigned (p->dst_mihfId().length()) << "\n"
- << " value:\n";
+ os << " destination MIHF_Id TLV:\n"
+ << " type : " << unsigned (p->dst_mihfId().type()) << "\n"
+ << " length : " << unsigned (p->dst_mihfId().length()) << "\n"
+ << " value :\n";
std::string dst_mihfId (p->dst_mihfId().asString());
hexdump(dst_mihfId.begin(), dst_mihfId.end(), os);
}
-
prefix_ void senf::MIHPacketType::finalize(packet p)
{
- p->src_mihfId().shrinkLength();
- p->dst_mihfId().shrinkLength();
+ p->src_mihfId().finalizeLength();
+ p->dst_mihfId().finalizeLength();
p->payloadLength_() << p.size() - 8;
+ p->messageId() << key(p.next(nothrow));
}
-
prefix_ senf::PacketInterpreterBase::factory_t senf::MIHPacketType::nextPacketType(packet p)
{
- return MIHPayloadPacket::factory();
+ if (p.data().size() < initSize())
+ return no_factory();
+ PkReg_Entry const * e (PacketRegistry<MIHMessageRegistry>::lookup( p->messageId(), nothrow ));
+ return e ? e->factory() : MIHPayloadPacket::factory();
}
-
prefix_ void senf::MIHPayloadPacketType::dump(packet p, std::ostream &os)
{
boost::io::ios_all_saver ias(os);
- os << "MIH Payload (service specific TLVs):\n";
+ os << "MIH Payload (service specific TLVs):\n"
+ << " ToDo!\n";
}
-
+///////////////////////////////cc.e////////////////////////////////////////
#undef prefix_
\f