// 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 #include "upb/mem/arena.h" #include "upb/message/map.h" #include "upb/message/message.h" #include "upb/message/value.h" // IWYU pragma: export #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 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_ */