Compare commits

..

14 Commits

Author SHA1 Message Date
60d30bff01 tsk-45: Warning fix
All checks were successful
Rust Build / Check (pull_request) Successful in 30s
Release Tagging / release (pull_request) Successful in 39s
Rust Build / Rustfmt (pull_request) Successful in 1m23s
Rust Build / Test Suite (pull_request) Successful in 34s
Rust Build / Clippy (pull_request) Successful in 54s
Rust Build / build (pull_request) Successful in 1m22s
2025-10-21 21:46:49 -04:00
8acf220fc4 tsk-45: Added macros of FileType
Some checks failed
Rust Build / Check (pull_request) Successful in 41s
Rust Build / Rustfmt (pull_request) Successful in 40s
Rust Build / Clippy (pull_request) Failing after 1m20s
Release Tagging / release (pull_request) Successful in 48s
Rust Build / Test Suite (pull_request) Successful in 1m32s
Rust Build / build (pull_request) Successful in 54s
2025-10-21 21:43:55 -04:00
561d740120 tsk-45: Workflow change
Some checks failed
Rust Build / Check (pull_request) Successful in 1m0s
Rust Build / Test Suite (pull_request) Successful in 49s
Rust Build / Rustfmt (pull_request) Successful in 1m1s
Release Tagging / release (pull_request) Successful in 54s
Rust Build / build (pull_request) Successful in 1m29s
Rust Build / Clippy (pull_request) Failing after 45s
2025-10-21 21:28:41 -04:00
80e2864312 tsk-45: Code formatting
Some checks failed
Rust Build / Test Suite (pull_request) Successful in 36s
Rust Build / Rustfmt (pull_request) Successful in 51s
Rust Build / build (pull_request) Successful in 1m6s
Rust Build / Check (pull_request) Successful in 1m26s
Rust Build / Clippy (pull_request) Failing after 47s
2025-10-21 21:08:57 -04:00
290cd4eaa8 tsk-45: Making use of constants 2025-10-21 21:08:14 -04:00
0c3e4bf82a tsk-45: Added test 2025-10-21 21:02:11 -04:00
82fe3ae8e8 tsk-45: Added another function 2025-10-21 21:00:06 -04:00
233bbdeaa1 tsk-45: Added test 2025-10-21 20:53:09 -04:00
a7ad40478c tsk-45: Version bump
All checks were successful
Rust Build / Rustfmt (pull_request) Successful in 52s
Rust Build / Check (pull_request) Successful in 35s
Rust Build / build (pull_request) Successful in 1m12s
Rust Build / Test Suite (pull_request) Successful in 1m0s
Rust Build / Clippy (pull_request) Successful in 1m10s
2025-10-21 20:37:36 -04:00
02631fc14c tsk-45: Code formatting
All checks were successful
Rust Build / Rustfmt (pull_request) Successful in 42s
Rust Build / build (pull_request) Successful in 1m8s
Rust Build / Clippy (pull_request) Successful in 1m17s
Rust Build / Test Suite (pull_request) Successful in 59s
Rust Build / Check (pull_request) Successful in 45s
2025-10-21 20:29:13 -04:00
25c85212ca tsk-45: Changed types of functions 2025-10-21 20:28:50 -04:00
250a009fad tsk-45: More changes 2025-10-21 20:21:07 -04:00
fef43b9799 tsk-45: Some changes 2025-10-21 20:08:41 -04:00
fa5203013c tsk-45: Adding functionality for itdentifying Song 2025-10-21 20:02:19 -04:00
6 changed files with 137 additions and 10 deletions

View File

@@ -4,6 +4,9 @@ on:
push:
branches:
- main
pull_request:
branches:
- main
jobs:
release:

2
Cargo.lock generated
View File

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

View File

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

View File

@@ -1,8 +1,16 @@
/// Gets the file type of a CoverArt given it's path
pub fn file_type_from_filepath(filepath: &str) -> Result<String, std::io::Error> {
pub fn file_type_from_filepath(
filepath: &str,
) -> Result<crate::detection::FileType, std::io::Error> {
match imghdr::from_file(filepath) {
Ok(Some(imghdr::Type::Jpeg)) => Ok(String::from("jpeg")),
Ok(Some(imghdr::Type::Png)) => Ok(String::from("png")),
Ok(Some(imghdr::Type::Jpeg)) => Ok(crate::detection::FileType {
mime: String::from(constants::mime::JPEG),
file_type: String::from(constants::JPEG_TYPE),
}),
Ok(Some(imghdr::Type::Png)) => Ok(crate::detection::FileType {
mime: String::from(constants::mime::PNG),
file_type: String::from(constants::PNG_TYPE),
}),
Ok(None) => Err(std::io::Error::other("Image file not supported")),
Err(err) => Err(err),
_ => Err(std::io::Error::other("Image file not supported")),
@@ -10,15 +18,32 @@ pub fn file_type_from_filepath(filepath: &str) -> Result<String, std::io::Error>
}
/// Gets the file type of a CoverArt given it's data
pub fn file_type_from_data(data: &Vec<u8>) -> Result<String, std::io::Error> {
pub fn file_type_from_data(data: &Vec<u8>) -> Result<crate::detection::FileType, std::io::Error> {
match imghdr::from_bytes(data) {
Some(imghdr::Type::Jpeg) => Ok(String::from("jpeg")),
Some(imghdr::Type::Png) => Ok(String::from("png")),
Some(imghdr::Type::Jpeg) => Ok(crate::detection::FileType {
mime: String::from(constants::mime::JPEG),
file_type: String::from(constants::JPEG_TYPE),
}),
Some(imghdr::Type::Png) => Ok(crate::detection::FileType {
mime: String::from(constants::mime::PNG),
file_type: String::from(constants::PNG_TYPE),
}),
None => Err(std::io::Error::other("Image file not supported")),
_ => Err(std::io::Error::other("Image file not supported")),
}
}
pub mod constants {
pub const PNG_TYPE: &str = "png";
pub const JPEG_TYPE: &str = "jpeg";
pub const JPG_TYPE: &str = "jpg";
pub mod mime {
pub const JPEG: &str = "image/jpeg";
pub const PNG: &str = "image/png";
}
}
#[cfg(test)]
mod tests {
#[test]
@@ -30,7 +55,8 @@ mod tests {
match super::file_type_from_filepath(&filepath) {
Ok(filetype) => {
assert_eq!(
filetype, "png",
filetype.file_type,
super::constants::PNG_TYPE,
"The file type of the CoverArt should have been png"
);
}
@@ -50,7 +76,8 @@ mod tests {
match super::file_type_from_data(&data) {
Ok(filetype) => {
assert_eq!(
filetype, "png",
filetype.file_type,
super::constants::PNG_TYPE,
"The file type of the CoverArt should have been png"
);
}

View File

@@ -1 +1,8 @@
pub mod coverart;
pub mod song;
#[derive(Debug, Default)]
pub struct FileType {
pub mime: String,
pub file_type: String,
}

90
src/detection/song.rs Normal file
View File

@@ -0,0 +1,90 @@
/// Gets the file type of a Song from it's path
pub fn file_type_from_filepath(
filepath: &str,
) -> Result<crate::detection::FileType, std::io::Error> {
match infer::get_from_path(filepath) {
Ok(Some(kind)) => {
let mime = kind.mime_type();
if mime == constants::mime::FLAC {
Ok(crate::detection::FileType {
mime: String::from(mime),
file_type: String::from(constants::FLAC_TYPE),
})
} else {
Err(std::io::Error::other("Unsupported file type"))
}
}
Ok(None) => Err(std::io::Error::other("File type not determined")),
Err(err) => Err(err),
}
}
/// Gets the file type of a Song given it's data
pub fn file_type_from_data(data: &[u8]) -> Result<crate::detection::FileType, std::io::Error> {
match infer::get(data) {
Some(kind) => {
let mime = kind.mime_type();
if mime == constants::mime::FLAC {
Ok(crate::detection::FileType {
mime: String::from(mime),
file_type: String::from(constants::FLAC_TYPE),
})
} else {
Err(std::io::Error::other("Unsupported file type"))
}
}
None => Err(std::io::Error::other("File type not determined")),
}
}
pub mod constants {
pub const FLAC_TYPE: &str = "flac";
pub mod mime {
pub const FLAC: &str = "audio/x-flac";
}
}
#[cfg(test)]
mod tests {
#[test]
fn test_song_file_type() {
let directory = String::from(crate::test_util::util::TESTFILEDIRECTORY);
let filename = String::from("track01.flac");
let filepath = format!("{directory}/{filename}");
match super::file_type_from_filepath(&filepath) {
Ok(filetype) => {
assert_eq!(
filetype.file_type,
crate::detection::song::constants::FLAC_TYPE,
"Types do not match"
)
}
Err(err) => {
assert!(false, "Error: {err:?}")
}
}
}
#[test]
fn test_song_file_type_from_data() {
let directory = String::from(crate::test_util::util::TESTFILEDIRECTORY);
let filename = String::from("track01.flac");
let filepath = format!("{directory}/{filename}");
let data = crate::test_util::util::get_data_from_file(&filepath).unwrap();
match super::file_type_from_data(&data) {
Ok(filetype) => {
assert_eq!(
filetype.file_type,
crate::detection::song::constants::FLAC_TYPE,
"Types do not match"
)
}
Err(err) => {
assert!(false, "Error: {err:?}")
}
}
}
}