Commit e5baa750 authored by Jacek Caban's avatar Jacek Caban Committed by Alexandre Julliard

jscript: Simplify identifier_eval function.

parent 9336c106
...@@ -488,7 +488,7 @@ static BOOL lookup_global_members(script_ctx_t *ctx, BSTR identifier, exprval_t ...@@ -488,7 +488,7 @@ static BOOL lookup_global_members(script_ctx_t *ctx, BSTR identifier, exprval_t
} }
/* ECMA-262 3rd Edition 10.1.4 */ /* ECMA-262 3rd Edition 10.1.4 */
static HRESULT identifier_eval(script_ctx_t *ctx, BSTR identifier, DWORD flags, jsexcept_t *ei, exprval_t *ret) static HRESULT identifier_eval(script_ctx_t *ctx, BSTR identifier, exprval_t *ret)
{ {
scope_chain_t *scope; scope_chain_t *scope;
named_item_t *item; named_item_t *item;
...@@ -545,15 +545,6 @@ static HRESULT identifier_eval(script_ctx_t *ctx, BSTR identifier, DWORD flags, ...@@ -545,15 +545,6 @@ static HRESULT identifier_eval(script_ctx_t *ctx, BSTR identifier, DWORD flags,
if(lookup_global_members(ctx, identifier, ret)) if(lookup_global_members(ctx, identifier, ret))
return S_OK; return S_OK;
if(flags & fdexNameEnsure) {
hres = jsdisp_get_id(ctx->global, identifier, fdexNameEnsure, &id);
if(FAILED(hres))
return hres;
exprval_set_idref(ret, to_disp(ctx->global), id);
return S_OK;
}
ret->type = EXPRVAL_INVALID; ret->type = EXPRVAL_INVALID;
return S_OK; return S_OK;
} }
...@@ -1083,7 +1074,7 @@ static HRESULT interp_ident(exec_ctx_t *ctx) ...@@ -1083,7 +1074,7 @@ static HRESULT interp_ident(exec_ctx_t *ctx)
TRACE("%s\n", debugstr_w(arg)); TRACE("%s\n", debugstr_w(arg));
hres = identifier_eval(ctx->parser->script, arg, 0, ctx->ei, &exprval); hres = identifier_eval(ctx->parser->script, arg, &exprval);
if(FAILED(hres)) if(FAILED(hres))
return hres; return hres;
...@@ -1108,10 +1099,20 @@ static HRESULT interp_identid(exec_ctx_t *ctx) ...@@ -1108,10 +1099,20 @@ static HRESULT interp_identid(exec_ctx_t *ctx)
TRACE("%s %x\n", debugstr_w(arg), flags); TRACE("%s %x\n", debugstr_w(arg), flags);
hres = identifier_eval(ctx->parser->script, arg, flags, ctx->ei, &exprval); hres = identifier_eval(ctx->parser->script, arg, &exprval);
if(FAILED(hres)) if(FAILED(hres))
return hres; return hres;
if(exprval.type == EXPRVAL_INVALID && (flags & fdexNameEnsure)) {
DISPID id;
hres = jsdisp_get_id(ctx->parser->script->global, arg, fdexNameEnsure, &id);
if(FAILED(hres))
return hres;
exprval_set_idref(&exprval, to_disp(ctx->parser->script->global), id);
}
if(exprval.type != EXPRVAL_IDREF) { if(exprval.type != EXPRVAL_IDREF) {
WARN("invalid ref\n"); WARN("invalid ref\n");
exprval_release(&exprval); exprval_release(&exprval);
...@@ -1686,7 +1687,7 @@ static HRESULT interp_delete_ident(exec_ctx_t *ctx) ...@@ -1686,7 +1687,7 @@ static HRESULT interp_delete_ident(exec_ctx_t *ctx)
TRACE("%s\n", debugstr_w(arg)); TRACE("%s\n", debugstr_w(arg));
hres = identifier_eval(ctx->parser->script, arg, 0, ctx->ei, &exprval); hres = identifier_eval(ctx->parser->script, arg, &exprval);
if(FAILED(hres)) if(FAILED(hres))
return hres; return hres;
...@@ -1804,7 +1805,7 @@ static HRESULT interp_typeofident(exec_ctx_t *ctx) ...@@ -1804,7 +1805,7 @@ static HRESULT interp_typeofident(exec_ctx_t *ctx)
TRACE("%s\n", debugstr_w(arg)); TRACE("%s\n", debugstr_w(arg));
hres = identifier_eval(ctx->parser->script, arg, 0, ctx->ei, &exprval); hres = identifier_eval(ctx->parser->script, arg, &exprval);
if(FAILED(hres)) if(FAILED(hres))
return hres; return hres;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment