Commands - done

- Converted the 'done' command to TDB2.  This has a negative impact
  on unit tests, but that represents bugs and ommissions in TDB2,
  not flaws in the 'done' command.
This commit is contained in:
Paul Beckingham 2011-09-03 11:14:59 -04:00
parent e7a255ca16
commit 2886151e64

View file

@ -54,14 +54,9 @@ int CmdDone::execute (std::string& output)
int count = 0; int count = 0;
std::stringstream out; std::stringstream out;
std::vector <Task> tasks;
context.tdb.lock (context.config.getBoolean ("locking"));
context.tdb.loadPending (tasks);
// Apply filter. // Apply filter.
std::vector <Task> filtered; std::vector <Task> filtered;
filter (tasks, filtered); filter (filtered);
if (filtered.size () == 0) if (filtered.size () == 0)
{ {
context.footnote (STRING_FEEDBACK_NO_TASKS_SP); context.footnote (STRING_FEEDBACK_NO_TASKS_SP);
@ -83,11 +78,7 @@ int CmdDone::execute (std::string& output)
task->getStatus () == Task::waiting) task->getStatus () == Task::waiting)
{ {
Task before (*task); Task before (*task);
modify_task_annotate (*task, modifications); modify_task_annotate (*task, modifications);
apply_defaults (*task);
task->setEnd ();
task->setStatus (Task::completed); task->setStatus (Task::completed);
// Stop the task, if started. // Stop the task, if started.
@ -95,14 +86,11 @@ int CmdDone::execute (std::string& output)
context.config.getBoolean ("journal.time")) context.config.getBoolean ("journal.time"))
task->addAnnotation (context.config.get ("journal.time.stop.annotation")); task->addAnnotation (context.config.get ("journal.time.stop.annotation"));
// Only allow valid tasks.
task->validate ();
if (taskDiff (before, *task)) if (taskDiff (before, *task))
{ {
if (permission.confirmed (before, taskDifferences (before, *task) + STRING_CMD_DONE_PROCEED)) if (permission.confirmed (before, taskDifferences (before, *task) + STRING_CMD_DONE_PROCEED))
{ {
context.tdb.update (*task); context.tdb2.modify (*task);
++count; ++count;
if (context.config.getBoolean ("echo.command")) if (context.config.getBoolean ("echo.command"))
@ -127,10 +115,7 @@ int CmdDone::execute (std::string& output)
} }
} }
if (count) context.tdb2.commit ();
context.tdb.commit ();
context.tdb.unlock ();
if (context.config.getBoolean ("echo.command")) if (context.config.getBoolean ("echo.command"))
out << format ((count == 1 out << format ((count == 1