diff options
author | Benedikt Peetz <benedikt.peetz@b-peetz.de> | 2024-09-29 10:11:35 +0200 |
---|---|---|
committer | Benedikt Peetz <benedikt.peetz@b-peetz.de> | 2024-09-29 10:11:35 +0200 |
commit | d0fe56f4e98fa552c5e271713a815d2382e614f7 (patch) | |
tree | 5564085c201fdac129e96fa6036c3da0b1c11a0b /src/new/section.rs | |
parent | feat(bundle): Support bundling a document into one TeX file (diff) | |
download | lpm-d0fe56f4e98fa552c5e271713a815d2382e614f7.zip |
feat(templates): Provide a consistent syntax for replacements
All replacements now start with `lpm::` and thus provide a future way to extend them. This change also adds the ability to access the chapter name in a new section and the current data in a new chapter.
Diffstat (limited to 'src/new/section.rs')
-rw-r--r-- | src/new/section.rs | 63 |
1 files changed, 13 insertions, 50 deletions
diff --git a/src/new/section.rs b/src/new/section.rs index 5e9f08c..a350f71 100644 --- a/src/new/section.rs +++ b/src/new/section.rs @@ -1,57 +1,14 @@ -use std::{ - fs, - path::Path, - time::{SystemTime, UNIX_EPOCH}, -}; +use std::{fs, path::Path}; use anyhow::Context; -use chrono::{Local, TimeDelta, TimeZone}; use log::debug; use crate::{ config_file::Config, file_tree::{FileTree, GeneratedFile}, - new::MangledName, + new::{replacement::untemplatize_section, MangledName}, }; -fn get_current_date() -> String { - let start = SystemTime::now(); - let seconds_since_epoch: TimeDelta = TimeDelta::from_std( - start - .duration_since(UNIX_EPOCH) - .expect("Time went backwards"), - ) - .expect("Time does not go backwards"); - - debug!( - "Adding a date with timestamp: {}", - seconds_since_epoch.num_seconds() - ); - - let our_date = format!( - "{}", - Local - .timestamp_opt(seconds_since_epoch.num_seconds(), 0) - // only has unwrap, no expect. But should always work - .unwrap() - .format("%Y-%m-%d %H:%M:%S%.f %:z") - ); - - // let date = Command::new("date") - // .args(["-d", &format!("@{}", seconds_since_epoch.num_seconds())]) - // .output() - // .unwrap() - // .stdout; - - // info!( - // "This is dated: '{}' vs. our date: '{}'", - // String::from_utf8(date).unwrap().strip_suffix('\n').unwrap(), - // our_date - // ); - - our_date -} - pub fn generate_new_section( config: &Config, name: String, @@ -63,11 +20,17 @@ pub fn generate_new_section( let mut file_tree = FileTree::new(); - let new_section_text = config - .templates - .section - .replace("REPLACMENT_SECTION_TITLE", &name) - .replace("DATE", &get_current_date()); + let display_chapter_name = MangledName::from_str_unsafe( + chapter_name + .chars() + .skip_while(|a: &char| a.is_digit(10) || *(a) == '_') + .collect::<String>() + .as_str(), + ) + .try_unmangle(); + + let new_section_text = + untemplatize_section(&config.templates.section, &name, &display_chapter_name); file_tree.add_file(GeneratedFile::new_clobber( chapter_root |