Compare commits

...

1 Commits

Author SHA1 Message Date
Andrei Stoica 2caa88ad43 seperated module into new file 2023-06-15 10:43:26 -04:00
2 changed files with 71 additions and 76 deletions

View File

@ -1,13 +1,14 @@
mod todo_file;
use crate::todo_file::TodoFile;
use chrono::naive::NaiveDate;
use chrono::{Datelike, Local};
use std::env;
use std::fs::{copy, read_dir};
use std::path::{Path, PathBuf};
use std::process::Command;
use todo_file::TodoFile;
//TODO handle unwraps and errors more uniformly
//TODO move TodoFile into its file
//TODO clean up verbose printing
fn main() {
@ -52,80 +53,6 @@ fn main() {
}
}
mod todo_file {
use chrono::naive::NaiveDate;
use regex::Regex;
use std::convert::TryFrom;
use std::fs::DirEntry;
use std::str::FromStr;
#[derive(Debug)]
pub struct TodoFile {
pub file: DirEntry,
pub date: NaiveDate,
}
impl TodoFile {
fn capture_as_number<T: FromStr>(
capture: &regex::Captures,
name: &str,
) -> Result<T, String> {
Ok(capture
.name(name)
.unwrap()
.as_str()
.parse::<T>()
.ok()
.ok_or("Something went wrong".to_owned())?)
}
pub fn latest_file(a: TodoFile, b: TodoFile) -> TodoFile {
if a.date > b.date {
a
} else {
b
}
}
fn get_file_regex() -> Regex {
//TODO This would ideally be configurable
Regex::new(r"(?P<year>\d{4})-(?P<month>\d{2})-(?P<day>\d{2}).md")
.expect("could not create regex")
}
}
impl TryFrom<DirEntry> for TodoFile {
type Error = String;
fn try_from(direntry: DirEntry) -> Result<Self, Self::Error> {
let re = TodoFile::get_file_regex();
println!("{:?}", re);
let file_name = direntry.file_name();
let file_name_str = match file_name.to_str() {
Some(name) => name,
_ => "",
};
println!("{:?}", file_name_str);
if let Some(caps) = re.captures(file_name_str) {
let year: i32 = Self::capture_as_number(&caps, "year").unwrap();
let month: u32 = Self::capture_as_number(&caps, "month").unwrap();
let day: u32 = Self::capture_as_number(&caps, "day").unwrap();
return Ok(Self {
file: direntry,
date: NaiveDate::from_ymd_opt(year, month, day).unwrap(),
});
};
Err(format!(
"Could not parse file name => {{ name: {:?}, re: {:?} }}",
file_name, re
)
.to_string())
}
}
}
fn get_editor(fallback: String) -> String {
match env::var("EDITOR") {
Ok(editor) => editor,

68
src/todo_file/mod.rs Normal file
View File

@ -0,0 +1,68 @@
use chrono::naive::NaiveDate;
use regex::Regex;
use std::convert::TryFrom;
use std::fs::DirEntry;
use std::str::FromStr;
#[derive(Debug)]
pub struct TodoFile {
pub file: DirEntry,
pub date: NaiveDate,
}
impl TodoFile {
fn capture_as_number<T: FromStr>(capture: &regex::Captures, name: &str) -> Result<T, String> {
Ok(capture
.name(name)
.unwrap()
.as_str()
.parse::<T>()
.ok()
.ok_or("Something went wrong".to_owned())?)
}
pub fn latest_file(a: TodoFile, b: TodoFile) -> TodoFile {
if a.date > b.date {
a
} else {
b
}
}
fn get_file_regex() -> Regex {
//TODO This would ideally be configurable
Regex::new(r"(?P<year>\d{4})-(?P<month>\d{2})-(?P<day>\d{2}).md")
.expect("could not create regex")
}
}
impl TryFrom<DirEntry> for TodoFile {
type Error = String;
fn try_from(direntry: DirEntry) -> Result<Self, Self::Error> {
let re = TodoFile::get_file_regex();
println!("{:?}", re);
let file_name = direntry.file_name();
let file_name_str = match file_name.to_str() {
Some(name) => name,
_ => "",
};
println!("{:?}", file_name_str);
if let Some(caps) = re.captures(file_name_str) {
let year: i32 = Self::capture_as_number(&caps, "year").unwrap();
let month: u32 = Self::capture_as_number(&caps, "month").unwrap();
let day: u32 = Self::capture_as_number(&caps, "day").unwrap();
return Ok(Self {
file: direntry,
date: NaiveDate::from_ymd_opt(year, month, day).unwrap(),
});
};
Err(format!(
"Could not parse file name => {{ name: {:?}, re: {:?} }}",
file_name, re
)
.to_string())
}
}