mirror of
https://github.com/pcvolkmer/osc-variant.git
synced 2025-04-19 19:56:50 +00:00
Improve Error handling
This commit is contained in:
parent
d5f1edf9c8
commit
70f6718ac5
104
src/main.rs
104
src/main.rs
@ -22,18 +22,19 @@
|
||||
* SOFTWARE.
|
||||
*/
|
||||
|
||||
use clap::Parser;
|
||||
use std::error::Error;
|
||||
use std::fmt::{Debug, Display, Formatter};
|
||||
use std::fs;
|
||||
use std::fs::OpenOptions;
|
||||
use std::io::Write;
|
||||
use std::ops::Add;
|
||||
use std::str::FromStr;
|
||||
|
||||
use crate::cli::{Cli, Command};
|
||||
use quick_xml::de::from_str;
|
||||
use clap::Parser;
|
||||
use quick_xml::se::Serializer;
|
||||
use serde::Serialize;
|
||||
|
||||
use crate::cli::{Cli, Command};
|
||||
use crate::model::onkostar_editor::OnkostarEditor;
|
||||
use crate::profile::Profile;
|
||||
|
||||
@ -41,43 +42,76 @@ mod cli;
|
||||
mod model;
|
||||
mod profile;
|
||||
|
||||
fn main() {
|
||||
enum FileError {
|
||||
Reading(String, String),
|
||||
Writing(String, String),
|
||||
Parsing(String, String),
|
||||
}
|
||||
|
||||
impl Error for FileError {}
|
||||
|
||||
impl Debug for FileError {
|
||||
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
|
||||
Display::fmt(self, f)
|
||||
}
|
||||
}
|
||||
|
||||
impl Display for FileError {
|
||||
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
|
||||
write!(
|
||||
f,
|
||||
"{}",
|
||||
match &self {
|
||||
FileError::Reading(filename, err) => format!("Kann Datei '{}' nicht lesen: {}", filename, err),
|
||||
FileError::Writing(filename, err) => format!("Kann Datei '{}' nicht schreiben: {}", filename, err),
|
||||
FileError::Parsing(filename, err) => format!(
|
||||
"Die Datei '{}' ist entweder keine OSC-Datei, fehlerhaft oder enthält zusätzliche Inhalte\n{}",
|
||||
filename,
|
||||
err
|
||||
),
|
||||
}
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
fn read_inputfile(inputfile: String) -> Result<OnkostarEditor, FileError> {
|
||||
return match fs::read_to_string(inputfile.clone()) {
|
||||
Ok(content) => match OnkostarEditor::from_str(content.as_str()) {
|
||||
Ok(data) => Ok(data),
|
||||
Err(err) => Err(FileError::Parsing(inputfile, err)),
|
||||
},
|
||||
Err(err) => Err(FileError::Reading(inputfile, err.to_string())),
|
||||
};
|
||||
}
|
||||
|
||||
fn read_profile(filename: String) -> Result<Profile, FileError> {
|
||||
let profile = fs::read_to_string(filename.clone())
|
||||
.map_err(|err| FileError::Reading(filename.clone(), err.to_string()))?;
|
||||
let profile =
|
||||
Profile::from_str(profile.as_str()).map_err(|err| FileError::Reading(filename, err))?;
|
||||
Ok(profile)
|
||||
}
|
||||
|
||||
fn main() -> Result<(), Box<dyn Error>> {
|
||||
let cli = Cli::parse();
|
||||
|
||||
match cli.command {
|
||||
Command::List { inputfile } => {
|
||||
let contents =
|
||||
fs::read_to_string(inputfile).expect("Should have been able to read the file");
|
||||
|
||||
match OnkostarEditor::from_str(contents.as_str()) {
|
||||
Ok(data) => data.list_forms(),
|
||||
Err(err) => {
|
||||
eprintln!("Kann Eingabedatei nicht lesen!");
|
||||
eprintln!(
|
||||
"Die Datei ist entweder keine OSC-Datei, fehlerhaft oder enthält zusätzliche Inhalte:\n{}",
|
||||
err
|
||||
);
|
||||
}
|
||||
}
|
||||
let data = read_inputfile(inputfile)?;
|
||||
data.list_forms();
|
||||
}
|
||||
Command::Modify {
|
||||
inputfile,
|
||||
profile,
|
||||
outputfile,
|
||||
} => {
|
||||
let contents =
|
||||
fs::read_to_string(inputfile).expect("Should have been able to read the file");
|
||||
let data = &mut read_inputfile(inputfile)?;
|
||||
|
||||
if let Ok(mut data) = from_str::<OnkostarEditor>(contents.as_str()) {
|
||||
if let Some(profile) = profile {
|
||||
let profile =
|
||||
fs::read_to_string(profile).expect("Should have been able to read profile");
|
||||
if let Ok(profile) = Profile::from_str(profile.as_str()) {
|
||||
let profile = read_profile(profile.clone()).map_err(|_| {
|
||||
FileError::Reading(profile, "Kann Profildatei nicht lesen!".into())
|
||||
})?;
|
||||
data.apply_profile(&profile);
|
||||
} else {
|
||||
eprintln!("Kann Profildatei nicht lesen!");
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
let mut buf = String::new();
|
||||
@ -104,21 +138,17 @@ fn main() {
|
||||
.write(true)
|
||||
.create(true)
|
||||
.truncate(true)
|
||||
.open(filename)
|
||||
.unwrap();
|
||||
.open(filename.clone())
|
||||
.map_err(|err| FileError::Writing(filename.clone(), err.to_string()))?;
|
||||
file.write_all(output.as_bytes())
|
||||
.expect("Should have written output file");
|
||||
.map_err(|err| FileError::Writing(filename, err.to_string()))?;
|
||||
}
|
||||
None => {
|
||||
println!("{}", output)
|
||||
}
|
||||
}
|
||||
} else {
|
||||
eprintln!("Kann Eingabedatei nicht lesen!");
|
||||
eprintln!(
|
||||
"Die Datei ist entweder keine OSC-Datei, fehlerhaft oder enthält zusätzliche Inhalte."
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user