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.
32 lines
1.1 KiB
32 lines
1.1 KiB
5 months ago
|
// 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>
|
||
|
|
||
|
namespace protos::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;
|
||
|
|
||
|
} // namespace protos::internal
|
||
|
|
||
|
#endif // PROTOBUF_HPB_EXTENSION_LOCK_H_
|