jscript: Always use bytecode for with statement.
[wine/multimedia.git] / dlls / jscript / engine.h
blob4f088b5a5cf2ea787bfaf85553e803547dc7b5fe
1 /*
2 * Copyright 2008 Jacek Caban for CodeWeavers
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19 typedef struct _source_elements_t source_elements_t;
20 typedef struct _function_expression_t function_expression_t;
21 typedef struct _expression_t expression_t;
22 typedef struct _statement_t statement_t;
24 typedef struct _function_declaration_t {
25 function_expression_t *expr;
27 struct _function_declaration_t *next;
28 } function_declaration_t;
30 typedef struct _var_list_t {
31 const WCHAR *identifier;
33 struct _var_list_t *next;
34 } var_list_t;
36 typedef struct _func_stack {
37 function_declaration_t *func_head;
38 function_declaration_t *func_tail;
39 var_list_t *var_head;
40 var_list_t *var_tail;
42 struct _func_stack *next;
43 } func_stack_t;
45 #define OP_LIST \
46 X(add, 1, 0,0) \
47 X(and, 1, 0,0) \
48 X(array, 1, 0,0) \
49 X(assign, 1, 0,0) \
50 X(bool, 1, ARG_INT, 0) \
51 X(bneg, 1, 0,0) \
52 X(call, 1, ARG_UINT, ARG_UINT) \
53 X(call_member,1, ARG_UINT, ARG_UINT) \
54 X(carray, 1, ARG_UINT, 0) \
55 X(case, 0, ARG_ADDR, 0) \
56 X(cnd_nz, 0, ARG_ADDR, 0) \
57 X(cnd_z, 0, ARG_ADDR, 0) \
58 X(delete, 1, 0,0) \
59 X(delete_ident,1,ARG_BSTR, 0) \
60 X(div, 1, 0,0) \
61 X(double, 1, ARG_DBL, 0) \
62 X(end_finally,1, 0,0) \
63 X(eq, 1, 0,0) \
64 X(eq2, 1, 0,0) \
65 X(forin, 0, ARG_ADDR, 0) \
66 X(func, 1, ARG_FUNC, 0) \
67 X(gt, 1, 0,0) \
68 X(gteq, 1, 0,0) \
69 X(ident, 1, ARG_BSTR, 0) \
70 X(identid, 1, ARG_BSTR, ARG_INT) \
71 X(in, 1, 0,0) \
72 X(instanceof, 1, 0,0) \
73 X(int, 1, ARG_INT, 0) \
74 X(jmp, 0, ARG_ADDR, 0) \
75 X(jmp_z, 0, ARG_ADDR, 0) \
76 X(label, 0, 0,0) \
77 X(lshift, 1, 0,0) \
78 X(lt, 1, 0,0) \
79 X(lteq, 1, 0,0) \
80 X(member, 1, ARG_BSTR, 0) \
81 X(memberid, 1, ARG_UINT, 0) \
82 X(minus, 1, 0,0) \
83 X(mod, 1, 0,0) \
84 X(mul, 1, 0,0) \
85 X(neg, 1, 0,0) \
86 X(neq, 1, 0,0) \
87 X(neq2, 1, 0,0) \
88 X(new, 1, ARG_INT, 0) \
89 X(new_obj, 1, 0,0) \
90 X(null, 1, 0,0) \
91 X(obj_prop, 1, ARG_BSTR, 0) \
92 X(or, 1, 0,0) \
93 X(pop, 1, 0,0) \
94 X(pop_except, 1, 0,0) \
95 X(pop_scope, 1, 0,0) \
96 X(postinc, 1, ARG_INT, 0) \
97 X(preinc, 1, ARG_INT, 0) \
98 X(push_except,1, ARG_ADDR, ARG_BSTR) \
99 X(push_scope, 1, 0,0) \
100 X(regexp, 1, ARG_STR, ARG_INT) \
101 X(rshift, 1, 0,0) \
102 X(rshift2, 1, 0,0) \
103 X(str, 1, ARG_STR, 0) \
104 X(this, 1, 0,0) \
105 X(throw, 0, 0,0) \
106 X(throw_ref, 0, ARG_UINT, 0) \
107 X(throw_type, 0, ARG_UINT, ARG_STR) \
108 X(tonum, 1, 0,0) \
109 X(tree, 1, ARG_STAT, 0) \
110 X(typeof, 1, 0,0) \
111 X(typeofid, 1, 0,0) \
112 X(typeofident,1, 0,0) \
113 X(refval, 1, 0,0) \
114 X(ret, 0, 0,0) \
115 X(sub, 1, 0,0) \
116 X(undefined, 1, 0,0) \
117 X(var_set, 1, ARG_BSTR, 0) \
118 X(void, 1, 0,0) \
119 X(xor, 1, 0,0)
121 typedef enum {
122 #define X(x,a,b,c) OP_##x,
123 OP_LIST
124 #undef X
125 OP_LAST
126 } jsop_t;
128 typedef union {
129 statement_t *stat;
130 BSTR bstr;
131 double *dbl;
132 LONG lng;
133 WCHAR *str;
134 unsigned uint;
135 function_expression_t *func; /* FIXME */
136 } instr_arg_t;
138 typedef enum {
139 ARG_NONE = 0,
140 ARG_ADDR,
141 ARG_BSTR,
142 ARG_DBL,
143 ARG_STAT,
144 ARG_FUNC,
145 ARG_INT,
146 ARG_STR,
147 ARG_UINT
148 } instr_arg_type_t;
150 typedef struct {
151 jsop_t op;
152 instr_arg_t arg1;
153 instr_arg_t arg2;
154 } instr_t;
156 typedef struct {
157 instr_t *instrs;
158 jsheap_t heap;
160 BSTR *bstr_pool;
161 unsigned bstr_pool_size;
162 unsigned bstr_cnt;
163 } bytecode_t;
165 void release_bytecode(bytecode_t*);
167 typedef struct _compiler_ctx_t compiler_ctx_t;
169 void release_compiler(compiler_ctx_t*);
171 typedef struct _parser_ctx_t {
172 LONG ref;
174 WCHAR *begin;
175 const WCHAR *end;
176 const WCHAR *ptr;
178 script_ctx_t *script;
179 source_elements_t *source;
180 BOOL nl;
181 BOOL is_html;
182 BOOL lexer_error;
183 HRESULT hres;
185 jsheap_t heap;
187 func_stack_t *func_stack;
189 bytecode_t *code;
190 compiler_ctx_t *compiler;
192 struct _parser_ctx_t *next;
193 } parser_ctx_t;
195 HRESULT script_parse(script_ctx_t*,const WCHAR*,const WCHAR*,parser_ctx_t**) DECLSPEC_HIDDEN;
196 void parser_release(parser_ctx_t*) DECLSPEC_HIDDEN;
198 int parser_lex(void*,parser_ctx_t*) DECLSPEC_HIDDEN;
200 static inline void parser_addref(parser_ctx_t *ctx)
202 ctx->ref++;
205 static inline void *parser_alloc(parser_ctx_t *ctx, DWORD size)
207 return jsheap_alloc(&ctx->heap, size);
210 static inline void *parser_alloc_tmp(parser_ctx_t *ctx, DWORD size)
212 return jsheap_alloc(&ctx->script->tmp_heap, size);
215 typedef struct _scope_chain_t {
216 LONG ref;
217 jsdisp_t *obj;
218 struct _scope_chain_t *next;
219 } scope_chain_t;
221 HRESULT scope_push(scope_chain_t*,jsdisp_t*,scope_chain_t**) DECLSPEC_HIDDEN;
222 void scope_release(scope_chain_t*) DECLSPEC_HIDDEN;
224 static inline void scope_addref(scope_chain_t *scope)
226 scope->ref++;
229 typedef struct _return_type_t return_type_t;
230 typedef struct _except_frame_t except_frame_t;
232 struct _exec_ctx_t {
233 LONG ref;
235 parser_ctx_t *parser;
236 scope_chain_t *scope_chain;
237 jsdisp_t *var_disp;
238 IDispatch *this_obj;
239 BOOL is_global;
241 VARIANT *stack;
242 unsigned stack_size;
243 unsigned top;
244 except_frame_t *except_frame;
246 unsigned ip;
247 jsexcept_t *ei;
248 return_type_t *rt; /* FIXME */
251 static inline void exec_addref(exec_ctx_t *ctx)
253 ctx->ref++;
256 void exec_release(exec_ctx_t*) DECLSPEC_HIDDEN;
257 HRESULT create_exec_ctx(script_ctx_t*,IDispatch*,jsdisp_t*,scope_chain_t*,BOOL,exec_ctx_t**) DECLSPEC_HIDDEN;
258 HRESULT exec_source(exec_ctx_t*,parser_ctx_t*,source_elements_t*,BOOL,jsexcept_t*,VARIANT*) DECLSPEC_HIDDEN;
260 typedef struct _parameter_t parameter_t;
262 HRESULT create_source_function(parser_ctx_t*,parameter_t*,source_elements_t*,scope_chain_t*,
263 const WCHAR*,DWORD,jsdisp_t**) DECLSPEC_HIDDEN;
265 typedef enum {
266 LT_INT,
267 LT_DOUBLE,
268 LT_STRING,
269 LT_BOOL,
270 LT_NULL,
271 LT_REGEXP
272 }literal_type_t;
274 typedef struct {
275 literal_type_t type;
276 union {
277 LONG lval;
278 double dval;
279 const WCHAR *wstr;
280 VARIANT_BOOL bval;
281 struct {
282 const WCHAR *str;
283 DWORD str_len;
284 DWORD flags;
285 } regexp;
286 } u;
287 } literal_t;
289 literal_t *parse_regexp(parser_ctx_t*) DECLSPEC_HIDDEN;
290 literal_t *new_boolean_literal(parser_ctx_t*,VARIANT_BOOL) DECLSPEC_HIDDEN;
292 typedef struct _variable_declaration_t {
293 const WCHAR *identifier;
294 expression_t *expr;
296 struct _variable_declaration_t *next;
297 } variable_declaration_t;
299 typedef HRESULT (*statement_eval_t)(script_ctx_t*,statement_t*,return_type_t*,VARIANT*);
301 typedef enum {
302 STAT_BLOCK,
303 STAT_BREAK,
304 STAT_CONTINUE,
305 STAT_EMPTY,
306 STAT_EXPR,
307 STAT_FOR,
308 STAT_FORIN,
309 STAT_IF,
310 STAT_LABEL,
311 STAT_RETURN,
312 STAT_SWITCH,
313 STAT_THROW,
314 STAT_TRY,
315 STAT_VAR,
316 STAT_WHILE,
317 STAT_WITH
318 } statement_type_t;
320 struct _statement_t {
321 statement_type_t type;
322 statement_eval_t eval;
323 unsigned instr_off;
324 statement_t *next;
327 typedef struct {
328 statement_t stat;
329 statement_t *stat_list;
330 } block_statement_t;
332 typedef struct {
333 statement_t stat;
334 variable_declaration_t *variable_list;
335 } var_statement_t;
337 typedef struct {
338 statement_t stat;
339 expression_t *expr;
340 } expression_statement_t;
342 typedef struct {
343 statement_t stat;
344 expression_t *expr;
345 statement_t *if_stat;
346 statement_t *else_stat;
347 } if_statement_t;
349 typedef struct {
350 statement_t stat;
351 BOOL do_while;
352 expression_t *expr;
353 statement_t *statement;
354 } while_statement_t;
356 typedef struct {
357 statement_t stat;
358 variable_declaration_t *variable_list;
359 expression_t *begin_expr;
360 expression_t *expr;
361 expression_t *end_expr;
362 statement_t *statement;
363 } for_statement_t;
365 typedef struct {
366 statement_t stat;
367 variable_declaration_t *variable;
368 expression_t *expr;
369 expression_t *in_expr;
370 statement_t *statement;
371 } forin_statement_t;
373 typedef struct {
374 statement_t stat;
375 const WCHAR *identifier;
376 } branch_statement_t;
378 typedef struct {
379 statement_t stat;
380 expression_t *expr;
381 statement_t *statement;
382 } with_statement_t;
384 typedef struct {
385 statement_t stat;
386 const WCHAR *identifier;
387 statement_t *statement;
388 } labelled_statement_t;
390 typedef struct _case_clausule_t {
391 expression_t *expr;
392 statement_t *stat;
394 struct _case_clausule_t *next;
395 } case_clausule_t;
397 typedef struct {
398 statement_t stat;
399 expression_t *expr;
400 case_clausule_t *case_list;
401 } switch_statement_t;
403 typedef struct {
404 const WCHAR *identifier;
405 statement_t *statement;
406 } catch_block_t;
408 typedef struct {
409 statement_t stat;
410 statement_t *try_statement;
411 catch_block_t *catch_block;
412 statement_t *finally_statement;
413 } try_statement_t;
415 HRESULT compiled_statement_eval(script_ctx_t*,statement_t*,return_type_t*,VARIANT*) DECLSPEC_HIDDEN;
416 HRESULT while_statement_eval(script_ctx_t*,statement_t*,return_type_t*,VARIANT*) DECLSPEC_HIDDEN;
417 HRESULT for_statement_eval(script_ctx_t*,statement_t*,return_type_t*,VARIANT*) DECLSPEC_HIDDEN;
418 HRESULT forin_statement_eval(script_ctx_t*,statement_t*,return_type_t*,VARIANT*) DECLSPEC_HIDDEN;
419 HRESULT continue_statement_eval(script_ctx_t*,statement_t*,return_type_t*,VARIANT*) DECLSPEC_HIDDEN;
420 HRESULT break_statement_eval(script_ctx_t*,statement_t*,return_type_t*,VARIANT*) DECLSPEC_HIDDEN;
421 HRESULT return_statement_eval(script_ctx_t*,statement_t*,return_type_t*,VARIANT*) DECLSPEC_HIDDEN;
422 HRESULT switch_statement_eval(script_ctx_t*,statement_t*,return_type_t*,VARIANT*) DECLSPEC_HIDDEN;
423 HRESULT try_statement_eval(script_ctx_t*,statement_t*,return_type_t*,VARIANT*) DECLSPEC_HIDDEN;
425 typedef struct {
426 enum {
427 EXPRVAL_VARIANT,
428 EXPRVAL_IDREF,
429 EXPRVAL_INVALID
430 } type;
431 union {
432 VARIANT var;
433 struct {
434 IDispatch *disp;
435 DISPID id;
436 } idref;
437 } u;
438 } exprval_t;
440 typedef enum {
441 EXPR_COMMA,
442 EXPR_OR,
443 EXPR_AND,
444 EXPR_BOR,
445 EXPR_BXOR,
446 EXPR_BAND,
447 EXPR_INSTANCEOF,
448 EXPR_IN,
449 EXPR_ADD,
450 EXPR_SUB,
451 EXPR_MUL,
452 EXPR_DIV,
453 EXPR_MOD,
454 EXPR_DELETE,
455 EXPR_VOID,
456 EXPR_TYPEOF,
457 EXPR_MINUS,
458 EXPR_PLUS,
459 EXPR_POSTINC,
460 EXPR_POSTDEC,
461 EXPR_PREINC,
462 EXPR_PREDEC,
463 EXPR_EQ,
464 EXPR_EQEQ,
465 EXPR_NOTEQ,
466 EXPR_NOTEQEQ,
467 EXPR_LESS,
468 EXPR_LESSEQ,
469 EXPR_GREATER,
470 EXPR_GREATEREQ,
471 EXPR_BITNEG,
472 EXPR_LOGNEG,
473 EXPR_LSHIFT,
474 EXPR_RSHIFT,
475 EXPR_RRSHIFT,
476 EXPR_ASSIGN,
477 EXPR_ASSIGNLSHIFT,
478 EXPR_ASSIGNRSHIFT,
479 EXPR_ASSIGNRRSHIFT,
480 EXPR_ASSIGNADD,
481 EXPR_ASSIGNSUB,
482 EXPR_ASSIGNMUL,
483 EXPR_ASSIGNDIV,
484 EXPR_ASSIGNMOD,
485 EXPR_ASSIGNAND,
486 EXPR_ASSIGNOR,
487 EXPR_ASSIGNXOR,
488 EXPR_COND,
489 EXPR_ARRAY,
490 EXPR_MEMBER,
491 EXPR_NEW,
492 EXPR_CALL,
493 EXPR_THIS,
494 EXPR_FUNC,
495 EXPR_IDENT,
496 EXPR_ARRAYLIT,
497 EXPR_PROPVAL,
498 EXPR_LITERAL
499 } expression_type_t;
501 struct _expression_t {
502 expression_type_t type;
503 unsigned instr_off;
506 struct _parameter_t {
507 const WCHAR *identifier;
509 struct _parameter_t *next;
512 struct _source_elements_t {
513 statement_t *statement;
514 statement_t *statement_tail;
515 function_declaration_t *functions;
516 var_list_t *variables;
519 struct _function_expression_t {
520 expression_t expr;
521 const WCHAR *identifier;
522 parameter_t *parameter_list;
523 source_elements_t *source_elements;
524 const WCHAR *src_str;
525 DWORD src_len;
528 typedef struct {
529 expression_t expr;
530 expression_t *expression1;
531 expression_t *expression2;
532 } binary_expression_t;
534 typedef struct {
535 expression_t expr;
536 expression_t *expression;
537 } unary_expression_t;
539 typedef struct {
540 expression_t expr;
541 expression_t *expression;
542 expression_t *true_expression;
543 expression_t *false_expression;
544 } conditional_expression_t;
546 typedef struct {
547 expression_t expr;
548 expression_t *expression;
549 const WCHAR *identifier;
550 } member_expression_t;
552 typedef struct _argument_t {
553 expression_t *expr;
555 struct _argument_t *next;
556 } argument_t;
558 typedef struct {
559 expression_t expr;
560 expression_t *expression;
561 argument_t *argument_list;
562 } call_expression_t;
564 typedef struct {
565 expression_t expr;
566 const WCHAR *identifier;
567 } identifier_expression_t;
569 typedef struct {
570 expression_t expr;
571 literal_t *literal;
572 } literal_expression_t;
574 typedef struct _array_element_t {
575 int elision;
576 expression_t *expr;
578 struct _array_element_t *next;
579 } array_element_t;
581 typedef struct {
582 expression_t expr;
583 array_element_t *element_list;
584 int length;
585 } array_literal_expression_t;
587 typedef struct _prop_val_t {
588 literal_t *name;
589 expression_t *value;
591 struct _prop_val_t *next;
592 } prop_val_t;
594 typedef struct {
595 expression_t expr;
596 prop_val_t *property_list;
597 } property_value_expression_t;
599 HRESULT compile_subscript(parser_ctx_t*,expression_t*,unsigned*) DECLSPEC_HIDDEN;
600 HRESULT compile_subscript_stat(parser_ctx_t*,statement_t*,BOOL,unsigned*) DECLSPEC_HIDDEN;