#include "log_field.h" #include static void memcpy_swapend(void* dest, const void* src, size_t num) { const char* src2 = reinterpret_cast(src); char* dest2 = reinterpret_cast(dest); for (size_t i = 0; i < num; i++) { // Endian swap - copy the end to the beginning dest2[i] = src2[num - 1 - i]; } } static void copyFloat(char* buffer, float value) { memcpy_swapend(buffer, reinterpret_cast(&value), sizeof(float)); } size_t LogField::writeHeader(char* buffer) const { // Offset 0, length 1 = type buffer[0] = static_cast(m_type); // Offset 0, length 34 = name strncpy(&buffer[1], m_name, 34); // Offset 35, length 10 = units strncpy(&buffer[35], m_units, 10); // Offset 45, length 1 = Display style // value 0 -> floating point number buffer[45] = 0; // Offset 46, length 4 = Scale copyFloat(buffer + 46, 1.0f / m_multiplier); // Offset 50, length 4 = shift before scaling (always 0) copyFloat(buffer + 50, 0); // Offset 54, size 1 = digits to display (signed int) buffer[54] = m_digits; // Total size = 55 return 55; } size_t LogField::writeData(char* buffer) const { size_t size = m_size; memcpy_swapend(buffer, m_addr, size); return size; }