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
6c8c617d
Commit
6c8c617d
authored
Sep 16, 2011
by
Jacek Caban
Committed by
Alexandre Julliard
Sep 16, 2011
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
vbscript: Added support for exit property statement.
parent
097a75f6
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
29 additions
and
1 deletion
+29
-1
compile.c
dlls/vbscript/compile.c
+21
-1
parse.h
dlls/vbscript/parse.h
+1
-0
parser.y
dlls/vbscript/parser.y
+1
-0
lang.vbs
dlls/vbscript/tests/lang.vbs
+6
-0
No files found.
dlls/vbscript/compile.c
View file @
6c8c617d
...
...
@@ -40,6 +40,7 @@ typedef struct {
unsigned
sub_end_label
;
unsigned
func_end_label
;
unsigned
prop_end_label
;
dim_decl_t
*
dim_decls
;
dynamic_var_t
*
global_vars
;
...
...
@@ -585,6 +586,16 @@ static HRESULT compile_exitfunc_statement(compile_ctx_t *ctx)
return
push_instr_addr
(
ctx
,
OP_jmp
,
ctx
->
func_end_label
);
}
static
HRESULT
compile_exitprop_statement
(
compile_ctx_t
*
ctx
)
{
if
(
ctx
->
prop_end_label
==
-
1
)
{
FIXME
(
"Exit Property outside Property?
\n
"
);
return
E_FAIL
;
}
return
push_instr_addr
(
ctx
,
OP_jmp
,
ctx
->
prop_end_label
);
}
static
HRESULT
compile_statement
(
compile_ctx_t
*
ctx
,
statement_t
*
stat
)
{
HRESULT
hres
;
...
...
@@ -603,6 +614,9 @@ static HRESULT compile_statement(compile_ctx_t *ctx, statement_t *stat)
case
STAT_EXITFUNC
:
hres
=
compile_exitfunc_statement
(
ctx
);
break
;
case
STAT_EXITPROP
:
hres
=
compile_exitprop_statement
(
ctx
);
break
;
case
STAT_EXITSUB
:
hres
=
compile_exitsub_statement
(
ctx
);
break
;
...
...
@@ -654,6 +668,7 @@ static HRESULT compile_func(compile_ctx_t *ctx, statement_t *stat, function_t *f
ctx
->
sub_end_label
=
-
1
;
ctx
->
func_end_label
=
-
1
;
ctx
->
prop_end_label
=
-
1
;
switch
(
func
->
type
)
{
case
FUNC_FUNCTION
:
...
...
@@ -669,7 +684,10 @@ static HRESULT compile_func(compile_ctx_t *ctx, statement_t *stat, function_t *f
case
FUNC_PROPGET
:
case
FUNC_PROPLET
:
case
FUNC_PROPSET
:
/* FIXME */
ctx
->
prop_end_label
=
alloc_label
(
ctx
);
if
(
ctx
->
prop_end_label
==
-
1
)
return
E_OUTOFMEMORY
;
break
;
case
FUNC_GLOBAL
:
break
;
}
...
...
@@ -685,6 +703,8 @@ static HRESULT compile_func(compile_ctx_t *ctx, statement_t *stat, function_t *f
label_set_addr
(
ctx
,
ctx
->
sub_end_label
);
if
(
ctx
->
func_end_label
!=
-
1
)
label_set_addr
(
ctx
,
ctx
->
func_end_label
);
if
(
ctx
->
prop_end_label
!=
-
1
)
label_set_addr
(
ctx
,
ctx
->
prop_end_label
);
if
(
push_instr
(
ctx
,
OP_ret
)
==
-
1
)
return
E_OUTOFMEMORY
;
...
...
dlls/vbscript/parse.h
View file @
6c8c617d
...
...
@@ -94,6 +94,7 @@ typedef enum {
STAT_CALL
,
STAT_DIM
,
STAT_EXITFUNC
,
STAT_EXITPROP
,
STAT_EXITSUB
,
STAT_FUNC
,
STAT_IF
,
...
...
dlls/vbscript/parser.y
View file @
6c8c617d
...
...
@@ -155,6 +155,7 @@ Statement
| IfStatement { $$ = $1; }
| FunctionDecl { $$ = new_function_statement(ctx, $1); CHECK_ERROR; }
| tEXIT tFUNCTION { $$ = new_statement(ctx, STAT_EXITFUNC, 0); CHECK_ERROR; }
| tEXIT tPROPERTY { $$ = new_statement(ctx, STAT_EXITPROP, 0); CHECK_ERROR; }
| tEXIT tSUB { $$ = new_statement(ctx, STAT_EXITSUB, 0); CHECK_ERROR; }
| tSET MemberExpression Arguments_opt '=' Expression
{ $2->args = $3; $$ = new_set_statement(ctx, $2, $5); CHECK_ERROR; }
...
...
dlls/vbscript/tests/lang.vbs
View file @
6c8c617d
...
...
@@ -402,6 +402,8 @@ Class TestClass
Public
Property
Get
gsProp
()
gsProp
=
privateProp
funcCalled
=
"gsProp get"
exit
property
Call
ok
(
false
,
"exit property not returned?"
)
End
Property
Public
publicProp2
...
...
@@ -412,10 +414,14 @@ Class TestClass
Public
Property
Let
gsProp
(
val
)
privateProp
=
val
funcCalled
=
"gsProp let"
exit
property
Call
ok
(
false
,
"exit property not returned?"
)
End
Property
Public
Property
Set
gsProp
(
val
)
funcCalled
=
"gsProp set"
exit
property
Call
ok
(
false
,
"exit property not returned?"
)
End
Property
Public
Sub
setPrivateProp
(
x
)
...
...
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