mirror of
https://github.com/GothenburgBitFactory/taskwarrior.git
synced 2025-08-22 20:23:09 +02:00
add done
This commit is contained in:
parent
42d988d601
commit
29ab993397
3 changed files with 57 additions and 0 deletions
51
cli/src/cmd/done.rs
Normal file
51
cli/src/cmd/done.rs
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
use clap::{App, ArgMatches, SubCommand as ClapSubCommand};
|
||||||
|
use failure::Fallible;
|
||||||
|
use taskchampion::Status;
|
||||||
|
|
||||||
|
use crate::cmd::{shared, ArgMatchResult, CommandInvocation};
|
||||||
|
|
||||||
|
#[derive(Debug)]
|
||||||
|
struct Invocation {
|
||||||
|
task: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
define_subcommand! {
|
||||||
|
fn decorate_app<'a>(&self, app: App<'a, 'a>) -> App<'a, 'a> {
|
||||||
|
app.subcommand(
|
||||||
|
ClapSubCommand::with_name("done")
|
||||||
|
.about("finish the given task (status Completed)")
|
||||||
|
.arg(shared::task_arg()))
|
||||||
|
}
|
||||||
|
|
||||||
|
fn arg_match<'a>(&self, matches: &ArgMatches<'a>) -> ArgMatchResult {
|
||||||
|
match matches.subcommand() {
|
||||||
|
("done", Some(matches)) => ArgMatchResult::Ok(Box::new(Invocation {
|
||||||
|
task: matches.value_of("task").unwrap().into(),
|
||||||
|
})),
|
||||||
|
_ => ArgMatchResult::None,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
subcommand_invocation! {
|
||||||
|
fn run(&self, command: &CommandInvocation) -> Fallible<()> {
|
||||||
|
let mut replica = command.get_replica()?;
|
||||||
|
let task = shared::get_task(&mut replica, &self.task)?;
|
||||||
|
let mut task = task.into_mut(&mut replica);
|
||||||
|
task.stop()?;
|
||||||
|
task.set_status(Status::Completed)?;
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod test {
|
||||||
|
use super::*;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn parse_command() {
|
||||||
|
with_subcommand_invocation!(vec!["task", "done", "1"], |inv: &Invocation| {
|
||||||
|
assert_eq!(inv.task, "1".to_string());
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
|
@ -2,6 +2,7 @@ use crate::table;
|
||||||
use clap::{App, ArgMatches, SubCommand as ClapSubCommand};
|
use clap::{App, ArgMatches, SubCommand as ClapSubCommand};
|
||||||
use failure::Fallible;
|
use failure::Fallible;
|
||||||
use prettytable::{cell, row, Table};
|
use prettytable::{cell, row, Table};
|
||||||
|
use taskchampion::Status;
|
||||||
|
|
||||||
use crate::cmd::{ArgMatchResult, CommandInvocation};
|
use crate::cmd::{ArgMatchResult, CommandInvocation};
|
||||||
|
|
||||||
|
@ -28,6 +29,9 @@ subcommand_invocation! {
|
||||||
t.set_format(table::format());
|
t.set_format(table::format());
|
||||||
t.set_titles(row![b->"id", b->"act", b->"description"]);
|
t.set_titles(row![b->"id", b->"act", b->"description"]);
|
||||||
for (uuid, task) in replica.all_tasks().unwrap() {
|
for (uuid, task) in replica.all_tasks().unwrap() {
|
||||||
|
if task.get_status() != Status::Pending {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
let mut id = uuid.to_string();
|
let mut id = uuid.to_string();
|
||||||
if let Some(i) = replica.get_working_set_index(&uuid)? {
|
if let Some(i) = replica.get_working_set_index(&uuid)? {
|
||||||
id = i.to_string();
|
id = i.to_string();
|
||||||
|
|
|
@ -7,6 +7,7 @@ mod shared;
|
||||||
|
|
||||||
mod add;
|
mod add;
|
||||||
mod debug;
|
mod debug;
|
||||||
|
mod done;
|
||||||
mod gc;
|
mod gc;
|
||||||
mod info;
|
mod info;
|
||||||
mod list;
|
mod list;
|
||||||
|
@ -21,6 +22,7 @@ pub(crate) fn subcommands() -> Vec<Box<dyn SubCommand>> {
|
||||||
vec![
|
vec![
|
||||||
add::cmd(),
|
add::cmd(),
|
||||||
debug::cmd(),
|
debug::cmd(),
|
||||||
|
done::cmd(),
|
||||||
gc::cmd(),
|
gc::cmd(),
|
||||||
info::cmd(),
|
info::cmd(),
|
||||||
list::cmd(),
|
list::cmd(),
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue