pub use bytes;
mod error;
mod message;
mod types;
pub mod descriptor_getter;
#[doc(hidden)]
pub mod encoding;
pub mod extension;
use bytes::{BufMut, Bytes};
pub use encoding::{DecodeContext, EncodeLengthContext};
use encoding::{decode_varint, encode_varint, encoded_len_varint};
pub use error::{DecodeError, EncodeError};
pub use linkedbytes::LinkedBytes;
pub use message::{EnumMessage, Message};
pub use protobuf::{
EnumOrUnknown, Message as PbMessage, UnknownValueRef, descriptor, reflect, well_known_types,
};
#[cfg(not(feature = "no-recursion-limit"))]
const RECURSION_LIMIT: u32 = 100;
pub fn encode_length_delimiter(length: usize, buf: &mut LinkedBytes) -> Result<(), EncodeError> {
let length = length as u64;
let required = encoded_len_varint(length);
let remaining = buf.remaining_mut();
if required > remaining {
return Err(EncodeError::new(required, remaining));
}
encode_varint(length, buf);
Ok(())
}
pub fn length_delimiter_len(length: usize) -> usize {
encoded_len_varint(length as u64)
}
pub fn decode_length_delimiter(mut buf: Bytes) -> Result<usize, DecodeError> {
let length = decode_varint(&mut buf)?;
if length > usize::MAX as u64 {
return Err(DecodeError::new(
"length delimiter exceeds maximum usize value",
));
}
Ok(length as usize)
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_length_delimiter_len() {
let length = length_delimiter_len(10);
assert_eq!(length, 1);
}
#[test]
fn test_encode_and_decode_length_delimiter() {
let mut buf = LinkedBytes::new();
encode_length_delimiter(10, &mut buf).unwrap();
let length = decode_length_delimiter(buf.bytes().clone().freeze()).unwrap();
assert_eq!(length, 10);
assert_eq!(buf.bytes().len(), 1);
}
}
#[cfg(all(target_os = "macos", target_arch = "aarch64"))]
const ZERO_COPY_THRESHOLD: usize = 1024;
#[cfg(not(all(target_os = "macos", target_arch = "aarch64")))]
const ZERO_COPY_THRESHOLD: usize = 4 * 1024;