*
* Copyright 1998,1999 <juergen.schmied@debitel.net>
*
- * This is the view visualizing the data provied by the shellfolder.
+ * This is the view visualizing the data provided by the shellfolder.
* No direct access to data from pidls should be done from here.
*
* This library is free software; you can redistribute it and/or
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*
* FIXME: The order by part of the background context menu should be
- * buily according to the columns shown.
+ * built according to the columns shown.
*
- * FIXME: Load/Save the view state from/into the stream provied by
+ * FIXME: Load/Save the view state from/into the stream provided by
* the ShellBrowser
*
* FIXME: CheckToolbar: handle the "new folder" and "folder up" button
TRACE("(%p)\n", This);
- tmpstyle = GetWindowLongW(This->hWndList, GWL_STYLE);
- SetWindowLongW(This->hWndList, GWL_STYLE, dwAdd | (tmpstyle & ~dwRemove));
+ tmpstyle = GetWindowLongPtrW(This->hWndList, GWL_STYLE);
+ SetWindowLongPtrW(This->hWndList, GWL_STYLE, dwAdd | (tmpstyle & ~dwRemove));
}
/**********************************************************
{
for (i=0; 1; i++)
{
- if (!SUCCEEDED(IShellFolder2_GetDetailsOf(This->pSF2Parent, NULL, i, &sd)))
+ if (FAILED(IShellFolder2_GetDetailsOf(This->pSF2Parent, NULL, i, &sd)))
break;
lvColumn.fmt = sd.fmt;
lvColumn.cx = sd.cxChar*8; /* chars->pixel */
FILETIME fd1, fd2;
char strName1[MAX_PATH], strName2[MAX_PATH];
BOOL bIsFolder1, bIsFolder2,bIsBothFolder;
- LPITEMIDLIST pItemIdList1 = (LPITEMIDLIST) lParam1;
- LPITEMIDLIST pItemIdList2 = (LPITEMIDLIST) lParam2;
+ LPITEMIDLIST pItemIdList1 = lParam1;
+ LPITEMIDLIST pItemIdList2 = lParam2;
LISTVIEW_SORT_INFO *pSortInfo = (LPLISTVIEW_SORT_INFO) lpData;
if (0 == CF_IDLIST)
{
- CF_IDLIST = RegisterClipboardFormatA(CFSTR_SHELLIDLIST);
+ CF_IDLIST = RegisterClipboardFormatW(CFSTR_SHELLIDLIST);
}
fetc.cfFormat = CF_IDLIST;
fetc.ptd = NULL;
break;
case NM_RETURN:
- TRACE("-- NM_DBLCLK %p\n",This);
+ TRACE("-- NM_RETURN %p\n",This);
if (OnDefaultCommand(This) != S_OK) ShellView_OpenSelectedItems(This);
break;
if (pds)
{
- DWORD dwEffect;
- DoDragDrop(pda, pds, dwEffect, &dwEffect);
+ DWORD dwEffect2;
+ DoDragDrop(pda, pds, dwEffect, &dwEffect2);
}
IDataObject_Release(pda);
}
DWORD dwAttr = SFGAO_CANRENAME;
pidl = (LPITEMIDLIST)lpdi->item.lParam;
- TRACE("-- LVN_BEGINLABELEDITA %p\n",This);
+ TRACE("-- LVN_BEGINLABELEDITW %p\n",This);
IShellFolder_GetAttributesOf(This->pSFParent, 1, (LPCITEMIDLIST*)&pidl, &dwAttr);
if (SFGAO_CANRENAME & dwAttr)
case LVN_ENDLABELEDITW:
{
- TRACE("-- LVN_ENDLABELEDITA %p\n",This);
+ TRACE("-- LVN_ENDLABELEDITW %p\n",This);
if (lpdi->item.pszText)
{
HRESULT hr;
msg.pt = 0;*/
LPNMLVKEYDOWN plvKeyDown = (LPNMLVKEYDOWN) lpnmh;
+ SHORT ctrl = GetKeyState(VK_CONTROL) & 0x8000;
/* initiate a rename of the selected file or directory */
if(plvKeyDown->wVKey == VK_F2)
IShellBrowser_BrowseObject(lpSb, NULL, SBSP_PARENT);
}
}
+ else if(plvKeyDown->wVKey == 'C' && ctrl)
+ {
+ if (ShellView_GetSelections(This))
+ {
+ IDataObject * pda;
+
+ if (SUCCEEDED(IShellFolder_GetUIObjectOf(This->pSFParent, This->hWnd, This->cidl, (LPCITEMIDLIST*)This->apidl, &IID_IDataObject,0,(LPVOID *)&pda)))
+ {
+ HRESULT hr = OleSetClipboard(pda);
+ if (FAILED(hr))
+ {
+ WARN("OleSetClipboard failed");
+ }
+ IDataObject_Release(pda);
+ }
+ }
+ break;
+ }
+ else if(plvKeyDown->wVKey == 'V' && ctrl)
+ {
+ IDataObject * pda;
+ STGMEDIUM medium;
+ FORMATETC formatetc;
+ LPITEMIDLIST * apidl;
+ LPITEMIDLIST pidl;
+ IShellFolder *psfFrom = NULL, *psfDesktop, *psfTarget = NULL;
+ LPIDA lpcida;
+ ISFHelper *psfhlpdst, *psfhlpsrc;
+ HRESULT hr;
+
+ hr = OleGetClipboard(&pda);
+ if (hr != S_OK)
+ {
+ ERR("Failed to get clipboard with %lx\n", hr);
+ return E_FAIL;
+ }
+
+ InitFormatEtc(formatetc, RegisterClipboardFormatW(CFSTR_SHELLIDLIST), TYMED_HGLOBAL);
+ hr = IDataObject_GetData(pda,&formatetc,&medium);
+
+ if (FAILED(hr))
+ {
+ ERR("Failed to get clipboard data with %lx\n", hr);
+ IDataObject_Release(pda);
+ return E_FAIL;
+ }
+
+ /* lock the handle */
+ lpcida = GlobalLock(medium.u.hGlobal);
+ if (!lpcida)
+ {
+ ERR("failed to lock pidl\n");
+ ReleaseStgMedium(&medium);
+ IDataObject_Release(pda);
+ return E_FAIL;
+ }
+
+ /* convert the data into pidl */
+ apidl = _ILCopyCidaToaPidl(&pidl, lpcida);
+
+ if (!apidl)
+ {
+ ERR("failed to copy pidl\n");
+ return E_FAIL;
+ }
+
+ if (FAILED(SHGetDesktopFolder(&psfDesktop)))
+ {
+ ERR("failed to get desktop folder\n");
+ SHFree(pidl);
+ _ILFreeaPidl(apidl, lpcida->cidl);
+ ReleaseStgMedium(&medium);
+ IDataObject_Release(pda);
+ return E_FAIL;
+ }
+
+ if (_ILIsDesktop(pidl))
+ {
+ /* use desktop shellfolder */
+ psfFrom = psfDesktop;
+ }
+ else if (FAILED(IShellFolder_BindToObject(psfDesktop, pidl, NULL, &IID_IShellFolder, (LPVOID*)&psfFrom)))
+ {
+ ERR("no IShellFolder\n");
+
+ IShellFolder_Release(psfDesktop);
+ SHFree(pidl);
+ _ILFreeaPidl(apidl, lpcida->cidl);
+ ReleaseStgMedium(&medium);
+ IDataObject_Release(pda);
+
+ return E_FAIL;
+ }
+
+ psfTarget = This->pSFParent;
+
+
+ /* get source and destination shellfolder */
+ if (FAILED(IShellFolder_QueryInterface(psfTarget, &IID_ISFHelper, (LPVOID*)&psfhlpdst)))
+ {
+ ERR("no IID_ISFHelper for destination\n");
+
+ IShellFolder_Release(psfFrom);
+ IShellFolder_Release(psfTarget);
+ SHFree(pidl);
+ _ILFreeaPidl(apidl, lpcida->cidl);
+ ReleaseStgMedium(&medium);
+ IDataObject_Release(pda);
+
+ return E_FAIL;
+ }
+
+ if (FAILED(IShellFolder_QueryInterface(psfFrom, &IID_ISFHelper, (LPVOID*)&psfhlpsrc)))
+ {
+ ERR("no IID_ISFHelper for source\n");
+
+ ISFHelper_Release(psfhlpdst);
+ IShellFolder_Release(psfFrom);
+ IShellFolder_Release(psfTarget);
+ SHFree(pidl);
+ _ILFreeaPidl(apidl, lpcida->cidl);
+ ReleaseStgMedium(&medium);
+ IDataObject_Release(pda);
+ return E_FAIL;
+ }
+
+ /* FIXXME
+ * do we want to perform a copy or move ???
+ */
+ hr = ISFHelper_CopyItems(psfhlpdst, psfFrom, lpcida->cidl, (LPCITEMIDLIST*)apidl);
+
+ ISFHelper_Release(psfhlpdst);
+ ISFHelper_Release(psfhlpsrc);
+ IShellFolder_Release(psfFrom);
+ SHFree(pidl);
+ _ILFreeaPidl(apidl, lpcida->cidl);
+ ReleaseStgMedium(&medium);
+ IDataObject_Release(pda);
+ TRACE("paste end hr %x\n", hr);
+ break;
+ }
else
FIXME("LVN_KEYDOWN key=0x%08x\n",plvKeyDown->wVKey);
}
TRACE("(%p)->(shlview=%p set=%p shlbrs=%p rec=%p hwnd=%p) incomplete\n",This, lpPrevView,lpfs, psb, prcView, phWnd);
- TRACE("-- vmode=%x flags=%x left=%i top=%i right=%i bottom=%i\n",lpfs->ViewMode, lpfs->fFlags ,prcView->left,prcView->top, prcView->right, prcView->bottom);
+ if (lpfs != NULL)
+ TRACE("-- vmode=%x flags=%x\n", lpfs->ViewMode, lpfs->fFlags);
+ if (prcView != NULL)
+ TRACE("-- left=%i top=%i right=%i bottom=%i\n", prcView->left, prcView->top, prcView->right, prcView->bottom);
+
+ /* Validate the Shell Browser */
+ if (psb == NULL)
+ return E_UNEXPECTED;
/*set up the member variables*/
This->pShellBrowser = psb;
IDropTarget_Release(This->pCurDropTarget);
This->pCurDropTarget = NULL;
}
- IDataObject_Release(This->pCurDataObject);
- This->pCurDataObject = NULL;
+
+ if (This->pCurDataObject != NULL)
+ {
+ IDataObject_Release(This->pCurDataObject);
+ This->pCurDataObject = NULL;
+ }
+
This->iDragOverItem = 0;
return S_OK;
This->pCurDropTarget = NULL;
}
- IDataObject_Release(This->pCurDataObject);
- This->pCurDataObject = NULL;
+ if (This->pCurDataObject != NULL)
+ {
+ IDataObject_Release(This->pCurDataObject);
+ This->pCurDataObject = NULL;
+ }
+
This->iDragOverItem = 0;
return S_OK;