Add interface builder function
This commit is contained in:
parent
86e810cc43
commit
2c876a3714
2 changed files with 113 additions and 0 deletions
|
@ -7,6 +7,10 @@ extern crate libimagrt;
|
|||
extern crate libimagstore;
|
||||
extern crate libimagutil;
|
||||
|
||||
mod ui;
|
||||
|
||||
use ui::build_ui;
|
||||
|
||||
fn main() {
|
||||
println!("Hello, world!");
|
||||
}
|
||||
|
|
109
imag-store/src/ui.rs
Normal file
109
imag-store/src/ui.rs
Normal file
|
@ -0,0 +1,109 @@
|
|||
use clap::{Arg, App, SubCommand};
|
||||
|
||||
pub fn build_ui<'a>(app: App<'a, 'a, 'a, 'a, 'a, 'a>) -> App<'a, 'a, 'a, 'a, 'a, 'a> {
|
||||
app.subcommand(SubCommand::with_name("create")
|
||||
.about("Create an entry from the store")
|
||||
.version("0.1")
|
||||
.arg(Arg::with_name("path")
|
||||
.long("path")
|
||||
.short("p")
|
||||
.takes_value(true)
|
||||
.required(true)
|
||||
.help("Create at this store path"))
|
||||
.arg(Arg::with_name("from-raw")
|
||||
.long("from-raw")
|
||||
.takes_value(true)
|
||||
.help("Create a new entry by reading this file ('-' for stdin)"))
|
||||
.subcommand(SubCommand::with_name("entry")
|
||||
.about("Create an entry via commandline")
|
||||
.version("0.1")
|
||||
.arg(Arg::with_name("content")
|
||||
.long("content")
|
||||
.short("c")
|
||||
.takes_value(true)
|
||||
.help("Content for the Entry from this file ('-' for stdin)"))
|
||||
.arg(Arg::with_name("header")
|
||||
.long("header")
|
||||
.short("h")
|
||||
.takes_value(true)
|
||||
.multiple(true)
|
||||
.help("Set a header field. Specify as 'header.field.value=value', multiple allowed"))
|
||||
)
|
||||
)
|
||||
|
||||
.subcommand(SubCommand::with_name("retrieve")
|
||||
.about("Get an entry from the store")
|
||||
.version("0.1")
|
||||
.arg(Arg::with_name("id")
|
||||
.long("id")
|
||||
.short("i")
|
||||
.takes_value(true)
|
||||
.required(true)
|
||||
.help("Retreive by Store Path, where root (/) is the store itself"))
|
||||
.arg(Arg::with_name("content")
|
||||
.long("content")
|
||||
.short("c")
|
||||
.help("Print content"))
|
||||
.arg(Arg::with_name("header")
|
||||
.long("header")
|
||||
.short("h")
|
||||
.help("Print header"))
|
||||
.arg(Arg::with_name("header-json")
|
||||
.long("header-json")
|
||||
.short("j")
|
||||
.help("Print header as json"))
|
||||
.arg(Arg::with_name("raw")
|
||||
.long("raw")
|
||||
.short("r")
|
||||
.help("Print Entries as they are in the store"))
|
||||
.subcommand(SubCommand::with_name("filter-header")
|
||||
.about("Retrieve Entries by filtering")
|
||||
.version("0.1")
|
||||
.arg(Arg::with_name("header-field-where")
|
||||
.long("where")
|
||||
.short("w")
|
||||
.takes_value(true)
|
||||
.help("Filter with 'header.field=foo' where the header field 'header.field' equals 'foo'")
|
||||
)
|
||||
.arg(Arg::with_name("header-field-grep")
|
||||
.long("grep")
|
||||
.short("g")
|
||||
.takes_value(true)
|
||||
.help("Filter with 'header.field=[a-zA-Z0-9]*' where the header field 'header.field' matches '[a-zA-Z0-9]*'"))
|
||||
)
|
||||
)
|
||||
|
||||
.subcommand(SubCommand::with_name("update")
|
||||
.about("Get an entry from the store")
|
||||
.version("0.1")
|
||||
.arg(Arg::with_name("id")
|
||||
.long("id")
|
||||
.short("i")
|
||||
.takes_value(true)
|
||||
.required(true)
|
||||
.help("Update Store Entry with this path. Root (/) is the store itself"))
|
||||
.arg(Arg::with_name("content")
|
||||
.long("content")
|
||||
.short("c")
|
||||
.takes_value(true)
|
||||
.help("Take the content for the new Entry from this file ('-' for stdin)"))
|
||||
.arg(Arg::with_name("header")
|
||||
.long("header")
|
||||
.short("h")
|
||||
.takes_value(true)
|
||||
.multiple(true)
|
||||
.help("Set a header field. Specify as 'header.field.value=value', multiple allowed"))
|
||||
)
|
||||
|
||||
.subcommand(SubCommand::with_name("delete")
|
||||
.about("Delete an entry from the store")
|
||||
.version("0.1")
|
||||
.arg(Arg::with_name("id")
|
||||
.long("id")
|
||||
.short("i")
|
||||
.takes_value(true)
|
||||
.required(true)
|
||||
.help("Remove Store Entry with this path. Root (/) is the store itself"))
|
||||
)
|
||||
}
|
||||
|
Loading…
Reference in a new issue