mirror of
https://github.com/GothenburgBitFactory/taskwarrior.git
synced 2025-06-26 10:54:26 +02:00
55 lines
1.6 KiB
Rust
55 lines
1.6 KiB
Rust
use crate::table;
|
|
use clap::{App, ArgMatches, SubCommand as ClapSubCommand};
|
|
use failure::Fallible;
|
|
use prettytable::{cell, row, Table};
|
|
|
|
use crate::cmd::{ArgMatchResult, CommandInvocation};
|
|
|
|
#[derive(Debug)]
|
|
struct Invocation {}
|
|
|
|
define_subcommand! {
|
|
fn decorate_app<'a>(&self, app: App<'a, 'a>) -> App<'a, 'a> {
|
|
app.subcommand(ClapSubCommand::with_name("pending").about("lists pending tasks"))
|
|
}
|
|
|
|
fn arg_match<'a>(&self, matches: &ArgMatches<'a>) -> ArgMatchResult {
|
|
match matches.subcommand() {
|
|
("pending", _) => ArgMatchResult::Ok(Box::new(Invocation {})),
|
|
// default to this command when no subcommand is given
|
|
("", _) => ArgMatchResult::Ok(Box::new(Invocation {})),
|
|
_ => ArgMatchResult::None,
|
|
}
|
|
}
|
|
}
|
|
|
|
subcommand_invocation! {
|
|
fn run(&self, command: &CommandInvocation) -> Fallible<()> {
|
|
let working_set = command.get_replica().working_set().unwrap();
|
|
let mut t = Table::new();
|
|
t.set_format(table::format());
|
|
t.set_titles(row![b->"id", b->"description"]);
|
|
for (i, item) in working_set.iter().enumerate() {
|
|
if let Some(ref task) = item {
|
|
t.add_row(row![i, task.get_description()]);
|
|
}
|
|
}
|
|
t.printstd();
|
|
Ok(())
|
|
}
|
|
}
|
|
|
|
#[cfg(test)]
|
|
mod test {
|
|
use super::*;
|
|
|
|
#[test]
|
|
fn parse_command() {
|
|
with_subcommand_invocation!(vec!["task", "pending"], |_inv| {});
|
|
}
|
|
|
|
#[test]
|
|
fn parse_command_default() {
|
|
with_subcommand_invocation!(vec!["task"], |_inv| {});
|
|
}
|
|
}
|