pub struct SnowflakeInstagramId { /* private fields */ }Expand description
A 64-bit Snowflake ID using the Instagram layout
- 41 bits timestamp (ms since
INSTAGRAM_EPOCH) - 13 bits machine ID
- 10 bits sequence
Bit Index: 63 23 22 10 9 0
+----------------+-----------------+---------------+
Field: | timestamp (41) | machine ID (13) | sequence (10) |
+----------------+-----------------+---------------+
|<----- MSB ---------- 64 bits --------- LSB ----->|Implementations§
Source§impl SnowflakeInstagramId
impl SnowflakeInstagramId
pub const RESERVED_BITS: u64 = 0u64
pub const TIMESTAMP_BITS: u64 = 41u64
pub const MACHINE_ID_BITS: u64 = 13u64
pub const SEQUENCE_BITS: u64 = 10u64
pub const SEQUENCE_SHIFT: u64 = 0u64
pub const MACHINE_ID_SHIFT: u64 = 10u64
pub const TIMESTAMP_SHIFT: u64 = 23u64
pub const RESERVED_SHIFT: u64 = 64u64
pub const RESERVED_MASK: u64 = 0u64
pub const TIMESTAMP_MASK: u64 = 2_199_023_255_551u64
pub const MACHINE_ID_MASK: u64 = 8_191u64
pub const SEQUENCE_MASK: u64 = 1_023u64
pub const fn from(timestamp: u64, machine_id: u64, sequence: u64) -> Self
Sourcepub const fn machine_id(&self) -> u64
pub const fn machine_id(&self) -> u64
Extracts the machine ID from the packed ID.
Sourcepub const fn max_timestamp() -> u64
pub const fn max_timestamp() -> u64
Returns the maximum representable timestamp value based on
Self::TIMESTAMP_BITS.
Sourcepub const fn max_machine_id() -> u64
pub const fn max_machine_id() -> u64
Returns the maximum representable machine ID value based on
Self::MACHINE_ID_BITS.
Sourcepub const fn max_sequence() -> u64
pub const fn max_sequence() -> u64
Returns the maximum representable sequence value based on
Self::SEQUENCE_BITS.
Trait Implementations§
Source§impl Clone for SnowflakeInstagramId
impl Clone for SnowflakeInstagramId
Source§fn clone(&self) -> SnowflakeInstagramId
fn clone(&self) -> SnowflakeInstagramId
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 SnowflakeInstagramId
impl Debug for SnowflakeInstagramId
Source§impl Display for SnowflakeInstagramId
impl Display for SnowflakeInstagramId
Source§impl FromStr for SnowflakeInstagramId
impl FromStr for SnowflakeInstagramId
Source§impl Hash for SnowflakeInstagramId
impl Hash for SnowflakeInstagramId
Source§impl Id for SnowflakeInstagramId
impl Id for SnowflakeInstagramId
Source§impl Ord for SnowflakeInstagramId
impl Ord for SnowflakeInstagramId
Source§fn cmp(&self, other: &SnowflakeInstagramId) -> Ordering
fn cmp(&self, other: &SnowflakeInstagramId) -> Ordering
1.21.0 · Source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
Compares and returns the maximum of two values. Read more
Source§impl PartialEq for SnowflakeInstagramId
impl PartialEq for SnowflakeInstagramId
Source§impl PartialOrd for SnowflakeInstagramId
impl PartialOrd for SnowflakeInstagramId
Source§impl SnowflakeId for SnowflakeInstagramId
impl SnowflakeId for SnowflakeInstagramId
Source§fn machine_id(&self) -> Self::Ty
fn machine_id(&self) -> Self::Ty
Returns the machine ID portion of the ID.
Source§fn max_timestamp() -> Self::Ty
fn max_timestamp() -> Self::Ty
Returns the maximum possible value for the timestamp field.
Source§fn max_machine_id() -> Self::Ty
fn max_machine_id() -> Self::Ty
Returns the maximum possible value for the
machine_id field.Source§fn max_sequence() -> Self::Ty
fn max_sequence() -> Self::Ty
Returns the maximum possible value for the sequence field.
Source§fn from_components(timestamp: u64, machine_id: u64, sequence: u64) -> Self
fn from_components(timestamp: u64, machine_id: u64, sequence: u64) -> Self
Constructs a new Snowflake ID from its components.
Source§fn is_valid(&self) -> bool
fn is_valid(&self) -> bool
Returns
true if the ID’s internal structure is valid, such as reserved
bits being unset or fields within expected ranges.Source§fn into_valid(self) -> Self
fn into_valid(self) -> Self
Returns a normalized version of the ID with any invalid or reserved bits
cleared. This guarantees a valid, canonical representation.
Source§fn has_sequence_room(&self) -> bool
fn has_sequence_room(&self) -> bool
Returns true if the current sequence value can be incremented.
Source§fn next_sequence(&self) -> Self::Ty
fn next_sequence(&self) -> Self::Ty
Returns the next sequence value.
Source§fn increment_sequence(&self) -> Self
fn increment_sequence(&self) -> Self
Returns a new ID with the sequence incremented.
Source§fn rollover_to_timestamp(&self, ts: Self::Ty) -> Self
fn rollover_to_timestamp(&self, ts: Self::Ty) -> Self
Returns a new ID for a newer timestamp with sequence reset to zero.
Source§impl TryFrom<&str> for SnowflakeInstagramId
impl TryFrom<&str> for SnowflakeInstagramId
impl Copy for SnowflakeInstagramId
impl Eq for SnowflakeInstagramId
impl StructuralPartialEq for SnowflakeInstagramId
Auto Trait Implementations§
impl Freeze for SnowflakeInstagramId
impl RefUnwindSafe for SnowflakeInstagramId
impl Send for SnowflakeInstagramId
impl Sync for SnowflakeInstagramId
impl Unpin for SnowflakeInstagramId
impl UnwindSafe for SnowflakeInstagramId
Blanket Implementations§
Source§impl<ID> Base32SnowExt for ID
impl<ID> Base32SnowExt for ID
Source§fn buf() -> <<Self as Id>::Ty as BeBytes>::Base32Array
fn buf() -> <<Self as Id>::Ty as BeBytes>::Base32Array
Returns a stack-allocated, zero-initialized buffer for Base32 encoding. Read more
Source§fn encode(&self) -> Base32SnowFormatter<Self>
fn encode(&self) -> Base32SnowFormatter<Self>
Returns a formatter containing the Crockford Base32 representation of
the ID. Read more
Source§fn encode_to_buf<'buf>(
&self,
buf: &'buf mut <<Self as Id>::Ty as BeBytes>::Base32Array,
) -> Base32SnowFormatterRef<'buf, Self>
fn encode_to_buf<'buf>( &self, buf: &'buf mut <<Self as Id>::Ty as BeBytes>::Base32Array, ) -> Base32SnowFormatterRef<'buf, Self>
Encodes this ID into the provided buffer without heap allocation and
returns a formatter view over the buffer similar to
Base32SnowExt::encode. Read moreSource§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