04338e3501
Merge documentation generation into a single binary, `bin/gen`. This includes: The changelog, man pages, the readme, and the book. type: reform |
||
---|---|---|
.. | ||
bin.rs | ||
changelog.rs | ||
cmd.rs | ||
command_ext.rs | ||
common.rs | ||
config.rs | ||
entry.rs | ||
example.rs | ||
exit_status_ext.rs | ||
introduction.rs | ||
kind.rs | ||
main.rs | ||
metadata.rs | ||
opt.rs | ||
project.rs | ||
readme.rs | ||
release.rs | ||
subcommand.rs | ||
summary.rs |
use crate::common::*; #[derive(Template)] #[template(path = "README.md")] pub(crate) struct Readme { pub(crate) table_of_contents: String, } const HEADING_PATTERN: &str = "(?m)^(?P<MARKER>#+) (?P<TEXT>.*)$"; impl Readme { #[throws] pub(crate) fn load(template: &Path) -> Readme { let text = fs::read_to_string(template)?; let header_re = Regex::new(HEADING_PATTERN)?; let mut lines = Vec::new(); for captures in header_re.captures_iter(&text).skip(2) { let marker = captures.name("MARKER").unwrap().as_str(); let text = captures.name("TEXT").unwrap().as_str(); let level = marker.len(); let indentation = " ".repeat((level - 2) * 2); let slug = text .to_lowercase() .replace(' ', "-") .replace('.', "") .replace('&', ""); lines.push(format!("{}- [{}](#{})", indentation, text, slug)); } Readme { table_of_contents: lines.join("\n"), } } }