| /* |
| * Copyright (c) 2009-2021, Google LLC |
| * All rights reserved. |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions are met: |
| * * Redistributions of source code must retain the above copyright |
| * notice, this list of conditions and the following disclaimer. |
| * * Redistributions in binary form must reproduce the above copyright |
| * notice, this list of conditions and the following disclaimer in the |
| * documentation and/or other materials provided with the distribution. |
| * * Neither the name of Google LLC nor the |
| * names of its contributors may be used to endorse or promote products |
| * derived from this software without specific prior written permission. |
| * |
| * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" |
| * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
| * ARE DISCLAIMED. IN NO EVENT SHALL Google LLC BE LIABLE FOR ANY DIRECT, |
| * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES |
| * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; |
| * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND |
| * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS |
| * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| */ |
| |
| #ifndef UPB_REFLECTION_MESSAGE_H_ |
| #define UPB_REFLECTION_MESSAGE_H_ |
| |
| #include "upb/collections/map.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_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. |
| 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. |
| void upb_Message_ClearFieldByDef(upb_Message* msg, const upb_FieldDef* f); |
| |
| // May only be called for fields where upb_FieldDef_HasPresence(f) == true. |
| bool upb_Message_HasFieldByDef(const upb_Message* msg, const upb_FieldDef* f); |
| |
| // Returns the value in the message associated with this field def. |
| 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. |
| 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. |
| 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_ */ |