Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
708c83e2
Commit
708c83e2
authored
Jan 02, 2012
by
Jacek Caban
Committed by
Alexandre Julliard
Jan 03, 2012
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
jscript: Make 0 an invalid code offset.
parent
11453b24
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
75 additions
and
74 deletions
+75
-74
compile.c
dlls/jscript/compile.c
+72
-71
engine.c
dlls/jscript/engine.c
+1
-1
parser.y
dlls/jscript/parser.y
+2
-2
No files found.
dlls/jscript/compile.c
View file @
708c83e2
...
@@ -155,7 +155,7 @@ static unsigned push_instr(compiler_ctx_t *ctx, jsop_t op)
...
@@ -155,7 +155,7 @@ static unsigned push_instr(compiler_ctx_t *ctx, jsop_t op)
new_instrs
=
heap_realloc
(
ctx
->
code
->
instrs
,
ctx
->
code_size
*
2
*
sizeof
(
instr_t
));
new_instrs
=
heap_realloc
(
ctx
->
code
->
instrs
,
ctx
->
code_size
*
2
*
sizeof
(
instr_t
));
if
(
!
new_instrs
)
if
(
!
new_instrs
)
return
-
1
;
return
0
;
ctx
->
code
->
instrs
=
new_instrs
;
ctx
->
code
->
instrs
=
new_instrs
;
ctx
->
code_size
*=
2
;
ctx
->
code_size
*=
2
;
...
@@ -176,7 +176,7 @@ static HRESULT push_instr_int(compiler_ctx_t *ctx, jsop_t op, LONG arg)
...
@@ -176,7 +176,7 @@ static HRESULT push_instr_int(compiler_ctx_t *ctx, jsop_t op, LONG arg)
unsigned
instr
;
unsigned
instr
;
instr
=
push_instr
(
ctx
,
op
);
instr
=
push_instr
(
ctx
,
op
);
if
(
instr
==
-
1
)
if
(
!
instr
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
lng
=
arg
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
lng
=
arg
;
...
@@ -193,7 +193,7 @@ static HRESULT push_instr_str(compiler_ctx_t *ctx, jsop_t op, const WCHAR *arg)
...
@@ -193,7 +193,7 @@ static HRESULT push_instr_str(compiler_ctx_t *ctx, jsop_t op, const WCHAR *arg)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr
=
push_instr
(
ctx
,
op
);
instr
=
push_instr
(
ctx
,
op
);
if
(
instr
==
-
1
)
if
(
!
instr
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
str
=
str
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
str
=
str
;
...
@@ -210,7 +210,7 @@ static HRESULT push_instr_bstr(compiler_ctx_t *ctx, jsop_t op, const WCHAR *arg)
...
@@ -210,7 +210,7 @@ static HRESULT push_instr_bstr(compiler_ctx_t *ctx, jsop_t op, const WCHAR *arg)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr
=
push_instr
(
ctx
,
op
);
instr
=
push_instr
(
ctx
,
op
);
if
(
instr
==
-
1
)
if
(
!
instr
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
bstr
=
str
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
bstr
=
str
;
...
@@ -227,7 +227,7 @@ static HRESULT push_instr_bstr_uint(compiler_ctx_t *ctx, jsop_t op, const WCHAR
...
@@ -227,7 +227,7 @@ static HRESULT push_instr_bstr_uint(compiler_ctx_t *ctx, jsop_t op, const WCHAR
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr
=
push_instr
(
ctx
,
op
);
instr
=
push_instr
(
ctx
,
op
);
if
(
instr
==
-
1
)
if
(
!
instr
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
bstr
=
str
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
bstr
=
str
;
...
@@ -245,7 +245,7 @@ static HRESULT push_instr_uint_str(compiler_ctx_t *ctx, jsop_t op, unsigned arg1
...
@@ -245,7 +245,7 @@ static HRESULT push_instr_uint_str(compiler_ctx_t *ctx, jsop_t op, unsigned arg1
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr
=
push_instr
(
ctx
,
op
);
instr
=
push_instr
(
ctx
,
op
);
if
(
instr
==
-
1
)
if
(
!
instr
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
uint
=
arg1
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
uint
=
arg1
;
...
@@ -264,7 +264,7 @@ static HRESULT push_instr_double(compiler_ctx_t *ctx, jsop_t op, double arg)
...
@@ -264,7 +264,7 @@ static HRESULT push_instr_double(compiler_ctx_t *ctx, jsop_t op, double arg)
*
dbl
=
arg
;
*
dbl
=
arg
;
instr
=
push_instr
(
ctx
,
op
);
instr
=
push_instr
(
ctx
,
op
);
if
(
instr
==
-
1
)
if
(
!
instr
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
dbl
=
dbl
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
dbl
=
dbl
;
...
@@ -276,7 +276,7 @@ static HRESULT push_instr_uint(compiler_ctx_t *ctx, jsop_t op, unsigned arg)
...
@@ -276,7 +276,7 @@ static HRESULT push_instr_uint(compiler_ctx_t *ctx, jsop_t op, unsigned arg)
unsigned
instr
;
unsigned
instr
;
instr
=
push_instr
(
ctx
,
op
);
instr
=
push_instr
(
ctx
,
op
);
if
(
instr
==
-
1
)
if
(
!
instr
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
uint
=
arg
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
uint
=
arg
;
...
@@ -295,7 +295,7 @@ static HRESULT compile_binary_expression(compiler_ctx_t *ctx, binary_expression_
...
@@ -295,7 +295,7 @@ static HRESULT compile_binary_expression(compiler_ctx_t *ctx, binary_expression_
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
return
push_instr
(
ctx
,
op
)
==
-
1
?
E_OUTOFMEMORY
:
S_OK
;
return
push_instr
(
ctx
,
op
)
?
S_OK
:
E_OUTOFMEMORY
;
}
}
static
HRESULT
compile_unary_expression
(
compiler_ctx_t
*
ctx
,
unary_expression_t
*
expr
,
jsop_t
op
)
static
HRESULT
compile_unary_expression
(
compiler_ctx_t
*
ctx
,
unary_expression_t
*
expr
,
jsop_t
op
)
...
@@ -306,7 +306,7 @@ static HRESULT compile_unary_expression(compiler_ctx_t *ctx, unary_expression_t
...
@@ -306,7 +306,7 @@ static HRESULT compile_unary_expression(compiler_ctx_t *ctx, unary_expression_t
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
return
push_instr
(
ctx
,
op
)
==
-
1
?
E_OUTOFMEMORY
:
S_OK
;
return
push_instr
(
ctx
,
op
)
?
S_OK
:
E_OUTOFMEMORY
;
}
}
/* ECMA-262 3rd Edition 11.2.1 */
/* ECMA-262 3rd Edition 11.2.1 */
...
@@ -430,7 +430,7 @@ static HRESULT compile_comma_expression(compiler_ctx_t *ctx, binary_expression_t
...
@@ -430,7 +430,7 @@ static HRESULT compile_comma_expression(compiler_ctx_t *ctx, binary_expression_t
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
if
(
push_instr
(
ctx
,
OP_pop
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_pop
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
return
compile_expression
(
ctx
,
expr
->
expression2
);
return
compile_expression
(
ctx
,
expr
->
expression2
);
...
@@ -447,7 +447,7 @@ static HRESULT compile_logical_expression(compiler_ctx_t *ctx, binary_expression
...
@@ -447,7 +447,7 @@ static HRESULT compile_logical_expression(compiler_ctx_t *ctx, binary_expression
return
hres
;
return
hres
;
instr
=
push_instr
(
ctx
,
op
);
instr
=
push_instr
(
ctx
,
op
);
if
(
instr
==
-
1
)
if
(
!
instr
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
hres
=
compile_expression
(
ctx
,
expr
->
expression2
);
hres
=
compile_expression
(
ctx
,
expr
->
expression2
);
...
@@ -469,7 +469,7 @@ static HRESULT compile_conditional_expression(compiler_ctx_t *ctx, conditional_e
...
@@ -469,7 +469,7 @@ static HRESULT compile_conditional_expression(compiler_ctx_t *ctx, conditional_e
return
hres
;
return
hres
;
jmp_false
=
push_instr
(
ctx
,
OP_cnd_z
);
jmp_false
=
push_instr
(
ctx
,
OP_cnd_z
);
if
(
jmp_false
==
-
1
)
if
(
!
jmp_false
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
hres
=
compile_expression
(
ctx
,
expr
->
true_expression
);
hres
=
compile_expression
(
ctx
,
expr
->
true_expression
);
...
@@ -477,11 +477,11 @@ static HRESULT compile_conditional_expression(compiler_ctx_t *ctx, conditional_e
...
@@ -477,11 +477,11 @@ static HRESULT compile_conditional_expression(compiler_ctx_t *ctx, conditional_e
return
hres
;
return
hres
;
jmp_end
=
push_instr
(
ctx
,
OP_jmp
);
jmp_end
=
push_instr
(
ctx
,
OP_jmp
);
if
(
jmp_end
==
-
1
)
if
(
!
jmp_end
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr_ptr
(
ctx
,
jmp_false
)
->
arg1
.
uint
=
ctx
->
code_off
;
instr_ptr
(
ctx
,
jmp_false
)
->
arg1
.
uint
=
ctx
->
code_off
;
if
(
push_instr
(
ctx
,
OP_pop
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_pop
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
hres
=
compile_expression
(
ctx
,
expr
->
false_expression
);
hres
=
compile_expression
(
ctx
,
expr
->
false_expression
);
...
@@ -539,7 +539,7 @@ static HRESULT compile_call_expression(compiler_ctx_t *ctx, call_expression_t *e
...
@@ -539,7 +539,7 @@ static HRESULT compile_call_expression(compiler_ctx_t *ctx, call_expression_t *e
}
}
instr
=
push_instr
(
ctx
,
op
);
instr
=
push_instr
(
ctx
,
op
);
if
(
instr
==
-
1
)
if
(
!
instr
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
uint
=
arg_cnt
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
uint
=
arg_cnt
;
...
@@ -565,7 +565,7 @@ static HRESULT compile_delete_expression(compiler_ctx_t *ctx, unary_expression_t
...
@@ -565,7 +565,7 @@ static HRESULT compile_delete_expression(compiler_ctx_t *ctx, unary_expression_t
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
if
(
push_instr
(
ctx
,
OP_delete
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_delete
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
break
;
break
;
}
}
...
@@ -581,7 +581,7 @@ static HRESULT compile_delete_expression(compiler_ctx_t *ctx, unary_expression_t
...
@@ -581,7 +581,7 @@ static HRESULT compile_delete_expression(compiler_ctx_t *ctx, unary_expression_t
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
if
(
push_instr
(
ctx
,
OP_delete
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_delete
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
break
;
break
;
}
}
...
@@ -616,7 +616,7 @@ static HRESULT compile_assign_expression(compiler_ctx_t *ctx, binary_expression_
...
@@ -616,7 +616,7 @@ static HRESULT compile_assign_expression(compiler_ctx_t *ctx, binary_expression_
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
if
(
op
!=
OP_LAST
&&
push_instr
(
ctx
,
op
)
==
-
1
)
if
(
op
!=
OP_LAST
&&
!
push_instr
(
ctx
,
op
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
return
push_instr_uint
(
ctx
,
OP_throw_ref
,
JS_E_ILLEGAL_ASSIGN
);
return
push_instr_uint
(
ctx
,
OP_throw_ref
,
JS_E_ILLEGAL_ASSIGN
);
...
@@ -626,17 +626,17 @@ static HRESULT compile_assign_expression(compiler_ctx_t *ctx, binary_expression_
...
@@ -626,17 +626,17 @@ static HRESULT compile_assign_expression(compiler_ctx_t *ctx, binary_expression_
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
if
(
op
!=
OP_LAST
&&
push_instr
(
ctx
,
OP_refval
)
==
-
1
)
if
(
op
!=
OP_LAST
&&
!
push_instr
(
ctx
,
OP_refval
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
hres
=
compile_expression
(
ctx
,
expr
->
expression2
);
hres
=
compile_expression
(
ctx
,
expr
->
expression2
);
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
if
(
op
!=
OP_LAST
&&
push_instr
(
ctx
,
op
)
==
-
1
)
if
(
op
!=
OP_LAST
&&
!
push_instr
(
ctx
,
op
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
if
(
push_instr
(
ctx
,
OP_assign
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_assign
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
return
S_OK
;
return
S_OK
;
...
@@ -660,7 +660,7 @@ static HRESULT compile_typeof_expression(compiler_ctx_t *ctx, unary_expression_t
...
@@ -660,7 +660,7 @@ static HRESULT compile_typeof_expression(compiler_ctx_t *ctx, unary_expression_t
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
return
push_instr
(
ctx
,
op
)
==
-
1
?
E_OUTOFMEMORY
:
S_OK
;
return
push_instr
(
ctx
,
op
)
?
S_OK
:
E_OUTOFMEMORY
;
}
}
static
HRESULT
compile_literal
(
compiler_ctx_t
*
ctx
,
literal_t
*
literal
)
static
HRESULT
compile_literal
(
compiler_ctx_t
*
ctx
,
literal_t
*
literal
)
...
@@ -673,7 +673,7 @@ static HRESULT compile_literal(compiler_ctx_t *ctx, literal_t *literal)
...
@@ -673,7 +673,7 @@ static HRESULT compile_literal(compiler_ctx_t *ctx, literal_t *literal)
case
LT_INT
:
case
LT_INT
:
return
push_instr_int
(
ctx
,
OP_int
,
literal
->
u
.
lval
);
return
push_instr_int
(
ctx
,
OP_int
,
literal
->
u
.
lval
);
case
LT_NULL
:
case
LT_NULL
:
return
push_instr
(
ctx
,
OP_null
);
return
push_instr
(
ctx
,
OP_null
)
?
S_OK
:
E_OUTOFMEMORY
;
case
LT_STRING
:
case
LT_STRING
:
return
push_instr_str
(
ctx
,
OP_str
,
literal
->
u
.
wstr
);
return
push_instr_str
(
ctx
,
OP_str
,
literal
->
u
.
wstr
);
case
LT_REGEXP
:
{
case
LT_REGEXP
:
{
...
@@ -687,7 +687,7 @@ static HRESULT compile_literal(compiler_ctx_t *ctx, literal_t *literal)
...
@@ -687,7 +687,7 @@ static HRESULT compile_literal(compiler_ctx_t *ctx, literal_t *literal)
str
[
literal
->
u
.
regexp
.
str_len
]
=
0
;
str
[
literal
->
u
.
regexp
.
str_len
]
=
0
;
instr
=
push_instr
(
ctx
,
OP_regexp
);
instr
=
push_instr
(
ctx
,
OP_regexp
);
if
(
instr
==
-
1
)
if
(
!
instr
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
str
=
str
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
str
=
str
;
...
@@ -727,7 +727,7 @@ static HRESULT compile_array_literal(compiler_ctx_t *ctx, array_literal_expressi
...
@@ -727,7 +727,7 @@ static HRESULT compile_array_literal(compiler_ctx_t *ctx, array_literal_expressi
elem_cnt
+=
iter
->
elision
+
1
;
elem_cnt
+=
iter
->
elision
+
1
;
for
(
i
=
0
;
i
<
iter
->
elision
;
i
++
)
{
for
(
i
=
0
;
i
<
iter
->
elision
;
i
++
)
{
if
(
push_instr
(
ctx
,
OP_undefined
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_undefined
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
}
}
...
@@ -737,7 +737,7 @@ static HRESULT compile_array_literal(compiler_ctx_t *ctx, array_literal_expressi
...
@@ -737,7 +737,7 @@ static HRESULT compile_array_literal(compiler_ctx_t *ctx, array_literal_expressi
}
}
for
(
i
=
0
;
i
<
expr
->
length
;
i
++
)
{
for
(
i
=
0
;
i
<
expr
->
length
;
i
++
)
{
if
(
push_instr
(
ctx
,
OP_undefined
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_undefined
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
}
}
...
@@ -751,7 +751,7 @@ static HRESULT compile_object_literal(compiler_ctx_t *ctx, property_value_expres
...
@@ -751,7 +751,7 @@ static HRESULT compile_object_literal(compiler_ctx_t *ctx, property_value_expres
BSTR
name
;
BSTR
name
;
HRESULT
hres
;
HRESULT
hres
;
if
(
push_instr
(
ctx
,
OP_new_obj
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_new_obj
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
for
(
iter
=
expr
->
property_list
;
iter
;
iter
=
iter
->
next
)
{
for
(
iter
=
expr
->
property_list
;
iter
;
iter
=
iter
->
next
)
{
...
@@ -764,7 +764,7 @@ static HRESULT compile_object_literal(compiler_ctx_t *ctx, property_value_expres
...
@@ -764,7 +764,7 @@ static HRESULT compile_object_literal(compiler_ctx_t *ctx, property_value_expres
return
hres
;
return
hres
;
instr
=
push_instr
(
ctx
,
OP_obj_prop
);
instr
=
push_instr
(
ctx
,
OP_obj_prop
);
if
(
instr
==
-
1
)
if
(
!
instr
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
bstr
=
name
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
bstr
=
name
;
...
@@ -782,7 +782,7 @@ static HRESULT compile_function_expression(compiler_ctx_t *ctx, function_express
...
@@ -782,7 +782,7 @@ static HRESULT compile_function_expression(compiler_ctx_t *ctx, function_express
return
push_instr_bstr
(
ctx
,
OP_ident
,
expr
->
identifier
);
return
push_instr_bstr
(
ctx
,
OP_ident
,
expr
->
identifier
);
instr
=
push_instr
(
ctx
,
OP_func
);
instr
=
push_instr
(
ctx
,
OP_func
);
if
(
instr
==
-
1
)
if
(
!
instr
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
func
=
expr
;
instr_ptr
(
ctx
,
instr
)
->
arg1
.
func
=
expr
;
...
@@ -901,7 +901,7 @@ static HRESULT compile_expression_noret(compiler_ctx_t *ctx, expression_t *expr,
...
@@ -901,7 +901,7 @@ static HRESULT compile_expression_noret(compiler_ctx_t *ctx, expression_t *expr,
case
EXPR_SUB
:
case
EXPR_SUB
:
return
compile_binary_expression
(
ctx
,
(
binary_expression_t
*
)
expr
,
OP_sub
);
return
compile_binary_expression
(
ctx
,
(
binary_expression_t
*
)
expr
,
OP_sub
);
case
EXPR_THIS
:
case
EXPR_THIS
:
return
push_instr
(
ctx
,
OP_this
)
==
-
1
?
E_OUTOFMEMORY
:
S_OK
;
return
push_instr
(
ctx
,
OP_this
)
?
S_OK
:
E_OUTOFMEMORY
;
case
EXPR_TYPEOF
:
case
EXPR_TYPEOF
:
return
compile_typeof_expression
(
ctx
,
(
unary_expression_t
*
)
expr
);
return
compile_typeof_expression
(
ctx
,
(
unary_expression_t
*
)
expr
);
case
EXPR_VOID
:
case
EXPR_VOID
:
...
@@ -927,7 +927,7 @@ static HRESULT compile_block_statement(compiler_ctx_t *ctx, statement_t *iter)
...
@@ -927,7 +927,7 @@ static HRESULT compile_block_statement(compiler_ctx_t *ctx, statement_t *iter)
/* FIXME: do it only if needed */
/* FIXME: do it only if needed */
if
(
!
iter
)
if
(
!
iter
)
return
push_instr
(
ctx
,
OP_undefined
)
==
-
1
?
E_OUTOFMEMORY
:
S_OK
;
return
push_instr
(
ctx
,
OP_undefined
)
?
S_OK
:
E_OUTOFMEMORY
;
while
(
1
)
{
while
(
1
)
{
hres
=
compile_statement
(
ctx
,
NULL
,
iter
);
hres
=
compile_statement
(
ctx
,
NULL
,
iter
);
...
@@ -938,7 +938,7 @@ static HRESULT compile_block_statement(compiler_ctx_t *ctx, statement_t *iter)
...
@@ -938,7 +938,7 @@ static HRESULT compile_block_statement(compiler_ctx_t *ctx, statement_t *iter)
if
(
!
iter
)
if
(
!
iter
)
break
;
break
;
if
(
push_instr
(
ctx
,
OP_pop
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_pop
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
}
}
...
@@ -976,7 +976,7 @@ static HRESULT compile_var_statement(compiler_ctx_t *ctx, var_statement_t *stat)
...
@@ -976,7 +976,7 @@ static HRESULT compile_var_statement(compiler_ctx_t *ctx, var_statement_t *stat)
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
return
push_instr
(
ctx
,
OP_undefined
)
==
-
1
?
E_OUTOFMEMORY
:
S_OK
;
return
push_instr
(
ctx
,
OP_undefined
)
?
S_OK
:
E_OUTOFMEMORY
;
}
}
/* ECMA-262 3rd Edition 12.4 */
/* ECMA-262 3rd Edition 12.4 */
...
@@ -990,7 +990,7 @@ static HRESULT compile_expression_statement(compiler_ctx_t *ctx, expression_stat
...
@@ -990,7 +990,7 @@ static HRESULT compile_expression_statement(compiler_ctx_t *ctx, expression_stat
return
hres
;
return
hres
;
/* FIXME: that's a big potential optimization */
/* FIXME: that's a big potential optimization */
if
(
no_ret
&&
!
push_instr
(
ctx
,
OP_undefined
)
==
-
1
)
if
(
no_ret
&&
!
push_instr
(
ctx
,
OP_undefined
))
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
return
S_OK
;
return
S_OK
;
...
@@ -1007,7 +1007,7 @@ static HRESULT compile_if_statement(compiler_ctx_t *ctx, if_statement_t *stat)
...
@@ -1007,7 +1007,7 @@ static HRESULT compile_if_statement(compiler_ctx_t *ctx, if_statement_t *stat)
return
hres
;
return
hres
;
jmp_else
=
push_instr
(
ctx
,
OP_jmp_z
);
jmp_else
=
push_instr
(
ctx
,
OP_jmp_z
);
if
(
jmp_else
==
-
1
)
if
(
!
jmp_else
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
hres
=
compile_statement
(
ctx
,
NULL
,
stat
->
if_stat
);
hres
=
compile_statement
(
ctx
,
NULL
,
stat
->
if_stat
);
...
@@ -1015,7 +1015,7 @@ static HRESULT compile_if_statement(compiler_ctx_t *ctx, if_statement_t *stat)
...
@@ -1015,7 +1015,7 @@ static HRESULT compile_if_statement(compiler_ctx_t *ctx, if_statement_t *stat)
return
hres
;
return
hres
;
jmp_end
=
push_instr
(
ctx
,
OP_jmp
);
jmp_end
=
push_instr
(
ctx
,
OP_jmp
);
if
(
jmp_end
==
-
1
)
if
(
!
jmp_end
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr_ptr
(
ctx
,
jmp_else
)
->
arg1
.
uint
=
ctx
->
code_off
;
instr_ptr
(
ctx
,
jmp_else
)
->
arg1
.
uint
=
ctx
->
code_off
;
...
@@ -1026,7 +1026,7 @@ static HRESULT compile_if_statement(compiler_ctx_t *ctx, if_statement_t *stat)
...
@@ -1026,7 +1026,7 @@ static HRESULT compile_if_statement(compiler_ctx_t *ctx, if_statement_t *stat)
return
hres
;
return
hres
;
}
else
{
}
else
{
/* FIXME: We could sometimes avoid it */
/* FIXME: We could sometimes avoid it */
if
(
push_instr
(
ctx
,
OP_undefined
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_undefined
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
}
}
...
@@ -1051,7 +1051,7 @@ static HRESULT compile_while_statement(compiler_ctx_t *ctx, while_statement_t *s
...
@@ -1051,7 +1051,7 @@ static HRESULT compile_while_statement(compiler_ctx_t *ctx, while_statement_t *s
if
(
!
stat
->
do_while
)
{
if
(
!
stat
->
do_while
)
{
/* FIXME: avoid */
/* FIXME: avoid */
if
(
push_instr
(
ctx
,
OP_undefined
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_undefined
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
jmp_off
=
ctx
->
code_off
;
jmp_off
=
ctx
->
code_off
;
...
@@ -1064,7 +1064,7 @@ static HRESULT compile_while_statement(compiler_ctx_t *ctx, while_statement_t *s
...
@@ -1064,7 +1064,7 @@ static HRESULT compile_while_statement(compiler_ctx_t *ctx, while_statement_t *s
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
if
(
push_instr
(
ctx
,
OP_pop
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_pop
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
}
else
{
}
else
{
jmp_off
=
ctx
->
code_off
;
jmp_off
=
ctx
->
code_off
;
...
@@ -1084,7 +1084,7 @@ static HRESULT compile_while_statement(compiler_ctx_t *ctx, while_statement_t *s
...
@@ -1084,7 +1084,7 @@ static HRESULT compile_while_statement(compiler_ctx_t *ctx, while_statement_t *s
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
if
(
push_instr
(
ctx
,
OP_pop
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_pop
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
}
}
...
@@ -1113,7 +1113,7 @@ static HRESULT compile_for_statement(compiler_ctx_t *ctx, for_statement_t *stat)
...
@@ -1113,7 +1113,7 @@ static HRESULT compile_for_statement(compiler_ctx_t *ctx, for_statement_t *stat)
hres
=
compile_expression_noret
(
ctx
,
stat
->
begin_expr
,
&
no_ret
);
hres
=
compile_expression_noret
(
ctx
,
stat
->
begin_expr
,
&
no_ret
);
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
if
(
!
no_ret
&&
push_instr
(
ctx
,
OP_pop
)
==
-
1
)
if
(
!
no_ret
&&
!
push_instr
(
ctx
,
OP_pop
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
}
}
...
@@ -1126,7 +1126,7 @@ static HRESULT compile_for_statement(compiler_ctx_t *ctx, for_statement_t *stat)
...
@@ -1126,7 +1126,7 @@ static HRESULT compile_for_statement(compiler_ctx_t *ctx, for_statement_t *stat)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
/* FIXME: avoid */
/* FIXME: avoid */
if
(
push_instr
(
ctx
,
OP_undefined
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_undefined
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
expr_off
=
ctx
->
code_off
;
expr_off
=
ctx
->
code_off
;
...
@@ -1141,7 +1141,7 @@ static HRESULT compile_for_statement(compiler_ctx_t *ctx, for_statement_t *stat)
...
@@ -1141,7 +1141,7 @@ static HRESULT compile_for_statement(compiler_ctx_t *ctx, for_statement_t *stat)
return
hres
;
return
hres
;
}
}
if
(
push_instr
(
ctx
,
OP_pop
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_pop
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
hres
=
compile_statement
(
ctx
,
&
stat_ctx
,
stat
->
statement
);
hres
=
compile_statement
(
ctx
,
&
stat_ctx
,
stat
->
statement
);
...
@@ -1157,7 +1157,7 @@ static HRESULT compile_for_statement(compiler_ctx_t *ctx, for_statement_t *stat)
...
@@ -1157,7 +1157,7 @@ static HRESULT compile_for_statement(compiler_ctx_t *ctx, for_statement_t *stat)
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
if
(
!
no_ret
&&
push_instr
(
ctx
,
OP_pop
)
==
-
1
)
if
(
!
no_ret
&&
!
push_instr
(
ctx
,
OP_pop
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
}
}
...
@@ -1215,7 +1215,7 @@ static HRESULT compile_forin_statement(compiler_ctx_t *ctx, forin_statement_t *s
...
@@ -1215,7 +1215,7 @@ static HRESULT compile_forin_statement(compiler_ctx_t *ctx, forin_statement_t *s
return
hres
;
return
hres
;
/* FIXME: avoid */
/* FIXME: avoid */
if
(
push_instr
(
ctx
,
OP_undefined
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_undefined
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
label_set_addr
(
ctx
,
stat_ctx
.
continue_label
);
label_set_addr
(
ctx
,
stat_ctx
.
continue_label
);
...
@@ -1241,9 +1241,9 @@ static HRESULT pop_to_stat(compiler_ctx_t *ctx, statement_ctx_t *stat_ctx)
...
@@ -1241,9 +1241,9 @@ static HRESULT pop_to_stat(compiler_ctx_t *ctx, statement_ctx_t *stat_ctx)
unsigned
stack_pop
=
0
;
unsigned
stack_pop
=
0
;
while
(
iter
)
{
while
(
iter
)
{
if
(
iter
->
using_scope
&&
push_instr
(
ctx
,
OP_pop_scope
)
==
-
1
)
if
(
iter
->
using_scope
&&
!
push_instr
(
ctx
,
OP_pop_scope
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
if
(
iter
->
using_except
&&
push_instr
(
ctx
,
OP_pop_except
)
==
-
1
)
if
(
iter
->
using_except
&&
!
push_instr
(
ctx
,
OP_pop_except
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
stack_pop
+=
iter
->
stack_use
;
stack_pop
+=
iter
->
stack_use
;
if
(
iter
==
stat_ctx
)
if
(
iter
==
stat_ctx
)
...
@@ -1253,7 +1253,7 @@ static HRESULT pop_to_stat(compiler_ctx_t *ctx, statement_ctx_t *stat_ctx)
...
@@ -1253,7 +1253,7 @@ static HRESULT pop_to_stat(compiler_ctx_t *ctx, statement_ctx_t *stat_ctx)
/* FIXME: optimize */
/* FIXME: optimize */
while
(
stack_pop
--
)
{
while
(
stack_pop
--
)
{
if
(
push_instr
(
ctx
,
OP_pop
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_pop
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
}
}
...
@@ -1277,13 +1277,13 @@ static HRESULT compile_continue_statement(compiler_ctx_t *ctx, branch_statement_
...
@@ -1277,13 +1277,13 @@ static HRESULT compile_continue_statement(compiler_ctx_t *ctx, branch_statement_
}
}
if
(
stat
->
identifier
)
if
(
stat
->
identifier
)
return
push_instr
(
ctx
,
OP_label
)
==
-
1
?
E_OUTOFMEMORY
:
S_OK
;
/* FIXME */
return
push_instr
(
ctx
,
OP_label
)
?
S_OK
:
E_OUTOFMEMORY
;
/* FIXME */
hres
=
pop_to_stat
(
ctx
,
pop_ctx
);
hres
=
pop_to_stat
(
ctx
,
pop_ctx
);
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
if
(
push_instr
(
ctx
,
OP_undefined
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_undefined
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
return
push_instr_uint
(
ctx
,
OP_jmp
,
pop_ctx
->
continue_label
);
return
push_instr_uint
(
ctx
,
OP_jmp
,
pop_ctx
->
continue_label
);
...
@@ -1306,13 +1306,13 @@ static HRESULT compile_break_statement(compiler_ctx_t *ctx, branch_statement_t *
...
@@ -1306,13 +1306,13 @@ static HRESULT compile_break_statement(compiler_ctx_t *ctx, branch_statement_t *
}
}
if
(
stat
->
identifier
)
if
(
stat
->
identifier
)
return
push_instr
(
ctx
,
OP_label
)
==
-
1
?
E_OUTOFMEMORY
:
S_OK
;
/* FIXME */
return
push_instr
(
ctx
,
OP_label
)
?
S_OK
:
E_OUTOFMEMORY
;
/* FIXME */
hres
=
pop_to_stat
(
ctx
,
pop_ctx
);
hres
=
pop_to_stat
(
ctx
,
pop_ctx
);
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
if
(
push_instr
(
ctx
,
OP_undefined
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_undefined
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
return
push_instr_uint
(
ctx
,
OP_jmp
,
pop_ctx
->
break_label
);
return
push_instr_uint
(
ctx
,
OP_jmp
,
pop_ctx
->
break_label
);
...
@@ -1333,7 +1333,7 @@ static HRESULT compile_return_statement(compiler_ctx_t *ctx, expression_statemen
...
@@ -1333,7 +1333,7 @@ static HRESULT compile_return_statement(compiler_ctx_t *ctx, expression_statemen
return
hres
;
return
hres
;
}
}
return
push_instr
(
ctx
,
OP_ret
)
==
-
1
?
E_OUTOFMEMORY
:
S_OK
;
return
push_instr
(
ctx
,
OP_ret
)
?
S_OK
:
E_OUTOFMEMORY
;
}
}
/* ECMA-262 3rd Edition 12.10 */
/* ECMA-262 3rd Edition 12.10 */
...
@@ -1346,14 +1346,14 @@ static HRESULT compile_with_statement(compiler_ctx_t *ctx, with_statement_t *sta
...
@@ -1346,14 +1346,14 @@ static HRESULT compile_with_statement(compiler_ctx_t *ctx, with_statement_t *sta
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
if
(
push_instr
(
ctx
,
OP_push_scope
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_push_scope
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
hres
=
compile_statement
(
ctx
,
&
stat_ctx
,
stat
->
statement
);
hres
=
compile_statement
(
ctx
,
&
stat_ctx
,
stat
->
statement
);
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
if
(
push_instr
(
ctx
,
OP_pop_scope
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_pop_scope
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
return
S_OK
;
return
S_OK
;
...
@@ -1398,7 +1398,7 @@ static HRESULT compile_switch_statement(compiler_ctx_t *ctx, switch_statement_t
...
@@ -1398,7 +1398,7 @@ static HRESULT compile_switch_statement(compiler_ctx_t *ctx, switch_statement_t
break
;
break
;
case_jmps
[
i
]
=
push_instr
(
ctx
,
OP_case
);
case_jmps
[
i
]
=
push_instr
(
ctx
,
OP_case
);
if
(
case_jmps
[
i
]
==
-
1
)
{
if
(
!
case_jmps
[
i
]
)
{
hres
=
E_OUTOFMEMORY
;
hres
=
E_OUTOFMEMORY
;
break
;
break
;
}
}
...
@@ -1406,9 +1406,9 @@ static HRESULT compile_switch_statement(compiler_ctx_t *ctx, switch_statement_t
...
@@ -1406,9 +1406,9 @@ static HRESULT compile_switch_statement(compiler_ctx_t *ctx, switch_statement_t
}
}
if
(
SUCCEEDED
(
hres
))
{
if
(
SUCCEEDED
(
hres
))
{
if
(
push_instr
(
ctx
,
OP_pop
)
!=
-
1
)
{
if
(
push_instr
(
ctx
,
OP_pop
))
{
default_jmp
=
push_instr
(
ctx
,
OP_jmp
);
default_jmp
=
push_instr
(
ctx
,
OP_jmp
);
if
(
default_jmp
==
-
1
)
if
(
!
default_jmp
)
hres
=
E_OUTOFMEMORY
;
hres
=
E_OUTOFMEMORY
;
}
else
{
}
else
{
hres
=
E_OUTOFMEMORY
;
hres
=
E_OUTOFMEMORY
;
...
@@ -1434,7 +1434,7 @@ static HRESULT compile_switch_statement(compiler_ctx_t *ctx, switch_statement_t
...
@@ -1434,7 +1434,7 @@ static HRESULT compile_switch_statement(compiler_ctx_t *ctx, switch_statement_t
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
break
;
break
;
if
(
stat_iter
->
next
&&
push_instr
(
ctx
,
OP_pop
)
==
-
1
)
{
if
(
stat_iter
->
next
&&
!
push_instr
(
ctx
,
OP_pop
)
)
{
hres
=
E_OUTOFMEMORY
;
hres
=
E_OUTOFMEMORY
;
break
;
break
;
}
}
...
@@ -1464,7 +1464,7 @@ static HRESULT compile_throw_statement(compiler_ctx_t *ctx, expression_statement
...
@@ -1464,7 +1464,7 @@ static HRESULT compile_throw_statement(compiler_ctx_t *ctx, expression_statement
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
return
push_instr
(
ctx
,
OP_throw
)
==
-
1
?
E_OUTOFMEMORY
:
S_OK
;
return
push_instr
(
ctx
,
OP_throw
)
?
S_OK
:
E_OUTOFMEMORY
;
}
}
/* ECMA-262 3rd Edition 12.14 */
/* ECMA-262 3rd Edition 12.14 */
...
@@ -1477,7 +1477,7 @@ static HRESULT compile_try_statement(compiler_ctx_t *ctx, try_statement_t *stat)
...
@@ -1477,7 +1477,7 @@ static HRESULT compile_try_statement(compiler_ctx_t *ctx, try_statement_t *stat)
HRESULT
hres
;
HRESULT
hres
;
push_except
=
push_instr
(
ctx
,
OP_push_except
);
push_except
=
push_instr
(
ctx
,
OP_push_except
);
if
(
push_except
==
-
1
)
if
(
!
push_except
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
if
(
stat
->
catch_block
)
{
if
(
stat
->
catch_block
)
{
...
@@ -1497,14 +1497,14 @@ static HRESULT compile_try_statement(compiler_ctx_t *ctx, try_statement_t *stat)
...
@@ -1497,14 +1497,14 @@ static HRESULT compile_try_statement(compiler_ctx_t *ctx, try_statement_t *stat)
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
if
(
push_instr
(
ctx
,
OP_pop_except
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_pop_except
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
if
(
stat
->
catch_block
)
{
if
(
stat
->
catch_block
)
{
unsigned
jmp_finally
;
unsigned
jmp_finally
;
jmp_finally
=
push_instr
(
ctx
,
OP_jmp
);
jmp_finally
=
push_instr
(
ctx
,
OP_jmp
);
if
(
jmp_finally
==
-
1
)
if
(
!
jmp_finally
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr_ptr
(
ctx
,
push_except
)
->
arg1
.
uint
=
ctx
->
code_off
;
instr_ptr
(
ctx
,
push_except
)
->
arg1
.
uint
=
ctx
->
code_off
;
...
@@ -1513,7 +1513,7 @@ static HRESULT compile_try_statement(compiler_ctx_t *ctx, try_statement_t *stat)
...
@@ -1513,7 +1513,7 @@ static HRESULT compile_try_statement(compiler_ctx_t *ctx, try_statement_t *stat)
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
if
(
push_instr
(
ctx
,
OP_pop_scope
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_pop_scope
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
instr_ptr
(
ctx
,
jmp_finally
)
->
arg1
.
uint
=
ctx
->
code_off
;
instr_ptr
(
ctx
,
jmp_finally
)
->
arg1
.
uint
=
ctx
->
code_off
;
...
@@ -1523,14 +1523,14 @@ static HRESULT compile_try_statement(compiler_ctx_t *ctx, try_statement_t *stat)
...
@@ -1523,14 +1523,14 @@ static HRESULT compile_try_statement(compiler_ctx_t *ctx, try_statement_t *stat)
if
(
stat
->
finally_statement
)
{
if
(
stat
->
finally_statement
)
{
/* FIXME: avoid */
/* FIXME: avoid */
if
(
push_instr
(
ctx
,
OP_pop
)
==
-
1
)
if
(
!
push_instr
(
ctx
,
OP_pop
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
hres
=
compile_statement
(
ctx
,
stat
->
catch_block
?
NULL
:
&
finally_ctx
,
stat
->
finally_statement
);
hres
=
compile_statement
(
ctx
,
stat
->
catch_block
?
NULL
:
&
finally_ctx
,
stat
->
finally_statement
);
if
(
FAILED
(
hres
))
if
(
FAILED
(
hres
))
return
hres
;
return
hres
;
if
(
!
stat
->
catch_block
&&
push_instr
(
ctx
,
OP_end_finally
)
==
-
1
)
if
(
!
stat
->
catch_block
&&
!
push_instr
(
ctx
,
OP_end_finally
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
}
}
...
@@ -1557,7 +1557,7 @@ static HRESULT compile_statement(compiler_ctx_t *ctx, statement_ctx_t *stat_ctx,
...
@@ -1557,7 +1557,7 @@ static HRESULT compile_statement(compiler_ctx_t *ctx, statement_ctx_t *stat_ctx,
hres
=
compile_continue_statement
(
ctx
,
(
branch_statement_t
*
)
stat
);
hres
=
compile_continue_statement
(
ctx
,
(
branch_statement_t
*
)
stat
);
break
;
break
;
case
STAT_EMPTY
:
case
STAT_EMPTY
:
hres
=
push_instr
(
ctx
,
OP_undefined
)
==
-
1
?
E_OUTOFMEMORY
:
S_OK
;
/* FIXME */
hres
=
push_instr
(
ctx
,
OP_undefined
)
?
S_OK
:
E_OUTOFMEMORY
;
/* FIXME */
break
;
break
;
case
STAT_EXPR
:
case
STAT_EXPR
:
hres
=
compile_expression_statement
(
ctx
,
(
expression_statement_t
*
)
stat
);
hres
=
compile_expression_statement
(
ctx
,
(
expression_statement_t
*
)
stat
);
...
@@ -1572,7 +1572,7 @@ static HRESULT compile_statement(compiler_ctx_t *ctx, statement_ctx_t *stat_ctx,
...
@@ -1572,7 +1572,7 @@ static HRESULT compile_statement(compiler_ctx_t *ctx, statement_ctx_t *stat_ctx,
hres
=
compile_if_statement
(
ctx
,
(
if_statement_t
*
)
stat
);
hres
=
compile_if_statement
(
ctx
,
(
if_statement_t
*
)
stat
);
break
;
break
;
case
STAT_LABEL
:
case
STAT_LABEL
:
hres
=
push_instr
(
ctx
,
OP_label
)
==
-
1
?
E_OUTOFMEMORY
:
S_OK
;
/* FIXME */
hres
=
push_instr
(
ctx
,
OP_label
)
?
S_OK
:
E_OUTOFMEMORY
;
/* FIXME */
break
;
break
;
case
STAT_RETURN
:
case
STAT_RETURN
:
hres
=
compile_return_statement
(
ctx
,
(
expression_statement_t
*
)
stat
);
hres
=
compile_return_statement
(
ctx
,
(
expression_statement_t
*
)
stat
);
...
@@ -1667,6 +1667,7 @@ static HRESULT init_compiler(parser_ctx_t *parser)
...
@@ -1667,6 +1667,7 @@ static HRESULT init_compiler(parser_ctx_t *parser)
}
}
compiler
->
code_size
=
64
;
compiler
->
code_size
=
64
;
compiler
->
code_off
=
1
;
compiler
->
parser
=
parser
;
compiler
->
parser
=
parser
;
...
@@ -1696,9 +1697,9 @@ HRESULT compile_subscript_stat(parser_ctx_t *parser, statement_t *stat, BOOL fro
...
@@ -1696,9 +1697,9 @@ HRESULT compile_subscript_stat(parser_ctx_t *parser, statement_t *stat, BOOL fro
resolve_labels
(
parser
->
compiler
,
off
);
resolve_labels
(
parser
->
compiler
,
off
);
if
(
!
from_eval
&&
push_instr
(
parser
->
compiler
,
OP_pop
)
==
-
1
)
if
(
!
from_eval
&&
!
push_instr
(
parser
->
compiler
,
OP_pop
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
if
(
push_instr
(
parser
->
compiler
,
OP_ret
)
==
-
1
)
if
(
!
push_instr
(
parser
->
compiler
,
OP_ret
)
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
if
(
TRACE_ON
(
jscript_disas
))
if
(
TRACE_ON
(
jscript_disas
))
...
...
dlls/jscript/engine.c
View file @
708c83e2
...
@@ -2614,7 +2614,7 @@ HRESULT exec_source(exec_ctx_t *ctx, parser_ctx_t *parser, source_elements_t *so
...
@@ -2614,7 +2614,7 @@ HRESULT exec_source(exec_ctx_t *ctx, parser_ctx_t *parser, source_elements_t *so
ctx
->
parser
=
parser
;
ctx
->
parser
=
parser
;
if
(
source
->
statement
)
{
if
(
source
->
statement
)
{
if
(
source
->
instr_off
==
-
1
)
{
if
(
!
source
->
instr_off
)
{
hres
=
compile_subscript_stat
(
ctx
->
parser
,
source
->
statement
,
from_eval
,
&
source
->
instr_off
);
hres
=
compile_subscript_stat
(
ctx
->
parser
,
source
->
statement
,
from_eval
,
&
source
->
instr_off
);
if
(
FAILED
(
hres
)
&&
is_jscript_error
(
hres
))
if
(
FAILED
(
hres
)
&&
is_jscript_error
(
hres
))
hres
=
throw_syntax_error
(
script
,
ei
,
hres
,
NULL
);
hres
=
throw_syntax_error
(
script
,
ei
,
hres
,
NULL
);
...
...
dlls/jscript/parser.y
View file @
708c83e2
...
@@ -1342,7 +1342,7 @@ static void *new_expression(parser_ctx_t *ctx, expression_type_t type, size_t si
...
@@ -1342,7 +1342,7 @@ static void *new_expression(parser_ctx_t *ctx, expression_type_t type, size_t si
expression_t *ret = parser_alloc(ctx, size ? size : sizeof(*ret));
expression_t *ret = parser_alloc(ctx, size ? size : sizeof(*ret));
ret->type = type;
ret->type = type;
ret->instr_off =
-1
;
ret->instr_off =
0
;
return ret;
return ret;
}
}
...
@@ -1470,7 +1470,7 @@ static source_elements_t *new_source_elements(parser_ctx_t *ctx)
...
@@ -1470,7 +1470,7 @@ static source_elements_t *new_source_elements(parser_ctx_t *ctx)
source_elements_t *ret = parser_alloc(ctx, sizeof(source_elements_t));
source_elements_t *ret = parser_alloc(ctx, sizeof(source_elements_t));
memset(ret, 0, sizeof(*ret));
memset(ret, 0, sizeof(*ret));
ret->instr_off =
-1
;
ret->instr_off =
0
;
return ret;
return ret;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment