Compare commits
1 Commits
v0.4.3
...
13bc89cd98
| Author | SHA1 | Date | |
|---|---|---|---|
|
13bc89cd98
|
@@ -4,9 +4,6 @@ on:
|
|||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- main
|
- main
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
release:
|
release:
|
||||||
|
|||||||
2
Cargo.lock
generated
2
Cargo.lock
generated
@@ -104,7 +104,7 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "icarus_meta"
|
name = "icarus_meta"
|
||||||
version = "0.4.3"
|
version = "0.4.2"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"imghdr",
|
"imghdr",
|
||||||
"infer",
|
"infer",
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
[package]
|
[package]
|
||||||
name = "icarus_meta"
|
name = "icarus_meta"
|
||||||
version = "0.4.3"
|
version = "0.4.2"
|
||||||
edition = "2024"
|
edition = "2024"
|
||||||
rust-version = "1.90"
|
rust-version = "1.90"
|
||||||
|
|
||||||
|
|||||||
@@ -1,16 +1,8 @@
|
|||||||
/// Gets the file type of a CoverArt given it's path
|
/// Gets the file type of a CoverArt given it's path
|
||||||
pub fn file_type_from_filepath(
|
pub fn file_type_from_filepath(filepath: &str) -> Result<String, std::io::Error> {
|
||||||
filepath: &str,
|
|
||||||
) -> Result<crate::detection::FileType, std::io::Error> {
|
|
||||||
match imghdr::from_file(filepath) {
|
match imghdr::from_file(filepath) {
|
||||||
Ok(Some(imghdr::Type::Jpeg)) => Ok(crate::detection::FileType {
|
Ok(Some(imghdr::Type::Jpeg)) => Ok(String::from("jpeg")),
|
||||||
mime: String::from(constants::mime::JPEG),
|
Ok(Some(imghdr::Type::Png)) => Ok(String::from("png")),
|
||||||
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")),
|
Ok(None) => Err(std::io::Error::other("Image file not supported")),
|
||||||
Err(err) => Err(err),
|
Err(err) => Err(err),
|
||||||
_ => Err(std::io::Error::other("Image file not supported")),
|
_ => Err(std::io::Error::other("Image file not supported")),
|
||||||
@@ -18,32 +10,15 @@ pub fn file_type_from_filepath(
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Gets the file type of a CoverArt given it's data
|
/// Gets the file type of a CoverArt given it's data
|
||||||
pub fn file_type_from_data(data: &Vec<u8>) -> Result<crate::detection::FileType, std::io::Error> {
|
pub fn file_type_from_data(data: &Vec<u8>) -> Result<String, std::io::Error> {
|
||||||
match imghdr::from_bytes(data) {
|
match imghdr::from_bytes(data) {
|
||||||
Some(imghdr::Type::Jpeg) => Ok(crate::detection::FileType {
|
Some(imghdr::Type::Jpeg) => Ok(String::from("jpeg")),
|
||||||
mime: String::from(constants::mime::JPEG),
|
Some(imghdr::Type::Png) => Ok(String::from("png")),
|
||||||
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")),
|
None => Err(std::io::Error::other("Image file not supported")),
|
||||||
_ => 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)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
#[test]
|
#[test]
|
||||||
@@ -55,8 +30,7 @@ mod tests {
|
|||||||
match super::file_type_from_filepath(&filepath) {
|
match super::file_type_from_filepath(&filepath) {
|
||||||
Ok(filetype) => {
|
Ok(filetype) => {
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
filetype.file_type,
|
filetype, "png",
|
||||||
super::constants::PNG_TYPE,
|
|
||||||
"The file type of the CoverArt should have been png"
|
"The file type of the CoverArt should have been png"
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@@ -76,8 +50,7 @@ mod tests {
|
|||||||
match super::file_type_from_data(&data) {
|
match super::file_type_from_data(&data) {
|
||||||
Ok(filetype) => {
|
Ok(filetype) => {
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
filetype.file_type,
|
filetype, "png",
|
||||||
super::constants::PNG_TYPE,
|
|
||||||
"The file type of the CoverArt should have been png"
|
"The file type of the CoverArt should have been png"
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,8 +1 @@
|
|||||||
pub mod coverart;
|
pub mod coverart;
|
||||||
pub mod song;
|
|
||||||
|
|
||||||
#[derive(Debug, Default)]
|
|
||||||
pub struct FileType {
|
|
||||||
pub mime: String,
|
|
||||||
pub file_type: String,
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -1,90 +0,0 @@
|
|||||||
/// 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:?}")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user