NanoPBHelper.cpp 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. #include "NanoPBHelper.h"
  2. static bool vectorWrite(pb_ostream_t *stream, const pb_byte_t *buf, size_t count)
  3. {
  4. size_t i;
  5. auto *dest = reinterpret_cast<std::vector<uint8_t> *>(stream->state);
  6. dest->insert(dest->end(), buf, buf + count);
  7. return true;
  8. }
  9. pb_ostream_t pb_ostream_from_vector(std::vector<uint8_t> &vec)
  10. {
  11. pb_ostream_t stream;
  12. stream.callback = &vectorWrite;
  13. stream.state = &vec;
  14. stream.max_size = 100000;
  15. stream.bytes_written = 0;
  16. return stream;
  17. }
  18. std::vector<uint8_t> pbEncode(const pb_msgdesc_t *fields, const void *src_struct)
  19. {
  20. std::vector<uint8_t> vecData(0);
  21. pb_ostream_t stream = pb_ostream_from_vector(vecData);
  22. pb_encode(&stream, fields, src_struct);
  23. return vecData;
  24. }
  25. void packString(char *&dst, std::string stringToPack)
  26. {
  27. dst = (char *)malloc((strlen(stringToPack.c_str()) + 1) * sizeof(char));
  28. strcpy(dst, stringToPack.c_str());
  29. }
  30. void pbFree(const pb_msgdesc_t *fields, void *src_struct) {
  31. pb_release(fields, src_struct);
  32. }
  33. pb_bytes_array_t* vectorToPbArray(const std::vector<uint8_t>& vectorToPack)
  34. {
  35. auto size = static_cast<pb_size_t>(vectorToPack.size());
  36. auto result = static_cast<pb_bytes_array_t *>(
  37. malloc(PB_BYTES_ARRAY_T_ALLOCSIZE(size)));
  38. result->size = size;
  39. memcpy(result->bytes, vectorToPack.data(), size);
  40. return result;
  41. }
  42. std::vector<uint8_t> pbArrayToVector(pb_bytes_array_t* pbArray) {
  43. return std::vector<uint8_t>(pbArray->bytes, pbArray->bytes + pbArray->size);
  44. }