mirror of
https://github.com/GothenburgBitFactory/taskwarrior.git
synced 2025-08-20 13:23:08 +02:00
Enhancements - stop command
- Implemented stop command - Fixed bug in TDB that failed to truncate the pending file on update.
This commit is contained in:
parent
1551362d1e
commit
41e137a92c
3 changed files with 31 additions and 13 deletions
|
@ -192,9 +192,7 @@ std::string Context::dispatch ()
|
||||||
else if (cmd.command == "undelete") { out = handleUndelete (); }
|
else if (cmd.command == "undelete") { out = handleUndelete (); }
|
||||||
*/
|
*/
|
||||||
else if (cmd.command == "start") { out = handleStart (); }
|
else if (cmd.command == "start") { out = handleStart (); }
|
||||||
/*
|
|
||||||
else if (cmd.command == "stop") { out = handleStop (); }
|
else if (cmd.command == "stop") { out = handleStop (); }
|
||||||
*/
|
|
||||||
else if (cmd.command == "export") { out = handleExport (); }
|
else if (cmd.command == "export") { out = handleExport (); }
|
||||||
/*
|
/*
|
||||||
else if (cmd.command == "import") { out = handleImport (); }
|
else if (cmd.command == "import") { out = handleImport (); }
|
||||||
|
|
|
@ -312,8 +312,11 @@ int TDB::commit ()
|
||||||
|
|
||||||
// Write out all pending.
|
// Write out all pending.
|
||||||
if (fseek (mLocations[0].pending, 0, SEEK_SET) == 0)
|
if (fseek (mLocations[0].pending, 0, SEEK_SET) == 0)
|
||||||
|
{
|
||||||
|
ftruncate (fileno (mLocations[0].pending), 0);
|
||||||
foreach (task, mPending)
|
foreach (task, mPending)
|
||||||
fputs (task->composeF4 ().c_str (), mLocations[0].pending);
|
fputs (task->composeF4 ().c_str (), mLocations[0].pending);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return quantity;
|
return quantity;
|
||||||
|
|
|
@ -570,27 +570,44 @@ std::string handleStart ()
|
||||||
std::string handleStop ()
|
std::string handleStop ()
|
||||||
{
|
{
|
||||||
std::stringstream out;
|
std::stringstream out;
|
||||||
/*
|
|
||||||
std::vector <T> all;
|
|
||||||
tdb.pendingT (all);
|
|
||||||
filterSequence (all, task);
|
|
||||||
|
|
||||||
foreach (t, all)
|
std::vector <Task> tasks;
|
||||||
|
context.tdb.lock (context.config.get ("locking", true));
|
||||||
|
context.tdb.loadPending (tasks, context.filter);
|
||||||
|
handleRecurrence (tasks);
|
||||||
|
|
||||||
|
// Filter sequence.
|
||||||
|
context.filter.applySequence (tasks, context.sequence);
|
||||||
|
|
||||||
|
foreach (task, tasks)
|
||||||
{
|
{
|
||||||
if (t->has ("start"))
|
if (task->has ("start"))
|
||||||
{
|
{
|
||||||
t->removeAttribute ("start");
|
task->remove ("start");
|
||||||
tdb.modifyT (*t);
|
context.tdb.update (*task);
|
||||||
|
|
||||||
if (context.config.get ("echo.command", true))
|
if (context.config.get ("echo.command", true))
|
||||||
out << "Stopped " << t->getId () << " '" << t->getDescription () << "'" << std::endl;
|
out << "Stopped "
|
||||||
|
<< task->id
|
||||||
|
<< " '"
|
||||||
|
<< task->get ("description")
|
||||||
|
<< "'"
|
||||||
|
<< std::endl;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
out << "Task " << t->getId () << " '" << t->getDescription () << "' not started." << std::endl;
|
out << "Task "
|
||||||
|
<< task->id
|
||||||
|
<< " '"
|
||||||
|
<< task->get ("description")
|
||||||
|
<< "' not started."
|
||||||
|
<< std::endl;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
|
context.tdb.commit ();
|
||||||
|
context.tdb.unlock ();
|
||||||
|
|
||||||
return out.str ();
|
return out.str ();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue