int CmdStop::execute (std::string&) { int rc = 0; int count = 0; // Apply filter. Filter filter; std::vector <Task> filtered; filter.subset (filtered); if (filtered.size () == 0) { context.footnote (STRING_FEEDBACK_NO_TASKS_SP); return 1; } // Accumulated project change notifications. std::map <std::string, std::string> projectChanges; for (auto& task : filtered) { if (task.has ("start")) { Task before (task); // Stop the specified task. std::string question = format (STRING_CMD_STOP_CONFIRM, task.id, task.get ("description")); task.modify (Task::modAnnotate); task.remove ("start"); if (context.config.getBoolean ("journal.time")) task.addAnnotation (context.config.get ("journal.time.stop.annotation")); if (permission (taskDifferences (before, task) + question, filtered.size ())) { updateRecurrenceMask (task); context.tdb2.modify (task); ++count; feedback_affected (STRING_CMD_STOP_TASK, task); dependencyChainOnStart (task); if (context.verbose ("project")) projectChanges[task.get ("project")] = onProjectChange (task, false); } else { std::cout << STRING_CMD_STOP_NO << "\n"; rc = 1; if (_permission_quit) break; } } else { std::cout << format (STRING_CMD_STOP_ALREADY, task.id, task.get ("description")) << "\n"; rc = 1; } } // Now list the project changes. for (auto& change : projectChanges) if (change.first != "") context.footnote (change.second); feedback_affected (count == 1 ? STRING_CMD_STOP_1 : STRING_CMD_STOP_N, count); return rc; }
int CmdStop::execute (std::string& output) { int rc = 0; int count = 0; // Apply filter. std::vector <Task> filtered; filter (filtered); if (filtered.size () == 0) { context.footnote (STRING_FEEDBACK_NO_TASKS_SP); return 1; } // Apply the command line modifications to the new task. A3 modifications = context.a3.extract_modifications (); // Accumulated project change notifications. std::map <std::string, std::string> projectChanges; std::vector <Task>::iterator task; for (task = filtered.begin (); task != filtered.end (); ++task) { if (task->has ("start")) { Task before (*task); // Stop the specified task. std::string question = format (STRING_CMD_STOP_CONFIRM, task->id, task->get ("description")); modify_task_annotate (*task, modifications); task->remove ("start"); if (context.config.getBoolean ("journal.time")) task->addAnnotation (context.config.get ("journal.time.stop.annotation")); if (permission (*task, taskDifferences (before, *task) + question, filtered.size ())) { updateRecurrenceMask (*task); context.tdb2.modify (*task); ++count; feedback_affected (STRING_CMD_STOP_TASK, *task); dependencyChainOnStart (*task); if (context.verbose ("project")) projectChanges[task->get ("project")] = onProjectChange (*task, false); } else { std::cout << STRING_CMD_STOP_NO << "\n"; rc = 1; if (_permission_quit) break; } } else { std::cout << format (STRING_CMD_STOP_ALREADY, task->id, task->get ("description")) << "\n"; rc = 1; } } // Now list the project changes. std::map <std::string, std::string>::iterator i; for (i = projectChanges.begin (); i != projectChanges.end (); ++i) if (i->first != "") context.footnote (i->second); context.tdb2.commit (); feedback_affected (count == 1 ? STRING_CMD_STOP_1 : STRING_CMD_STOP_N, count); return rc; }