Compare commits

..

1 Commits

Author SHA1 Message Date
b9d9c7feeb tsk-49: Initialize FileType with file type of the media
Some checks failed
Release Tagging / release (pull_request) Successful in 48s
Rust Build / Check (pull_request) Successful in 31s
Rust Build / Clippy (pull_request) Successful in 34s
Rust Build / Rustfmt (pull_request) Failing after 39s
Rust Build / Test Suite (pull_request) Successful in 46s
Rust Build / build (pull_request) Successful in 41s
2025-11-06 10:43:52 -05:00
5 changed files with 23 additions and 27 deletions

2
Cargo.lock generated
View File

@@ -104,7 +104,7 @@ dependencies = [
[[package]] [[package]]
name = "icarus_meta" name = "icarus_meta"
version = "0.4.4" version = "0.4.3"
dependencies = [ dependencies = [
"imghdr", "imghdr",
"infer", "infer",

View File

@@ -1,6 +1,6 @@
[package] [package]
name = "icarus_meta" name = "icarus_meta"
version = "0.4.4" version = "0.4.3"
edition = "2024" edition = "2024"
rust-version = "1.90" rust-version = "1.90"

View File

@@ -7,6 +7,7 @@ pub struct FileType {
pub file_type: String, pub file_type: String,
} }
/// Initializes a FileType given a filetype passed. /// Initializes a FileType given a filetype passed.
pub fn init_filetype(filetype: &str) -> Result<FileType, std::io::Error> { pub fn init_filetype(filetype: &str) -> Result<FileType, std::io::Error> {
if filetype == song::constants::FLAC_TYPE { if filetype == song::constants::FLAC_TYPE {
@@ -19,16 +20,12 @@ pub fn init_filetype(filetype: &str) -> Result<FileType, std::io::Error> {
mime: String::from(coverart::constants::mime::PNG), mime: String::from(coverart::constants::mime::PNG),
file_type: String::from(coverart::constants::PNG_TYPE), file_type: String::from(coverart::constants::PNG_TYPE),
}) })
} else if filetype == coverart::constants::JPEG_TYPE } else if filetype == coverart::constants::JPEG_TYPE || filetype == coverart::constants::JPG_TYPE {
|| filetype == coverart::constants::JPG_TYPE
{
Ok(FileType { Ok(FileType {
mime: String::from(coverart::constants::mime::JPEG), mime: String::from(coverart::constants::mime::JPEG),
file_type: String::from(coverart::constants::JPEG_TYPE), file_type: String::from(coverart::constants::JPEG_TYPE),
}) })
} else { } else {
Err(std::io::Error::other(format!( Err(std::io::Error::other(format!("Unsupported FileType: {filetype:?}")))
"Unsupported FileType: {filetype:?}"
)))
} }
} }

View File

@@ -1,4 +1,20 @@
pub mod properties; use lofty::file::AudioFile;
pub fn get_duration(song_path: &String) -> Result<std::time::Duration, std::io::Error> {
match std::fs::File::open(song_path) {
Ok(mut content) => {
match lofty::flac::FlacFile::read_from(&mut content, lofty::config::ParseOptions::new())
{
Ok(flac_file) => {
let properties = flac_file.properties();
Ok(properties.duration())
}
Err(err) => Err(std::io::Error::other(err.to_string())),
}
}
Err(err) => Err(err),
}
}
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {
@@ -12,7 +28,7 @@ mod tests {
match test_util::util::file_exists(&dir, &filename) { match test_util::util::file_exists(&dir, &filename) {
Ok(_) => { Ok(_) => {
let filepath = test_util::util::get_full_path(&dir, &filename).unwrap(); let filepath = test_util::util::get_full_path(&dir, &filename).unwrap();
match super::properties::get_duration(&filepath) { match super::get_duration(&filepath) {
Ok(duration) => { Ok(duration) => {
let song_duration: u64 = 41; let song_duration: u64 = 41;
let fetched_song_duration = duration.as_secs(); let fetched_song_duration = duration.as_secs();

View File

@@ -1,17 +0,0 @@
use lofty::file::AudioFile;
pub fn get_duration(song_path: &String) -> Result<std::time::Duration, std::io::Error> {
match std::fs::File::open(song_path) {
Ok(mut content) => {
match lofty::flac::FlacFile::read_from(&mut content, lofty::config::ParseOptions::new())
{
Ok(flac_file) => {
let properties = flac_file.properties();
Ok(properties.duration())
}
Err(err) => Err(std::io::Error::other(err.to_string())),
}
}
Err(err) => Err(err),
}
}