Skip to main content

Int

Struct Int 

Source
pub struct Int<'a> {
    pub action_type: u8,
    pub platform_id_hash: u8,
    pub version_number: u8,
    pub current_next_indicator: bool,
    pub section_number: u8,
    pub last_section_number: u8,
    pub platform_id: u32,
    pub processing_order: u8,
    pub platform_descriptors: DescriptorLoop<'a>,
    pub loops: &'a [u8],
}
Expand description

IP/MAC Notification Table (INT), ETSI EN 301 192 v1.7.1 §8.4.

All variable-length regions are borrowed as raw bytes from the source slice. The per-target-and-operational-descriptor loops are exposed as a single loops slice covering everything after the platform_descriptor_loop and before the CRC; callers that need to iterate individual entries must walk the raw bytes using the same 4-bit-reserved + 12-bit-length framing described by the spec.

Fields§

§action_type: u8

Semantics of this INT announcement — 0x01 = stream announcement/location.

§platform_id_hash: u8

8-bit XOR hash over the 24-bit platform_id. Used for fast section filtering; not unique — always verify against the full platform_id.

§version_number: u8

5-bit version_number.

§current_next_indicator: bool

current_next_indicator bit. true means this section is currently applicable; false means it will become applicable at the next update.

§section_number: u8

section_number within this sub-table.

§last_section_number: u8

last_section_number in this sub-table.

§platform_id: u32

24-bit platform identifier (TS 101 162) stored in the low 24 bits of a u32. The high byte is always zero on the wire.

§processing_order: u8

Processing order relative to other INT sections for the same platform_id. 0x00 means no ordering constraint.

§platform_descriptors: DescriptorLoop<'a>

The platform_descriptor_loop (descriptors only, not the 2-byte length field). Serializes as the typed descriptor sequence; .raw() yields the wire bytes.

§loops: &'a [u8]

Raw bytes of all N × (target_descriptor_loop | operational_descriptor_loop) entries that follow the platform_descriptor_loop and precede the CRC.

Each iteration starts with a target_descriptor_loop length field (4-bit reserved + 12-bit length) followed by target descriptors, then an operational_descriptor_loop length field followed by operational descriptors. Callers iterate this by walking the 2-byte length headers in sequence.

Trait Implementations§

Source§

impl<'a> Clone for Int<'a>

Source§

fn clone(&self) -> Int<'a>

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<'a> Debug for Int<'a>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'a> Eq for Int<'a>

Source§

impl<'a> From<Int<'a>> for AnyTable<'a>

Source§

fn from(t: Int<'a>) -> Self

Converts to this type from the input type.
Source§

impl<'a> Parse<'a> for Int<'a>

Source§

type Error = Error

The error type this implementer returns. Typically the enclosing crate’s Error enum.
Source§

fn parse(bytes: &'a [u8]) -> Result<Self>

Parse bytes as Self. Returns Err(Self::Error) on any protocol violation or buffer underrun.
Source§

impl<'a> PartialEq for Int<'a>

Source§

fn eq(&self, other: &Int<'a>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for Int<'_>

Source§

type Error = Error

The error type this implementer returns (usually the same as the corresponding Parse impl, but need not be).
Source§

fn serialized_len(&self) -> usize

Number of bytes serialize_into will write.
Source§

fn serialize_into(&self, buf: &mut [u8]) -> Result<usize>

Write the serialised form into buf. Returns the number of bytes written (always equal to serialized_len()).
Source§

fn to_bytes(&self) -> Vec<u8>
where Self::Error: Debug,

Convenience: allocate a Vec and serialise into it. Panics only if serialize_into misreports serialized_len() — a contract every implementer is responsible for upholding.
Source§

impl<'a> Serialize for Int<'a>

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl<'a> StructuralPartialEq for Int<'a>

Source§

impl<'a> Table<'a> for Int<'a>

Source§

const TABLE_ID: u8 = TABLE_ID

Expected table_id for this table. Read more
Source§

const PID: u16 = PID

PID on which this table is typically carried. Read more
Source§

impl<'a> TableDef<'a> for Int<'a>

Source§

const TABLE_ID_RANGES: &'static [(u8, u8)]

Inclusive (lo, hi) table_id ranges this type parses. Read more
Source§

const NAME: &'static str = "IP_MAC_NOTIFICATION"

Spec name for diagnostics. SCREAMING_SNAKE, suffix-free: PROGRAM_ASSOCIATION, EVENT_INFORMATION, SERVICE_DESCRIPTION. Read more

Auto Trait Implementations§

§

impl<'a> Freeze for Int<'a>

§

impl<'a> RefUnwindSafe for Int<'a>

§

impl<'a> Send for Int<'a>

§

impl<'a> Sync for Int<'a>

§

impl<'a> Unpin for Int<'a>

§

impl<'a> UnsafeUnpin for Int<'a>

§

impl<'a> UnwindSafe for Int<'a>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> DescriptorObject for T
where T: Debug + Any + Send + Sync + Serialize,

Source§

fn as_any(&self) -> &(dyn Any + 'static)

Borrow as &dyn Any so the caller can downcast to the concrete type.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Serialize for T
where T: Serialize + ?Sized,

Source§

fn erased_serialize(&self, serializer: &mut dyn Serializer) -> Result<(), Error>

Source§

fn do_erased_serialize( &self, serializer: &mut dyn Serializer, ) -> Result<(), ErrorImpl>

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.