Hooks
- Implemented ::onModify.
This commit is contained in:
@@ -174,7 +174,7 @@ void Hooks::onAdd (Task& after)
|
|||||||
if (status == 0)
|
if (status == 0)
|
||||||
{
|
{
|
||||||
for (line = lines.begin (); line != lines.end (); ++line)
|
for (line = lines.begin (); line != lines.end (); ++line)
|
||||||
context.header (*line);
|
context.footnote (*line);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -206,19 +206,35 @@ void Hooks::onModify (const Task& before, Task& after)
|
|||||||
std::vector <std::string>::iterator i;
|
std::vector <std::string>::iterator i;
|
||||||
for (i = _scripts.begin (); i != _scripts.end (); ++i)
|
for (i = _scripts.begin (); i != _scripts.end (); ++i)
|
||||||
{
|
{
|
||||||
if (i->substr (0, 9) == "on-modify")
|
if (i->find ("/on-modify") != std::string::npos)
|
||||||
{
|
{
|
||||||
File script (*i);
|
File script (*i);
|
||||||
if (script.executable ())
|
if (script.executable ())
|
||||||
{
|
{
|
||||||
// TODO Call all modify hook scripts.
|
std::string afterJSON = after.composeJSON ();
|
||||||
|
std::string input = before.composeJSON ()
|
||||||
|
+ "\n"
|
||||||
|
+ afterJSON;
|
||||||
|
std::string output;
|
||||||
|
int status = execute (*i, input, output);
|
||||||
|
|
||||||
// TODO On zero status:
|
std::vector <std::string> lines;
|
||||||
// - first line is modified JSON
|
split (lines, output, '\n');
|
||||||
// - remaining lines --> context.footnote
|
std::vector <std::string>::iterator line;
|
||||||
|
|
||||||
// TODO On non-zero status:
|
if (status == 0)
|
||||||
// - all stdout --> context.error
|
{
|
||||||
|
after = Task (afterJSON);
|
||||||
|
for (line = lines.begin (); line != lines.end (); ++line)
|
||||||
|
context.footnote (*line);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for (line = lines.begin (); line != lines.end (); ++line)
|
||||||
|
context.error (*line);
|
||||||
|
|
||||||
|
throw 0; // This is how hooks silently terminate processing.
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user