Skip to content

Commit

Permalink
boulder/cli: Add --generate-manpages here too
Browse files Browse the repository at this point in the history
Signed-off-by: Ikey Doherty <ikey@serpentos.com>
  • Loading branch information
ikeycode committed Nov 6, 2024
1 parent 4dc67aa commit 0e5537e
Show file tree
Hide file tree
Showing 3 changed files with 44 additions and 9 deletions.
1 change: 1 addition & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions boulder/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ yaml = { path = "../crates/yaml" }

chrono.workspace = true
clap.workspace = true
clap_mangen.workspace = true
derive_more.workspace = true
dirs.workspace = true
elf.workspace = true
Expand Down
51 changes: 42 additions & 9 deletions boulder/src/cli.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,9 @@
use std::path::PathBuf;

use boulder::{env, Env};
use clap::{Args, Parser};
use clap::{Args, CommandFactory, Parser};
use clap_mangen::Man;
use std::fs::{self, File};
use thiserror::Error;

mod build;
Expand All @@ -18,7 +20,7 @@ pub struct Command {
#[command(flatten)]
pub global: Global,
#[command(subcommand)]
pub subcommand: Subcommand,
pub subcommand: Option<Subcommand>,
}

#[derive(Debug, Args)]
Expand All @@ -39,6 +41,8 @@ pub struct Global {
pub data_dir: Option<PathBuf>,
#[arg(long, global = true)]
pub moss_root: Option<PathBuf>,
#[arg(long, global = true)]
pub generate_manpages: Option<PathBuf>,
}

#[derive(Debug, clap::Subcommand)]
Expand All @@ -52,13 +56,39 @@ pub enum Subcommand {

pub fn process() -> Result<(), Error> {
let args = replace_aliases(std::env::args());
let Command { global, subcommand } = Command::parse_from(args);
let Command { global, subcommand } = Command::parse_from(args.clone());

if let Some(dir) = global.generate_manpages {
fs::create_dir_all(&dir)?;
let main_cmd = Command::command();
// Generate man page for the main command
let main_man = Man::new(main_cmd.clone());
let mut buffer = File::create(dir.join("boulder.1"))?;
main_man.render(&mut buffer)?;

// Generate man pages for all subcommands
for sub in main_cmd.get_subcommands() {
let sub_man = Man::new(sub.clone());
let name = format!("boulder-{}.1", sub.get_name());
let mut buffer = File::create(dir.join(&name))?;
sub_man.render(&mut buffer)?;

// Generate man pages for nested subcommands
for nested in sub.get_subcommands() {
let nested_man = Man::new(nested.clone());
let name = format!("boulder-{}-{}.1", sub.get_name(), nested.get_name());
let mut buffer = File::create(dir.join(&name))?;
nested_man.render(&mut buffer)?;
}
}
return Ok(());
}

let env = Env::new(global.cache_dir, global.config_dir, global.data_dir, global.moss_root)?;

if global.verbose {
match subcommand {
Subcommand::Version(_) => (),
Some(Subcommand::Version(_)) => (),
_ => version::print(),
}
println!("{:?}", env.config);
Expand All @@ -68,11 +98,12 @@ pub fn process() -> Result<(), Error> {
}

match subcommand {
Subcommand::Build(command) => build::handle(command, env)?,
Subcommand::Chroot(command) => chroot::handle(command, env)?,
Subcommand::Profile(command) => profile::handle(command, env)?,
Subcommand::Recipe(command) => recipe::handle(command, env)?,
Subcommand::Version(command) => version::handle(command),
Some(Subcommand::Build(command)) => build::handle(command, env)?,
Some(Subcommand::Chroot(command)) => chroot::handle(command, env)?,
Some(Subcommand::Profile(command)) => profile::handle(command, env)?,
Some(Subcommand::Recipe(command)) => recipe::handle(command, env)?,
Some(Subcommand::Version(command)) => version::handle(command),
None => (),
}

Ok(())
Expand Down Expand Up @@ -119,4 +150,6 @@ pub enum Error {
Env(#[from] env::Error),
#[error("recipe")]
Recipe(#[from] recipe::Error),
#[error("io error")]
Io(#[from] std::io::Error),
}

0 comments on commit 0e5537e

Please sign in to comment.