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:
parent
56e2553eff
commit
f728fe168b
|
@ -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;
|
||||||
|
|
Loading…
Reference in New Issue