|
@@ -1,5 +1,5 @@
|
|
|
/*
|
|
|
-** $Id: ldebug.c,v 2.141 2017/11/07 17:20:42 roberto Exp roberto $
|
|
|
+** $Id: ldebug.c,v 2.142 2017/11/08 14:50:23 roberto Exp roberto $
|
|
|
** Debug Interface
|
|
|
** See Copyright Notice in lua.h
|
|
|
*/
|
|
@@ -754,15 +754,16 @@ void luaG_traceexec (lua_State *L) {
|
|
|
luaD_hook(L, LUA_HOOKCOUNT, -1); /* call count hook */
|
|
|
if (mask & LUA_MASKLINE) {
|
|
|
Proto *p = ci_func(ci)->p;
|
|
|
- int npc = pcRel(ci->u.l.savedpc, p);
|
|
|
- if (npc == 0 || /* call linehook when enter a new function, */
|
|
|
- ci->u.l.savedpc <= L->oldpc || /* when jump back (loop), or when */
|
|
|
- changedline(p, pcRel(L->oldpc, p), npc)) { /* enter new line */
|
|
|
- int newline = luaG_getfuncline(p, npc); /* new line */
|
|
|
+ const Instruction *npc = ci->u.l.savedpc;
|
|
|
+ int npci = pcRel(npc, p);
|
|
|
+ if (npci == 0 || /* call linehook when enter a new function, */
|
|
|
+ npc <= L->oldpc || /* when jump back (loop), or when */
|
|
|
+ changedline(p, pcRel(L->oldpc, p), npci)) { /* enter new line */
|
|
|
+ int newline = luaG_getfuncline(p, npci); /* new line */
|
|
|
luaD_hook(L, LUA_HOOKLINE, newline); /* call line hook */
|
|
|
}
|
|
|
+ L->oldpc = npc;
|
|
|
}
|
|
|
- L->oldpc = ci->u.l.savedpc;
|
|
|
if (L->status == LUA_YIELD) { /* did hook yield? */
|
|
|
if (counthook)
|
|
|
L->hookcount = 1; /* undo decrement to zero */
|