mirror of
https://git.asonix.dog/asonix/pict-rs
synced 2025-01-05 17:21:28 +00:00
Remove special-case for animated avif
This commit is contained in:
parent
b844f5ef4e
commit
bd3cdc925e
1 changed files with 1 additions and 98 deletions
|
@ -39,40 +39,7 @@ pub(super) async fn confirm_bytes(
|
||||||
) -> Result<Discovery, MagickError> {
|
) -> Result<Discovery, MagickError> {
|
||||||
match discovery {
|
match discovery {
|
||||||
Some(Discovery {
|
Some(Discovery {
|
||||||
input: InputFile::Animation(AnimationFormat::Avif),
|
input: InputFile::Animation(AnimationFormat::Webp | AnimationFormat::Avif),
|
||||||
width,
|
|
||||||
height,
|
|
||||||
..
|
|
||||||
}) => {
|
|
||||||
let frames = count_avif_frames(tmp_dir, timeout, move |mut file| async move {
|
|
||||||
file.write_from_bytes(bytes)
|
|
||||||
.await
|
|
||||||
.map_err(MagickError::Write)?;
|
|
||||||
Ok(file)
|
|
||||||
})
|
|
||||||
.await?;
|
|
||||||
|
|
||||||
if frames == 1 {
|
|
||||||
return Ok(Discovery {
|
|
||||||
input: InputFile::Image(ImageInput {
|
|
||||||
format: ImageFormat::Avif,
|
|
||||||
needs_reorient: false,
|
|
||||||
}),
|
|
||||||
width,
|
|
||||||
height,
|
|
||||||
frames: None,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
return Ok(Discovery {
|
|
||||||
input: InputFile::Animation(AnimationFormat::Avif),
|
|
||||||
width,
|
|
||||||
height,
|
|
||||||
frames: Some(frames),
|
|
||||||
});
|
|
||||||
}
|
|
||||||
Some(Discovery {
|
|
||||||
input: InputFile::Animation(AnimationFormat::Webp),
|
|
||||||
..
|
..
|
||||||
}) => {
|
}) => {
|
||||||
// continue
|
// continue
|
||||||
|
@ -93,70 +60,6 @@ pub(super) async fn confirm_bytes(
|
||||||
.await
|
.await
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tracing::instrument(level = "debug", skip_all)]
|
|
||||||
async fn count_avif_frames<F, Fut>(tmp_dir: &TmpDir, timeout: u64, f: F) -> Result<u32, MagickError>
|
|
||||||
where
|
|
||||||
F: FnOnce(crate::file::File) -> Fut,
|
|
||||||
Fut: std::future::Future<Output = Result<crate::file::File, MagickError>>,
|
|
||||||
{
|
|
||||||
let temporary_path = tmp_dir
|
|
||||||
.tmp_folder()
|
|
||||||
.await
|
|
||||||
.map_err(MagickError::CreateTemporaryDirectory)?;
|
|
||||||
|
|
||||||
let input_file = tmp_dir.tmp_file(None);
|
|
||||||
crate::store::file_store::safe_create_parent(&input_file)
|
|
||||||
.await
|
|
||||||
.map_err(MagickError::CreateDir)?;
|
|
||||||
|
|
||||||
let tmp_one = crate::file::File::create(&input_file)
|
|
||||||
.await
|
|
||||||
.map_err(MagickError::CreateFile)?;
|
|
||||||
let tmp_one = (f)(tmp_one).await?;
|
|
||||||
tmp_one.close().await.map_err(MagickError::CloseFile)?;
|
|
||||||
|
|
||||||
let envs = [(MAGICK_TEMPORARY_PATH, temporary_path.as_os_str())];
|
|
||||||
|
|
||||||
let res = Process::run(
|
|
||||||
"magick",
|
|
||||||
&[
|
|
||||||
"convert".as_ref(),
|
|
||||||
"-ping".as_ref(),
|
|
||||||
input_file.as_os_str(),
|
|
||||||
"INFO:".as_ref(),
|
|
||||||
],
|
|
||||||
&envs,
|
|
||||||
timeout,
|
|
||||||
)?
|
|
||||||
.read()
|
|
||||||
.into_string()
|
|
||||||
.await;
|
|
||||||
|
|
||||||
input_file.cleanup().await.map_err(MagickError::Cleanup)?;
|
|
||||||
temporary_path
|
|
||||||
.cleanup()
|
|
||||||
.await
|
|
||||||
.map_err(MagickError::Cleanup)?;
|
|
||||||
|
|
||||||
let output = res?;
|
|
||||||
|
|
||||||
if output.is_empty() {
|
|
||||||
return Err(MagickError::Empty);
|
|
||||||
}
|
|
||||||
|
|
||||||
let lines: u32 = output
|
|
||||||
.lines()
|
|
||||||
.count()
|
|
||||||
.try_into()
|
|
||||||
.expect("Reasonable frame count");
|
|
||||||
|
|
||||||
if lines == 0 {
|
|
||||||
return Err(MagickError::Empty);
|
|
||||||
}
|
|
||||||
|
|
||||||
Ok(lines)
|
|
||||||
}
|
|
||||||
|
|
||||||
#[tracing::instrument(level = "debug", skip_all)]
|
#[tracing::instrument(level = "debug", skip_all)]
|
||||||
async fn discover_file<F, Fut>(
|
async fn discover_file<F, Fut>(
|
||||||
tmp_dir: &TmpDir,
|
tmp_dir: &TmpDir,
|
||||||
|
|
Loading…
Reference in a new issue