| // 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_REFLECTION_MESSAGE_H_ |
| #define UPB_REFLECTION_MESSAGE_H_ |
| |
| #include <stddef.h> |
| |
| #include "upb/mem/arena.h" |
| #include "upb/message/map.h" |
| #include "upb/message/message.h" |
| #include "upb/reflection/common.h" |
| |
| // Must be last. |
| #include "upb/port/def.inc" |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif |
| |
| // Returns a mutable pointer to a map, array, or submessage value. If the given |
| // arena is non-NULL this will construct a new object if it was not previously |
| // present. May not be called for primitive fields. |
| UPB_API upb_MutableMessageValue upb_Message_Mutable(upb_Message* msg, |
| const upb_FieldDef* f, |
| upb_Arena* a); |
| |
| // Returns the field that is set in the oneof, or NULL if none are set. |
| UPB_API const upb_FieldDef* upb_Message_WhichOneof(const upb_Message* msg, |
| const upb_OneofDef* o); |
| |
| // Clear all data and unknown fields. |
| void upb_Message_ClearByDef(upb_Message* msg, const upb_MessageDef* m); |
| |
| // Clears any field presence and sets the value back to its default. |
| UPB_API void upb_Message_ClearFieldByDef(upb_Message* msg, |
| const upb_FieldDef* f); |
| |
| // May only be called for fields where upb_FieldDef_HasPresence(f) == true. |
| UPB_API bool upb_Message_HasFieldByDef(const upb_Message* msg, |
| const upb_FieldDef* f); |
| |
| // Returns the value in the message associated with this field def. |
| UPB_API upb_MessageValue upb_Message_GetFieldByDef(const upb_Message* msg, |
| const upb_FieldDef* f); |
| |
| // Sets the given field to the given value. For a msg/array/map/string, the |
| // caller must ensure that the target data outlives |msg| (by living either in |
| // the same arena or a different arena that outlives it). |
| // |
| // Returns false if allocation fails. |
| UPB_API bool upb_Message_SetFieldByDef(upb_Message* msg, const upb_FieldDef* f, |
| upb_MessageValue val, upb_Arena* a); |
| |
| // Iterate over present fields. |
| // |
| // size_t iter = kUpb_Message_Begin; |
| // const upb_FieldDef *f; |
| // upb_MessageValue val; |
| // while (upb_Message_Next(msg, m, ext_pool, &f, &val, &iter)) { |
| // process_field(f, val); |
| // } |
| // |
| // If ext_pool is NULL, no extensions will be returned. If the given symtab |
| // returns extensions that don't match what is in this message, those extensions |
| // will be skipped. |
| |
| #define kUpb_Message_Begin -1 |
| |
| UPB_API bool upb_Message_Next(const upb_Message* msg, const upb_MessageDef* m, |
| const upb_DefPool* ext_pool, |
| const upb_FieldDef** f, upb_MessageValue* val, |
| size_t* iter); |
| |
| // Clears all unknown field data from this message and all submessages. |
| UPB_API bool upb_Message_DiscardUnknown(upb_Message* msg, |
| const upb_MessageDef* m, int maxdepth); |
| |
| #ifdef __cplusplus |
| } /* extern "C" */ |
| #endif |
| |
| #include "upb/port/undef.inc" |
| |
| #endif /* UPB_REFLECTION_MESSAGE_H_ */ |