diff options
author | Nicolas "Pixel" Noble <pixel@nobis-crew.org> | 2013-08-05 19:19:51 +0200 |
---|---|---|
committer | Nicolas "Pixel" Noble <pixel@nobis-crew.org> | 2013-08-05 19:19:51 +0200 |
commit | 911858d8d7cab0108f1c14abd676ad37ccb9c95a (patch) | |
tree | 9a28cadbcf7a2fd133cfcba32ebce5864f680938 /src | |
parent | e6e2b7afcc92cf0baecd83188e859af7a510da09 (diff) |
Adding a helper to LuaExecCell to find the LuaMainTask, and making the exec() call interruptible.
Diffstat (limited to 'src')
-rw-r--r-- | src/LuaTask.cc | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/src/LuaTask.cc b/src/LuaTask.cc index a549563..cc0bb60 100644 --- a/src/LuaTask.cc +++ b/src/LuaTask.cc @@ -101,11 +101,18 @@ void Balau::LuaTask::Do() { } void Balau::LuaExecCell::exec(LuaMainTask * mainTask) { + if (m_running) + return; + m_running = true; if (!m_detached) Task::prepare(&m_event); mainTask->exec(this); if (!m_detached) - Task::operationYield(&m_event); + Task::operationYield(&m_event, Task::INTERRUPTIBLE); +} + +void Balau::LuaExecCell::exec(Lua & L) { + exec(LuaMainTask::getMainTask(L)); } void Balau::LuaExecCell::throwError() throw (GeneralException) { |