oleaut32: Fix ITypeInfo::GetNames for functions.
This commit is contained in:
parent
cee0a726ed
commit
3983bbf7d9
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue