| // 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 PROTOBUF_HPB_EXTENSION_LOCK_H_ |
| #define PROTOBUF_HPB_EXTENSION_LOCK_H_ |
| |
| #include <atomic> |
| |
| #include "absl/status/statusor.h" |
| #include "absl/strings/string_view.h" |
| #include "upb/message/message.h" |
| |
| namespace hpb::internal { |
| |
| // TODO: Temporary locking api for cross-language |
| // concurrency issue around extension api that uses lazy promotion |
| // from unknown data to upb_MiniTableExtension. Will be replaced by |
| // a core runtime solution in the future. |
| // |
| // Any api(s) using unknown or extension data (GetOrPromoteExtension, |
| // Serialize and others) call lock/unlock to provide a way for |
| // mixed language implementations to avoid race conditions) |
| using UpbExtensionUnlocker = void (*)(const void*); |
| using UpbExtensionLocker = UpbExtensionUnlocker (*)(const void*); |
| |
| // TODO: Expose as function instead of global. |
| extern std::atomic<UpbExtensionLocker> upb_extension_locker_global; |
| |
| absl::StatusOr<absl::string_view> Serialize(const upb_Message* message, |
| const upb_MiniTable* mini_table, |
| upb_Arena* arena, int options); |
| |
| bool HasExtensionOrUnknown(const upb_Message* msg, |
| const upb_MiniTableExtension* eid); |
| |
| bool GetOrPromoteExtension(const upb_Message* msg, |
| const upb_MiniTableExtension* eid, upb_Arena* arena, |
| upb_MessageValue* value); |
| |
| void DeepCopy(upb_Message* target, const upb_Message* source, |
| const upb_MiniTable* mini_table, upb_Arena* arena); |
| |
| upb_Message* DeepClone(const upb_Message* source, |
| const upb_MiniTable* mini_table, upb_Arena* arena); |
| |
| } // namespace hpb::internal |
| |
| #endif // PROTOBUF_HPB_EXTENSION_LOCK_H_ |