From 222c810b07ffc635fc7908d121e97e4d65ccc5c8 Mon Sep 17 00:00:00 2001 From: jacqueline Date: Fri, 2 Dec 2022 13:39:00 +1100 Subject: fix build errors --- src/cbor_wrapper/cbor_decoder.cpp | 112 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 112 insertions(+) create mode 100644 src/cbor_wrapper/cbor_decoder.cpp (limited to 'src/cbor_wrapper/cbor_decoder.cpp') diff --git a/src/cbor_wrapper/cbor_decoder.cpp b/src/cbor_wrapper/cbor_decoder.cpp new file mode 100644 index 00000000..a99cca02 --- /dev/null +++ b/src/cbor_wrapper/cbor_decoder.cpp @@ -0,0 +1,112 @@ +#include "cbor_decoder.hpp" + +#include +#include + +#include "cbor.h" +#include "result.hpp" + +static const int kDecoderFlags = 0; + +namespace cbor { + +auto parse_stdstring(const CborValue* val, std::string* out) -> CborError { + char* buf; + size_t len; + CborError err = cbor_value_dup_text_string(val, &buf, &len, NULL); + if (err != CborNoError) { + return err; + } + *out = std::string(buf, len); + free(buf); + return err; +} + +auto ArrayDecoder::Create(uint8_t* buffer, size_t buffer_len) + -> cpp::result, CborError> { + auto decoder = std::make_unique(); + cbor_parser_init(buffer, buffer_len, kDecoderFlags, &decoder->parser_, + &decoder->root_); + if (!cbor_value_is_array(&decoder->root_)) { + return cpp::fail(CborErrorIllegalType); + } + CborError err = cbor_value_enter_container(&decoder->root_, &decoder->it_); + if (err != CborNoError) { + return cpp::fail(err); + } + return std::move(decoder); +} + +auto ArrayDecoder::Create(CborValue& root) + -> cpp::result, CborError> { + auto decoder = std::make_unique(); + decoder->root_ = root; + if (!cbor_value_is_array(&decoder->root_)) { + return cpp::fail(CborErrorIllegalType); + } + + CborError err = cbor_value_enter_container(&decoder->root_, &decoder->it_); + if (err != CborNoError) { + return cpp::fail(err); + } + return std::move(decoder); +} + +template <> +auto ArrayDecoder::NextValue() -> cpp::result { + return NextValue(&cbor_value_is_integer, &cbor_value_get_int); +} +template <> +auto ArrayDecoder::NextValue() -> cpp::result { + return NextValue(&cbor_value_is_unsigned_integer, &cbor_value_get_uint64); +} +template <> +auto ArrayDecoder::NextValue() -> cpp::result { + return NextValue(&cbor_value_is_byte_string, &parse_stdstring); +} + +auto MapDecoder::Create(uint8_t* buffer, size_t buffer_len) + -> cpp::result, CborError> { + auto decoder = std::make_unique(); + cbor_parser_init(buffer, buffer_len, kDecoderFlags, &decoder->parser_, + &decoder->root_); + if (!cbor_value_is_map(&decoder->root_)) { + return cpp::fail(CborErrorIllegalType); + } + CborError err = cbor_value_enter_container(&decoder->root_, &decoder->it_); + if (err != CborNoError) { + return cpp::fail(err); + } + return std::move(decoder); +} + +auto MapDecoder::Create(CborValue& root) + -> cpp::result, CborError> { + auto decoder = std::make_unique(); + decoder->root_ = root; + if (!cbor_value_is_map(&decoder->root_)) { + return cpp::fail(CborErrorIllegalType); + } + CborError err = cbor_value_enter_container(&decoder->root_, &decoder->it_); + if (err != CborNoError) { + return cpp::fail(err); + } + return std::move(decoder); +} + +template <> +auto MapDecoder::FindValue(const std::string& key) -> std::optional { + return FindValue(key, &cbor_value_is_integer, &cbor_value_get_int); +} +template <> +auto MapDecoder::FindValue(const std::string& key) -> std::optional { + return FindValue(key, &cbor_value_is_unsigned_integer, + &cbor_value_get_uint64); +} +template <> +auto MapDecoder::FindValue(const std::string& key) + -> std::optional { + return FindValue(key, &cbor_value_is_byte_string, &parse_stdstring); +} + +} // namespace cbor -- cgit v1.2.3