Add CliSpec trait for Runtime initialisation
This commit is contained in:
parent
297eeb1bd2
commit
0def6a3d5a
3 changed files with 33 additions and 4 deletions
|
@ -53,4 +53,5 @@ pub mod configuration;
|
||||||
pub mod logger;
|
pub mod logger;
|
||||||
pub mod runtime;
|
pub mod runtime;
|
||||||
pub mod setup;
|
pub mod setup;
|
||||||
|
pub mod spec;
|
||||||
|
|
||||||
|
|
|
@ -36,6 +36,7 @@ use error::MapErrInto;
|
||||||
use logger::ImagLogger;
|
use logger::ImagLogger;
|
||||||
|
|
||||||
use libimagstore::store::Store;
|
use libimagstore::store::Store;
|
||||||
|
use spec::CliSpec;
|
||||||
|
|
||||||
/// The Runtime object
|
/// The Runtime object
|
||||||
///
|
///
|
||||||
|
@ -55,7 +56,7 @@ impl<'a> Runtime<'a> {
|
||||||
/// and builds the Runtime object with it.
|
/// and builds the Runtime object with it.
|
||||||
///
|
///
|
||||||
/// The cli_spec object should be initially build with the ::get_default_cli_builder() function.
|
/// The cli_spec object should be initially build with the ::get_default_cli_builder() function.
|
||||||
pub fn new(mut cli_spec: App<'a, 'a>) -> Result<Runtime<'a>, RuntimeError> {
|
pub fn new<C: Clone + CliSpec<'a>>(mut cli_spec: C) -> Result<Runtime<'a>, RuntimeError> {
|
||||||
use std::env;
|
use std::env;
|
||||||
use std::io::stdout;
|
use std::io::stdout;
|
||||||
|
|
||||||
|
@ -66,7 +67,7 @@ impl<'a> Runtime<'a> {
|
||||||
|
|
||||||
use configuration::error::ConfigErrorKind;
|
use configuration::error::ConfigErrorKind;
|
||||||
|
|
||||||
let matches = cli_spec.clone().get_matches();
|
let matches = cli_spec.clone().matches();
|
||||||
|
|
||||||
let is_debugging = matches.is_present("debugging");
|
let is_debugging = matches.is_present("debugging");
|
||||||
let is_verbose = matches.is_present("verbosity");
|
let is_verbose = matches.is_present("verbosity");
|
||||||
|
@ -78,8 +79,8 @@ impl<'a> Runtime<'a> {
|
||||||
Some(shell) => {
|
Some(shell) => {
|
||||||
debug!("Generating shell completion script, writing to stdout");
|
debug!("Generating shell completion script, writing to stdout");
|
||||||
let shell = shell.parse::<Shell>().unwrap(); // clap has our back here.
|
let shell = shell.parse::<Shell>().unwrap(); // clap has our back here.
|
||||||
let appname = String::from(cli_spec.get_name());
|
let appname = String::from(cli_spec.name());
|
||||||
cli_spec.gen_completions_to(appname, shell, &mut stdout());
|
cli_spec.completions(appname, shell, &mut stdout());
|
||||||
},
|
},
|
||||||
_ => debug!("Not generating shell completion script"),
|
_ => debug!("Not generating shell completion script"),
|
||||||
}
|
}
|
||||||
|
|
27
libimagrt/src/spec.rs
Normal file
27
libimagrt/src/spec.rs
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
use std::io::Write;
|
||||||
|
|
||||||
|
use clap::{App, ArgMatches, Shell};
|
||||||
|
|
||||||
|
pub trait CliSpec<'a> {
|
||||||
|
fn name(&self) -> &str;
|
||||||
|
fn matches(self) -> ArgMatches<'a>;
|
||||||
|
fn completions<W: Write, S: Into<String>>(&mut self, _: S, _: Shell, _: &mut W) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a> CliSpec<'a> for App<'a, 'a> {
|
||||||
|
fn name(&self) -> &str {
|
||||||
|
self.get_name()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn matches(self) -> ArgMatches<'a> {
|
||||||
|
self.get_matches()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn completions<W: Write, S: Into<String>>(&mut self,
|
||||||
|
bin_name: S,
|
||||||
|
for_shell: Shell,
|
||||||
|
buf: &mut W) {
|
||||||
|
|
||||||
|
self.gen_completions_to(bin_name, for_shell, buf);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue