Skip to main content

FormatSpecifier

Enum FormatSpecifier 

Source
#[non_exhaustive]
pub enum FormatSpecifier<'a> { Absent, Aggregated { module_version: u8, module_id: u16, block_size: u16, module_size: u32, compression_method: u8, original_size: u32, timeout: u8, object_key: &'a [u8], }, Other { format_id: u8, bytes: &'a [u8], }, }
Expand description

FormatSpecifier — the optional aggregated block in a carousel_identifier_descriptor (ISO/IEC 13818-6 / TR 101 202 Table 4.17a).

Dispatch on FormatId:

FormatIdVariantMeaning
0x00AbsentNo specifier bytes
0x01AggregatedFull field set (Table 4.17a)
0x020xFFOtherReserved/private; raw bytes

This is a data-carrying ADT — the variants hold payloads, not just labels. Use FormatSpecifier::format_id to retrieve the wire FormatId value.

Variants (Non-exhaustive)§

This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
§

Absent

FormatId = 0x00: no FormatSpecifier bytes.

§

Aggregated

FormatId = 0x01: aggregated FormatSpecifier (TR 101 202 Table 4.17a).

Wire layout of the specifier block (all uimsbf):

ModuleVersion      8
ModuleId          16
BlockSize         16
ModuleSize        32
CompressionMethod  8
OriginalSize      32
TimeOut            8   (8-bit per TR 101 202 v1.2.1)
ObjectKeyLength    8   = N1
ObjectKeyData      8×N1

Fields

§module_version: u8

ModuleVersion [7:0] — version of the DSM-CC module.

§module_id: u16

ModuleId [15:0] — identity of the DSM-CC module.

§block_size: u16

BlockSize [15:0] — download block size in bytes.

§module_size: u32

ModuleSize [31:0] — total module size in bytes.

§compression_method: u8

CompressionMethod [7:0] — 0x00 = none.

§original_size: u32

OriginalSize [31:0] — uncompressed module size in bytes; only meaningful when compression_method != 0x00.

§timeout: u8

TimeOut [7:0] — acquisition timeout (8-bit; TR 101 202 v1.2.1).

§object_key: &'a [u8]

ObjectKeyData — the object key bytes (ObjectKeyLength bytes).

§

Other

FormatId = 0x020xFF: reserved or private format; carried opaque.

Fields

§format_id: u8

The raw FormatId byte.

§bytes: &'a [u8]

Raw specifier bytes (remainder after the carousel_id + FormatId prefix, before private_data_byte).

For unknown FormatId values the caller cannot know where the specifier ends and private data begins, so the entire body remainder is treated as specifier bytes and private_data is empty.

Implementations§

Source§

impl<'a> FormatSpecifier<'a>

Source

pub fn format_id(&self) -> u8

The wire FormatId byte for this variant.

Trait Implementations§

Source§

impl<'a> Clone for FormatSpecifier<'a>

Source§

fn clone(&self) -> FormatSpecifier<'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 FormatSpecifier<'a>

Source§

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

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

impl<'a> Eq for FormatSpecifier<'a>

Source§

impl<'a> PartialEq for FormatSpecifier<'a>

Source§

fn eq(&self, other: &FormatSpecifier<'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<'a> Serialize for FormatSpecifier<'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 FormatSpecifier<'a>

Auto Trait Implementations§

§

impl<'a> Freeze for FormatSpecifier<'a>

§

impl<'a> RefUnwindSafe for FormatSpecifier<'a>

§

impl<'a> Send for FormatSpecifier<'a>

§

impl<'a> Sync for FormatSpecifier<'a>

§

impl<'a> Unpin for FormatSpecifier<'a>

§

impl<'a> UnsafeUnpin for FormatSpecifier<'a>

§

impl<'a> UnwindSafe for FormatSpecifier<'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> ErasedDestructor for T
where T: 'static,

Source§

impl<T> ExtensionObject 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> TableObject 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> 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.