Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
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-winehq
Commits
f17aaf8d
Commit
f17aaf8d
authored
Jul 20, 2012
by
Jacek Caban
Committed by
Alexandre Julliard
Jul 20, 2012
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
vbscript: Added compiler support for select case statement.
parent
119c985c
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
90 additions
and
2 deletions
+90
-2
compile.c
dlls/vbscript/compile.c
+83
-2
interp.c
dlls/vbscript/interp.c
+6
-0
vbscript.h
dlls/vbscript/vbscript.h
+1
-0
No files found.
dlls/vbscript/compile.c
View file @
f17aaf8d
...
@@ -754,8 +754,89 @@ static HRESULT compile_forto_statement(compile_ctx_t *ctx, forto_statement_t *st
...
@@ -754,8 +754,89 @@ static HRESULT compile_forto_statement(compile_ctx_t *ctx, forto_statement_t *st
static
HRESULT
compile_select_statement
(
compile_ctx_t
*
ctx
,
select_statement_t
*
stat
)
static
HRESULT
compile_select_statement
(
compile_ctx_t
*
ctx
,
select_statement_t
*
stat
)
{
{
FIXME
(
"
\n
"
);
unsigned
end_label
,
case_cnt
=
0
,
*
case_labels
=
NULL
,
i
;
return
E_NOTIMPL
;
case_clausule_t
*
case_iter
;
expression_t
*
expr_iter
;
HRESULT
hres
;
hres
=
compile_expression
(
ctx
,
stat
->
expr
);
if
(
FAILED
(
hres
))
return
hres
;
if
(
!
push_instr
(
ctx
,
OP_val
))
return
E_OUTOFMEMORY
;
end_label
=
alloc_label
(
ctx
);
if
(
!
end_label
)
return
E_OUTOFMEMORY
;
for
(
case_iter
=
stat
->
case_clausules
;
case_iter
;
case_iter
=
case_iter
->
next
)
case_cnt
++
;
if
(
case_cnt
)
{
case_labels
=
heap_alloc
(
case_cnt
*
sizeof
(
*
case_labels
));
if
(
!
case_labels
)
return
E_OUTOFMEMORY
;
}
for
(
case_iter
=
stat
->
case_clausules
,
i
=
0
;
case_iter
;
case_iter
=
case_iter
->
next
,
i
++
)
{
case_labels
[
i
]
=
alloc_label
(
ctx
);
if
(
!
case_labels
[
i
])
{
hres
=
E_OUTOFMEMORY
;
break
;
}
if
(
!
case_iter
->
expr
)
break
;
for
(
expr_iter
=
case_iter
->
expr
;
expr_iter
;
expr_iter
=
expr_iter
->
next
)
{
hres
=
compile_expression
(
ctx
,
expr_iter
);
if
(
FAILED
(
hres
))
break
;
hres
=
push_instr_addr
(
ctx
,
OP_case
,
case_labels
[
i
]);
if
(
FAILED
(
hres
))
break
;
}
}
if
(
FAILED
(
hres
))
{
heap_free
(
case_labels
);
return
hres
;
}
hres
=
push_instr_uint
(
ctx
,
OP_pop
,
1
);
if
(
FAILED
(
hres
))
{
heap_free
(
case_labels
);
return
hres
;
}
hres
=
push_instr_addr
(
ctx
,
OP_jmp
,
case_iter
?
case_labels
[
i
]
:
end_label
);
if
(
FAILED
(
hres
))
{
heap_free
(
case_labels
);
return
hres
;
}
for
(
case_iter
=
stat
->
case_clausules
,
i
=
0
;
case_iter
;
case_iter
=
case_iter
->
next
,
i
++
)
{
label_set_addr
(
ctx
,
case_labels
[
i
]);
hres
=
compile_statement
(
ctx
,
NULL
,
case_iter
->
stat
);
if
(
FAILED
(
hres
))
break
;
if
(
!
case_iter
->
next
)
break
;
hres
=
push_instr_addr
(
ctx
,
OP_jmp
,
end_label
);
if
(
FAILED
(
hres
))
return
hres
;
}
heap_free
(
case_labels
);
if
(
FAILED
(
hres
))
return
hres
;
label_set_addr
(
ctx
,
end_label
);
return
S_OK
;
}
}
static
HRESULT
compile_assignment
(
compile_ctx_t
*
ctx
,
member_expression_t
*
member_expr
,
expression_t
*
value_expr
,
BOOL
is_set
)
static
HRESULT
compile_assignment
(
compile_ctx_t
*
ctx
,
member_expression_t
*
member_expr
,
expression_t
*
value_expr
,
BOOL
is_set
)
...
...
dlls/vbscript/interp.c
View file @
f17aaf8d
...
@@ -1422,6 +1422,12 @@ static HRESULT interp_lteq(exec_ctx_t *ctx)
...
@@ -1422,6 +1422,12 @@ static HRESULT interp_lteq(exec_ctx_t *ctx)
return
stack_push
(
ctx
,
&
v
);
return
stack_push
(
ctx
,
&
v
);
}
}
static
HRESULT
interp_case
(
exec_ctx_t
*
ctx
)
{
FIXME
(
"
\n
"
);
return
E_NOTIMPL
;
}
static
HRESULT
disp_cmp
(
IDispatch
*
disp1
,
IDispatch
*
disp2
,
VARIANT_BOOL
*
ret
)
static
HRESULT
disp_cmp
(
IDispatch
*
disp1
,
IDispatch
*
disp2
,
VARIANT_BOOL
*
ret
)
{
{
IObjectIdentity
*
identity
;
IObjectIdentity
*
identity
;
...
...
dlls/vbscript/vbscript.h
View file @
f17aaf8d
...
@@ -189,6 +189,7 @@ typedef enum {
...
@@ -189,6 +189,7 @@ typedef enum {
X(assign_ident, 1, ARG_BSTR, ARG_UINT) \
X(assign_ident, 1, ARG_BSTR, ARG_UINT) \
X(assign_member, 1, ARG_BSTR, ARG_UINT) \
X(assign_member, 1, ARG_BSTR, ARG_UINT) \
X(bool, 1, ARG_INT, 0) \
X(bool, 1, ARG_INT, 0) \
X(case, 0, ARG_ADDR, 0) \
X(concat, 1, 0, 0) \
X(concat, 1, 0, 0) \
X(const, 1, ARG_BSTR, 0) \
X(const, 1, ARG_BSTR, 0) \
X(div, 1, 0, 0) \
X(div, 1, 0, 0) \
...
...
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