widl: The lval member of var_t is essentially a duplicate of eval->cval.

- Generate eval's for enums that don't explicitly have one. This means
that enums written in header files won't match exactly what has been put
into the IDL file, but the numeric constat is the same and MIDL does a
similar thing.
- Replace constant lookups with eval->cval instead of lval.
This commit is contained in:
Robert Shearman 2006-03-31 12:45:43 +01:00 committed by Alexandre Julliard
parent 4edcf2de35
commit 4cd506b8fd
3 changed files with 7 additions and 10 deletions

View File

@ -436,7 +436,6 @@ case: tCASE expr ':' field { attr_t *a = make_attrp(ATTR_CASE, $2);
constdef: tCONST type ident '=' expr_const { $$ = reg_const($3); constdef: tCONST type ident '=' expr_const { $$ = reg_const($3);
set_type($$, $2, NULL); set_type($$, $2, NULL);
$$->eval = $5; $$->eval = $5;
$$->lval = $5->cval;
} }
; ;
@ -445,20 +444,20 @@ enums: { $$ = NULL; }
| enum_list | enum_list
; ;
enum_list: enum enum_list: enum { if (!$$->eval)
$$->eval = make_exprl(EXPR_NUM, 0 /* default for first enum entry */);
}
| enum_list ',' enum { LINK($3, $1); $$ = $3; | enum_list ',' enum { LINK($3, $1); $$ = $3;
if ($1 && !$3->eval) if (!$$->eval)
$3->lval = $1->lval + 1; $$->eval = make_exprl(EXPR_NUM, $1->eval->cval + 1);
} }
; ;
enum: ident '=' expr_const { $$ = reg_const($1); enum: ident '=' expr_const { $$ = reg_const($1);
$$->eval = $3; $$->eval = $3;
$$->lval = $3->cval;
$$->type = make_type(RPC_FC_LONG, &std_int); $$->type = make_type(RPC_FC_LONG, &std_int);
} }
| ident { $$ = reg_const($1); | ident { $$ = reg_const($1);
$$->lval = 0; /* default for first enum entry */
$$->type = make_type(RPC_FC_LONG, &std_int); $$->type = make_type(RPC_FC_LONG, &std_int);
} }
; ;
@ -875,7 +874,7 @@ static expr_t *make_exprs(enum expr_type type, char *val)
e->u.sval = c->name; e->u.sval = c->name;
free(val); free(val);
e->is_const = TRUE; e->is_const = TRUE;
e->cval = c->lval; e->cval = c->eval->cval;
} }
} }
return e; return e;
@ -1101,7 +1100,6 @@ static var_t *make_var(char *name)
v->attrs = NULL; v->attrs = NULL;
v->array = NULL; v->array = NULL;
v->eval = NULL; v->eval = NULL;
v->lval = 0;
INIT_LINK(v); INIT_LINK(v);
return v; return v;
} }

View File

@ -216,7 +216,6 @@ struct _var_t {
const char *tname; const char *tname;
attr_t *attrs; attr_t *attrs;
expr_t *eval; expr_t *eval;
long lval;
/* parser-internal */ /* parser-internal */
DECL_LINK(var_t) DECL_LINK(var_t)

View File

@ -1559,7 +1559,7 @@ static HRESULT add_var_desc(msft_typeinfo_t *typeinfo, UINT index, var_t* var)
switch(typeinfo->typeinfo->typekind & 0xf) { switch(typeinfo->typeinfo->typekind & 0xf) {
case TKIND_ENUM: case TKIND_ENUM:
write_value(typeinfo->typelib, &typedata[4], VT_I4, &var->lval); write_value(typeinfo->typelib, &typedata[4], VT_I4, &var->eval->cval);
var_kind = 2; /* VAR_CONST */ var_kind = 2; /* VAR_CONST */
var_type_size += 16; /* sizeof(VARIANT) */ var_type_size += 16; /* sizeof(VARIANT) */
typeinfo->datawidth = var_datawidth; typeinfo->datawidth = var_datawidth;