Compare commits
13 Commits
v0.4.4-52-
...
v0.4.3-48-
| Author | SHA1 | Date | |
|---|---|---|---|
|
561d740120
|
|||
|
80e2864312
|
|||
|
290cd4eaa8
|
|||
|
0c3e4bf82a
|
|||
|
82fe3ae8e8
|
|||
|
233bbdeaa1
|
|||
|
a7ad40478c
|
|||
|
02631fc14c
|
|||
|
25c85212ca
|
|||
|
250a009fad
|
|||
|
fef43b9799
|
|||
|
fa5203013c
|
|||
|
13bc89cd98
|
2
Cargo.lock
generated
2
Cargo.lock
generated
@@ -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",
|
||||||
|
|||||||
@@ -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"
|
||||||
|
|
||||||
|
|||||||
@@ -1,34 +1,7 @@
|
|||||||
pub mod coverart;
|
pub mod coverart;
|
||||||
pub mod song;
|
pub mod song;
|
||||||
|
|
||||||
#[derive(Debug, Default)]
|
|
||||||
pub struct FileType {
|
pub struct FileType {
|
||||||
pub mime: String,
|
pub mime: String,
|
||||||
pub file_type: String,
|
pub file_type: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Initializes a FileType given a filetype passed.
|
|
||||||
pub fn init_filetype(filetype: &str) -> Result<FileType, std::io::Error> {
|
|
||||||
if filetype == song::constants::FLAC_TYPE {
|
|
||||||
Ok(FileType {
|
|
||||||
mime: String::from(song::constants::mime::FLAC),
|
|
||||||
file_type: String::from(song::constants::FLAC_TYPE),
|
|
||||||
})
|
|
||||||
} else if filetype == coverart::constants::PNG_TYPE {
|
|
||||||
Ok(FileType {
|
|
||||||
mime: String::from(coverart::constants::mime::PNG),
|
|
||||||
file_type: String::from(coverart::constants::PNG_TYPE),
|
|
||||||
})
|
|
||||||
} else if filetype == coverart::constants::JPEG_TYPE
|
|
||||||
|| filetype == coverart::constants::JPG_TYPE
|
|
||||||
{
|
|
||||||
Ok(FileType {
|
|
||||||
mime: String::from(coverart::constants::mime::JPEG),
|
|
||||||
file_type: String::from(coverart::constants::JPEG_TYPE),
|
|
||||||
})
|
|
||||||
} else {
|
|
||||||
Err(std::io::Error::other(format!(
|
|
||||||
"Unsupported FileType: {filetype:?}"
|
|
||||||
)))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -20,7 +20,7 @@ pub fn file_type_from_filepath(
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Gets the file type of a Song given it's data
|
/// 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> {
|
pub fn file_type_from_data(data: &Vec<u8>) -> Result<crate::detection::FileType, std::io::Error> {
|
||||||
match infer::get(data) {
|
match infer::get(data) {
|
||||||
Some(kind) => {
|
Some(kind) => {
|
||||||
let mime = kind.mime_type();
|
let mime = kind.mime_type();
|
||||||
|
|||||||
@@ -1,43 +1,21 @@
|
|||||||
pub mod audio;
|
use lofty::file::AudioFile;
|
||||||
|
|
||||||
|
|
||||||
#[derive(Clone, Debug, Default)]
|
|
||||||
pub struct SongProperties {
|
|
||||||
pub duration: std::time::Duration,
|
|
||||||
pub sample_rate: u32,
|
|
||||||
pub bitrate: u32,
|
|
||||||
pub overall_bitrate: u32,
|
|
||||||
pub bit_depth: u8,
|
|
||||||
pub channels: u8,
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
pub fn get_song_properties(song_path: &str) -> Result<SongProperties, std::io::Error> {
|
|
||||||
match audio::get_properties(song_path) {
|
|
||||||
Ok(flac_properties) => {
|
|
||||||
Ok(SongProperties {
|
|
||||||
duration: flac_properties.duration(),
|
|
||||||
sample_rate: flac_properties.sample_rate(),
|
|
||||||
bitrate: flac_properties.audio_bitrate(),
|
|
||||||
overall_bitrate: flac_properties.overall_bitrate(),
|
|
||||||
bit_depth: flac_properties.bit_depth(),
|
|
||||||
channels: flac_properties.channels(),
|
|
||||||
})
|
|
||||||
}
|
|
||||||
Err(err) => Err(err),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_duration(song_path: &String) -> Result<std::time::Duration, std::io::Error> {
|
pub fn get_duration(song_path: &String) -> Result<std::time::Duration, std::io::Error> {
|
||||||
match get_song_properties(song_path) {
|
match std::fs::File::open(song_path) {
|
||||||
Ok(song_properties) => {
|
Ok(mut content) => {
|
||||||
Ok(song_properties.duration)
|
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),
|
Err(err) => Err(err),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use crate::test_util;
|
use crate::test_util;
|
||||||
@@ -1,16 +0,0 @@
|
|||||||
use lofty::file::AudioFile;
|
|
||||||
|
|
||||||
pub fn get_properties(songpath: &str) -> Result<lofty::flac::FlacProperties, std::io::Error> {
|
|
||||||
match std::fs::File::open(songpath) {
|
|
||||||
Ok(mut content) => {
|
|
||||||
match lofty::flac::FlacFile::read_from(&mut content, lofty::config::ParseOptions::new())
|
|
||||||
{
|
|
||||||
Ok(flac_file) => {
|
|
||||||
Ok(*flac_file.properties())
|
|
||||||
}
|
|
||||||
Err(err) => Err(std::io::Error::other(err.to_string())),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Err(err) => Err(err),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user