Generate manpages in a slightly more DRY way
This commit is contained in:
parent
00b43cec25
commit
f4462a36b8
56
build.rs
56
build.rs
|
|
@ -6,44 +6,26 @@ use std::path::Path;
|
||||||
#[path = "src/cli.rs"]
|
#[path = "src/cli.rs"]
|
||||||
mod cli;
|
mod cli;
|
||||||
|
|
||||||
|
macro_rules! generate_manpage {
|
||||||
|
($struct:ident) => {
|
||||||
|
let target_dir = env::var("CARGO_TARGET_DIR").unwrap_or("target".to_string());
|
||||||
|
let output_dir = Path::new(&target_dir).join(env::var("PROFILE").unwrap());
|
||||||
|
|
||||||
|
let cmd = cli::$struct::command();
|
||||||
|
let cmd_name = format!("{}.1", cmd.get_name());
|
||||||
|
let man = Man::new(cmd);
|
||||||
|
let mut buffer: Vec<u8> = Default::default();
|
||||||
|
man.render(&mut buffer)?;
|
||||||
|
std::fs::write(output_dir.join(cmd_name), buffer)?;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
fn main() -> std::io::Result<()> {
|
fn main() -> std::io::Result<()> {
|
||||||
let target_dir = env::var("CARGO_TARGET_DIR").unwrap_or("target".to_string());
|
generate_manpage!(GitMob);
|
||||||
let output_dir = Path::new(&target_dir).join(env::var("PROFILE").unwrap());
|
generate_manpage!(GitSolo);
|
||||||
|
generate_manpage!(GitAddCoauthor);
|
||||||
// git-mob docs
|
generate_manpage!(GitEditCoauthor);
|
||||||
let cmd = cli::GitMob::command();
|
generate_manpage!(GitDeleteCoauthor);
|
||||||
let man = Man::new(cmd);
|
|
||||||
let mut buffer: Vec<u8> = Default::default();
|
|
||||||
man.render(&mut buffer)?;
|
|
||||||
std::fs::write(output_dir.join("git-mob.1"), buffer)?;
|
|
||||||
|
|
||||||
// git-solo docs
|
|
||||||
let cmd = cli::GitSolo::command();
|
|
||||||
let man = Man::new(cmd);
|
|
||||||
let mut buffer: Vec<u8> = Default::default();
|
|
||||||
man.render(&mut buffer)?;
|
|
||||||
std::fs::write(output_dir.join("git-solo.1"), buffer)?;
|
|
||||||
|
|
||||||
// git-add-coauthor docs
|
|
||||||
let cmd = cli::GitAddCoauthor::command();
|
|
||||||
let man = Man::new(cmd);
|
|
||||||
let mut buffer: Vec<u8> = Default::default();
|
|
||||||
man.render(&mut buffer)?;
|
|
||||||
std::fs::write(output_dir.join("git-add-coauthor.1"), buffer)?;
|
|
||||||
|
|
||||||
// git-edit-coauthor docs
|
|
||||||
let cmd = cli::GitEditCoauthor::command();
|
|
||||||
let man = Man::new(cmd);
|
|
||||||
let mut buffer: Vec<u8> = Default::default();
|
|
||||||
man.render(&mut buffer)?;
|
|
||||||
std::fs::write(output_dir.join("git-edit-coauthor.1"), buffer)?;
|
|
||||||
|
|
||||||
// git-delete-coauthor docs
|
|
||||||
let cmd = cli::GitDeleteCoauthor::command();
|
|
||||||
let man = Man::new(cmd);
|
|
||||||
let mut buffer: Vec<u8> = Default::default();
|
|
||||||
man.render(&mut buffer)?;
|
|
||||||
std::fs::write(output_dir.join("git-delete-coauthor.1"), buffer)?;
|
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue