| // Protocol Buffers - Google's data interchange format |
| // Copyright 2023 Google LLC. All rights reserved. |
| // |
| // Use of this source code is governed by a BSD-style |
| // license that can be found in the LICENSE file or at |
| // https://developers.google.com/open-source/licenses/bsd |
| |
| #ifndef UPB_MINI_DESCRIPTOR_INTERNAL_DECODER_H_ |
| #define UPB_MINI_DESCRIPTOR_INTERNAL_DECODER_H_ |
| |
| #include "upb/base/status.h" |
| #include "upb/mini_descriptor/internal/base92.h" |
| |
| // Must be last. |
| #include "upb/port/def.inc" |
| |
| // upb_MdDecoder: used internally for decoding MiniDescriptors for messages, |
| // extensions, and enums. |
| typedef struct { |
| const char* end; |
| upb_Status* status; |
| jmp_buf err; |
| } upb_MdDecoder; |
| |
| UPB_PRINTF(2, 3) |
| UPB_NORETURN UPB_INLINE void upb_MdDecoder_ErrorJmp(upb_MdDecoder* d, |
| const char* fmt, ...) { |
| if (d->status) { |
| va_list argp; |
| upb_Status_SetErrorMessage(d->status, "Error building mini table: "); |
| va_start(argp, fmt); |
| upb_Status_VAppendErrorFormat(d->status, fmt, argp); |
| va_end(argp); |
| } |
| UPB_LONGJMP(d->err, 1); |
| } |
| |
| UPB_INLINE void upb_MdDecoder_CheckOutOfMemory(upb_MdDecoder* d, |
| const void* ptr) { |
| if (!ptr) upb_MdDecoder_ErrorJmp(d, "Out of memory"); |
| } |
| |
| UPB_INLINE const char* upb_MdDecoder_DecodeBase92Varint( |
| upb_MdDecoder* d, const char* ptr, char first_ch, uint8_t min, uint8_t max, |
| uint32_t* out_val) { |
| ptr = _upb_Base92_DecodeVarint(ptr, d->end, first_ch, min, max, out_val); |
| if (!ptr) upb_MdDecoder_ErrorJmp(d, "Overlong varint"); |
| return ptr; |
| } |
| |
| #include "upb/port/undef.inc" |
| |
| #endif // UPB_MINI_DESCRIPTOR_INTERNAL_DECODER_H_ |