diff options
author | Benoit Giannangeli <benoit.giannangeli@boursorama.fr> | 2017-02-07 08:40:43 +0100 |
---|---|---|
committer | Benoit Giannangeli <benoit.giannangeli@boursorama.fr> | 2017-02-07 11:46:03 +0100 |
commit | c7b6e2364b3ff9bed781215f57a6398979b287d4 (patch) | |
tree | f8f8f131b61769c76a21b8791dccc78236ead80f /src | |
parent | ba36e0249a7c3209b9cf64aef69d75bce4c4f726 (diff) | |
download | fengari-c7b6e2364b3ff9bed781215f57a6398979b287d4.tar.gz fengari-c7b6e2364b3ff9bed781215f57a6398979b287d4.tar.bz2 fengari-c7b6e2364b3ff9bed781215f57a6398979b287d4.zip |
GETUPVAL, SETUPVAL
Diffstat (limited to 'src')
-rw-r--r-- | src/lvm.js | 15 |
1 files changed, 10 insertions, 5 deletions
@@ -70,6 +70,8 @@ class LuaVM { let i = ci.u.l.savedpc[ci.pcOff++]; let ra = this.RA(base, i); + console.log(`Before ${OC.OpCodes[i.opcode]} L.top is ${L.top}`); + switch (OC.OpCodes[i.opcode]) { case "OP_MOVE": { L.stack[ra] = L.stack[this.RB(base, i)]; @@ -98,15 +100,17 @@ class LuaVM { break; } case "OP_GETUPVAL": { + L.stack[ra] = L.stack[cl.upvals[i.B].v]; break; } - case "OP_GETTABUP": { + case "OP_SETUPVAL": { + L.stack[cl.upvals[i.B].v] = L.stack[ra]; break; } - case "OP_SETTABUP": { + case "OP_GETTABUP": { break; } - case "OP_SETUPVAL": { + case "OP_SETTABUP": { break; } case "OP_GETTABLE": { @@ -442,7 +446,7 @@ class LuaVM { L.stack[ra] = ncl; - for (let i = 0; i < nup; i++) { // TODO test + for (let i = 0; i < nup; i++) { if (uv[i].instack) ncl.upvals[i] = this.findupval(base + uv[i].idx); else @@ -571,7 +575,8 @@ class LuaVM { return true; } - findupval(level) { // TODO test + findupval(level) { + let L = this.L; let pp = L.openupval; while(pp !== null && pp.v >= level) { |