Compare commits

...

3 commits

4 changed files with 27 additions and 13 deletions

View file

@ -1,6 +1,6 @@
[package] [package]
name = "oink" name = "oink"
version = "0.0.1" version = "0.0.2"
edition = "2021" edition = "2021"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

4
rust-toolchain.toml Normal file
View file

@ -0,0 +1,4 @@
[toolchain]
channel = "nightly"

View file

@ -1,3 +1,4 @@
#![feature(error_in_core)]
use std::process::exit; use std::process::exit;
use pico_args::Arguments; use pico_args::Arguments;

View file

@ -5,6 +5,7 @@ use std::{
io::Write, io::Write,
path::Path path::Path
}; };
use core::error::Error;
use tera::{ Context, Tera }; use tera::{ Context, Tera };
use termion::{ use termion::{
@ -13,6 +14,11 @@ use termion::{
}; };
use toml::{ map::Map, Value }; use toml::{ map::Map, Value };
static FAIL: Fg<color::LightRed> = Fg(color::LightRed);
static SUCCESS: Fg<color::LightGreen> = Fg(color::LightGreen);
static WARN: Fg<color::Yellow> = Fg(color::Yellow);
static RESET: Fg<color::Reset> = Fg(color::Reset);
pub fn apply(targets: &Vec<Map<String, Value>>) { pub fn apply(targets: &Vec<Map<String, Value>>) {
let home = var("HOME").unwrap(); let home = var("HOME").unwrap();
println!("{}running apply{}", style::Bold, style::Reset); println!("{}running apply{}", style::Bold, style::Reset);
@ -25,18 +31,18 @@ pub fn apply(targets: &Vec<Map<String, Value>>) {
if path.is_none() { if path.is_none() {
if i_name.is_some() { if i_name.is_some() {
let name = i_name.unwrap().as_str().unwrap(); let name = i_name.unwrap().as_str().unwrap();
println!(" \"{name}\" is missing its path property; skipping"); println!(" {WARN}\"{name}\" is missing its path property; skipping{RESET}");
} else { println!(" skipping empty target"); } } else { println!(" {WARN}skipping empty target{RESET}"); }
continue; continue;
} }
if i_name.is_none() { if i_name.is_none() {
println!(" target missing name; skipping"); println!(" {WARN}target missing name; skipping{RESET}");
continue; continue;
} }
// print applying text // print applying text
let name = i_name.unwrap().as_str().unwrap(); let name = i_name.unwrap().as_str().unwrap();
println!(" applying \"{name}\":"); println!(" applying \"{name}\":");
// set up paths // set up paths
let destination = Path::new(path.unwrap().as_str().unwrap()); let destination = Path::new(path.unwrap().as_str().unwrap());
@ -45,8 +51,8 @@ pub fn apply(targets: &Vec<Map<String, Value>>) {
// copy and print // copy and print
let result = fs::copy(source, destination); let result = fs::copy(source, destination);
if result.is_err() { println!(" failed to copy!"); } if result.is_err() { println!(" {FAIL}failed to copy!{RESET}"); }
else { println!(" completed successfully"); } else { println!(" {SUCCESS}completed successfully{RESET}"); }
} }
} }
@ -58,19 +64,22 @@ pub fn build(targets: &Vec<Map<String, Value>>, tera: &mut Tera, context: &Conte
let i_name = target.get("name"); let i_name = target.get("name");
// handle empty names gracefully // handle empty names gracefully
if i_name.is_none() { if i_name.is_none() {
println!(" {}target missing name; skipping{}", Fg(color::Yellow), Fg(color::Reset)); println!(" {WARN}target missing name; skipping{RESET}");
continue; continue;
} }
// print building text // print building text
let name = i_name.unwrap().as_str().unwrap(); let name = i_name.unwrap().as_str().unwrap();
println!(" building \"{name}\":"); println!(" building \"{name}\":");
// render template // render template
let render = tera.render(name, context); let render = tera.render(name, context);
// handle rendering errors gracefully // handle rendering errors gracefully
if render.is_err() { if render.is_err() {
println!(" failed to render template"); let error = render.err().unwrap();
let message = error.source().unwrap();
println!(" {FAIL}failed to render template:\n {message}{RESET}");
continue; continue;
} }
@ -80,14 +89,14 @@ pub fn build(targets: &Vec<Map<String, Value>>, tera: &mut Tera, context: &Conte
let path = Path::new(&destination); let path = Path::new(&destination);
let i_file = File::create(path); let i_file = File::create(path);
if i_file.is_err() { if i_file.is_err() {
println!(" failed to create destination file at {path:?}"); println!(" {FAIL}failed to create destination file at {path:?}{RESET}");
continue; continue;
} }
let mut file = i_file.unwrap(); let mut file = i_file.unwrap();
// write to destination file // write to destination file
let written = write!(&mut file, "{output}"); let written = write!(&mut file, "{output}");
if written.is_err() { println!(" failed to write to destination file at {path:?}"); } if written.is_err() { println!(" {FAIL}failed to write to destination file at {path:?}{RESET}"); }
else { println!(" completed successfully"); } else { println!(" {SUCCESS}completed successfully{RESET}"); }
} }
} }