diff options
author | Nicolas Noble <pixel@nobis-crew.org> | 2013-08-05 11:53:57 -0700 |
---|---|---|
committer | Nicolas Noble <pixel@nobis-crew.org> | 2013-08-05 11:53:57 -0700 |
commit | cd5da6097812baf125c2dc4f1d12e1a3f4985464 (patch) | |
tree | ff16f50f3bdd9dad22ec6a1020b1c577a7969ad0 /src | |
parent | 911858d8d7cab0108f1c14abd676ad37ccb9c95a (diff) |
Greatly simplifying the LuaYield mechanism so to avoid double-recursive calls in resume().
Diffstat (limited to 'src')
-rw-r--r-- | src/BLua.cc | 59 |
1 files changed, 28 insertions, 31 deletions
diff --git a/src/BLua.cc b/src/BLua.cc index bed33a0..247a8ab 100644 --- a/src/BLua.cc +++ b/src/BLua.cc @@ -98,7 +98,7 @@ int Balau::LuaStatics::dumpvars(lua_State * __L) { L.dumpvars(h, prefix); Task * t = new CopyTask(s, h); Events::TaskEvent * evt = new Events::TaskEvent(t); - L.yield(Future<int>([evt, s]() mutable { + return L.yield(Future<int>([evt, s]() mutable { for (;;) { if (evt->gotSignal()) { evt->ack(); @@ -767,19 +767,15 @@ Balau::Lua Balau::Lua::thread(bool saveit) { bool Balau::Lua::resume(int nargs) throw (GeneralException) { int r; - if (resumeC()) { - if (yielded()) { - yieldC(); - return true; - } else { - return false; - } - } + if (resumeC(nargs)) + yieldC(); r = lua_resume(L, nargs); - if (r == LUA_YIELD) - return yieldC(); + if (r == LUA_YIELD) { + yieldC(); + return true; + } if (r == 0) return false; @@ -805,7 +801,7 @@ bool Balau::Lua::resume(int nargs) throw (GeneralException) { } } -bool Balau::Lua::resumeC() { +bool Balau::Lua::resumeC(int & nargs) { if (!yielded()) return false; @@ -829,9 +825,6 @@ bool Balau::Lua::resumeC() { delete p; pop(); - int nargs = 0; - bool yieldedAgain = false; - try { nargs = f.get(); } @@ -843,50 +836,54 @@ bool Balau::Lua::resumeC() { p->m_evt = e.getEvent(); push((void *) p); push((void *) &s_signature); - yieldedAgain = true; } catch (LuaYield & y) { Future<int> * p = new Future<int>(y.m_f); push((void *) p); push((void *) &s_signature); - yieldedAgain = true; } catch (Balau::GeneralException & e) { processException(e); } - if (!yieldedAgain) - resume(nargs); + return true; } int Balau::Lua::yield(Future<int> f) throw (GeneralException) { - throw LuaYield(f); + int r = 0; + try { + r = f.get(); + } + catch (EAgain & e) { + LuaYield y(f); + y.m_f.m_evt = e.getEvent(); + throw y; + } + return r; } -bool Balau::Lua::yieldC() throw (GeneralException) { +void Balau::Lua::yieldC() throw (GeneralException) { if (!yielded()) - return true; + return; if (gettop() < 2) - return true; + return; if (!islightuserdata(-1)) - return true; + return; if (!islightuserdata(-2)) - return true; + return; void * s = touserdata(); if (s != &s_signature) - return true; + return; Future<int> * p = (Future<int> *) touserdata(-2); - if (p->m_ranOnce) - Task::operationYield(p->m_evt, Task::STACKLESS); - - resumeC(); - return yieldC(); + IAssert(p->m_evt, "There should always be an event here at that point..."); + Task::operationYield(p->m_evt, Task::STACKLESS); + IAssert(false, "That point shouldn't be reached."); } void Balau::Lua::processException(GeneralException & e) { |