vbscript: Store entire EXCEPINFO in script context.

Signed-off-by: Jacek Caban <jacek@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Jacek Caban 2019-10-03 18:18:37 +02:00 committed by Alexandre Julliard
parent 925e56acff
commit 8277c24806
4 changed files with 15 additions and 5 deletions

View File

@ -2477,7 +2477,7 @@ static HRESULT Err_Number(vbdisp_t *This, VARIANT *args, unsigned args_cnt, VARI
return E_NOTIMPL; return E_NOTIMPL;
} }
hres = This->desc->ctx->err_number; hres = This->desc->ctx->ei.scode;
return return_int(res, HRESULT_FACILITY(hres) == FACILITY_VBS ? HRESULT_CODE(hres) : hres); return return_int(res, HRESULT_FACILITY(hres) == FACILITY_VBS ? HRESULT_CODE(hres) : hres);
} }
@ -2494,7 +2494,7 @@ static HRESULT Err_Clear(vbdisp_t *This, VARIANT *args, unsigned args_cnt, VARIA
if(!This->desc) if(!This->desc)
return E_UNEXPECTED; return E_UNEXPECTED;
This->desc->ctx->err_number = S_OK; clear_ei(&This->desc->ctx->ei);
return S_OK; return S_OK;
} }

View File

@ -247,6 +247,14 @@ static HRESULT add_dynamic_var(exec_ctx_t *ctx, const WCHAR *name,
return S_OK; return S_OK;
} }
void clear_ei(EXCEPINFO *ei)
{
SysFreeString(ei->bstrSource);
SysFreeString(ei->bstrDescription);
SysFreeString(ei->bstrHelpFile);
memset(ei, 0, sizeof(*ei));
}
static inline VARIANT *stack_pop(exec_ctx_t *ctx) static inline VARIANT *stack_pop(exec_ctx_t *ctx)
{ {
assert(ctx->top); assert(ctx->top);
@ -1321,7 +1329,7 @@ static HRESULT interp_errmode(exec_ctx_t *ctx)
TRACE("%d\n", err_mode); TRACE("%d\n", err_mode);
ctx->resume_next = err_mode; ctx->resume_next = err_mode;
ctx->script->err_number = S_OK; clear_ei(&ctx->script->ei);
return S_OK; return S_OK;
} }
@ -2158,7 +2166,7 @@ HRESULT exec_script(script_ctx_t *ctx, function_t *func, vbdisp_t *vbthis, DISPP
op = exec.instr->op; op = exec.instr->op;
hres = op_funcs[op](&exec); hres = op_funcs[op](&exec);
if(FAILED(hres)) { if(FAILED(hres)) {
ctx->err_number = hres = map_hres(hres); ctx->ei.scode = hres = map_hres(hres);
if(exec.resume_next) { if(exec.resume_next) {
unsigned stack_off; unsigned stack_off;

View File

@ -153,6 +153,7 @@ static void release_script(script_ctx_t *ctx)
class_desc_t *class_desc; class_desc_t *class_desc;
collect_objects(ctx); collect_objects(ctx);
clear_ei(&ctx->ei);
release_dynamic_vars(ctx->global_vars); release_dynamic_vars(ctx->global_vars);
ctx->global_vars = NULL; ctx->global_vars = NULL;

View File

@ -192,7 +192,7 @@ struct _script_ctx_t {
class_desc_t err_desc; class_desc_t err_desc;
vbdisp_t *err_obj; vbdisp_t *err_obj;
HRESULT err_number; EXCEPINFO ei;
dynamic_var_t *global_vars; dynamic_var_t *global_vars;
function_t *global_funcs; function_t *global_funcs;
@ -358,6 +358,7 @@ HRESULT compile_script(script_ctx_t*,const WCHAR*,const WCHAR*,DWORD,vbscode_t**
HRESULT exec_script(script_ctx_t*,function_t*,vbdisp_t*,DISPPARAMS*,VARIANT*) DECLSPEC_HIDDEN; HRESULT exec_script(script_ctx_t*,function_t*,vbdisp_t*,DISPPARAMS*,VARIANT*) DECLSPEC_HIDDEN;
void release_dynamic_vars(dynamic_var_t*) DECLSPEC_HIDDEN; void release_dynamic_vars(dynamic_var_t*) DECLSPEC_HIDDEN;
IDispatch *lookup_named_item(script_ctx_t*,const WCHAR*,unsigned) DECLSPEC_HIDDEN; IDispatch *lookup_named_item(script_ctx_t*,const WCHAR*,unsigned) DECLSPEC_HIDDEN;
void clear_ei(EXCEPINFO*) DECLSPEC_HIDDEN;
typedef struct { typedef struct {
UINT16 len; UINT16 len;