symphonia_core::io

Trait MediaSource

Source
pub trait MediaSource:
    Read
    + Seek
    + Send
    + Sync {
    // Required methods
    fn is_seekable(&self) -> bool;
    fn byte_len(&self) -> Option<u64>;
}
Expand description

MediaSource is a composite trait of std::io::Read and std::io::Seek. A source must implement this trait to be used by MediaSourceStream.

Despite requiring the std::io::Seek trait, seeking is an optional capability that can be queried at runtime.

Required Methods§

Source

fn is_seekable(&self) -> bool

Returns if the source is seekable. This may be an expensive operation.

Source

fn byte_len(&self) -> Option<u64>

Returns the length in bytes, if available. This may be an expensive operation.

Implementations on Foreign Types§

Source§

impl MediaSource for File

Source§

fn is_seekable(&self) -> bool

Returns if the std::io::File backing the MediaSource is seekable.

Note: This operation involves querying the underlying file descriptor for information and may be moderately expensive. Therefore it is recommended to cache this value if used often.

Source§

fn byte_len(&self) -> Option<u64>

Returns the length in bytes of the std::io::File backing the MediaSource.

Note: This operation involves querying the underlying file descriptor for information and may be moderately expensive. Therefore it is recommended to cache this value if used often.

Source§

impl<T: AsRef<[u8]> + Send + Sync> MediaSource for Cursor<T>

Source§

fn is_seekable(&self) -> bool

Always returns true since a io::Cursor<u8> is always seekable.

Source§

fn byte_len(&self) -> Option<u64>

Returns the length in bytes of the io::Cursor<u8> backing the MediaSource.

Implementors§