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

vbscript: Added bytecode decompiler implementation.

parent d028453f
...@@ -25,6 +25,7 @@ ...@@ -25,6 +25,7 @@
#include "wine/debug.h" #include "wine/debug.h"
WINE_DEFAULT_DEBUG_CHANNEL(vbscript); WINE_DEFAULT_DEBUG_CHANNEL(vbscript);
WINE_DECLARE_DEBUG_CHANNEL(vbscript_disas);
typedef struct { typedef struct {
parser_ctx_t parser; parser_ctx_t parser;
...@@ -45,14 +46,51 @@ static HRESULT compile_expression(compile_ctx_t*,expression_t*); ...@@ -45,14 +46,51 @@ static HRESULT compile_expression(compile_ctx_t*,expression_t*);
static HRESULT compile_statement(compile_ctx_t*,statement_t*); static HRESULT compile_statement(compile_ctx_t*,statement_t*);
static const struct { static const struct {
const char *op_str;
instr_arg_type_t arg1_type; instr_arg_type_t arg1_type;
instr_arg_type_t arg2_type; instr_arg_type_t arg2_type;
} instr_info[] = { } instr_info[] = {
#define X(n,a,b,c) {b,c}, #define X(n,a,b,c) {#n,b,c},
OP_LIST OP_LIST
#undef X #undef X
}; };
static void dump_instr_arg(instr_arg_type_t type, instr_arg_t *arg)
{
switch(type) {
case ARG_STR:
case ARG_BSTR:
TRACE_(vbscript_disas)("\t%s", debugstr_w(arg->str));
break;
case ARG_INT:
TRACE_(vbscript_disas)("\t%d", arg->uint);
break;
case ARG_UINT:
case ARG_ADDR:
TRACE_(vbscript_disas)("\t%u", arg->uint);
break;
case ARG_DOUBLE:
TRACE_(vbscript_disas)("\t%lf", *arg->dbl);
break;
case ARG_NONE:
break;
default:
assert(0);
}
}
static void dump_code(compile_ctx_t *ctx)
{
instr_t *instr;
for(instr = ctx->code->instrs; instr < ctx->code->instrs+ctx->instr_cnt; instr++) {
TRACE_(vbscript_disas)("%d:\t%s", instr-ctx->code->instrs, instr_info[instr->op].op_str);
dump_instr_arg(instr_info[instr->op].arg1_type, &instr->arg1);
dump_instr_arg(instr_info[instr->op].arg2_type, &instr->arg2);
TRACE_(vbscript_disas)("\n");
}
}
static inline void *compiler_alloc(vbscode_t *vbscode, size_t size) static inline void *compiler_alloc(vbscode_t *vbscode, size_t size)
{ {
return vbsheap_alloc(&vbscode->heap, size); return vbsheap_alloc(&vbscode->heap, size);
...@@ -670,6 +708,9 @@ HRESULT compile_script(script_ctx_t *script, const WCHAR *src, vbscode_t **ret) ...@@ -670,6 +708,9 @@ HRESULT compile_script(script_ctx_t *script, const WCHAR *src, vbscode_t **ret)
parser_release(&ctx.parser); parser_release(&ctx.parser);
if(TRACE_ON(vbscript_disas))
dump_code(&ctx);
list_add_tail(&script->code_list, &ctx.code->entry); list_add_tail(&script->code_list, &ctx.code->entry);
*ret = ctx.code; *ret = ctx.code;
return S_OK; return S_OK;
......
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