.. _program_listing_file__tmp_ws_src_kobuki_core_include_kobuki_core_packets_unique_device_id.hpp: Program Listing for File unique_device_id.hpp ============================================= |exhale_lsh| :ref:`Return to documentation for file ` (``/tmp/ws/src/kobuki_core/include/kobuki_core/packets/unique_device_id.hpp``) .. |exhale_lsh| unicode:: U+021B0 .. UPWARDS ARROW WITH TIP LEFTWARDS .. code-block:: cpp /***************************************************************************** ** Preprocessor *****************************************************************************/ #ifndef KOBUKI_CORE_UDID_DATA_HPP__ #define KOBUKI_CORE_UDID_DATA_HPP__ /***************************************************************************** ** Include *****************************************************************************/ #include "../packet_handler/payload_base.hpp" #include "../packet_handler/payload_headers.hpp" /***************************************************************************** ** Namespace *****************************************************************************/ namespace kobuki { /***************************************************************************** ** Interface *****************************************************************************/ class UniqueDeviceID : public packet_handler::payloadBase { public: UniqueDeviceID() : packet_handler::payloadBase(false, 12) {}; struct Data { uint32_t udid0; uint32_t udid1; uint32_t udid2; } data; // methods bool serialise(ecl::PushAndPop & byteStream) { buildBytes(Header::UniqueDeviceID, byteStream); buildBytes(length, byteStream); buildBytes(data.udid0, byteStream); buildBytes(data.udid1, byteStream); buildBytes(data.udid2, byteStream); return true; } bool deserialise(ecl::PushAndPop & byteStream) { if (byteStream.size() < static_cast(length)+2) { //std::cout << "kobuki_node: kobuki_udid: deserialise failed. not enough byte stream." << std::endl; return false; } unsigned char header_id(0x00), length_packed(0x00); buildVariable(header_id, byteStream); buildVariable(length_packed, byteStream); if( header_id != Header::UniqueDeviceID ) return false; if( length_packed != length ) return false; buildVariable(data.udid0, byteStream); buildVariable(data.udid1, byteStream); buildVariable(data.udid2, byteStream); //showMe(); return constrain(); } bool constrain() { return true; } void showMe() { } }; } // namespace kobuki #endif /* KOBUKI_CORE_UDID_DATA_HPP__ */