shell32/shellview: Improve error handling on some helpers, fix possible leak.

This commit is contained in:
Nikolay Sivov 2010-03-06 23:47:59 +03:00 committed by Alexandre Julliard
parent 115efbed69
commit 571159d5ff
1 changed files with 69 additions and 69 deletions

View File

@ -638,32 +638,28 @@ static HRESULT ShellView_FillList(IShellViewImpl * This)
{
LPENUMIDLIST pEnumIDList;
LPITEMIDLIST pidl;
DWORD dwFetched;
HRESULT hRes;
DWORD fetched;
HRESULT hr;
HDPA hdpa;
TRACE("%p\n",This);
TRACE("(%p)\n", This);
/* get the itemlist from the shfolder*/
hRes = IShellFolder_EnumObjects(This->pSFParent,This->hWnd, SHCONTF_NONFOLDERS | SHCONTF_FOLDERS, &pEnumIDList);
if (hRes != S_OK)
{
if (hRes==S_FALSE)
return(NOERROR);
return(hRes);
}
hr = IShellFolder_EnumObjects(This->pSFParent, This->hWnd, SHCONTF_NONFOLDERS | SHCONTF_FOLDERS, &pEnumIDList);
if (hr != S_OK) return hr;
/* create a pointer array */
hdpa = DPA_Create(16);
if (!hdpa)
{
return(E_OUTOFMEMORY);
IEnumIDList_Release(pEnumIDList);
return E_OUTOFMEMORY;
}
/* copy the items into the array*/
while((S_OK == IEnumIDList_Next(pEnumIDList,1, &pidl, &dwFetched)) && dwFetched)
while((S_OK == IEnumIDList_Next(pEnumIDList, 1, &pidl, &fetched)) && fetched)
{
if (DPA_InsertPtr(hdpa, 0x7fff, pidl) == -1)
if (DPA_InsertPtr(hdpa, DPA_GetPtrCount(hdpa), pidl) == -1)
{
SHFree(pidl);
}
@ -672,15 +668,11 @@ static HRESULT ShellView_FillList(IShellViewImpl * This)
/* sort the array */
DPA_Sort(hdpa, ShellView_CompareItems, (LPARAM)This->pSFParent);
/*turn the listview's redrawing off*/
SendMessageA(This->hWndList, WM_SETREDRAW, FALSE, 0);
SendMessageW(This->hWndList, WM_SETREDRAW, FALSE, 0);
DPA_DestroyCallback(hdpa, fill_list, This);
SendMessageW(This->hWndList, WM_SETREDRAW, TRUE, 0);
/*turn the listview's redrawing back on and force it to draw*/
SendMessageA(This->hWndList, WM_SETREDRAW, TRUE, 0);
IEnumIDList_Release(pEnumIDList); /* destroy the list*/
IEnumIDList_Release(pEnumIDList);
return S_OK;
}
@ -690,11 +682,12 @@ static HRESULT ShellView_FillList(IShellViewImpl * This)
*/
static LRESULT ShellView_OnCreate(IShellViewImpl *This)
{
IShellView2 *iface = (IShellView2*)This;
IPersistFolder2 *ppf2;
IDropTarget* pdt;
SHChangeNotifyEntry ntreg;
IPersistFolder2 * ppf2 = NULL;
HRESULT hr;
TRACE("%p\n",This);
TRACE("(%p)\n", This);
if (ShellView_CreateList(This))
{
@ -704,20 +697,27 @@ static LRESULT ShellView_OnCreate(IShellViewImpl * This)
}
}
if (SUCCEEDED(IUnknown_QueryInterface((IUnknown*)&This->lpVtbl, &IID_IDropTarget, (LPVOID*)&pdt)))
hr = IShellView2_QueryInterface(iface, &IID_IDropTarget, (LPVOID*)&pdt);
if (hr == S_OK)
{
RegisterDragDrop(This->hWnd, pdt);
IDropTarget_Release(pdt);
}
/* register for receiving notifications */
IShellFolder_QueryInterface(This->pSFParent, &IID_IPersistFolder2, (LPVOID*)&ppf2);
if (ppf2)
hr = IShellFolder_QueryInterface(This->pSFParent, &IID_IPersistFolder2, (LPVOID*)&ppf2);
if (hr == S_OK)
{
SHChangeNotifyEntry ntreg;
hr = IPersistFolder2_GetCurFolder(ppf2, (LPITEMIDLIST*)&ntreg.pidl);
if (hr == S_OK)
{
IPersistFolder2_GetCurFolder(ppf2, (LPITEMIDLIST*)&ntreg.pidl);
ntreg.fRecursive = TRUE;
This->hNotify = SHChangeNotifyRegister(This->hWnd, SHCNF_IDLIST, SHCNE_ALLEVENTS, SHV_CHANGE_NOTIFY, 1, &ntreg);
This->hNotify = SHChangeNotifyRegister(This->hWnd, SHCNF_IDLIST, SHCNE_ALLEVENTS,
SHV_CHANGE_NOTIFY, 1, &ntreg);
SHFree((LPITEMIDLIST)ntreg.pidl);
}
IPersistFolder2_Release(ppf2);
}