fix file starts with minus.
This commit is contained in:
parent
a8e45940ea
commit
81bcb8f543
2
Cargo.lock
generated
2
Cargo.lock
generated
@ -4,4 +4,4 @@ version = 3
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "unzip-all"
|
name = "unzip-all"
|
||||||
version = "0.1.0"
|
version = "0.2.0"
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
[package]
|
[package]
|
||||||
name = "unzip-all"
|
name = "unzip-all"
|
||||||
version = "0.1.0"
|
version = "0.2.0"
|
||||||
authors = ["licsber <admin@licsber.site>"]
|
authors = ["licsber <admin@licsber.site>"]
|
||||||
edition = "2021"
|
edition = "2021"
|
||||||
|
|
||||||
|
54
src/main.rs
54
src/main.rs
@ -1,34 +1,9 @@
|
|||||||
use std::env;
|
mod unar;
|
||||||
|
|
||||||
use std::fs;
|
use std::fs;
|
||||||
use std::io;
|
use std::io::Result;
|
||||||
use std::path::{Path, PathBuf};
|
use std::path::{Path, PathBuf};
|
||||||
use std::process::Command;
|
use std::{env, io};
|
||||||
|
|
||||||
fn unar_file(path: &Path) -> io::Result<()> {
|
|
||||||
println!("UNAR: {}", path.display());
|
|
||||||
let parent_dir = path.parent().unwrap();
|
|
||||||
let filename = path.file_name().unwrap();
|
|
||||||
let output = Command::new("unar")
|
|
||||||
.current_dir(parent_dir)
|
|
||||||
.arg("-s")
|
|
||||||
.arg("-d")
|
|
||||||
.arg(filename)
|
|
||||||
.output();
|
|
||||||
|
|
||||||
match output {
|
|
||||||
Ok(res) => {
|
|
||||||
if !res.status.success() {
|
|
||||||
eprintln!("Error processing compressed file {:?}: {}", path, String::from_utf8_lossy(&res.stderr));
|
|
||||||
return Err(io::ErrorKind::Other.into());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Err(e) => {
|
|
||||||
eprintln!("Failed to execute unar for {:?}: {}", path, e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Ok(())
|
|
||||||
}
|
|
||||||
|
|
||||||
fn is_compressed(path: &Path) -> bool {
|
fn is_compressed(path: &Path) -> bool {
|
||||||
if let Some(ext) = path.extension() {
|
if let Some(ext) = path.extension() {
|
||||||
@ -41,25 +16,30 @@ fn is_compressed(path: &Path) -> bool {
|
|||||||
false
|
false
|
||||||
}
|
}
|
||||||
|
|
||||||
fn process_compressed_files(path: &Path) -> io::Result<()> {
|
fn process_compressed_files(path: &Path) -> Result<()> {
|
||||||
if !path.is_dir() {
|
if !path.is_dir() {
|
||||||
return Err(io::Error::new(io::ErrorKind::Other, "Not a directory"));
|
return Err(io::Error::new(io::ErrorKind::Other, "Not a directory"));
|
||||||
}
|
}
|
||||||
|
|
||||||
println!("Processing directory: {}", path.display());
|
println!("Processing directory: {:?}", path);
|
||||||
|
let mut waiting_files: Vec<PathBuf> = Vec::new();
|
||||||
for entry in fs::read_dir(path)? {
|
for entry in fs::read_dir(path)? {
|
||||||
let entry_path = entry?.path();
|
let entry_path: PathBuf = entry?.path();
|
||||||
if entry_path.is_dir() {
|
if entry_path.is_dir() {
|
||||||
process_compressed_files(&entry_path)?;
|
process_compressed_files(&entry_path)?;
|
||||||
} else if is_compressed(entry_path.as_path()) {
|
} else if is_compressed(entry_path.as_path()) {
|
||||||
unar_file(&entry_path).expect("UNAR Error.");
|
waiting_files.push(entry_path);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for f in waiting_files {
|
||||||
|
unar::unar_file(&f).expect("UNAR Error.");
|
||||||
|
}
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn main() -> io::Result<()> {
|
fn main() -> Result<()> {
|
||||||
let args: Vec<String> = env::args().collect();
|
let args: Vec<String> = env::args().collect();
|
||||||
|
|
||||||
let start_path = if args.len() > 1 {
|
let start_path = if args.len() > 1 {
|
||||||
@ -69,10 +49,8 @@ fn main() -> io::Result<()> {
|
|||||||
};
|
};
|
||||||
|
|
||||||
if start_path.is_file() {
|
if start_path.is_file() {
|
||||||
return unar_file(&start_path);
|
return unar::unar_file(&start_path);
|
||||||
}
|
}
|
||||||
|
|
||||||
process_compressed_files(&start_path)?;
|
process_compressed_files(&start_path)
|
||||||
|
|
||||||
Ok(())
|
|
||||||
}
|
}
|
||||||
|
35
src/unar.rs
Normal file
35
src/unar.rs
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
use std::io;
|
||||||
|
use std::path::Path;
|
||||||
|
use std::process::Command;
|
||||||
|
|
||||||
|
pub fn unar_file(path: &Path) -> io::Result<()> {
|
||||||
|
println!("UNAR: {}", path.display());
|
||||||
|
let parent_dir = if path.parent().unwrap().exists() {
|
||||||
|
path.parent().unwrap()
|
||||||
|
} else {
|
||||||
|
Path::new(".")
|
||||||
|
};
|
||||||
|
|
||||||
|
let filename = path.canonicalize()?;
|
||||||
|
|
||||||
|
let output = Command::new("unar")
|
||||||
|
.current_dir(parent_dir)
|
||||||
|
.arg("-s") // -force-skip: skip if exists
|
||||||
|
.arg(filename)
|
||||||
|
.spawn()?.wait_with_output();
|
||||||
|
|
||||||
|
match output {
|
||||||
|
Ok(res) => {
|
||||||
|
if !res.status.success() {
|
||||||
|
eprintln!("Error processing compressed file {:?}: {}", path, String::from_utf8_lossy(&res.stderr));
|
||||||
|
return Err(io::ErrorKind::Other.into());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Err(e) => {
|
||||||
|
eprintln!("Failed to execute unar for {:?}: {}", path, e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user