blob: ed299b51c432e2946cf7a13de95bda0d0d570210 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
/*jshint esversion: 6 */
"use strict";
const LUA_MULTRET = require('./lua.js').LUA_MULTRET;
const Table = require('./lobject.js').Table;
class CallInfo {
constructor(funcOff, func, top, base, previous, next) {
this.func = func;
this.funcOff = funcOff;
this.top = top;
this.previous = previous;
this.next = next;
this.pcOff = 0;
this.u = {
l: {
base: base,
savedpc: []
}
};
this.nresults = 0;
this.callstatus = 0;
}
}
class lua_State {
constructor(cl) {
this.top = 1;
this.ci = new CallInfo(0, cl, 1, 1, null, null);
this.ci.u.l.savedpc = cl.p.code;
this.ci.nresults = LUA_MULTRET;
this.ciOff = 0;
this.stack = [
cl
];
this.openupval = [];
}
}
module.exports.lua_State = lua_State;
module.exports.CallInfo = CallInfo;
module.exports.CIST_OAH = (1<<0); /* original value of 'allowhook' */
module.exports.CIST_LUA = (1<<1); /* call is running a Lua function */
module.exports.CIST_HOOKED = (1<<2); /* call is running a debug hook */
module.exports.CIST_FRESH = (1<<3); /* call is running on a fresh invocation of luaV_execute */
module.exports.CIST_YPCALL = (1<<4); /* call is a yieldable protected call */
module.exports.CIST_TAIL = (1<<5); /* call was tail called */
module.exports.CIST_HOOKYIELD = (1<<6); /* last hook called yielded */
module.exports.CIST_LEQ = (1<<7); /* using __lt for __le */
module.exports.CIST_FIN = (1<<8); /* call is running a finalizer */
|