diff --git a/src/Hooks.cpp b/src/Hooks.cpp index c2e56b345..020ae1464 100644 --- a/src/Hooks.cpp +++ b/src/Hooks.cpp @@ -70,35 +70,37 @@ void Hooks::onLaunch () { context.timer_hooks.start (); + std::vector matchingScripts = scripts ("on-launch"); std::vector ::iterator i; - for (i = _scripts.begin (); i != _scripts.end (); ++i) + for (i = matchingScripts.begin (); i != matchingScripts.end (); ++i) { - if (i->find ("/on-launch") != std::string::npos) + std::string output; + int status = execute (*i, "", output); + + std::vector lines; + split (lines, output, '\n'); + std::vector ::iterator line; + + if (status == 0) { - File script (*i); - if (script.executable ()) + for (line = lines.begin (); line != lines.end (); ++line) { - std::string output; - int status = execute (*i, "", output); - - std::vector lines; - split (lines, output, '\n'); - std::vector ::iterator line; - - if (status == 0) + if (line->length () && (*line)[0] == '{') { - for (line = lines.begin (); line != lines.end (); ++line) - context.header (*line); + Task newTask (*line); + context.tdb2.add (newTask); } else - { - for (line = lines.begin (); line != lines.end (); ++line) - context.error (*line); - - throw 0; // This is how hooks silently terminate processing. - } + context.header (*line); } } + 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 ();