pub struct ByteSequence { /* private fields */ }Expand description
A struct representing a sequence of bytes. It provides methods to create an empty sequence and compute the next lexicographical sequence.
§Examples
let seq = ByteSequence::from("abc");
let next_seq = seq.next();
assert_eq!(next_seq.as_bytes(), b"abd");Implementations§
Source§impl ByteSequence
impl ByteSequence
pub fn as_bytes(&self) -> &[u8] ⓘ
Sourcepub fn empty() -> ByteSequence
pub fn empty() -> ByteSequence
Creates an empty ByteSequence.
§Examples
let empty_seq = ByteSequence::empty();
assert_eq!(empty_seq.as_bytes(), b"\0");Sourcepub fn next(&self) -> ByteSequence
pub fn next(&self) -> ByteSequence
Computes the next lexicographical byte sequence. If the current sequence is empty, it returns an empty sequence. If all bytes are at their maximum value, it returns an empty sequence. If the last byte can be incremented, it increments it and truncates the sequence.
§Examples
- Basic test case
let from = ByteSequence::from("abc");
let next_seq = from.next();
assert_eq!(next_seq, ByteSequence::from("abd"));- Test case with
0xffbytes
let from = ByteSequence::from(b"ab\xff\xff" as &[u8]); // [0x61,0x62,0xff,0xff]
let next_seq = from.next();
assert_eq!(next_seq.as_bytes(), b"ac");- Test case where all bytes are
0xff
let from = ByteSequence::from(b"\xff\xff" as &[u8]); // [0xff,0xff]
let next_seq = from.next();
assert_eq!(next_seq.as_bytes(), ByteSequence::empty().as_bytes());Trait Implementations§
Source§impl Clone for ByteSequence
impl Clone for ByteSequence
Source§fn clone(&self) -> ByteSequence
fn clone(&self) -> ByteSequence
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for ByteSequence
impl Debug for ByteSequence
Source§impl From<&[u8]> for ByteSequence
impl From<&[u8]> for ByteSequence
Source§fn from(value: &[u8]) -> ByteSequence
fn from(value: &[u8]) -> ByteSequence
Converts to this type from the input type.
Source§impl From<&str> for ByteSequence
impl From<&str> for ByteSequence
Source§fn from(value: &str) -> ByteSequence
fn from(value: &str) -> ByteSequence
Converts to this type from the input type.
Source§impl From<String> for ByteSequence
impl From<String> for ByteSequence
Source§fn from(value: String) -> ByteSequence
fn from(value: String) -> ByteSequence
Converts to this type from the input type.
Source§impl PartialEq for ByteSequence
impl PartialEq for ByteSequence
impl Eq for ByteSequence
impl StructuralPartialEq for ByteSequence
Auto Trait Implementations§
impl Freeze for ByteSequence
impl RefUnwindSafe for ByteSequence
impl Send for ByteSequence
impl Sync for ByteSequence
impl Unpin for ByteSequence
impl UnwindSafe for ByteSequence
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request