mirror of
https://github.com/reactos/wine.git
synced 2025-04-01 15:41:37 +00:00
jscript: Use bytecode for '>>>=' expression implementation.
This commit is contained in:
parent
96e822a33e
commit
7904932a9e
@ -627,6 +627,8 @@ static HRESULT compile_expression_noret(compiler_ctx_t *ctx, expression_t *expr,
|
||||
return compile_assign_expression(ctx, (binary_expression_t*)expr, OP_or);
|
||||
case EXPR_ASSIGNRSHIFT:
|
||||
return compile_assign_expression(ctx, (binary_expression_t*)expr, OP_rshift);
|
||||
case EXPR_ASSIGNRRSHIFT:
|
||||
return compile_assign_expression(ctx, (binary_expression_t*)expr, OP_rshift2);
|
||||
case EXPR_ASSIGNXOR:
|
||||
return compile_assign_expression(ctx, (binary_expression_t*)expr, OP_xor);
|
||||
case EXPR_BAND:
|
||||
|
@ -3140,25 +3140,6 @@ static HRESULT interp_rshift(exec_ctx_t *ctx)
|
||||
return stack_push_int(ctx, l >> (r&0x1f));
|
||||
}
|
||||
|
||||
/* ECMA-262 3rd Edition 11.7.3 */
|
||||
static HRESULT rshift2_eval(script_ctx_t *ctx, VARIANT *lval, VARIANT *rval, jsexcept_t *ei, VARIANT *retv)
|
||||
{
|
||||
DWORD li, ri;
|
||||
HRESULT hres;
|
||||
|
||||
hres = to_uint32(ctx, lval, ei, &li);
|
||||
if(FAILED(hres))
|
||||
return hres;
|
||||
|
||||
hres = to_uint32(ctx, rval, ei, &ri);
|
||||
if(FAILED(hres))
|
||||
return hres;
|
||||
|
||||
V_VT(retv) = VT_I4;
|
||||
V_I4(retv) = li >> (ri&0x1f);
|
||||
return S_OK;
|
||||
}
|
||||
|
||||
/* ECMA-262 3rd Edition 11.7.3 */
|
||||
static HRESULT interp_rshift2(exec_ctx_t *ctx)
|
||||
{
|
||||
@ -3212,16 +3193,6 @@ HRESULT assign_lshift_expression_eval(script_ctx_t *ctx, expression_t *_expr, DW
|
||||
return assign_oper_eval(ctx, expr->expression1, expr->expression2, lshift_eval, ei, ret);
|
||||
}
|
||||
|
||||
/* ECMA-262 3rd Edition 11.13.2 */
|
||||
HRESULT assign_rrshift_expression_eval(script_ctx_t *ctx, expression_t *_expr, DWORD flags, jsexcept_t *ei, exprval_t *ret)
|
||||
{
|
||||
binary_expression_t *expr = (binary_expression_t*)_expr;
|
||||
|
||||
TRACE("\n");
|
||||
|
||||
return assign_oper_eval(ctx, expr->expression1, expr->expression2, rshift2_eval, ei, ret);
|
||||
}
|
||||
|
||||
static HRESULT interp_undefined(exec_ctx_t *ctx)
|
||||
{
|
||||
VARIANT v;
|
||||
|
@ -569,7 +569,6 @@ HRESULT delete_expression_eval(script_ctx_t*,expression_t*,DWORD,jsexcept_t*,exp
|
||||
HRESULT typeof_expression_eval(script_ctx_t*,expression_t*,DWORD,jsexcept_t*,exprval_t*) DECLSPEC_HIDDEN;
|
||||
HRESULT left_shift_expression_eval(script_ctx_t*,expression_t*,DWORD,jsexcept_t*,exprval_t*) DECLSPEC_HIDDEN;
|
||||
HRESULT assign_lshift_expression_eval(script_ctx_t*,expression_t*,DWORD,jsexcept_t*,exprval_t*) DECLSPEC_HIDDEN;
|
||||
HRESULT assign_rrshift_expression_eval(script_ctx_t*,expression_t*,DWORD,jsexcept_t*,exprval_t*) DECLSPEC_HIDDEN;
|
||||
|
||||
HRESULT compiled_expression_eval(script_ctx_t*,expression_t*,DWORD,jsexcept_t*,exprval_t*) DECLSPEC_HIDDEN;
|
||||
|
||||
|
@ -1342,7 +1342,7 @@ static const expression_eval_t expression_eval_table[] = {
|
||||
compiled_expression_eval,
|
||||
assign_lshift_expression_eval,
|
||||
compiled_expression_eval,
|
||||
assign_rrshift_expression_eval,
|
||||
compiled_expression_eval,
|
||||
compiled_expression_eval,
|
||||
compiled_expression_eval,
|
||||
compiled_expression_eval,
|
||||
|
Loading…
x
Reference in New Issue
Block a user