oleaut32: Fix ITypeInfo::GetNames for functions.

This commit is contained in:
Andrew Eikum 2013-06-05 07:56:42 -05:00 committed by Alexandre Julliard
parent cee0a726ed
commit 3983bbf7d9
1 changed files with 27 additions and 24 deletions

View File

@ -2392,12 +2392,7 @@ MSFT_DoFuncs(TLBContext* pcx,
elemdesc->u.paramdesc.wParamFlags = paraminfo.Flags; elemdesc->u.paramdesc.wParamFlags = paraminfo.Flags;
/* name */ /* name */
if (paraminfo.oName == -1) if (paraminfo.oName != -1)
/* this occurs for [propput] or [propget] methods, so
* we should just set the name of the parameter to the
* name of the method. */
ptfd->pParamDesc[j].Name = ptfd->Name;
else
ptfd->pParamDesc[j].Name = ptfd->pParamDesc[j].Name =
MSFT_ReadName( pcx, paraminfo.oName ); MSFT_ReadName( pcx, paraminfo.oName );
TRACE_(typelib)("param[%d] = %s\n", j, debugstr_w(TLB_get_bstr(ptfd->pParamDesc[j].Name))); TRACE_(typelib)("param[%d] = %s\n", j, debugstr_w(TLB_get_bstr(ptfd->pParamDesc[j].Name)));
@ -5959,29 +5954,38 @@ static HRESULT WINAPI ITypeInfo_fnGetNames( ITypeInfo2 *iface, MEMBERID memid,
const TLBVarDesc *pVDesc; const TLBVarDesc *pVDesc;
int i; int i;
TRACE("(%p) memid=0x%08x Maxname=%d\n", This, memid, cMaxNames); TRACE("(%p) memid=0x%08x Maxname=%d\n", This, memid, cMaxNames);
if(!rgBstrNames)
return E_INVALIDARG;
*pcNames = 0;
pFDesc = TLB_get_funcdesc_by_memberid(This->funcdescs, This->cFuncs, memid); pFDesc = TLB_get_funcdesc_by_memberid(This->funcdescs, This->cFuncs, memid);
if(pFDesc) if(pFDesc)
{ {
/* function found, now return function and parameter names */ if(!cMaxNames || !pFDesc->Name)
for(i=0; i<cMaxNames && i <= pFDesc->funcdesc.cParams; i++) return S_OK;
{
if(!i) *rgBstrNames = SysAllocString(TLB_get_bstr(pFDesc->Name));
*rgBstrNames=SysAllocString(TLB_get_bstr(pFDesc->Name)); ++(*pcNames);
else
rgBstrNames[i]=SysAllocString(TLB_get_bstr(pFDesc->pParamDesc[i-1].Name)); for(i = 0; i < pFDesc->funcdesc.cParams; ++i){
} if(*pcNames >= cMaxNames || !pFDesc->pParamDesc[i].Name)
*pcNames=i; return S_OK;
rgBstrNames[*pcNames] = SysAllocString(TLB_get_bstr(pFDesc->pParamDesc[i].Name));
++(*pcNames);
}
return S_OK;
}
pVDesc = TLB_get_vardesc_by_memberid(This->vardescs, This->cVars, memid);
if(pVDesc)
{
*rgBstrNames=SysAllocString(TLB_get_bstr(pVDesc->Name));
*pcNames=1;
} }
else else
{ {
pVDesc = TLB_get_vardesc_by_memberid(This->vardescs, This->cVars, memid);
if(pVDesc)
{
*rgBstrNames=SysAllocString(TLB_get_bstr(pVDesc->Name));
*pcNames=1;
}
else
{
if(This->impltypes && if(This->impltypes &&
(This->typekind==TKIND_INTERFACE || This->typekind==TKIND_DISPATCH)) { (This->typekind==TKIND_INTERFACE || This->typekind==TKIND_DISPATCH)) {
/* recursive search */ /* recursive search */
@ -6002,7 +6006,6 @@ static HRESULT WINAPI ITypeInfo_fnGetNames( ITypeInfo2 *iface, MEMBERID memid,
} }
*pcNames=0; *pcNames=0;
return TYPE_E_ELEMENTNOTFOUND; return TYPE_E_ELEMENTNOTFOUND;
}
} }
return S_OK; return S_OK;
} }