|
|
|
// Protocol Buffers - Google's data interchange format
|
|
|
|
// Copyright 2024 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
|
|
|
|
|
|
|
|
//! Traits that are implemented by codegen types.
|
|
|
|
|
|
|
|
use crate::__internal::SealedInternal;
|
|
|
|
use crate::{MutProxied, MutProxy, ViewProxy};
|
|
|
|
use create::Parse;
|
|
|
|
use interop::{MessageMutInterop, MessageViewInterop, OwnedMessageInterop};
|
|
|
|
use read::Serialize;
|
|
|
|
use std::fmt::Debug;
|
|
|
|
use write::{Clear, ClearAndParse, MergeFrom};
|
|
|
|
|
|
|
|
/// A trait that all generated owned message types implement.
|
|
|
|
pub trait Message: SealedInternal
|
|
|
|
+ MutProxied
|
|
|
|
// Create traits:
|
|
|
|
+ Parse + Default
|
|
|
|
// Read traits:
|
|
|
|
+ Debug + Serialize
|
|
|
|
// Write traits:
|
|
|
|
+ Clear + ClearAndParse + MergeFrom
|
|
|
|
// Thread safety:
|
|
|
|
+ Send + Sync
|
|
|
|
// Copy/Clone:
|
|
|
|
+ Clone
|
|
|
|
// C++ Interop:
|
|
|
|
+ OwnedMessageInterop
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/// A trait that all generated message views implement.
|
|
|
|
pub trait MessageView<'msg>: SealedInternal
|
|
|
|
+ ViewProxy<'msg, Proxied = Self::Message>
|
|
|
|
// Read traits:
|
|
|
|
+ Debug + Serialize + Default
|
|
|
|
// Thread safety:
|
|
|
|
+ Send + Sync
|
|
|
|
// Copy/Clone:
|
|
|
|
+ Copy + Clone
|
|
|
|
// C++ Interop:
|
|
|
|
+ MessageViewInterop<'msg>
|
|
|
|
{
|
|
|
|
#[doc(hidden)]
|
|
|
|
type Message: Message;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// A trait that all generated message muts implement.
|
|
|
|
pub trait MessageMut<'msg>: SealedInternal
|
|
|
|
+ MutProxy<'msg, MutProxied = Self::Message>
|
|
|
|
// Read traits:
|
|
|
|
+ Debug + Serialize
|
|
|
|
// Write traits:
|
|
|
|
// TODO: MsgMut should impl ClearAndParse.
|
|
|
|
+ Clear + MergeFrom
|
|
|
|
// Thread safety:
|
|
|
|
+ Sync
|
|
|
|
// Copy/Clone:
|
|
|
|
// (Neither)
|
|
|
|
// C++ Interop:
|
|
|
|
+ MessageMutInterop<'msg>
|
|
|
|
{
|
|
|
|
#[doc(hidden)]
|
|
|
|
type Message: Message;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Operations related to constructing a message. Only owned messages implement
|
|
|
|
/// these traits.
|
|
|
|
pub(crate) mod create {
|
|
|
|
use super::SealedInternal;
|
|
|
|
pub trait Parse: SealedInternal + Sized {
|
|
|
|
fn parse(serialized: &[u8]) -> Result<Self, crate::ParseError>;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Operations related to reading some aspect of a message (methods that would
|
|
|
|
/// have a `&self` receiver on an owned message). Owned messages, views, and
|
|
|
|
/// muts all implement these traits.
|
|
|
|
pub(crate) mod read {
|
|
|
|
use super::SealedInternal;
|
|
|
|
|
|
|
|
pub trait Serialize: SealedInternal {
|
|
|
|
fn serialize(&self) -> Result<Vec<u8>, crate::SerializeError>;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Operations related to mutating a message (methods that would have a `&mut
|
|
|
|
/// self` receiver on an owned message). Owned messages and muts implement these
|
|
|
|
/// traits.
|
|
|
|
pub(crate) mod write {
|
|
|
|
use super::SealedInternal;
|
|
|
|
use crate::AsView;
|
|
|
|
|
|
|
|
pub trait Clear: SealedInternal {
|
|
|
|
fn clear(&mut self);
|
|
|
|
}
|
|
|
|
|
|
|
|
pub trait ClearAndParse: SealedInternal {
|
|
|
|
fn clear_and_parse(&mut self, data: &[u8]) -> Result<(), crate::ParseError>;
|
|
|
|
}
|
|
|
|
|
|
|
|
pub trait MergeFrom: AsView + SealedInternal {
|
|
|
|
fn merge_from(&mut self, src: impl AsView<Proxied = Self::Proxied>);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Traits related to interop with C or C++.
|
|
|
|
///
|
|
|
|
/// These traits are deliberately not available on the prelude, as they should
|
|
|
|
/// be used rarely and with great care.
|
|
|
|
pub(crate) mod interop {
|
|
|
|
use super::SealedInternal;
|
|
|
|
use std::ffi::c_void;
|
|
|
|
|
|
|
|
/// Traits related to owned message interop. Note that these trait fns
|
|
|
|
/// are only available on C++ kernel as upb interop of owned messages
|
|
|
|
/// requires more work to handle the Arena behavior.
|
|
|
|
pub trait OwnedMessageInterop: SealedInternal {
|
|
|
|
/// Drops `self` and returns an underlying pointer that it was wrapping
|
|
|
|
/// without deleting it.
|
|
|
|
///
|
|
|
|
/// The caller is responsible for ensuring the returned pointer is
|
|
|
|
/// subsequently deleted (eg by moving it into a std::unique_ptr in
|
|
|
|
/// C++), or else it will leak.
|
|
|
|
#[cfg(cpp_kernel)]
|
|
|
|
fn __unstable_leak_raw_message(self) -> *mut c_void;
|
|
|
|
|
|
|
|
/// Takes exclusive ownership of the `raw_message`.
|
|
|
|
///
|
|
|
|
/// # Safety
|
|
|
|
/// - The underlying message must be for the same type as `Self`
|
|
|
|
/// - The pointer passed in must not be used by the caller after being
|
|
|
|
/// passed here (must not be read, written, or deleted)
|
|
|
|
#[cfg(cpp_kernel)]
|
|
|
|
unsafe fn __unstable_take_ownership_of_raw_message(raw_message: *mut c_void) -> Self;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Traits related to message view interop.
|
|
|
|
pub trait MessageViewInterop<'msg>: SealedInternal {
|
|
|
|
/// Borrows `self` as an underlying C++ raw pointer.
|
|
|
|
///
|
|
|
|
/// Note that the returned Value must be used under the same constraints
|
|
|
|
/// as though it were a borrow of `self`: it should be treated as a
|
|
|
|
/// `const Message*` in C++, and not be mutated in any way, and any
|
|
|
|
/// mutation to the parent message may invalidate it, and it
|
|
|
|
/// must not be deleted.
|
|
|
|
fn __unstable_as_raw_message(&self) -> *const c_void;
|
|
|
|
|
|
|
|
/// Wraps the provided pointer as a MessageView.
|
|
|
|
///
|
|
|
|
/// This takes a ref of a pointer so that a stack variable's lifetime
|
|
|
|
/// can be used for a safe lifetime; under most cases this is
|
|
|
|
/// the correct lifetime and this should be used as:
|
|
|
|
/// ```ignore
|
|
|
|
/// fn called_from_cpp(msg: *const c_void) {
|
|
|
|
/// // `msg` is known live for the current stack frame, so view's
|
|
|
|
/// // lifetime is also tied to the current stack frame here:
|
|
|
|
/// let view = unsafe { __unstable_wrap_raw_message(&msg) };
|
|
|
|
/// do_something_with_view(view);
|
|
|
|
/// }
|
|
|
|
/// ```
|
|
|
|
///
|
|
|
|
/// # Safety
|
|
|
|
/// - The underlying message must be for the same type as `Self`
|
|
|
|
/// - The underlying message must be alive for 'msg and not mutated
|
|
|
|
/// while the wrapper is live.
|
|
|
|
unsafe fn __unstable_wrap_raw_message(raw: &'msg *const c_void) -> Self;
|
|
|
|
|
|
|
|
/// Wraps the provided pointer as a MessageView.
|
|
|
|
///
|
|
|
|
/// Unlike `__unstable_wrap_raw_message` this has no constraints
|
|
|
|
/// on lifetime: the caller has a free choice for the lifetime.
|
|
|
|
///
|
|
|
|
/// As this is much easier to get the lifetime wrong than
|
|
|
|
/// `__unstable_wrap_raw_message`, prefer using that wherever
|
|
|
|
/// your lifetime can be tied to a stack lifetime, and only use this one
|
|
|
|
/// if its not possible (e.g. with a 'static lifetime).
|
|
|
|
///
|
|
|
|
/// # Safety
|
|
|
|
/// - The underlying message must be for the same type as `Self`
|
|
|
|
/// - The underlying message must be alive for the caller-chosen 'msg
|
|
|
|
/// and not mutated while the wrapper is live.
|
|
|
|
unsafe fn __unstable_wrap_raw_message_unchecked_lifetime(raw: *const c_void) -> Self;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Traits related to message mut interop. Note that these trait fns
|
|
|
|
/// are only available on C++ kernel as upb interop of owned messages
|
|
|
|
/// requires more work to handle the Arena behavior.
|
|
|
|
pub trait MessageMutInterop<'msg>: SealedInternal {
|
|
|
|
/// Exclusive borrows `self` as an underlying mutable C++ raw pointer.
|
|
|
|
///
|
|
|
|
/// Note that the returned Value must be used under the same constraints
|
|
|
|
/// as though it were a mut borrow of `self`: it should be treated as a
|
|
|
|
/// non-owned `Message*` in C++. And any mutation to the parent message
|
|
|
|
/// may invalidate it, and it must not be deleted.
|
|
|
|
#[cfg(cpp_kernel)]
|
|
|
|
fn __unstable_as_raw_message_mut(&mut self) -> *mut c_void;
|
|
|
|
|
|
|
|
/// Wraps the provided C++ pointer as a MessageMut.
|
|
|
|
///
|
|
|
|
/// This takes a ref of a pointer so that a stack variable's lifetime
|
|
|
|
/// can be used for a safe lifetime; under most cases this is
|
|
|
|
/// the correct lifetime and this should be used as:
|
|
|
|
/// ```ignore
|
|
|
|
/// fn called_from_cpp(msg: *mut c_void) {
|
|
|
|
/// // `msg` is known live for the current stack frame, so mut's
|
|
|
|
/// // lifetime is also tied to the current stack frame here:
|
|
|
|
/// let m = unsafe { __unstable_wrap_raw_message_mut(&mut msg) };
|
|
|
|
/// do_something_with_mut(m);
|
|
|
|
/// }
|
|
|
|
///
|
|
|
|
/// # Safety
|
|
|
|
/// - The underlying message must be for the same type as `Self`
|
|
|
|
/// - The underlying message must be alive for 'msg and not read or
|
|
|
|
/// mutated while the wrapper is live.
|
|
|
|
#[cfg(cpp_kernel)]
|
|
|
|
unsafe fn __unstable_wrap_raw_message_mut(raw: &'msg mut *mut c_void) -> Self;
|
|
|
|
|
|
|
|
/// Wraps the provided pointer as a MessageMut.
|
|
|
|
///
|
|
|
|
/// Unlike `__unstable_wrap_raw_message_mut` this has no constraints
|
|
|
|
/// on lifetime: the caller has a free choice for the lifetime.
|
|
|
|
///
|
|
|
|
/// As this is much easier to get the lifetime wrong than
|
|
|
|
/// `__unstable_wrap_raw_message_mut`, prefer using that wherever
|
|
|
|
/// the lifetime can be tied to a stack lifetime, and only use this one
|
|
|
|
/// if its not possible (e.g. with a 'static lifetime).
|
|
|
|
///
|
|
|
|
/// # Safety
|
|
|
|
/// - The underlying message must be for the same type as `Self`
|
|
|
|
/// - The underlying message must be alive for the caller-chosen 'msg
|
|
|
|
/// and not mutated while the wrapper is live.
|
|
|
|
#[cfg(cpp_kernel)]
|
|
|
|
unsafe fn __unstable_wrap_raw_message_mut_unchecked_lifetime(raw: *mut c_void) -> Self;
|
|
|
|
}
|
|
|
|
}
|