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
80ad3a23
Commit
80ad3a23
authored
Sep 15, 2011
by
Jacek Caban
Committed by
Alexandre Julliard
Sep 15, 2011
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
vbscript: Added class parser implementation.
parent
84ec1acc
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
39 additions
and
0 deletions
+39
-0
parse.h
dlls/vbscript/parse.h
+6
-0
parser.y
dlls/vbscript/parser.y
+30
-0
lang.vbs
dlls/vbscript/tests/lang.vbs
+3
-0
No files found.
dlls/vbscript/parse.h
View file @
80ad3a23
...
@@ -142,6 +142,11 @@ typedef struct _function_statement_t {
...
@@ -142,6 +142,11 @@ typedef struct _function_statement_t {
function_decl_t
*
func_decl
;
function_decl_t
*
func_decl
;
}
function_statement_t
;
}
function_statement_t
;
typedef
struct
_class_decl_t
{
const
WCHAR
*
name
;
struct
_class_decl_t
*
next
;
}
class_decl_t
;
typedef
struct
_elseif_decl_t
{
typedef
struct
_elseif_decl_t
{
expression_t
*
expr
;
expression_t
*
expr
;
statement_t
*
stat
;
statement_t
*
stat
;
...
@@ -170,6 +175,7 @@ typedef struct {
...
@@ -170,6 +175,7 @@ typedef struct {
statement_t
*
stats
;
statement_t
*
stats
;
statement_t
*
stats_tail
;
statement_t
*
stats_tail
;
class_decl_t
*
class_decls
;
vbsheap_t
heap
;
vbsheap_t
heap
;
}
parser_ctx_t
;
}
parser_ctx_t
;
...
...
dlls/vbscript/parser.y
View file @
80ad3a23
...
@@ -34,6 +34,7 @@ static int parser_error(const char*);
...
@@ -34,6 +34,7 @@ static int parser_error(const char*);
static void parse_complete(parser_ctx_t*,BOOL);
static void parse_complete(parser_ctx_t*,BOOL);
static void source_add_statement(parser_ctx_t*,statement_t*);
static void source_add_statement(parser_ctx_t*,statement_t*);
static void source_add_class(parser_ctx_t*,class_decl_t*);
static void *new_expression(parser_ctx_t*,expression_type_t,size_t);
static void *new_expression(parser_ctx_t*,expression_type_t,size_t);
static expression_t *new_bool_expression(parser_ctx_t*,VARIANT_BOOL);
static expression_t *new_bool_expression(parser_ctx_t*,VARIANT_BOOL);
...
@@ -56,6 +57,7 @@ static dim_decl_t *new_dim_decl(parser_ctx_t*,const WCHAR*,dim_decl_t*);
...
@@ -56,6 +57,7 @@ static dim_decl_t *new_dim_decl(parser_ctx_t*,const WCHAR*,dim_decl_t*);
static elseif_decl_t *new_elseif_decl(parser_ctx_t*,expression_t*,statement_t*);
static elseif_decl_t *new_elseif_decl(parser_ctx_t*,expression_t*,statement_t*);
static function_decl_t *new_function_decl(parser_ctx_t*,const WCHAR*,function_type_t,arg_decl_t*,statement_t*);
static function_decl_t *new_function_decl(parser_ctx_t*,const WCHAR*,function_type_t,arg_decl_t*,statement_t*);
static arg_decl_t *new_argument_decl(parser_ctx_t*,const WCHAR*,BOOL);
static arg_decl_t *new_argument_decl(parser_ctx_t*,const WCHAR*,BOOL);
static class_decl_t *new_class_decl(parser_ctx_t*);
#define CHECK_ERROR if(((parser_ctx_t*)ctx)->hres != S_OK) YYABORT
#define CHECK_ERROR if(((parser_ctx_t*)ctx)->hres != S_OK) YYABORT
...
@@ -73,6 +75,7 @@ static arg_decl_t *new_argument_decl(parser_ctx_t*,const WCHAR*,BOOL);
...
@@ -73,6 +75,7 @@ static arg_decl_t *new_argument_decl(parser_ctx_t*,const WCHAR*,BOOL);
dim_decl_t *dim_decl;
dim_decl_t *dim_decl;
function_decl_t *func_decl;
function_decl_t *func_decl;
arg_decl_t *arg_decl;
arg_decl_t *arg_decl;
class_decl_t *class_decl;
LONG lng;
LONG lng;
BOOL bool;
BOOL bool;
double dbl;
double dbl;
...
@@ -105,6 +108,7 @@ static arg_decl_t *new_argument_decl(parser_ctx_t*,const WCHAR*,BOOL);
...
@@ -105,6 +108,7 @@ static arg_decl_t *new_argument_decl(parser_ctx_t*,const WCHAR*,BOOL);
%type <arg_decl> ArgumentsDecl_opt ArgumentDeclList ArgumentDecl
%type <arg_decl> ArgumentsDecl_opt ArgumentDeclList ArgumentDecl
%type <func_decl> FunctionDecl
%type <func_decl> FunctionDecl
%type <elseif> ElseIfs_opt ElseIfs ElseIf
%type <elseif> ElseIfs_opt ElseIfs ElseIf
%type <class_decl> ClassDeclaration ClassBody
%type <dim_decl> DimDeclList
%type <dim_decl> DimDeclList
%%
%%
...
@@ -119,6 +123,7 @@ OptionExplicit_opt
...
@@ -119,6 +123,7 @@ OptionExplicit_opt
SourceElements
SourceElements
: /* empty */
: /* empty */
| SourceElements StatementNl { source_add_statement(ctx, $2); }
| SourceElements StatementNl { source_add_statement(ctx, $2); }
| SourceElements ClassDeclaration { source_add_class(ctx, $2); }
StatementsNl_opt
StatementsNl_opt
: /* empty */ { $$ = NULL; }
: /* empty */ { $$ = NULL; }
...
@@ -268,6 +273,12 @@ LiteralExpression
...
@@ -268,6 +273,12 @@ LiteralExpression
PrimaryExpression
PrimaryExpression
: '(' Expression ')' { $$ = $2; }
: '(' Expression ')' { $$ = $2; }
ClassDeclaration
: tCLASS tIdentifier tNL ClassBody tEND tCLASS tNL { $4->name = $2; $$ = $4; }
ClassBody
: /* empty */ { $$ = new_class_decl(ctx); }
FunctionDecl
FunctionDecl
: /* Storage_opt */ tSUB tIdentifier ArgumentsDecl_opt tNL StatementsNl_opt tEND tSUB
: /* Storage_opt */ tSUB tIdentifier ArgumentsDecl_opt tNL StatementsNl_opt tEND tSUB
{ $$ = new_function_decl(ctx, $2, FUNC_SUB, $3, $5); CHECK_ERROR; }
{ $$ = new_function_decl(ctx, $2, FUNC_SUB, $3, $5); CHECK_ERROR; }
...
@@ -304,6 +315,12 @@ static void source_add_statement(parser_ctx_t *ctx, statement_t *stat)
...
@@ -304,6 +315,12 @@ static void source_add_statement(parser_ctx_t *ctx, statement_t *stat)
}
}
}
}
static void source_add_class(parser_ctx_t *ctx, class_decl_t *class_decl)
{
class_decl->next = ctx->class_decls;
ctx->class_decls = class_decl;
}
static void parse_complete(parser_ctx_t *ctx, BOOL option_explicit)
static void parse_complete(parser_ctx_t *ctx, BOOL option_explicit)
{
{
ctx->parse_complete = TRUE;
ctx->parse_complete = TRUE;
...
@@ -545,6 +562,18 @@ static statement_t *new_function_statement(parser_ctx_t *ctx, function_decl_t *d
...
@@ -545,6 +562,18 @@ static statement_t *new_function_statement(parser_ctx_t *ctx, function_decl_t *d
return &stat->stat;
return &stat->stat;
}
}
static class_decl_t *new_class_decl(parser_ctx_t *ctx)
{
class_decl_t *class_decl;
class_decl = parser_alloc(ctx, sizeof(*class_decl));
if(!class_decl)
return NULL;
class_decl->next = NULL;
return class_decl;
}
void *parser_alloc(parser_ctx_t *ctx, size_t size)
void *parser_alloc(parser_ctx_t *ctx, size_t size)
{
{
void *ret;
void *ret;
...
@@ -568,6 +597,7 @@ HRESULT parse_script(parser_ctx_t *ctx, const WCHAR *code)
...
@@ -568,6 +597,7 @@ HRESULT parse_script(parser_ctx_t *ctx, const WCHAR *code)
ctx->last_token = tNL;
ctx->last_token = tNL;
ctx->last_nl = 0;
ctx->last_nl = 0;
ctx->stats = ctx->stats_tail = NULL;
ctx->stats = ctx->stats_tail = NULL;
ctx->class_decls = NULL;
ctx->option_explicit = FALSE;
ctx->option_explicit = FALSE;
parser_parse(ctx);
parser_parse(ctx);
...
...
dlls/vbscript/tests/lang.vbs
View file @
80ad3a23
...
@@ -355,4 +355,7 @@ x = false
...
@@ -355,4 +355,7 @@ x = false
ok
SetVal
(
x
,
true
),
"SetVal returned false?"
ok
SetVal
(
x
,
true
),
"SetVal returned false?"
Call
ok
(
x
,
"x is not set to true by SetVal?"
)
Call
ok
(
x
,
"x is not set to true by SetVal?"
)
Class
EmptyClass
End
Class
reportSuccess
()
reportSuccess
()
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