X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=simgear%2Fnasal%2Fcode.c;h=2bf46451d8501223ed99e2ea97aa1ceb4786b09c;hb=b409f93240dfde9891435869c64a6f879790d3bd;hp=5f94217f45d403c769a5f898294994587f3fc99b;hpb=b2170197234e63ff567ca070b6d5583edbab80cf;p=simgear.git diff --git a/simgear/nasal/code.c b/simgear/nasal/code.c index 5f94217f..2bf46451 100644 --- a/simgear/nasal/code.c +++ b/simgear/nasal/code.c @@ -71,7 +71,9 @@ static double numify(naContext ctx, naRef o) else if(IS_NIL(o)) ERR(ctx, "nil used in numeric context"); else if(!IS_STR(o)) ERR(ctx, "non-scalar in numeric context"); else if(naStr_tonum(o, &n)) return n; - else ERR(ctx, "non-numeric string in numeric context"); + else naRuntimeError( ctx, + "non-numeric string in numeric context: '%s'", + naStr_data(o) ); return 0; } @@ -592,6 +594,9 @@ static naRef run(naContext ctx) case OP_LTE: BINOP(l <= r ? 1 : 0); break; case OP_GT: BINOP(l > r ? 1 : 0); break; case OP_GTE: BINOP(l >= r ? 1 : 0); break; + case OP_BIT_AND: BINOP((int)l & (int)r); break; + case OP_BIT_OR: BINOP((int)l | (int)r); break; + case OP_BIT_XOR: BINOP((int)l ^ (int)r); break; #undef BINOP case OP_EQ: case OP_NEQ: @@ -605,6 +610,9 @@ static naRef run(naContext ctx) case OP_NEG: STK(1) = naNum(-numify(ctx, STK(1))); break; + case OP_BIT_NEG: + STK(1) = naNum(~(int)numify(ctx, STK(1))); + break; case OP_NOT: STK(1) = naNum(boolify(ctx, STK(1)) ? 0 : 1); break;