Protocol Buffers - Google's data interchange format (grpc依赖)
https://developers.google.com/protocol-buffers/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
52 lines
2.0 KiB
52 lines
2.0 KiB
// 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_
|
|
|