widl: Write out TYPEFLAG, FUNCFLAG and VARFLAG flags for all attribute we currently parse.

Add FIXMEs for the remaining ones and remove the warning for 
unimplemented attribute types since we now support all the attributes 
that we parse.
This commit is contained in:
Rob Shearman 2008-04-14 11:00:07 +01:00 committed by Alexandre Julliard
parent 56e2553eff
commit f728fe168b
1 changed files with 50 additions and 19 deletions

View File

@ -1319,10 +1319,14 @@ static HRESULT add_func_desc(msft_typeinfo_t* typeinfo, const func_t *func, int
expr_t *expr = attr->u.pval; expr_t *expr = attr->u.pval;
switch(attr->type) { switch(attr->type) {
case ATTR_BINDABLE: case ATTR_BINDABLE:
funcflags |= 0x4; /* FUNCFLAG_BINDABLE */ funcflags |= 0x4; /* FUNCFLAG_FBINDABLE */
break;
/* FIXME: FUNCFLAG_FDEFAULTBIND */
case ATTR_DEFAULTCOLLELEM:
funcflags |= 0x100; /* FUNCFLAG_FDEFAULTCOLLELEM */
break; break;
case ATTR_DISPLAYBIND: case ATTR_DISPLAYBIND:
funcflags |= 0x10; /* FUNCFLAG_DISPLAYBIND */ funcflags |= 0x10; /* FUNCFLAG_FDISPLAYBIND */
break; break;
case ATTR_ENTRY_ORDINAL: case ATTR_ENTRY_ORDINAL:
extra_attr = max(extra_attr, 3); extra_attr = max(extra_attr, 3);
@ -1351,8 +1355,11 @@ static HRESULT add_func_desc(msft_typeinfo_t* typeinfo, const func_t *func, int
case ATTR_ID: case ATTR_ID:
id = expr->cval; id = expr->cval;
break; break;
case ATTR_IMMEDIATEBIND:
funcflags |= 0x1000; /* FUNCFLAG_FIMMEDIATEBIND */
break;
case ATTR_NONBROWSABLE: case ATTR_NONBROWSABLE:
funcflags |= 0x400; /* FUNCFLAG_NONBROWSABLE */ funcflags |= 0x400; /* FUNCFLAG_FNONBROWSABLE */
break; break;
case ATTR_OUT: case ATTR_OUT:
break; break;
@ -1365,9 +1372,18 @@ static HRESULT add_func_desc(msft_typeinfo_t* typeinfo, const func_t *func, int
case ATTR_PROPPUTREF: case ATTR_PROPPUTREF:
invokekind = 0x8; /* INVOKE_PROPERTYPUTREF */ invokekind = 0x8; /* INVOKE_PROPERTYPUTREF */
break; break;
/* FIXME: FUNCFLAG_FREPLACEABLE */
case ATTR_REQUESTEDIT:
funcflags |= 0x8; /* FUNCFLAG_FREQUESTEDIT */
break;
case ATTR_RESTRICTED: case ATTR_RESTRICTED:
funcflags |= 0x1; /* FUNCFLAG_FRESTRICTED */ funcflags |= 0x1; /* FUNCFLAG_FRESTRICTED */
break; break;
case ATTR_SOURCE:
funcflags |= 0x2; /* FUNCFLAG_FSOURCE */
break;
/* FIXME: FUNCFLAG_FUIDEFAULT */
/* FIXME: FUNCFLAG_FUSESGETLASTERROR */
case ATTR_VARARG: case ATTR_VARARG:
if (num_optional || num_defaults) if (num_optional || num_defaults)
warning("add_func_desc: ignoring vararg in function with optional or defaultvalue params\n"); warning("add_func_desc: ignoring vararg in function with optional or defaultvalue params\n");
@ -1375,7 +1391,6 @@ static HRESULT add_func_desc(msft_typeinfo_t* typeinfo, const func_t *func, int
num_optional = -1; num_optional = -1;
break; break;
default: default:
warning("add_func_desc: ignoring attr %d\n", attr->type);
break; break;
} }
} }
@ -1597,23 +1612,44 @@ static HRESULT add_var_desc(msft_typeinfo_t *typeinfo, UINT index, var_t* var)
if (var->attrs) LIST_FOR_EACH_ENTRY( attr, var->attrs, const attr_t, entry ) { if (var->attrs) LIST_FOR_EACH_ENTRY( attr, var->attrs, const attr_t, entry ) {
expr_t *expr = attr->u.pval; expr_t *expr = attr->u.pval;
switch(attr->type) { switch(attr->type) {
case ATTR_BINDABLE:
varflags |= 0x04; /* VARFLAG_FBINDABLE */
break;
/* FIXME: VARFLAG_FDEFAULTBIND */
case ATTR_DEFAULTCOLLELEM:
varflags |= 0x100; /* VARFLAG_FDEFAULTCOLLELEM */
break;
case ATTR_DISPLAYBIND:
varflags |= 0x10; /* VARFLAG_FDISPLAYBIND */
break;
case ATTR_HIDDEN: case ATTR_HIDDEN:
varflags |= 0x40; /* VARFLAG_FHIDDEN */ varflags |= 0x40; /* VARFLAG_FHIDDEN */
break; break;
case ATTR_ID: case ATTR_ID:
id = expr->cval; id = expr->cval;
break; break;
case ATTR_IMMEDIATEBIND:
varflags |= 0x1000; /* VARFLAG_FIMMEDIATEBIND */
break;
case ATTR_NONBROWSABLE:
varflags |= 0x400; /* VARFLAG_FNONBROWSABLE */
break;
case ATTR_READONLY: case ATTR_READONLY:
varflags |= 0x01; /* VARFLAG_FREADONLY */ varflags |= 0x01; /* VARFLAG_FREADONLY */
break; break;
/* FIXME: VARFLAG_FREPLACEABLE */
break;
case ATTR_REQUESTEDIT:
varflags |= 0x08; /* VARFLAG_FREQUESTEDIT */
break;
case ATTR_RESTRICTED: case ATTR_RESTRICTED:
varflags |= 0x80; /* VARFLAG_FRESTRICTED */ varflags |= 0x80; /* VARFLAG_FRESTRICTED */
break; break;
case ATTR_SOURCE: case ATTR_SOURCE:
varflags |= 0x02; /* VARFLAG_FSOURCE */ varflags |= 0x02; /* VARFLAG_FSOURCE */
break; break;
/* FIXME: VARFLAG_FUIDEFAULT */
default: default:
warning("AddVarDesc: unhandled attr type %d\n", attr->type);
break; break;
} }
} }
@ -1801,9 +1837,6 @@ static msft_typeinfo_t *create_msft_typeinfo(msft_typelib_t *typelib, enum type_
typeinfo->flags |= 0x20; /* TYPEFLAG_FCONTROL */ typeinfo->flags |= 0x20; /* TYPEFLAG_FCONTROL */
break; break;
case ATTR_DISPINTERFACE:
break;
case ATTR_DLLNAME: case ATTR_DLLNAME:
{ {
int offset = ctl2_alloc_string(typelib, attr->u.pval); int offset = ctl2_alloc_string(typelib, attr->u.pval);
@ -1840,8 +1873,7 @@ static msft_typeinfo_t *create_msft_typeinfo(msft_typelib_t *typelib, enum type_
typeinfo->flags |= 0x10; /* TYPEFLAG_FHIDDEN */ typeinfo->flags |= 0x10; /* TYPEFLAG_FHIDDEN */
break; break;
case ATTR_LOCAL: /* FIXME: TYPEFLAG_FLICENSED */
break;
case ATTR_NONCREATABLE: case ATTR_NONCREATABLE:
typeinfo->flags &= ~0x2; /* TYPEFLAG_FCANCREATE */ typeinfo->flags &= ~0x2; /* TYPEFLAG_FCANCREATE */
@ -1851,18 +1883,15 @@ static msft_typeinfo_t *create_msft_typeinfo(msft_typelib_t *typelib, enum type_
typeinfo->flags |= 0x80; /* TYPEFLAG_FNONEXTENSIBLE */ typeinfo->flags |= 0x80; /* TYPEFLAG_FNONEXTENSIBLE */
break; break;
case ATTR_OBJECT:
break;
case ATTR_ODL:
break;
case ATTR_OLEAUTOMATION: case ATTR_OLEAUTOMATION:
typeinfo->flags |= 0x100; /* TYPEFLAG_FOLEAUTOMATION */ typeinfo->flags |= 0x100; /* TYPEFLAG_FOLEAUTOMATION */
break; break;
case ATTR_PUBLIC: /* FIXME: TYPEFLAG_FPREDCLID */
break;
/* FIXME: TYPEFLAG_FPROXY */
/* FIXME: TYPEFLAG_FREPLACEABLE */
case ATTR_RESTRICTED: case ATTR_RESTRICTED:
typeinfo->flags |= 0x200; /* TYPEFLAG_FRESTRICTED */ typeinfo->flags |= 0x200; /* TYPEFLAG_FRESTRICTED */
@ -1885,7 +1914,6 @@ static msft_typeinfo_t *create_msft_typeinfo(msft_typelib_t *typelib, enum type_
break; break;
default: default:
warning("create_msft_typeinfo: ignoring attr %d\n", attr->type);
break; break;
} }
} }
@ -2104,6 +2132,9 @@ static void add_coclass_typeinfo(msft_typelib_t *typelib, type_t *cls)
case ATTR_DEFAULT: case ATTR_DEFAULT:
ref->flags |= 0x1; /* IMPLTYPEFLAG_FDEFAULT */ ref->flags |= 0x1; /* IMPLTYPEFLAG_FDEFAULT */
break; break;
case ATTR_DEFAULTVTABLE:
ref->flags |= 0x8; /* IMPLTYPEFLAG_FDEFAULTVTABLE */
break;
case ATTR_RESTRICTED: case ATTR_RESTRICTED:
ref->flags |= 0x4; /* IMPLTYPEFLAG_FRESTRICTED */ ref->flags |= 0x4; /* IMPLTYPEFLAG_FRESTRICTED */
break; break;