mirror of
https://git.do.srb2.org/STJr/SRB2.git
synced 2025-03-13 22:33:32 +00:00
Merge branch 'blua-urite' into 'next'
Fix crash when trying to use bitwise NOT on true/false/nil See merge request STJr/SRB2!1262
This commit is contained in:
commit
8701caa110
1 changed files with 12 additions and 19 deletions
|
@ -686,6 +686,15 @@ static void codearith (FuncState *fs, OpCode op, expdesc *e1, expdesc *e2) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void codeunaryarith (FuncState *fs, OpCode op, expdesc *e) {
|
||||||
|
expdesc e2;
|
||||||
|
e2.t = e2.f = NO_JUMP; e2.k = VKNUM; e2.u.nval = 0;
|
||||||
|
if (op == OP_LEN || !isnumeral(e))
|
||||||
|
luaK_exp2anyreg(fs, e); /* cannot operate on non-numeric constants */
|
||||||
|
codearith(fs, op, e, &e2);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static void codecomp (FuncState *fs, OpCode op, int cond, expdesc *e1,
|
static void codecomp (FuncState *fs, OpCode op, int cond, expdesc *e1,
|
||||||
expdesc *e2) {
|
expdesc *e2) {
|
||||||
int o1 = luaK_exp2RK(fs, e1);
|
int o1 = luaK_exp2RK(fs, e1);
|
||||||
|
@ -703,27 +712,11 @@ static void codecomp (FuncState *fs, OpCode op, int cond, expdesc *e1,
|
||||||
|
|
||||||
|
|
||||||
void luaK_prefix (FuncState *fs, UnOpr op, expdesc *e) {
|
void luaK_prefix (FuncState *fs, UnOpr op, expdesc *e) {
|
||||||
expdesc e2;
|
|
||||||
e2.t = e2.f = NO_JUMP; e2.k = VKNUM; e2.u.nval = 0;
|
|
||||||
switch (op) {
|
switch (op) {
|
||||||
case OPR_MINUS: {
|
case OPR_MINUS: codeunaryarith(fs, OP_UNM, e); break;
|
||||||
if (!isnumeral(e))
|
case OPR_BNOT: codeunaryarith(fs, OP_BNOT, e); break;
|
||||||
luaK_exp2anyreg(fs, e); /* cannot operate on non-numeric constants */
|
|
||||||
codearith(fs, OP_UNM, e, &e2);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case OPR_BNOT: {
|
|
||||||
if (e->k == VK)
|
|
||||||
luaK_exp2anyreg(fs, e); /* cannot operate on non-numeric constants */
|
|
||||||
codearith(fs, OP_BNOT, e, &e2);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case OPR_NOT: codenot(fs, e); break;
|
case OPR_NOT: codenot(fs, e); break;
|
||||||
case OPR_LEN: {
|
case OPR_LEN: codeunaryarith(fs, OP_LEN, e); break;
|
||||||
luaK_exp2anyreg(fs, e); /* cannot operate on constants */
|
|
||||||
codearith(fs, OP_LEN, e, &e2);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
default: lua_assert(0);
|
default: lua_assert(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue