mirror of
https://github.com/Serial-ATA/lofty-rs
synced 2025-01-21 00:23:55 +00:00
Fix feature issue and add AIFF bench
Signed-off-by: Serial <69764315+Serial-ATA@users.noreply.github.com>
This commit is contained in:
parent
f490879263
commit
8b82e0969b
2 changed files with 28 additions and 22 deletions
|
@ -9,6 +9,7 @@ macro_rules! test_read {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
test_read!(read_aiff, "tests/assets/a_text.aiff");
|
||||||
test_read!(read_ape, "tests/assets/a.ape");
|
test_read!(read_ape, "tests/assets/a.ape");
|
||||||
test_read!(read_flac, "tests/assets/a.flac");
|
test_read!(read_flac, "tests/assets/a.flac");
|
||||||
test_read!(read_m4a, "tests/assets/a.m4a");
|
test_read!(read_m4a, "tests/assets/a.m4a");
|
||||||
|
@ -19,6 +20,7 @@ test_read!(read_riff, "tests/assets/a.wav");
|
||||||
|
|
||||||
fn bench_sig(c: &mut Criterion) {
|
fn bench_sig(c: &mut Criterion) {
|
||||||
let mut g = c.benchmark_group("From signature");
|
let mut g = c.benchmark_group("From signature");
|
||||||
|
g.bench_function("AIFF", |b| b.iter(read_aiff));
|
||||||
g.bench_function("APE", |b| b.iter(read_ape));
|
g.bench_function("APE", |b| b.iter(read_ape));
|
||||||
g.bench_function("FLAC", |b| b.iter(read_flac));
|
g.bench_function("FLAC", |b| b.iter(read_flac));
|
||||||
g.bench_function("MP4", |b| b.iter(read_m4a));
|
g.bench_function("MP4", |b| b.iter(read_m4a));
|
||||||
|
|
16
src/tag.rs
16
src/tag.rs
|
@ -240,7 +240,7 @@ impl TagType {
|
||||||
77 if sig.starts_with(&MAC) => Ok(Self::Ape),
|
77 if sig.starts_with(&MAC) => Ok(Self::Ape),
|
||||||
#[cfg(feature = "format-id3")]
|
#[cfg(feature = "format-id3")]
|
||||||
73 if sig.starts_with(&ID3) => Ok(Self::Id3v2(Id3Format::Default)),
|
73 if sig.starts_with(&ID3) => Ok(Self::Id3v2(Id3Format::Default)),
|
||||||
#[cfg(feature = "format-id3")]
|
#[cfg(any(feature = "format-id3", feature = "format-aiff"))]
|
||||||
70 if sig.starts_with(&FORM) => {
|
70 if sig.starts_with(&FORM) => {
|
||||||
use byteorder::{BigEndian, LittleEndian, ReadBytesExt};
|
use byteorder::{BigEndian, LittleEndian, ReadBytesExt};
|
||||||
|
|
||||||
|
@ -249,10 +249,9 @@ impl TagType {
|
||||||
let mut id = [0; 4];
|
let mut id = [0; 4];
|
||||||
data.read_exact(&mut id)?;
|
data.read_exact(&mut id)?;
|
||||||
|
|
||||||
if &id != b"AIFF" && &id != b"AIFC" {
|
if &id == b"AIFF" || &id == b"AIFC" {
|
||||||
return Err(LoftyError::UnknownFormat);
|
#[cfg(feature = "format-id3")]
|
||||||
}
|
{
|
||||||
|
|
||||||
let mut found_id3 = false;
|
let mut found_id3 = false;
|
||||||
|
|
||||||
while let (Ok(fourcc), Ok(size)) = (
|
while let (Ok(fourcc), Ok(size)) = (
|
||||||
|
@ -274,8 +273,13 @@ impl TagType {
|
||||||
if found_id3 {
|
if found_id3 {
|
||||||
return Ok(Self::Id3v2(Id3Format::Form));
|
return Ok(Self::Id3v2(Id3Format::Form));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Ok(Self::AiffText)
|
#[cfg(feature = "format-aiff")]
|
||||||
|
return Ok(Self::AiffText);
|
||||||
|
}
|
||||||
|
|
||||||
|
Err(LoftyError::UnknownFormat)
|
||||||
},
|
},
|
||||||
#[cfg(feature = "format-flac")]
|
#[cfg(feature = "format-flac")]
|
||||||
102 if sig.starts_with(&FLAC) => Ok(Self::Ogg(OggFormat::Flac)),
|
102 if sig.starts_with(&FLAC) => Ok(Self::Ogg(OggFormat::Flac)),
|
||||||
|
|
Loading…
Reference in a new issue