Merge pull request #255 from matthiasbeyer/imag-counter/list
Imag counter/list
This commit is contained in:
commit
791271c988
4 changed files with 121 additions and 0 deletions
35
imag-counter/src/list.rs
Normal file
35
imag-counter/src/list.rs
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
use libimagrt::runtime::Runtime;
|
||||||
|
use libimagutil::trace::trace_error;
|
||||||
|
use libimagcounter::counter::Counter;
|
||||||
|
use libimagcounter::result::Result;
|
||||||
|
|
||||||
|
pub fn list(rt: &Runtime) {
|
||||||
|
rt.cli()
|
||||||
|
.subcommand_matches("list")
|
||||||
|
.map(|scmd| {
|
||||||
|
debug!("Found 'list' subcommand...");
|
||||||
|
|
||||||
|
Counter::all_counters(rt.store()).map(|iterator| {
|
||||||
|
for counter in iterator {
|
||||||
|
counter.map(|c| {
|
||||||
|
let name = c.name();
|
||||||
|
let value = c.value();
|
||||||
|
|
||||||
|
if name.is_err() {
|
||||||
|
trace_error(&name.err().unwrap());
|
||||||
|
} else {
|
||||||
|
|
||||||
|
if value.is_err() {
|
||||||
|
trace_error(&value.err().unwrap());
|
||||||
|
} else {
|
||||||
|
println!("{} - {}", name.unwrap(), value.unwrap());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.map_err(|e| trace_error(&e));
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.map_err(|e| trace_error(&e))
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
|
@ -17,12 +17,14 @@ use libimagutil::key_value_split::IntoKeyValue;
|
||||||
mod create;
|
mod create;
|
||||||
mod delete;
|
mod delete;
|
||||||
mod interactive;
|
mod interactive;
|
||||||
|
mod list;
|
||||||
mod ui;
|
mod ui;
|
||||||
|
|
||||||
use ui::build_ui;
|
use ui::build_ui;
|
||||||
use create::create;
|
use create::create;
|
||||||
use delete::delete;
|
use delete::delete;
|
||||||
use interactive::interactive;
|
use interactive::interactive;
|
||||||
|
use list::list;
|
||||||
|
|
||||||
enum Action {
|
enum Action {
|
||||||
Inc,
|
Inc,
|
||||||
|
@ -126,6 +128,7 @@ fn main() {
|
||||||
"create" => create(&rt),
|
"create" => create(&rt),
|
||||||
"delete" => delete(&rt),
|
"delete" => delete(&rt),
|
||||||
"interactive" => interactive(&rt),
|
"interactive" => interactive(&rt),
|
||||||
|
"list" => list(&rt),
|
||||||
_ => {
|
_ => {
|
||||||
debug!("Unknown command"); // More error handling
|
debug!("Unknown command"); // More error handling
|
||||||
},
|
},
|
||||||
|
|
|
@ -54,6 +54,38 @@ pub fn build_ui<'a>(app: App<'a, 'a>) -> App<'a, 'a> {
|
||||||
.required(true)
|
.required(true)
|
||||||
.help("Create counter with this name")))
|
.help("Create counter with this name")))
|
||||||
|
|
||||||
|
.subcommand(SubCommand::with_name("list")
|
||||||
|
.about("List counters")
|
||||||
|
.version("0.1")
|
||||||
|
.arg(Arg::with_name("name")
|
||||||
|
.long("name")
|
||||||
|
.short("n")
|
||||||
|
.takes_value(true)
|
||||||
|
.required(false)
|
||||||
|
.help("List counters with this name (foo/bar and baz/bar would match 'bar')"))
|
||||||
|
|
||||||
|
.arg(Arg::with_name("greater-than")
|
||||||
|
.long("greater")
|
||||||
|
.short("g")
|
||||||
|
.takes_value(true)
|
||||||
|
.required(false)
|
||||||
|
.help("List counters which are greater than VALUE"))
|
||||||
|
|
||||||
|
.arg(Arg::with_name("lower-than")
|
||||||
|
.long("lower")
|
||||||
|
.short("l")
|
||||||
|
.takes_value(true)
|
||||||
|
.required(false)
|
||||||
|
.help("List counters which are lower than VALUE"))
|
||||||
|
|
||||||
|
.arg(Arg::with_name("equals")
|
||||||
|
.long("equal")
|
||||||
|
.short("e")
|
||||||
|
.takes_value(true)
|
||||||
|
.required(false)
|
||||||
|
.help("List counters which equal VALUE"))
|
||||||
|
)
|
||||||
|
|
||||||
.subcommand(SubCommand::with_name("interactive")
|
.subcommand(SubCommand::with_name("interactive")
|
||||||
.about("Interactively count things")
|
.about("Interactively count things")
|
||||||
.version("0.1")
|
.version("0.1")
|
||||||
|
|
|
@ -8,6 +8,7 @@ use toml::Value;
|
||||||
use std::collections::BTreeMap;
|
use std::collections::BTreeMap;
|
||||||
|
|
||||||
use libimagstore::store::Store;
|
use libimagstore::store::Store;
|
||||||
|
use libimagstore::storeid::StoreIdIterator;
|
||||||
use libimagstore::store::FileLockEntry;
|
use libimagstore::store::FileLockEntry;
|
||||||
use libimagstore::storeid::StoreId;
|
use libimagstore::storeid::StoreId;
|
||||||
use libimagstore::error::StoreError;
|
use libimagstore::error::StoreError;
|
||||||
|
@ -140,5 +141,55 @@ impl<'a> Counter<'a> {
|
||||||
store.delete(ModuleEntryPath::new(name).into_storeid())
|
store.delete(ModuleEntryPath::new(name).into_storeid())
|
||||||
.map_err(|e| CE::new(CEK::StoreWriteError, Some(Box::new(e))))
|
.map_err(|e| CE::new(CEK::StoreWriteError, Some(Box::new(e))))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn all_counters(store: &Store) -> Result<CounterIterator> {
|
||||||
|
store.retrieve_for_module("counter")
|
||||||
|
.map(|iter| CounterIterator::new(store, iter))
|
||||||
|
.map_err(|e| CE::new(CEK::StoreReadError, Some(Box::new(e))))
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
trait FromStoreId {
|
||||||
|
fn from_storeid<'a>(&'a Store, StoreId) -> Result<Counter<'a>>;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a> FromStoreId for Counter<'a> {
|
||||||
|
|
||||||
|
fn from_storeid<'b>(store: &'b Store, id: StoreId) -> Result<Counter<'b>> {
|
||||||
|
debug!("Loading counter from storeid: '{:?}'", id);
|
||||||
|
match store.retrieve(id) {
|
||||||
|
Err(e) => Err(CE::new(CEK::StoreReadError, Some(Box::new(e)))),
|
||||||
|
Ok(c) => Ok(Counter { fle: c }),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct CounterIterator<'a> {
|
||||||
|
store: &'a Store,
|
||||||
|
iditer: StoreIdIterator,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a> CounterIterator<'a> {
|
||||||
|
|
||||||
|
pub fn new(store: &'a Store, iditer: StoreIdIterator) -> CounterIterator<'a> {
|
||||||
|
CounterIterator {
|
||||||
|
store: store,
|
||||||
|
iditer: iditer,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a> Iterator for CounterIterator<'a> {
|
||||||
|
type Item = Result<Counter<'a>>;
|
||||||
|
|
||||||
|
fn next(&mut self) -> Option<Result<Counter<'a>>> {
|
||||||
|
self.iditer
|
||||||
|
.next()
|
||||||
|
.map(|id| Counter::from_storeid(self.store, id))
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue