mirror of
https://github.com/GothenburgBitFactory/taskwarrior.git
synced 2025-06-26 10:54:26 +02:00
Hooks
- ::onAdd now conforms to design.
This commit is contained in:
parent
0d2bc00527
commit
3010ac667b
1 changed files with 31 additions and 21 deletions
|
@ -164,36 +164,46 @@ void Hooks::onAdd (Task& after)
|
||||||
{
|
{
|
||||||
context.timer_hooks.start ();
|
context.timer_hooks.start ();
|
||||||
|
|
||||||
|
std::vector <std::string> matchingScripts = scripts ("on-add");
|
||||||
std::vector <std::string>::iterator i;
|
std::vector <std::string>::iterator i;
|
||||||
for (i = _scripts.begin (); i != _scripts.end (); ++i)
|
for (i = matchingScripts.begin (); i != matchingScripts.end (); ++i)
|
||||||
{
|
{
|
||||||
if (i->find ("/on-add") != std::string::npos)
|
std::string input = after.composeJSON () + "\n";
|
||||||
|
std::string output;
|
||||||
|
int status = execute (*i, input, output);
|
||||||
|
|
||||||
|
std::vector <std::string> lines;
|
||||||
|
split (lines, output, '\n');
|
||||||
|
std::vector <std::string>::iterator line;
|
||||||
|
|
||||||
|
if (status == 0)
|
||||||
{
|
{
|
||||||
File script (*i);
|
bool first = true;
|
||||||
if (script.executable ())
|
for (line = lines.begin (); line != lines.end (); ++line)
|
||||||
{
|
{
|
||||||
std::string input = after.composeJSON ();
|
if (line->length () && (*line)[0] == '{')
|
||||||
std::string output;
|
|
||||||
int status = execute (*i, input, output);
|
|
||||||
|
|
||||||
std::vector <std::string> lines;
|
|
||||||
split (lines, output, '\n');
|
|
||||||
std::vector <std::string>::iterator line;
|
|
||||||
|
|
||||||
if (status == 0)
|
|
||||||
{
|
{
|
||||||
for (line = lines.begin (); line != lines.end (); ++line)
|
Task newTask (*line);
|
||||||
context.footnote (*line);
|
|
||||||
|
if (first)
|
||||||
|
{
|
||||||
|
after = newTask;
|
||||||
|
first = false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
context.tdb2.add (newTask);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
context.footnote (*line);
|
||||||
for (line = lines.begin (); line != lines.end (); ++line)
|
|
||||||
context.error (*line);
|
|
||||||
|
|
||||||
throw 0; // This is how hooks silently terminate processing.
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for (line = lines.begin (); line != lines.end (); ++line)
|
||||||
|
context.error (*line);
|
||||||
|
|
||||||
|
throw 0; // This is how hooks silently terminate processing.
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
context.timer_hooks.stop ();
|
context.timer_hooks.stop ();
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue