NanoPBHelper.cpp 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  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. pb_bytes_array_t* vectorToPbArray(const std::vector<uint8_t>& vectorToPack)
  31. {
  32. auto size = static_cast<pb_size_t>(vectorToPack.size());
  33. auto result = static_cast<pb_bytes_array_t *>(
  34. malloc(PB_BYTES_ARRAY_T_ALLOCSIZE(size)));
  35. result->size = size;
  36. memcpy(result->bytes, vectorToPack.data(), size);
  37. return result;
  38. }
  39. std::vector<uint8_t> pbArrayToVector(pb_bytes_array_t* pbArray) {
  40. return std::vector<uint8_t>(pbArray->bytes, pbArray->bytes + pbArray->size);
  41. }
  42. const char *pb_encode_to_string(const pb_msgdesc_t *fields, const void *data) {
  43. size_t len;
  44. pb_get_encoded_size(&len, fields, data);
  45. auto *buf = static_cast<uint8_t *>(malloc(len + 1));
  46. auto ostream = pb_ostream_from_buffer(buf, len);
  47. pb_encode(&ostream, fields, data);
  48. buf[len] = '\0';
  49. return reinterpret_cast<const char *>(buf);
  50. }
  51. static bool pb_read_from_http(pb_istream_t *stream, pb_byte_t *buf, size_t count) {
  52. auto *response = (bell::HTTPClient::HTTPResponse *)stream->state;
  53. size_t len = response->read(buf, count, /* wait */ true);
  54. if (response->isComplete)
  55. stream->bytes_left = count; // count is subtracted after the callback
  56. return len == count;
  57. }
  58. pb_istream_t pb_istream_from_http(bell::HTTPClient::HTTPResponse *response, size_t length) {
  59. if (!length)
  60. length = response->contentLength;
  61. if (!length)
  62. length = SIZE_MAX;
  63. return {
  64. .callback = &pb_read_from_http,
  65. .state = response,
  66. .bytes_left = length,
  67. };
  68. }