mirror of
https://github.com/Serial-ATA/lofty-rs
synced 2025-01-22 08:55:00 +00:00
MP3: Rename MP3File
to MPEGFile
This commit is contained in:
parent
da45191187
commit
0805e6683b
24 changed files with 69 additions and 68 deletions
|
@ -18,6 +18,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||||
### Changed
|
### Changed
|
||||||
- **TaggedFile**: `tag{_mut}` no longer takes a reference to `TagType`
|
- **TaggedFile**: `tag{_mut}` no longer takes a reference to `TagType`
|
||||||
- **ID3v2**: `LanguageFrame`'s `lang` field has changed type - `String` -> `[u8; 3]`
|
- **ID3v2**: `LanguageFrame`'s `lang` field has changed type - `String` -> `[u8; 3]`
|
||||||
|
- **MP3**: Renamed `MP3File` -> `MPEGFile`
|
||||||
|
|
||||||
## [0.7.3] - 2022-07-22
|
## [0.7.3] - 2022-07-22
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ path = "fuzz_targets/filetype_from_buffer.rs"
|
||||||
|
|
||||||
[[bin]]
|
[[bin]]
|
||||||
name = "mp3file_read_from"
|
name = "mp3file_read_from"
|
||||||
path = "fuzz_targets/mp3file_read_from.rs"
|
path = "fuzz_targets/mpegfile_read_from.rs"
|
||||||
|
|
||||||
[[bin]]
|
[[bin]]
|
||||||
name = "aifffile_read_from"
|
name = "aifffile_read_from"
|
||||||
|
|
|
@ -2,9 +2,9 @@
|
||||||
|
|
||||||
use std::io::Cursor;
|
use std::io::Cursor;
|
||||||
|
|
||||||
use lofty::AudioFile;
|
|
||||||
use libfuzzer_sys::fuzz_target;
|
use libfuzzer_sys::fuzz_target;
|
||||||
|
use lofty::AudioFile;
|
||||||
|
|
||||||
fuzz_target!(|data: Vec<u8>| {
|
fuzz_target!(|data: Vec<u8>| {
|
||||||
let _ = lofty::mp3::Mp3File::read_from(&mut Cursor::new(data), false);
|
let _ = lofty::mp3::MPEGFile::read_from(&mut Cursor::new(data), false);
|
||||||
});
|
});
|
|
@ -9,7 +9,7 @@ use syn::{
|
||||||
};
|
};
|
||||||
|
|
||||||
const LOFTY_FILE_TYPES: [&str; 10] = [
|
const LOFTY_FILE_TYPES: [&str; 10] = [
|
||||||
"AIFF", "APE", "FLAC", "MP3", "MP4", "Opus", "Vorbis", "Speex", "WAV", "WavPack",
|
"AIFF", "APE", "FLAC", "MPEG", "MP4", "Opus", "Vorbis", "Speex", "WAV", "WavPack",
|
||||||
];
|
];
|
||||||
|
|
||||||
#[proc_macro_derive(LoftyFile, attributes(lofty))]
|
#[proc_macro_derive(LoftyFile, attributes(lofty))]
|
||||||
|
|
|
@ -53,7 +53,7 @@ macro_rules! impl_accessor {
|
||||||
/// ## Supported file types
|
/// ## Supported file types
|
||||||
///
|
///
|
||||||
/// * [`FileType::APE`](crate::FileType::APE)
|
/// * [`FileType::APE`](crate::FileType::APE)
|
||||||
/// * [`FileType::MP3`](crate::FileType::MP3)
|
/// * [`FileType::MP3`](crate::FileType::MPEG)
|
||||||
/// * [`FileType::WavPack`](crate::FileType::WavPack)
|
/// * [`FileType::WavPack`](crate::FileType::WavPack)
|
||||||
///
|
///
|
||||||
/// ## Item storage
|
/// ## Item storage
|
||||||
|
|
|
@ -23,7 +23,7 @@ where
|
||||||
let probe = Probe::new(data).guess_file_type()?;
|
let probe = Probe::new(data).guess_file_type()?;
|
||||||
|
|
||||||
match probe.file_type() {
|
match probe.file_type() {
|
||||||
Some(FileType::APE | FileType::MP3 | FileType::WavPack) => {},
|
Some(FileType::APE | FileType::MPEG | FileType::WavPack) => {},
|
||||||
_ => err!(UnsupportedTag),
|
_ => err!(UnsupportedTag),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
30
src/file.rs
30
src/file.rs
|
@ -68,7 +68,7 @@ impl TaggedFile {
|
||||||
/// # let path_to_mp3 = "tests/files/assets/minimal/full_test.mp3";
|
/// # let path_to_mp3 = "tests/files/assets/minimal/full_test.mp3";
|
||||||
/// let mut tagged_file = lofty::read_from_path(path_to_mp3, true)?;
|
/// let mut tagged_file = lofty::read_from_path(path_to_mp3, true)?;
|
||||||
///
|
///
|
||||||
/// assert_eq!(tagged_file.file_type(), FileType::MP3);
|
/// assert_eq!(tagged_file.file_type(), FileType::MPEG);
|
||||||
/// # Ok(()) }
|
/// # Ok(()) }
|
||||||
/// ```
|
/// ```
|
||||||
pub fn file_type(&self) -> FileType {
|
pub fn file_type(&self) -> FileType {
|
||||||
|
@ -483,7 +483,7 @@ pub enum FileType {
|
||||||
AIFF,
|
AIFF,
|
||||||
APE,
|
APE,
|
||||||
FLAC,
|
FLAC,
|
||||||
MP3,
|
MPEG,
|
||||||
MP4,
|
MP4,
|
||||||
Opus,
|
Opus,
|
||||||
Vorbis,
|
Vorbis,
|
||||||
|
@ -513,7 +513,7 @@ impl FileType {
|
||||||
/// ```rust
|
/// ```rust
|
||||||
/// use lofty::{FileType, TagType};
|
/// use lofty::{FileType, TagType};
|
||||||
///
|
///
|
||||||
/// let file_type = FileType::MP3;
|
/// let file_type = FileType::MPEG;
|
||||||
/// assert_eq!(file_type.primary_tag_type(), TagType::ID3v2);
|
/// assert_eq!(file_type.primary_tag_type(), TagType::ID3v2);
|
||||||
/// ```
|
/// ```
|
||||||
pub fn primary_tag_type(&self) -> TagType {
|
pub fn primary_tag_type(&self) -> TagType {
|
||||||
|
@ -523,12 +523,12 @@ impl FileType {
|
||||||
#[cfg(all(not(feature = "id3v2"), feature = "riff_info_list"))]
|
#[cfg(all(not(feature = "id3v2"), feature = "riff_info_list"))]
|
||||||
FileType::WAV => TagType::RIFFInfo,
|
FileType::WAV => TagType::RIFFInfo,
|
||||||
#[cfg(all(not(feature = "id3v2"), feature = "id3v1"))]
|
#[cfg(all(not(feature = "id3v2"), feature = "id3v1"))]
|
||||||
FileType::MP3 => TagType::ID3v1,
|
FileType::MPEG => TagType::ID3v1,
|
||||||
#[cfg(all(not(feature = "id3v2"), not(feature = "id3v1"), feature = "ape"))]
|
#[cfg(all(not(feature = "id3v2"), not(feature = "id3v1"), feature = "ape"))]
|
||||||
FileType::MP3 => TagType::APE,
|
FileType::MPEG => TagType::APE,
|
||||||
FileType::AIFF | FileType::MP3 | FileType::WAV => TagType::ID3v2,
|
FileType::AIFF | FileType::MPEG | FileType::WAV => TagType::ID3v2,
|
||||||
#[cfg(all(not(feature = "ape"), feature = "id3v1"))]
|
#[cfg(all(not(feature = "ape"), feature = "id3v1"))]
|
||||||
FileType::MP3 | FileType::WavPack => TagType::ID3v1,
|
FileType::MPEG | FileType::WavPack => TagType::ID3v1,
|
||||||
FileType::APE | FileType::WavPack => TagType::APE,
|
FileType::APE | FileType::WavPack => TagType::APE,
|
||||||
FileType::FLAC | FileType::Opus | FileType::Vorbis | FileType::Speex => {
|
FileType::FLAC | FileType::Opus | FileType::Vorbis | FileType::Speex => {
|
||||||
TagType::VorbisComments
|
TagType::VorbisComments
|
||||||
|
@ -558,13 +558,13 @@ impl FileType {
|
||||||
/// ```rust
|
/// ```rust
|
||||||
/// use lofty::{FileType, TagType};
|
/// use lofty::{FileType, TagType};
|
||||||
///
|
///
|
||||||
/// let file_type = FileType::MP3;
|
/// let file_type = FileType::MPEG;
|
||||||
/// assert!(file_type.supports_tag_type(TagType::ID3v2));
|
/// assert!(file_type.supports_tag_type(TagType::ID3v2));
|
||||||
/// ```
|
/// ```
|
||||||
pub fn supports_tag_type(&self, tag_type: TagType) -> bool {
|
pub fn supports_tag_type(&self, tag_type: TagType) -> bool {
|
||||||
match self {
|
match self {
|
||||||
#[cfg(feature = "id3v2")]
|
#[cfg(feature = "id3v2")]
|
||||||
FileType::AIFF | FileType::APE | FileType::MP3 | FileType::WAV
|
FileType::AIFF | FileType::APE | FileType::MPEG | FileType::WAV
|
||||||
if tag_type == TagType::ID3v2 =>
|
if tag_type == TagType::ID3v2 =>
|
||||||
{
|
{
|
||||||
true
|
true
|
||||||
|
@ -572,9 +572,9 @@ impl FileType {
|
||||||
#[cfg(feature = "aiff_text_chunks")]
|
#[cfg(feature = "aiff_text_chunks")]
|
||||||
FileType::AIFF if tag_type == TagType::AIFFText => true,
|
FileType::AIFF if tag_type == TagType::AIFFText => true,
|
||||||
#[cfg(feature = "id3v1")]
|
#[cfg(feature = "id3v1")]
|
||||||
FileType::APE | FileType::MP3 | FileType::WavPack if tag_type == TagType::ID3v1 => true,
|
FileType::APE | FileType::MPEG | FileType::WavPack if tag_type == TagType::ID3v1 => true,
|
||||||
#[cfg(feature = "ape")]
|
#[cfg(feature = "ape")]
|
||||||
FileType::APE | FileType::MP3 | FileType::WavPack if tag_type == TagType::APE => true,
|
FileType::APE | FileType::MPEG | FileType::WavPack if tag_type == TagType::APE => true,
|
||||||
#[cfg(feature = "vorbis_comments")]
|
#[cfg(feature = "vorbis_comments")]
|
||||||
FileType::Opus | FileType::FLAC | FileType::Vorbis | FileType::Speex => {
|
FileType::Opus | FileType::FLAC | FileType::Vorbis | FileType::Speex => {
|
||||||
tag_type == TagType::VorbisComments
|
tag_type == TagType::VorbisComments
|
||||||
|
@ -605,7 +605,7 @@ impl FileType {
|
||||||
/// use lofty::FileType;
|
/// use lofty::FileType;
|
||||||
///
|
///
|
||||||
/// let extension = "mp3";
|
/// let extension = "mp3";
|
||||||
/// assert_eq!(FileType::from_ext(extension), Some(FileType::MP3));
|
/// assert_eq!(FileType::from_ext(extension), Some(FileType::MPEG));
|
||||||
/// ```
|
/// ```
|
||||||
pub fn from_ext<E>(ext: E) -> Option<Self>
|
pub fn from_ext<E>(ext: E) -> Option<Self>
|
||||||
where
|
where
|
||||||
|
@ -616,7 +616,7 @@ impl FileType {
|
||||||
match ext.as_str() {
|
match ext.as_str() {
|
||||||
"ape" => Some(Self::APE),
|
"ape" => Some(Self::APE),
|
||||||
"aiff" | "aif" | "afc" | "aifc" => Some(Self::AIFF),
|
"aiff" | "aif" | "afc" | "aifc" => Some(Self::AIFF),
|
||||||
"mp3" | "mp2" | "mp1" => Some(Self::MP3),
|
"mp3" | "mp2" | "mp1" => Some(Self::MPEG),
|
||||||
"wav" | "wave" => Some(Self::WAV),
|
"wav" | "wave" => Some(Self::WAV),
|
||||||
"wv" => Some(Self::WavPack),
|
"wv" => Some(Self::WavPack),
|
||||||
"opus" => Some(Self::Opus),
|
"opus" => Some(Self::Opus),
|
||||||
|
@ -648,7 +648,7 @@ impl FileType {
|
||||||
/// use std::path::Path;
|
/// use std::path::Path;
|
||||||
///
|
///
|
||||||
/// let path = Path::new("path/to/my.mp3");
|
/// let path = Path::new("path/to/my.mp3");
|
||||||
/// assert_eq!(FileType::from_path(path), Some(FileType::MP3));
|
/// assert_eq!(FileType::from_path(path), Some(FileType::MPEG));
|
||||||
/// ```
|
/// ```
|
||||||
pub fn from_path<P>(path: P) -> Option<Self>
|
pub fn from_path<P>(path: P) -> Option<Self>
|
||||||
where
|
where
|
||||||
|
@ -733,7 +733,7 @@ impl FileType {
|
||||||
// Safe to index, since we return early on an empty buffer
|
// Safe to index, since we return early on an empty buffer
|
||||||
match buf[0] {
|
match buf[0] {
|
||||||
77 if buf.starts_with(b"MAC") => Some(Self::APE),
|
77 if buf.starts_with(b"MAC") => Some(Self::APE),
|
||||||
255 if buf.len() >= 2 && verify_frame_sync([buf[0], buf[1]]) => Some(Self::MP3),
|
255 if buf.len() >= 2 && verify_frame_sync([buf[0], buf[1]]) => Some(Self::MPEG),
|
||||||
70 if buf.len() >= 12 && &buf[..4] == b"FORM" => {
|
70 if buf.len() >= 12 && &buf[..4] == b"FORM" => {
|
||||||
let id = &buf[8..12];
|
let id = &buf[8..12];
|
||||||
|
|
||||||
|
|
|
@ -41,7 +41,7 @@ macro_rules! impl_accessor {
|
||||||
/// ## Supported file types
|
/// ## Supported file types
|
||||||
///
|
///
|
||||||
/// * [`FileType::APE`](crate::FileType::APE)
|
/// * [`FileType::APE`](crate::FileType::APE)
|
||||||
/// * [`FileType::MP3`](crate::FileType::MP3)
|
/// * [`FileType::MP3`](crate::FileType::MPEG)
|
||||||
/// * [`FileType::WavPack`](crate::FileType::WavPack)
|
/// * [`FileType::WavPack`](crate::FileType::WavPack)
|
||||||
///
|
///
|
||||||
/// ## Conversions
|
/// ## Conversions
|
||||||
|
|
|
@ -15,7 +15,7 @@ pub(crate) fn write_id3v1(writer: &mut File, tag: &Id3v1TagRef<'_>) -> Result<()
|
||||||
let probe = Probe::new(writer).guess_file_type()?;
|
let probe = Probe::new(writer).guess_file_type()?;
|
||||||
|
|
||||||
match probe.file_type() {
|
match probe.file_type() {
|
||||||
Some(FileType::APE | FileType::MP3 | FileType::WavPack) => {},
|
Some(FileType::APE | FileType::MPEG | FileType::WavPack) => {},
|
||||||
_ => err!(UnsupportedTag),
|
_ => err!(UnsupportedTag),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -64,7 +64,7 @@ macro_rules! impl_accessor {
|
||||||
///
|
///
|
||||||
/// ## Supported file types
|
/// ## Supported file types
|
||||||
///
|
///
|
||||||
/// * [`FileType::MP3`](crate::FileType::MP3)
|
/// * [`FileType::MP3`](crate::FileType::MPEG)
|
||||||
/// * [`FileType::WAV`](crate::FileType::WAV)
|
/// * [`FileType::WAV`](crate::FileType::WAV)
|
||||||
/// * [`FileType::AIFF`](crate::FileType::AIFF)
|
/// * [`FileType::AIFF`](crate::FileType::AIFF)
|
||||||
/// * [`FileType::APE`](crate::FileType::APE) **(READ ONLY)**
|
/// * [`FileType::APE`](crate::FileType::APE) **(READ ONLY)**
|
||||||
|
|
|
@ -42,7 +42,7 @@ pub(crate) fn write_id3v2<'a, I: Iterator<Item = FrameRef<'a>> + 'a>(
|
||||||
let data = probe.into_inner();
|
let data = probe.into_inner();
|
||||||
|
|
||||||
match file_type {
|
match file_type {
|
||||||
Some(FileType::APE | FileType::MP3 | FileType::FLAC) => {},
|
Some(FileType::APE | FileType::MPEG | FileType::FLAC) => {},
|
||||||
// Formats such as WAV and AIFF store the ID3v2 tag in an 'ID3 ' chunk rather than at the beginning of the file
|
// Formats such as WAV and AIFF store the ID3v2 tag in an 'ID3 ' chunk rather than at the beginning of the file
|
||||||
Some(FileType::WAV) => {
|
Some(FileType::WAV) => {
|
||||||
tag.flags.footer = false;
|
tag.flags.footer = false;
|
||||||
|
|
|
@ -91,7 +91,7 @@
|
||||||
//! ```rust
|
//! ```rust
|
||||||
//! # use lofty::LoftyError;
|
//! # use lofty::LoftyError;
|
||||||
//! # fn main() -> Result<(), LoftyError> {
|
//! # fn main() -> Result<(), LoftyError> {
|
||||||
//! use lofty::mp3::Mp3File;
|
//! use lofty::mp3::MPEGFile;
|
||||||
//! use lofty::{AudioFile, TagType};
|
//! use lofty::{AudioFile, TagType};
|
||||||
//! use std::fs::File;
|
//! use std::fs::File;
|
||||||
//!
|
//!
|
||||||
|
@ -99,7 +99,7 @@
|
||||||
//! let mut file_content = File::open(path)?;
|
//! let mut file_content = File::open(path)?;
|
||||||
//!
|
//!
|
||||||
//! // We are expecting an MP3 file
|
//! // We are expecting an MP3 file
|
||||||
//! let mp3_file = Mp3File::read_from(&mut file_content, true)?;
|
//! let mp3_file = MPEGFile::read_from(&mut file_content, true)?;
|
||||||
//!
|
//!
|
||||||
//! assert_eq!(mp3_file.properties().channels(), 2);
|
//! assert_eq!(mp3_file.properties().channels(), 2);
|
||||||
//!
|
//!
|
||||||
|
|
|
@ -309,7 +309,7 @@ impl XingHeader {
|
||||||
b"Xing" | b"Info" => {
|
b"Xing" | b"Info" => {
|
||||||
if reader_len < 16 {
|
if reader_len < 16 {
|
||||||
return Err(FileDecodingError::new(
|
return Err(FileDecodingError::new(
|
||||||
FileType::MP3,
|
FileType::MPEG,
|
||||||
"Xing header has an invalid size (< 16)",
|
"Xing header has an invalid size (< 16)",
|
||||||
)
|
)
|
||||||
.into());
|
.into());
|
||||||
|
@ -336,7 +336,7 @@ impl XingHeader {
|
||||||
b"VBRI" => {
|
b"VBRI" => {
|
||||||
if reader_len < 32 {
|
if reader_len < 32 {
|
||||||
return Err(FileDecodingError::new(
|
return Err(FileDecodingError::new(
|
||||||
FileType::MP3,
|
FileType::MPEG,
|
||||||
"VBRI header has an invalid size (< 32)",
|
"VBRI header has an invalid size (< 32)",
|
||||||
)
|
)
|
||||||
.into());
|
.into());
|
||||||
|
|
|
@ -18,10 +18,10 @@ use crate::tag::TagType;
|
||||||
|
|
||||||
use lofty_attr::LoftyFile;
|
use lofty_attr::LoftyFile;
|
||||||
|
|
||||||
/// An MP3 file
|
/// An MPEG file
|
||||||
#[derive(Default, LoftyFile)]
|
#[derive(LoftyFile, Default)]
|
||||||
#[lofty(read_fn = "read::read_from")]
|
#[lofty(read_fn = "read::read_from")]
|
||||||
pub struct Mp3File {
|
pub struct MPEGFile {
|
||||||
/// An ID3v2 tag
|
/// An ID3v2 tag
|
||||||
#[cfg(feature = "id3v2")]
|
#[cfg(feature = "id3v2")]
|
||||||
#[lofty(tag_type = "ID3v2")]
|
#[lofty(tag_type = "ID3v2")]
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
use super::header::{cmp_header, search_for_frame_sync, Header, HeaderCmpResult, XingHeader};
|
use super::header::{cmp_header, search_for_frame_sync, Header, HeaderCmpResult, XingHeader};
|
||||||
use super::{Mp3File, Mp3Properties};
|
use super::{MPEGFile, Mp3Properties};
|
||||||
use crate::ape::constants::APE_PREAMBLE;
|
use crate::ape::constants::APE_PREAMBLE;
|
||||||
use crate::ape::header::read_ape_header;
|
use crate::ape::header::read_ape_header;
|
||||||
#[cfg(feature = "ape")]
|
#[cfg(feature = "ape")]
|
||||||
|
@ -16,11 +16,11 @@ use std::io::{Read, Seek, SeekFrom};
|
||||||
|
|
||||||
use byteorder::{BigEndian, ReadBytesExt};
|
use byteorder::{BigEndian, ReadBytesExt};
|
||||||
|
|
||||||
pub(super) fn read_from<R>(reader: &mut R, read_properties: bool) -> Result<Mp3File>
|
pub(super) fn read_from<R>(reader: &mut R, read_properties: bool) -> Result<MPEGFile>
|
||||||
where
|
where
|
||||||
R: Read + Seek,
|
R: Read + Seek,
|
||||||
{
|
{
|
||||||
let mut file = Mp3File::default();
|
let mut file = MPEGFile::default();
|
||||||
|
|
||||||
let mut first_frame_offset = 0;
|
let mut first_frame_offset = 0;
|
||||||
let mut first_frame_header = None;
|
let mut first_frame_header = None;
|
||||||
|
@ -141,7 +141,7 @@ where
|
||||||
None => {
|
None => {
|
||||||
// The search for sync bits was unsuccessful
|
// The search for sync bits was unsuccessful
|
||||||
return Err(FileDecodingError::new(
|
return Err(FileDecodingError::new(
|
||||||
FileType::MP3,
|
FileType::MPEG,
|
||||||
"File contains an invalid frame",
|
"File contains an invalid frame",
|
||||||
)
|
)
|
||||||
.into());
|
.into());
|
||||||
|
@ -149,7 +149,7 @@ where
|
||||||
};
|
};
|
||||||
|
|
||||||
if first_frame_header.sample_rate == 0 {
|
if first_frame_header.sample_rate == 0 {
|
||||||
return Err(FileDecodingError::new(FileType::MP3, "Sample rate is 0").into());
|
return Err(FileDecodingError::new(FileType::MPEG, "Sample rate is 0").into());
|
||||||
}
|
}
|
||||||
|
|
||||||
let first_frame_offset = first_frame_offset;
|
let first_frame_offset = first_frame_offset;
|
||||||
|
|
24
src/probe.rs
24
src/probe.rs
|
@ -6,7 +6,7 @@ use crate::iff::aiff::AiffFile;
|
||||||
use crate::iff::wav::WavFile;
|
use crate::iff::wav::WavFile;
|
||||||
use crate::macros::err;
|
use crate::macros::err;
|
||||||
use crate::mp3::header::search_for_frame_sync;
|
use crate::mp3::header::search_for_frame_sync;
|
||||||
use crate::mp3::Mp3File;
|
use crate::mp3::MPEGFile;
|
||||||
use crate::mp4::Mp4File;
|
use crate::mp4::Mp4File;
|
||||||
use crate::ogg::opus::OpusFile;
|
use crate::ogg::opus::OpusFile;
|
||||||
use crate::ogg::speex::SpeexFile;
|
use crate::ogg::speex::SpeexFile;
|
||||||
|
@ -36,7 +36,7 @@ use std::path::Path;
|
||||||
/// let probe = Probe::open("path/to/my.mp3")?;
|
/// let probe = Probe::open("path/to/my.mp3")?;
|
||||||
///
|
///
|
||||||
/// // Inferred from the `mp3` extension
|
/// // Inferred from the `mp3` extension
|
||||||
/// assert_eq!(probe.file_type(), Some(FileType::MP3));
|
/// assert_eq!(probe.file_type(), Some(FileType::MPEG));
|
||||||
/// # Ok(())
|
/// # Ok(())
|
||||||
/// # }
|
/// # }
|
||||||
/// ```
|
/// ```
|
||||||
|
@ -52,7 +52,7 @@ use std::path::Path;
|
||||||
/// let probe = Probe::open("path/to/my.mp3")?.guess_file_type()?;
|
/// let probe = Probe::open("path/to/my.mp3")?.guess_file_type()?;
|
||||||
///
|
///
|
||||||
/// // Inferred from the file's content
|
/// // Inferred from the file's content
|
||||||
/// assert_eq!(probe.file_type(), Some(FileType::MP3));
|
/// assert_eq!(probe.file_type(), Some(FileType::MPEG));
|
||||||
/// # Ok(())
|
/// # Ok(())
|
||||||
/// # }
|
/// # }
|
||||||
/// ```
|
/// ```
|
||||||
|
@ -126,7 +126,7 @@ impl<R: Read> Probe<R> {
|
||||||
/// let file = File::open(my_mp3_path)?;
|
/// let file = File::open(my_mp3_path)?;
|
||||||
/// let reader = BufReader::new(file);
|
/// let reader = BufReader::new(file);
|
||||||
///
|
///
|
||||||
/// let probe = Probe::with_file_type(reader, FileType::MP3);
|
/// let probe = Probe::with_file_type(reader, FileType::MPEG);
|
||||||
/// # Ok(()) }
|
/// # Ok(()) }
|
||||||
/// ```
|
/// ```
|
||||||
pub fn with_file_type(reader: R, file_type: FileType) -> Self {
|
pub fn with_file_type(reader: R, file_type: FileType) -> Self {
|
||||||
|
@ -166,9 +166,9 @@ impl<R: Read> Probe<R> {
|
||||||
/// let mut probe = Probe::new(reader);
|
/// let mut probe = Probe::new(reader);
|
||||||
/// assert_eq!(probe.file_type(), None);
|
/// assert_eq!(probe.file_type(), None);
|
||||||
///
|
///
|
||||||
/// probe.set_file_type(FileType::MP3);
|
/// probe.set_file_type(FileType::MPEG);
|
||||||
///
|
///
|
||||||
/// assert_eq!(probe.file_type(), Some(FileType::MP3));
|
/// assert_eq!(probe.file_type(), Some(FileType::MPEG));
|
||||||
/// # Ok(()) }
|
/// # Ok(()) }
|
||||||
/// ```
|
/// ```
|
||||||
pub fn set_file_type(&mut self, file_type: FileType) {
|
pub fn set_file_type(&mut self, file_type: FileType) {
|
||||||
|
@ -213,7 +213,7 @@ impl Probe<BufReader<File>> {
|
||||||
/// let probe = Probe::open("path/to/my.mp3")?;
|
/// let probe = Probe::open("path/to/my.mp3")?;
|
||||||
///
|
///
|
||||||
/// // Guessed from the "mp3" extension, see `FileType::from_ext`
|
/// // Guessed from the "mp3" extension, see `FileType::from_ext`
|
||||||
/// assert_eq!(probe.file_type(), Some(FileType::MP3));
|
/// assert_eq!(probe.file_type(), Some(FileType::MPEG));
|
||||||
/// # Ok(()) }
|
/// # Ok(()) }
|
||||||
/// ```
|
/// ```
|
||||||
pub fn open<P>(path: P) -> Result<Self>
|
pub fn open<P>(path: P) -> Result<Self>
|
||||||
|
@ -252,7 +252,7 @@ impl<R: Read + Seek> Probe<R> {
|
||||||
/// let probe = Probe::new(reader).guess_file_type()?;
|
/// let probe = Probe::new(reader).guess_file_type()?;
|
||||||
///
|
///
|
||||||
/// // Determined the file is MP3 from the content
|
/// // Determined the file is MP3 from the content
|
||||||
/// assert_eq!(probe.file_type(), Some(FileType::MP3));
|
/// assert_eq!(probe.file_type(), Some(FileType::MPEG));
|
||||||
/// # Ok(()) }
|
/// # Ok(()) }
|
||||||
/// ```
|
/// ```
|
||||||
pub fn guess_file_type(mut self) -> std::io::Result<Self> {
|
pub fn guess_file_type(mut self) -> std::io::Result<Self> {
|
||||||
|
@ -302,7 +302,7 @@ impl<R: Read + Seek> Probe<R> {
|
||||||
b"fLaC" => Ok(Some(FileType::FLAC)),
|
b"fLaC" => Ok(Some(FileType::FLAC)),
|
||||||
// Search for a frame sync, which may be preceded by junk
|
// Search for a frame sync, which may be preceded by junk
|
||||||
_ if search_for_frame_sync(&mut self.inner)?.is_some() => {
|
_ if search_for_frame_sync(&mut self.inner)?.is_some() => {
|
||||||
Ok(Some(FileType::MP3))
|
Ok(Some(FileType::MPEG))
|
||||||
},
|
},
|
||||||
_ => Ok(None),
|
_ => Ok(None),
|
||||||
};
|
};
|
||||||
|
@ -365,7 +365,7 @@ impl<R: Read + Seek> Probe<R> {
|
||||||
FileType::AIFF => AiffFile::read_from(reader, read_properties)?.into(),
|
FileType::AIFF => AiffFile::read_from(reader, read_properties)?.into(),
|
||||||
FileType::APE => ApeFile::read_from(reader, read_properties)?.into(),
|
FileType::APE => ApeFile::read_from(reader, read_properties)?.into(),
|
||||||
FileType::FLAC => FlacFile::read_from(reader, read_properties)?.into(),
|
FileType::FLAC => FlacFile::read_from(reader, read_properties)?.into(),
|
||||||
FileType::MP3 => Mp3File::read_from(reader, read_properties)?.into(),
|
FileType::MPEG => MPEGFile::read_from(reader, read_properties)?.into(),
|
||||||
FileType::Opus => OpusFile::read_from(reader, read_properties)?.into(),
|
FileType::Opus => OpusFile::read_from(reader, read_properties)?.into(),
|
||||||
FileType::Vorbis => VorbisFile::read_from(reader, read_properties)?.into(),
|
FileType::Vorbis => VorbisFile::read_from(reader, read_properties)?.into(),
|
||||||
FileType::WAV => WavFile::read_from(reader, read_properties)?.into(),
|
FileType::WAV => WavFile::read_from(reader, read_properties)?.into(),
|
||||||
|
@ -473,7 +473,7 @@ mod tests {
|
||||||
let data: Vec<u8> = data.into_iter().flatten().copied().collect();
|
let data: Vec<u8> = data.into_iter().flatten().copied().collect();
|
||||||
let data = std::io::Cursor::new(&data);
|
let data = std::io::Cursor::new(&data);
|
||||||
let probe = Probe::new(data).guess_file_type().unwrap();
|
let probe = Probe::new(data).guess_file_type().unwrap();
|
||||||
assert_eq!(probe.file_type(), Some(FileType::MP3));
|
assert_eq!(probe.file_type(), Some(FileType::MPEG));
|
||||||
}
|
}
|
||||||
|
|
||||||
fn test_probe(path: &str, expected_file_type_guess: FileType) {
|
fn test_probe(path: &str, expected_file_type_guess: FileType) {
|
||||||
|
@ -516,7 +516,7 @@ mod tests {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn probe_mp3_with_id3v2() {
|
fn probe_mp3_with_id3v2() {
|
||||||
test_probe("tests/files/assets/minimal/full_test.mp3", FileType::MP3);
|
test_probe("tests/files/assets/minimal/full_test.mp3", FileType::MPEG);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|
|
@ -62,7 +62,7 @@ mod tests {
|
||||||
use crate::ape::{ApeFile, ApeProperties};
|
use crate::ape::{ApeFile, ApeProperties};
|
||||||
use crate::flac::FlacFile;
|
use crate::flac::FlacFile;
|
||||||
use crate::iff::{AiffFile, WavFile, WavFormat, WavProperties};
|
use crate::iff::{AiffFile, WavFile, WavFormat, WavProperties};
|
||||||
use crate::mp3::{ChannelMode, Emphasis, Layer, Mp3File, Mp3Properties, MpegVersion};
|
use crate::mp3::{ChannelMode, Emphasis, Layer, MPEGFile, Mp3Properties, MpegVersion};
|
||||||
use crate::mp4::{AudioObjectType, Mp4Codec, Mp4File, Mp4Properties};
|
use crate::mp4::{AudioObjectType, Mp4Codec, Mp4File, Mp4Properties};
|
||||||
use crate::ogg::{
|
use crate::ogg::{
|
||||||
OpusFile, OpusProperties, SpeexFile, SpeexProperties, VorbisFile, VorbisProperties,
|
OpusFile, OpusProperties, SpeexFile, SpeexProperties, VorbisFile, VorbisProperties,
|
||||||
|
@ -287,7 +287,7 @@ mod tests {
|
||||||
#[test]
|
#[test]
|
||||||
fn mp1_properties() {
|
fn mp1_properties() {
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
get_properties::<Mp3File>("tests/files/assets/minimal/full_test.mp1"),
|
get_properties::<MPEGFile>("tests/files/assets/minimal/full_test.mp1"),
|
||||||
MP1_PROPERTIES
|
MP1_PROPERTIES
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -295,7 +295,7 @@ mod tests {
|
||||||
#[test]
|
#[test]
|
||||||
fn mp2_properties() {
|
fn mp2_properties() {
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
get_properties::<Mp3File>("tests/files/assets/minimal/full_test.mp2"),
|
get_properties::<MPEGFile>("tests/files/assets/minimal/full_test.mp2"),
|
||||||
MP2_PROPERTIES
|
MP2_PROPERTIES
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -303,7 +303,7 @@ mod tests {
|
||||||
#[test]
|
#[test]
|
||||||
fn mp3_properties() {
|
fn mp3_properties() {
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
get_properties::<Mp3File>("tests/files/assets/minimal/full_test.mp3"),
|
get_properties::<MPEGFile>("tests/files/assets/minimal/full_test.mp3"),
|
||||||
MP3_PROPERTIES
|
MP3_PROPERTIES
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,7 +31,7 @@ pub(crate) fn write_tag(tag: &Tag, file: &mut File, file_type: FileType) -> Resu
|
||||||
FileType::FLAC | FileType::Opus | FileType::Speex | FileType::Vorbis => {
|
FileType::FLAC | FileType::Opus | FileType::Speex | FileType::Vorbis => {
|
||||||
crate::ogg::write::write_to(file, tag, file_type)
|
crate::ogg::write::write_to(file, tag, file_type)
|
||||||
},
|
},
|
||||||
FileType::MP3 => mp3::write::write_to(file, tag),
|
FileType::MPEG => mp3::write::write_to(file, tag),
|
||||||
#[cfg(feature = "mp4_ilst")]
|
#[cfg(feature = "mp4_ilst")]
|
||||||
FileType::MP4 => {
|
FileType::MP4 => {
|
||||||
crate::mp4::ilst::write::write_to(file, &mut Into::<Ilst>::into(tag.clone()).as_ref())
|
crate::mp4::ilst::write::write_to(file, &mut Into::<Ilst>::into(tag.clone()).as_ref())
|
||||||
|
|
|
@ -7,7 +7,7 @@ fn read() {
|
||||||
// Here we have an MP3 file with an ID3v2, ID3v1, and an APEv2 tag
|
// Here we have an MP3 file with an ID3v2, ID3v1, and an APEv2 tag
|
||||||
let file = lofty::read_from_path("tests/files/assets/minimal/full_test.mp3", false).unwrap();
|
let file = lofty::read_from_path("tests/files/assets/minimal/full_test.mp3", false).unwrap();
|
||||||
|
|
||||||
assert_eq!(file.file_type(), FileType::MP3);
|
assert_eq!(file.file_type(), FileType::MPEG);
|
||||||
|
|
||||||
// Verify the ID3v2 tag first
|
// Verify the ID3v2 tag first
|
||||||
crate::verify_artist!(file, primary_tag, "Foo artist", 1);
|
crate::verify_artist!(file, primary_tag, "Foo artist", 1);
|
||||||
|
@ -26,7 +26,7 @@ fn read_with_junk_bytes_between_frames() {
|
||||||
lofty::read_from_path("tests/files/assets/junk_between_id3_and_mp3.mp3", true).unwrap();
|
lofty::read_from_path("tests/files/assets/junk_between_id3_and_mp3.mp3", true).unwrap();
|
||||||
|
|
||||||
// note that the file contains ID3v2 and ID3v1 data
|
// note that the file contains ID3v2 and ID3v1 data
|
||||||
assert_eq!(file.file_type(), FileType::MP3);
|
assert_eq!(file.file_type(), FileType::MPEG);
|
||||||
|
|
||||||
let id3v2_tag = &file.tags()[0];
|
let id3v2_tag = &file.tags()[0];
|
||||||
assert_eq!(id3v2_tag.artist(), Some("artist test"));
|
assert_eq!(id3v2_tag.artist(), Some("artist test"));
|
||||||
|
@ -49,7 +49,7 @@ fn write() {
|
||||||
|
|
||||||
let mut tagged_file = lofty::read_from(&mut file, false).unwrap();
|
let mut tagged_file = lofty::read_from(&mut file, false).unwrap();
|
||||||
|
|
||||||
assert_eq!(tagged_file.file_type(), FileType::MP3);
|
assert_eq!(tagged_file.file_type(), FileType::MPEG);
|
||||||
|
|
||||||
// ID3v2
|
// ID3v2
|
||||||
crate::set_artist!(tagged_file, primary_tag_mut, "Foo artist", 1 => file, "Bar artist");
|
crate::set_artist!(tagged_file, primary_tag_mut, "Foo artist", 1 => file, "Bar artist");
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
use lofty::ape::ApeFile;
|
use lofty::ape::ApeFile;
|
||||||
use lofty::flac::FlacFile;
|
use lofty::flac::FlacFile;
|
||||||
use lofty::iff::{AiffFile, WavFile};
|
use lofty::iff::{AiffFile, WavFile};
|
||||||
use lofty::mp3::Mp3File;
|
use lofty::mp3::MPEGFile;
|
||||||
use lofty::mp4::Mp4File;
|
use lofty::mp4::Mp4File;
|
||||||
use lofty::AudioFile;
|
use lofty::AudioFile;
|
||||||
|
|
||||||
|
@ -46,9 +46,9 @@ fn zero_audio_flac() {
|
||||||
fn zero_audio_mp3() {
|
fn zero_audio_mp3() {
|
||||||
let path = "tests/files/assets/zero/zero.mp3";
|
let path = "tests/files/assets/zero/zero.mp3";
|
||||||
// A zero-size MP3 will error, since we need MPEG frames to extract audio properties
|
// A zero-size MP3 will error, since we need MPEG frames to extract audio properties
|
||||||
assert!(!read_file_with_properties::<Mp3File>(path));
|
assert!(!read_file_with_properties::<MPEGFile>(path));
|
||||||
|
|
||||||
assert!(read_file_no_properties::<Mp3File>(path))
|
assert!(read_file_no_properties::<MPEGFile>(path))
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|
|
@ -6,8 +6,8 @@ use std::time::Instant;
|
||||||
|
|
||||||
mod aifffile_read_from;
|
mod aifffile_read_from;
|
||||||
mod flacfile_read_from;
|
mod flacfile_read_from;
|
||||||
mod mp3file_read_from;
|
|
||||||
mod mp4file_read_from;
|
mod mp4file_read_from;
|
||||||
|
mod mpegfile_read_from;
|
||||||
mod opusfile_read_from;
|
mod opusfile_read_from;
|
||||||
mod pictureinformation_from_jpeg;
|
mod pictureinformation_from_jpeg;
|
||||||
mod pictureinformation_from_png;
|
mod pictureinformation_from_png;
|
||||||
|
|
|
@ -1,7 +0,0 @@
|
||||||
use crate::oom_test;
|
|
||||||
use lofty::mp3::Mp3File;
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn oom1() {
|
|
||||||
oom_test::<Mp3File>("mp3file_read_from/oom-f8730cbfa5682ab12343ccb70de9b71a061ef4d0");
|
|
||||||
}
|
|
7
tests/fuzz/mpegfile_read_from.rs
Normal file
7
tests/fuzz/mpegfile_read_from.rs
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
use crate::oom_test;
|
||||||
|
use lofty::mp3::MPEGFile;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn oom1() {
|
||||||
|
oom_test::<MPEGFile>("mpegfile_read_from/oom-f8730cbfa5682ab12343ccb70de9b71a061ef4d0");
|
||||||
|
}
|
Loading…
Reference in a new issue