Compare commits

..

3 commits

Author SHA1 Message Date
Penelope Gwen
aa4ae137ff bump version 2025-09-22 19:13:55 -07:00
Penelope Gwen
3a9eda480a use jpg as extension for all output files 2025-09-22 19:13:26 -07:00
Penelope Gwen
69dbead6ee fixed image processing logic, implement creating dir if it doesn't already exist 2025-09-22 19:10:08 -07:00
3 changed files with 21 additions and 11 deletions

2
Cargo.lock generated
View file

@ -420,7 +420,7 @@ dependencies = [
[[package]] [[package]]
name = "random-image" name = "random-image"
version = "0.1.0" version = "0.1.3"
dependencies = [ dependencies = [
"clap", "clap",
"globwalk", "globwalk",

View file

@ -1,7 +1,7 @@
[package] [package]
name = "random-image" name = "random-image"
authors = ["Penelope Gwen <support@pogmom.me>"] authors = ["Penelope Gwen <support@pogmom.me>"]
version = "0.1.0" version = "0.1.3"
edition = "2024" edition = "2024"
description = "Finds a random image file in a directory and converts it into a sized square" description = "Finds a random image file in a directory and converts it into a sized square"
license-file = "license.md" license-file = "license.md"

View file

@ -2,7 +2,7 @@
use clap::Parser; use clap::Parser;
use magick_rust::MagickWand; use magick_rust::MagickWand;
use std::path::{Path, PathBuf}; use std::{fs, path::{Path, PathBuf}};
use rand::seq::IteratorRandom; use rand::seq::IteratorRandom;
use xdg::BaseDirectories; use xdg::BaseDirectories;
@ -63,6 +63,7 @@ pub fn output_path(image_path: PathBuf) -> Result<PathBuf,String> {
Some(cache) => match xdg_dirs.create_cache_directory(cache) { Some(cache) => match xdg_dirs.create_cache_directory(cache) {
Ok(mut cache) => { Ok(mut cache) => {
cache.push(image_path.strip_prefix("/").unwrap()); cache.push(image_path.strip_prefix("/").unwrap());
cache.add_extension("jpg");
Ok(cache) Ok(cache)
}, },
Err(e) => Err(e.to_string()), Err(e) => Err(e.to_string()),
@ -73,22 +74,27 @@ pub fn output_path(image_path: PathBuf) -> Result<PathBuf,String> {
pub fn calc_img_ops(orig_height: usize, orig_width: usize, size: usize) -> ImgOps { pub fn calc_img_ops(orig_height: usize, orig_width: usize, size: usize) -> ImgOps {
let r = orig_width as f32 / orig_height as f32; let r = orig_width as f32 / orig_height as f32;
//println!("r: {:#?}",r);
let w = match r.gt(&1.0) { let w = match r.gt(&1.0) {
true => (r.abs() * size as f32) as usize, true => (r.abs() * size as f32) as usize,
false => size, false => size,
}; };
//println!("w: {:#?}",w);
let h = match r.lt(&1.0) { let h = match r.lt(&1.0) {
true => (r.abs() * size as f32) as usize, true => (size as f32 / r) as usize,
false => size, false => size,
}; };
//println!("h: {:#?}",h);
let x = match r.gt(&1.0) { let x = match r.gt(&1.0) {
true => (w - size) / 2, true => (w - size) / 2,
false => 0_usize, false => 0_usize,
} as isize; } as isize;
//println!("x: {:#?}",x);
let y = match r.lt(&1.0) { let y = match r.lt(&1.0) {
true => (h - size) / 2, true => (h - size) / 2,
false => 0_usize, false => 0_usize,
} as isize; } as isize;
//println!("y: {:#?}",y);
ImgOps{ width: w, height: h, x_offset: x, y_offset: y } ImgOps{ width: w, height: h, x_offset: x, y_offset: y }
} }
@ -99,14 +105,18 @@ pub fn scale_image(image_path: PathBuf, cached_image_path: PathBuf, size: usize)
match magick_image.read_image(img_str) { match magick_image.read_image(img_str) {
Ok(_) => { Ok(_) => {
let ops = calc_img_ops(magick_image.get_image_height(), magick_image.get_image_width(), size); let ops = calc_img_ops(magick_image.get_image_height(), magick_image.get_image_width(), size);
match magick_image.resize_image(ops.width, ops.height, magick_rust::FilterType::Cubic) { match magick_image.resize_image(ops.width, ops.height, magick_rust::FilterType::Undefined) {
Ok(_) => match magick_image.crop_image(size, size, ops.x_offset, ops.y_offset) { Ok(_) => match magick_image.crop_image(size, size, ops.x_offset, ops.y_offset) {
Ok(_) => match cached_image_path.to_str() { Ok(_) => {
Some(cache_str) => match magick_image.write_image(cache_str) { let mut dir = fs::DirBuilder::new();
Ok(_) => Ok(cached_image_path), let _ = dir.recursive(true).create(cached_image_path.parent().unwrap());
Err(e) => Err(e.to_string()), match cached_image_path.to_str() {
}, Some(cache_str) => match magick_image.write_image(cache_str) {
None => Err("Undefined filepath error".to_string()), Ok(_) => Ok(cached_image_path),
Err(e) => Err(e.to_string()),
},
None => Err("Undefined filepath error".to_string()),
}
}, },
Err(_) => todo!(), Err(_) => todo!(),
} }