ReactOS 0.4.16-dev-1946-g52006dd
CDesktopFolder.cpp
Go to the documentation of this file.
1/*
2 * Virtual Desktop Folder
3 *
4 * Copyright 1997 Marcus Meissner
5 * Copyright 1998, 1999, 2002 Juergen Schmied
6 * Copyright 2009 Andrew Hill
7 *
8 * This library is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU Lesser General Public
10 * License as published by the Free Software Foundation; either
11 * version 2.1 of the License, or (at your option) any later version.
12 *
13 * This library is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * Lesser General Public License for more details.
17 *
18 * You should have received a copy of the GNU Lesser General Public
19 * License along with this library; if not, write to the Free Software
20 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
21 */
22
23#include <precomp.h>
24#include "CFSFolder.h" // Only for CFSFolder::*FSColumn* helpers!
25
27
29
31{
32 { CLSID_MyComputer, "sysdm.cpl", REGITEMORDER_MYCOMPUTER },
33 { CLSID_NetworkPlaces, "ncpa.cpl", REGITEMORDER_NETHOOD },
34 { CLSID_Internet, "inetcpl.cpl", REGITEMORDER_INTERNET },
35};
37{
40 CLSID_ShellDesktop,
41 L"",
42 L"Desktop",
43};
44
46{
47 return cidl == 0 || (cidl == 1 && apidl && _ILIsEmpty(apidl[0]));
48}
49
50static const CLSID* IsRegItem(PCUITEMID_CHILD pidl)
51{
52 if (pidl && pidl->mkid.cb == 2 + 2 + sizeof(CLSID) && pidl->mkid.abID[0] == PT_DESKTOP_REGITEM)
53 return (const CLSID*)(&pidl->mkid.abID[2]);
54 return NULL;
55}
56
58{
59 const CLSID *pClass = IsRegItem(pidl);
60 return pClass && *pClass == clsid;
61}
62
63static inline void MarkAsCommonItem(LPITEMIDLIST pidl)
64{
65 ASSERT(_ILGetFSType(pidl) & PT_FS);
66 ((PIDLDATA*)pidl->mkid.abID)->type |= PT_FS_COMMON_FLAG;
67}
68
71 HWND hwndOwner,
72 LPBC pbc,
73 LPOLESTR lpszDisplayName,
74 DWORD *pchEaten,
75 PIDLIST_RELATIVE *ppidl,
76 DWORD *pdwAttributes)
77{
78 LPWSTR pch;
79 INT cch, csidl;
81 PARSEDURLW ParsedURL = { sizeof(ParsedURL) };
82
83 ::ParseURLW(lpszDisplayName, &ParsedURL);
84
85 DWORD attrs = (pdwAttributes ? *pdwAttributes : 0) | SFGAO_STREAM;
86 if (ParsedURL.pszSuffix[0] == L':' && ParsedURL.pszSuffix[1] == L':') // It begins from "::"
87 {
88 CComPtr<IShellFolder> psfDesktop;
89 hr = SHGetDesktopFolder(&psfDesktop);
90 if (SUCCEEDED(hr))
91 {
92 CComPtr<IBindCtx> pBindCtx;
93 hr = ::CreateBindCtx(0, &pBindCtx);
94 if (SUCCEEDED(hr))
95 {
96 BIND_OPTS BindOps = { sizeof(BindOps) };
97 BindOps.grfMode = STGM_CREATE;
98 pBindCtx->SetBindOptions(&BindOps);
99 hr = psfDesktop->ParseDisplayName(hwndOwner, pBindCtx,
100 (LPWSTR)ParsedURL.pszSuffix,
101 pchEaten, ppidl, &attrs);
102 }
103 }
104 }
105 else
106 {
107 csidl = Shell_ParseSpecialFolder(ParsedURL.pszSuffix, &pch, &cch);
108 if (csidl == -1)
109 {
110 ERR("\n");
111 return hr;
112 }
113
114 CComHeapPtr<ITEMIDLIST> pidlLocation;
115 hr = SHGetFolderLocation(hwndOwner, (csidl | CSIDL_FLAG_CREATE), NULL, 0, &pidlLocation);
117 return hr;
118
119 if (pch && *pch)
120 {
121 CComPtr<IShellFolder> psfFolder;
122 hr = SHBindToObject(NULL, pidlLocation, IID_PPV_ARG(IShellFolder, &psfFolder));
123 if (SUCCEEDED(hr))
124 {
125 CComHeapPtr<ITEMIDLIST> pidlNew;
126 hr = psfFolder->ParseDisplayName(hwndOwner, pbc, pch, pchEaten, &pidlNew, &attrs);
127 if (SUCCEEDED(hr))
128 {
129 hr = SHILCombine(pidlLocation, pidlNew, ppidl);
130 if (pchEaten)
131 *pchEaten += cch;
132 }
133 }
134 }
135 else
136 {
137 if (attrs)
138 hr = SHGetNameAndFlagsW(pidlLocation, 0, NULL, 0, &attrs);
139
140 if (SUCCEEDED(hr))
141 {
142 if (pchEaten)
143 *pchEaten = cch;
144 *ppidl = pidlLocation.Detach();
145 }
146 }
147 }
148
149 // FIXME: SHWindowsPolicy
150 if (SUCCEEDED(hr) && (attrs & SFGAO_STREAM) &&
151 !BindCtx_ContainsObject(pbc, STR_PARSE_SHELL_PROTOCOL_TO_FILE_OBJECTS))
152 {
153 ILFree(*ppidl);
154 *ppidl = NULL;
156 }
157
158 if (pdwAttributes)
159 *pdwAttributes = attrs;
160
161 // FIXME: SHWindowsPolicy
164
165 return hr;
166}
167
170 HWND hwndOwner,
171 LPBC pbc,
172 LPOLESTR lpszDisplayName,
173 DWORD *pchEaten,
174 PIDLIST_RELATIVE *ppidl,
175 DWORD *pdwAttributes)
176{
177 FIXME("\n");
178 return E_NOTIMPL; // FIXME
179}
180
181/*
182CDesktopFolder should create two file system folders internally, one representing the
183user's desktop folder, and the other representing the common desktop folder. It should
184also create a CRegFolder to represent the virtual items that exist only in the registry.
185The CRegFolder is aggregated by the CDesktopFolder, and queries for the CLSID_IShellFolder,
186CLSID_IShellFolder2, or CLSID_IShellIconOverlay interfaces prefer the CRegFolder
187implementation.
188The CDesktopFolderEnum class should create two enumerators, one for each of the file
189system folders, and enumerate the contents of each folder. Since the CRegFolder
190implementation of IShellFolder::EnumObjects enumerates the virtual items, the
191CDesktopFolderEnum is only responsible for returning the physical items.
192CDesktopFolderViewCB is responsible for filtering hidden regitems.
193The enumerator always shows My Computer.
194*/
195
196/* Undocumented functions from shdocvw */
197extern "C" HRESULT WINAPI IEParseDisplayNameWithBCW(DWORD codepage, LPCWSTR lpszDisplayName, LPBC pbc, LPITEMIDLIST *ppidl);
198
200 public CEnumIDListBase
201{
202 private:
203// CComPtr fDesktopEnumerator;
204// CComPtr fCommonDesktopEnumerator;
205 public:
206
208 IEnumIDList *pDesktopEnumerator, IEnumIDList *pCommonDesktopEnumerator)
209 {
210 TRACE("(%p)->(flags=0x%08x)\n", this, dwFlags);
211
212 AppendItemsFromEnumerator(pRegEnumerator);
213
214 /* Enumerate the items in the two fs folders */
215 AppendItemsFromEnumerator(pDesktopEnumerator);
216 ENUMLIST *pCommon = this->mpLast;
217 AppendItemsFromEnumerator(pCommonDesktopEnumerator);
218 if (pCommon != this->mpLast) // Any common items added?
219 {
220 ENUMLIST fake;
221 if (!pCommon) // In the unlikely case that there are no RegItems nor user items
222 {
223 fake.pNext = this->mpFirst;
224 pCommon = &fake;
225 }
226 while ((pCommon = pCommon->pNext) != NULL)
227 MarkAsCommonItem(pCommon->pidl);
228 }
229 return S_OK;
230 }
231
233 COM_INTERFACE_ENTRY_IID(IID_IEnumIDList, IEnumIDList)
235};
236
237int SHELL_ConfirmMsgBox(HWND hWnd, LPWSTR lpszText, LPWSTR lpszCaption, HICON hIcon, BOOL bYesToAll);
238
240 SFGAO_HASSUBFOLDER | SFGAO_FILESYSTEM | SFGAO_FOLDER | SFGAO_FILESYSANCESTOR |
241 SFGAO_STORAGEANCESTOR | SFGAO_HASPROPSHEET | SFGAO_STORAGE;
243 SFGAO_CANRENAME | SFGAO_CANDELETE | SFGAO_HASPROPSHEET | SFGAO_DROPTARGET |
244 SFGAO_FILESYSANCESTOR | SFGAO_FOLDER | SFGAO_HASSUBFOLDER | SFGAO_CANLINK;
246 SFGAO_CANRENAME | SFGAO_CANDELETE | SFGAO_HASPROPSHEET | SFGAO_DROPTARGET |
247 SFGAO_FILESYSANCESTOR | SFGAO_FOLDER | SFGAO_HASSUBFOLDER | SFGAO_CANLINK;
248
250 sPathTarget(NULL),
251 pidlRoot(NULL)
252{
253}
254
256{
257}
258
260{
261 WCHAR szMyPath[MAX_PATH];
262 HRESULT hr;
263
264 /* Create the root pidl */
266 if (!pidlRoot)
267 return E_OUTOFMEMORY;
268
269 /* Create the inner fs folder */
271 &CLSID_ShellFSFolder,
275 return hr;
276
277 /* Create the inner shared fs folder. Dont fail on failure. */
279 &CLSID_ShellFSFolder,
283 return hr;
284
285 /* Create the inner reg folder */
286 REGFOLDERINITDATA RegInit = { static_cast<IShellFolder*>(this), &g_RegFolderInfo };
287 hr = CRegFolder_CreateInstance(&RegInit,
288 pidlRoot,
291 return hr;
292
293 /* Cache the path to the user desktop directory */
295 return E_UNEXPECTED;
296
297 sPathTarget = (LPWSTR)SHAlloc((wcslen(szMyPath) + 1) * sizeof(WCHAR));
298 if (!sPathTarget)
299 return E_OUTOFMEMORY;
300
301 wcscpy(sPathTarget, szMyPath);
302 return S_OK;
303}
304
306{
307 if (IsRegItem(pidl))
308 return m_regFolder->QueryInterface(IID_PPV_ARG(IShellFolder2, psf));
309#if DBG
310 if (_ILIsDesktop(pidl))
311 {
312 FIXME("Desktop is unexpected here!\n");
313 }
314 else if (_ILIsSpecialFolder(pidl))
315 {
316 FIXME("Unexpected PIDL type %#x\n", pidl->mkid.abID[0]);
317 }
318#endif
320 return pSF->QueryInterface(IID_PPV_ARG(IShellFolder2, psf));
321}
322
324 HWND hwndOwner,
325 LPBC pbc,
326 LPOLESTR lpszDisplayName,
327 DWORD *pchEaten,
328 PIDLIST_RELATIVE *ppidl,
329 DWORD *pdwAttributes)
330{
331 if (pchEaten)
332 *pchEaten = 0;
333
334 CComHeapPtr<ITEMIDLIST> pidlParent;
335 BOOL bPath = FALSE;
336 WCHAR wch = *lpszDisplayName;
337 if (((L'A' <= wch && wch <= L'Z') || (L'a' <= wch && wch <= L'z')) &&
338 (lpszDisplayName[1] == L':'))
339 {
340 // "C:..."
341 bPath = TRUE;
342 pidlParent.Attach(_ILCreateMyComputer());
343 }
344 else if (PathIsUNCW(lpszDisplayName)) // "\\\\..."
345 {
346 bPath = TRUE;
347 pidlParent.Attach(_ILCreateNetwork());
348 }
349
350 if (bPath)
351 {
352 if (!pidlParent)
353 return E_OUTOFMEMORY;
354
355 CComPtr<IShellFolder> pParentFolder;
356 SHBindToObject(NULL, pidlParent, IID_PPV_ARG(IShellFolder, &pParentFolder));
357
358 CComHeapPtr<ITEMIDLIST> pidlChild;
359 HRESULT hr = pParentFolder->ParseDisplayName(hwndOwner, pbc, lpszDisplayName,
360 pchEaten, &pidlChild, pdwAttributes);
361 if (FAILED(hr))
362 return hr;
363
364 *ppidl = ILCombine(pidlParent, pidlChild);
365 return (*ppidl ? S_OK : E_OUTOFMEMORY);
366 }
367
368 if (!UrlIsW(lpszDisplayName, URLIS_URL) || SHSkipJunctionBinding(pbc, NULL))
369 return E_INVALIDARG;
370
371 // Now lpszDisplayName is a URL
372 PARSEDURLW ParsedURL = { sizeof(ParsedURL) };
373 ::ParseURLW(lpszDisplayName, &ParsedURL);
374
375 switch (ParsedURL.nScheme)
376 {
377 case URL_SCHEME_FILE: // "file:..."
378 {
379 // Convert "file://..." to a normal path
381 DWORD cchPath = _countof(szPath);
382 HRESULT hr = PathCreateFromUrlW(lpszDisplayName, szPath, &cchPath, 0);
384 return hr;
385
386 CComPtr<IShellFolder> psfDesktop;
387 hr = SHGetDesktopFolder(&psfDesktop);
389 return hr;
390
391 // Parse by desktop folder
392 return psfDesktop->ParseDisplayName(hwndOwner, pbc, szPath, pchEaten, ppidl,
393 pdwAttributes);
394 }
395 case URL_SCHEME_HTTP: // "http:..."
396 case URL_SCHEME_HTTPS: // "https:..."
397 {
398 if (!BindCtx_ContainsObject(pbc, STR_PARSE_PREFER_FOLDER_BROWSING))
399 return E_INVALIDARG;
400
401 return HttpUrlParseDisplayName(hwndOwner,
402 pbc,
403 lpszDisplayName,
404 pchEaten,
405 ppidl,
406 pdwAttributes);
407 }
408 case URL_SCHEME_SHELL: // "shell:..."
409 {
410 return ShellUrlParseDisplayName(hwndOwner,
411 pbc,
412 lpszDisplayName,
413 pchEaten,
414 ppidl,
415 pdwAttributes);
416 }
419 {
420 WARN("We don't support 'ms-shell-rooted:' and 'ms-shell-idlist:' schemes\n");
421 break;
422 }
423 default:
424 {
425 TRACE("Scheme: %u\n", ParsedURL.nScheme);
426 break;
427 }
428 }
429
430 return E_INVALIDARG;
431}
432
433/**************************************************************************
434 * CDesktopFolder::ParseDisplayName
435 *
436 * NOTES
437 * "::{20D04FE0-3AEA-1069-A2D8-08002B30309D}" and "" binds
438 * to MyComputer
439 */
441 HWND hwndOwner,
442 LPBC pbc,
443 LPOLESTR lpszDisplayName,
444 DWORD *pchEaten,
445 PIDLIST_RELATIVE *ppidl,
446 DWORD *pdwAttributes)
447{
448 TRACE ("(%p)->(HWND=%p,%p,%p=%s,%p,pidl=%p,%p)\n",
449 this, hwndOwner, pbc, lpszDisplayName, debugstr_w(lpszDisplayName),
450 pchEaten, ppidl, pdwAttributes);
451
452 if (!ppidl)
453 return E_INVALIDARG;
454
455 *ppidl = NULL;
456
457 if (!lpszDisplayName)
458 return E_INVALIDARG;
459
460 if (!*lpszDisplayName)
461 {
462 *ppidl = _ILCreateMyComputer();
463 return (*ppidl ? S_OK : E_OUTOFMEMORY);
464 }
465
466 if (lpszDisplayName[0] == ':' && lpszDisplayName[1] == ':')
467 {
468 return m_regFolder->ParseDisplayName(hwndOwner, pbc, lpszDisplayName, pchEaten, ppidl,
469 pdwAttributes);
470 }
471
472 HRESULT hr = _ParseDisplayNameByParent(hwndOwner, pbc, lpszDisplayName, pchEaten, ppidl,
473 pdwAttributes);
474 if (SUCCEEDED(hr))
475 {
476 if (BindCtx_ContainsObject(pbc, STR_PARSE_TRANSLATE_ALIASES))
477 {
478 CComHeapPtr<ITEMIDLIST> pidlAlias;
479 if (SUCCEEDED(Shell_TranslateIDListAlias(*ppidl, NULL, &pidlAlias, 0xFFFF)))
480 {
481 ILFree(*ppidl);
482 *ppidl = pidlAlias.Detach();
483 }
484 }
485
486 TRACE ("(%p)->(-- ret=0x%08x)\n", this, hr);
487 return hr;
488 }
489
491 return hr;
492
493 if (BindCtx_ContainsObject(pbc, STR_DONT_PARSE_RELATIVE))
494 return E_INVALIDARG;
495
496 if (SHIsFileSysBindCtx(pbc, NULL) == S_OK)
497 return hr;
498
499 BIND_OPTS BindOps = { sizeof(BindOps) };
501 if (pbc && SUCCEEDED(pbc->GetBindOptions(&BindOps)) && (BindOps.grfMode & STGM_CREATE))
502 {
503 BindOps.grfMode &= ~STGM_CREATE;
504 bCreate = TRUE;
505 pbc->SetBindOptions(&BindOps);
506 }
507
509 {
510 hr = m_DesktopFSFolder->ParseDisplayName(hwndOwner,
511 pbc,
512 lpszDisplayName,
513 pchEaten,
514 ppidl,
515 pdwAttributes);
516 }
517
519 {
520 hr = m_SharedDesktopFSFolder->ParseDisplayName(hwndOwner,
521 pbc,
522 lpszDisplayName,
523 pchEaten,
524 ppidl,
525 pdwAttributes);
526 if (SUCCEEDED(hr))
527 MarkAsCommonItem(*ppidl);
528 }
529
531 {
532 BindOps.grfMode |= STGM_CREATE;
533 pbc->SetBindOptions(&BindOps);
534 hr = m_DesktopFSFolder->ParseDisplayName(hwndOwner,
535 pbc,
536 lpszDisplayName,
537 pchEaten,
538 ppidl,
539 pdwAttributes);
540 }
541
542 TRACE ("(%p)->(-- ret=0x%08x)\n", this, hr);
543
544 return hr;
545}
546
547/**************************************************************************
548 * CDesktopFolder::EnumObjects
549 */
550HRESULT WINAPI CDesktopFolder::EnumObjects(HWND hwndOwner, DWORD dwFlags, LPENUMIDLIST *ppEnumIDList)
551{
552 CComPtr<IEnumIDList> pRegEnumerator;
553 CComPtr<IEnumIDList> pDesktopEnumerator;
554 CComPtr<IEnumIDList> pCommonDesktopEnumerator;
555 HRESULT hr;
556
557 hr = m_regFolder->EnumObjects(hwndOwner, dwFlags, &pRegEnumerator);
558 if (FAILED(hr))
559 ERR("EnumObjects for reg folder failed\n");
560
561 hr = m_DesktopFSFolder->EnumObjects(hwndOwner, dwFlags, &pDesktopEnumerator);
562 if (FAILED(hr))
563 ERR("EnumObjects for desktop fs folder failed\n");
564
565 hr = m_SharedDesktopFSFolder->EnumObjects(hwndOwner, dwFlags, &pCommonDesktopEnumerator);
566 if (FAILED(hr))
567 ERR("EnumObjects for shared desktop fs folder failed\n");
568
569 return ShellObjectCreatorInit<CDesktopFolderEnum>(m_regFolder, dwFlags, pRegEnumerator, pDesktopEnumerator,
570 pCommonDesktopEnumerator, IID_PPV_ARG(IEnumIDList, ppEnumIDList));
571}
572
573/**************************************************************************
574 * CDesktopFolder::BindToObject
575 */
578 LPBC pbcReserved,
579 REFIID riid,
580 LPVOID *ppvOut)
581{
582 if (!pidl)
583 return E_INVALIDARG;
584
585 CComPtr<IShellFolder2> psf;
586 HRESULT hr = _GetSFFromPidl(pidl, &psf);
588 return hr;
589
590 return psf->BindToObject(pidl, pbcReserved, riid, ppvOut);
591}
592
593/**************************************************************************
594 * CDesktopFolder::BindToStorage
595 */
598 LPBC pbcReserved,
599 REFIID riid,
600 LPVOID *ppvOut)
601{
602 FIXME ("(%p)->(pidl=%p,%p,%s,%p) stub\n",
603 this, pidl, pbcReserved, shdebugstr_guid (&riid), ppvOut);
604
605 *ppvOut = NULL;
606 return E_NOTIMPL;
607}
608
609/**************************************************************************
610 * CDesktopFolder::CompareIDs
611 */
613{
614 bool bIsDesktopFolder1, bIsDesktopFolder2;
615
616 if (!pidl1 || !pidl2)
617 {
618 ERR("Got null pidl pointer (%Ix %p %p)!\n", lParam, pidl1, pidl2);
619 return E_INVALIDARG;
620 }
621
622 bIsDesktopFolder1 = _ILIsDesktop(pidl1);
623 bIsDesktopFolder2 = _ILIsDesktop(pidl2);
624 if (bIsDesktopFolder1 || bIsDesktopFolder2)
625 return MAKE_COMPARE_HRESULT(bIsDesktopFolder1 - bIsDesktopFolder2);
626
627 if (_ILIsSpecialFolder(pidl1) || _ILIsSpecialFolder(pidl2))
628 return m_regFolder->CompareIDs(lParam, pidl1, pidl2);
629
630 HRESULT ret = m_DesktopFSFolder->CompareIDs(lParam, pidl1, pidl2);
631 if (ret == 0 && ((lParam & SHCIDS_COLUMNMASK) == SHFSF_COL_NAME || (lParam & (SHCIDS_ALLFIELDS | SHCIDS_CANONICALONLY))))
633 return ret;
634}
635
636/**************************************************************************
637 * CDesktopFolder::CreateViewObject
638 */
640 HWND hwndOwner,
641 REFIID riid,
642 LPVOID *ppvOut)
643{
645
646 TRACE ("(%p)->(hwnd=%p,%s,%p)\n",
647 this, hwndOwner, shdebugstr_guid (&riid), ppvOut);
648
649 if (!ppvOut)
650 return hr;
651
652 *ppvOut = NULL;
653
654 if (IsEqualIID (riid, IID_IDropTarget))
655 {
656 hr = m_DesktopFSFolder->CreateViewObject(hwndOwner, riid, ppvOut);
657 }
658 else if (IsEqualIID (riid, IID_IContextMenu))
659 {
660 CRegKeyHandleArray keys;
661 AddClassKeyToArray(L"Directory\\Background", keys, keys);
662 DEFCONTEXTMENU dcm = { hwndOwner, this, pidlRoot, this, 0, NULL, NULL, keys, keys };
663 hr = SHCreateDefaultContextMenu(&dcm, riid, ppvOut);
664 }
665 else if (IsEqualIID (riid, IID_IShellView))
666 {
667 CComPtr<CDesktopFolderViewCB> sfviewcb;
668 if (SUCCEEDED(hr = ShellObjectCreator(sfviewcb)))
669 {
670 SFV_CREATE create = { sizeof(create), this, NULL, sfviewcb };
672 if (SUCCEEDED(hr))
673 sfviewcb->Initialize((IShellView*)*ppvOut);
674 }
675 }
676 TRACE ("-- (%p)->(interface=%p)\n", this, ppvOut);
677 return hr;
678}
679
680/**************************************************************************
681 * CDesktopFolder::GetAttributesOf
682 */
684 UINT cidl,
686 DWORD *rgfInOut)
687{
688 HRESULT hr = S_OK;
689
690 TRACE("(%p)->(cidl=%d apidl=%p mask=%p (0x%08x))\n",
691 this, cidl, apidl, rgfInOut, rgfInOut ? *rgfInOut : 0);
692
693 if (cidl && !apidl)
694 return E_INVALIDARG;
695
696 if (*rgfInOut == 0)
697 *rgfInOut = ~0;
698
699 if(cidl == 0)
700 *rgfInOut &= dwDesktopAttributes;
701 else
702 {
703 /* TODO: always add SFGAO_CANLINK */
704 for (UINT i = 0; i < cidl; ++i)
705 {
706 pdump(apidl[i]);
707 if (_ILIsDesktop(apidl[i]))
708 *rgfInOut &= dwDesktopAttributes;
709 else if (_ILIsMyComputer(apidl[i]))
710 *rgfInOut &= dwMyComputerAttributes;
711 else if (IsRegItem(apidl[i], CLSID_NetworkPlaces))
712 *rgfInOut &= dwMyNetPlacesAttributes;
713 else if (_ILIsFolderOrFile(apidl[i]) || _ILIsSpecialFolder(apidl[i]))
714 {
715 CComPtr<IShellFolder2> psf;
716 HRESULT hr = _GetSFFromPidl(apidl[i], &psf);
718 continue;
719
720 psf->GetAttributesOf(1, &apidl[i], rgfInOut);
721 }
722 else
723 ERR("Got an unknown pidl type!!!\n");
724 }
725 }
726 /* make sure SFGAO_VALIDATE is cleared, some apps depend on that */
727 *rgfInOut &= ~SFGAO_VALIDATE;
728
729 TRACE("-- result=0x%08x\n", *rgfInOut);
730
731 return hr;
732}
733
734/**************************************************************************
735 * CDesktopFolder::GetUIObjectOf
736 *
737 * PARAMETERS
738 * HWND hwndOwner, //[in ] Parent window for any output
739 * UINT cidl, //[in ] array size
740 * LPCITEMIDLIST* apidl, //[in ] simple pidl array
741 * REFIID riid, //[in ] Requested Interface
742 * UINT* prgfInOut, //[ ] reserved
743 * LPVOID* ppvObject) //[out] Resulting Interface
744 *
745 */
747 HWND hwndOwner,
748 UINT cidl,
750 REFIID riid,
751 UINT *prgfInOut,
752 LPVOID *ppvOut)
753{
754 LPVOID pObj = NULL;
756
757 TRACE ("(%p)->(%p,%u,apidl=%p,%s,%p,%p)\n",
758 this, hwndOwner, cidl, apidl, shdebugstr_guid (&riid), prgfInOut, ppvOut);
759
760 if (!ppvOut)
761 return hr;
762 *ppvOut = NULL;
763
764 BOOL self = IsSelf(cidl, apidl);
765 if (cidl == 1 && !_ILIsSpecialFolder(apidl[0]) && !self)
766 {
767 CComPtr<IShellFolder2> psf;
768 HRESULT hr = _GetSFFromPidl(apidl[0], &psf);
770 return hr;
771
772 return psf->GetUIObjectOf(hwndOwner, cidl, apidl, riid, prgfInOut, ppvOut);
773 }
774
775 if (IsEqualIID (riid, IID_IContextMenu))
776 {
777 // FIXME: m_regFolder vs AddFSClassKeysToArray is incorrect when the selection includes both regitems and FS items
778 if (!self && cidl > 0 && _ILIsSpecialFolder(apidl[0]))
779 {
780 hr = m_regFolder->GetUIObjectOf(hwndOwner, cidl, apidl, riid, prgfInOut, &pObj);
781 }
782 else
783 {
784 /* Do not use the context menu of the CFSFolder here. */
785 /* We need to pass a pointer of the CDesktopFolder so as the data object that the context menu gets is rooted to the desktop */
786 /* Otherwise operations like that involve items from both user and shared desktop will not work */
787 CRegKeyHandleArray keys;
788 if (self)
789 {
790 AddClsidKeyToArray(CLSID_ShellDesktop, keys, keys);
791 AddClassKeyToArray(L"Folder", keys, keys);
792 }
793 else if (cidl > 0)
794 {
795 AddFSClassKeysToArray(cidl, apidl, keys, keys);
796 }
797
798 DEFCONTEXTMENU dcm = { hwndOwner, this, pidlRoot, this, cidl, apidl, NULL, keys, keys };
799 hr = SHCreateDefaultContextMenu(&dcm, riid, &pObj);
800 }
801 }
802 else if (IsEqualIID (riid, IID_IDataObject) && (cidl >= 1))
803 {
804 hr = IDataObject_Constructor( hwndOwner, pidlRoot, apidl, cidl, TRUE, (IDataObject **)&pObj);
805 }
806 else if ((IsEqualIID (riid, IID_IExtractIconA) || IsEqualIID (riid, IID_IExtractIconW)) && (cidl == 1))
807 {
808 hr = m_regFolder->GetUIObjectOf(hwndOwner, cidl, apidl, riid, prgfInOut, &pObj);
809 }
810 else if (IsEqualIID (riid, IID_IDropTarget) && (cidl == 1))
811 {
812 CComPtr<IShellFolder> psfChild;
813 hr = this->BindToObject(apidl[0], NULL, IID_PPV_ARG(IShellFolder, &psfChild));
815 return hr;
816
817 return psfChild->CreateViewObject(NULL, riid, ppvOut);
818 }
819 else
821
822 if (SUCCEEDED(hr) && !pObj)
824
825 *ppvOut = pObj;
826 TRACE ("(%p)->hr=0x%08x\n", this, hr);
827 return hr;
828}
829
830/**************************************************************************
831 * CDesktopFolder::GetDisplayNameOf
832 *
833 * NOTES
834 * special case: pidl = null gives desktop-name back
835 */
837{
838 TRACE ("(%p)->(pidl=%p,0x%08x,%p)\n", this, pidl, dwFlags, strRet);
839 pdump (pidl);
840
841 if (!strRet)
842 return E_INVALIDARG;
843
844 if (!_ILIsPidlSimple (pidl))
845 {
846 return SHELL32_GetDisplayNameOfChild(this, pidl, dwFlags, strRet);
847 }
848 else if (_ILIsDesktop(pidl))
849 {
851 return SHSetStrRet(strRet, sPathTarget);
852 else
853 return m_regFolder->GetDisplayNameOf(pidl, dwFlags, strRet);
854 }
855
856 /* file system folder or file rooted at the desktop */
857 CComPtr<IShellFolder2> psf;
858 HRESULT hr = _GetSFFromPidl(pidl, &psf);
860 return hr;
861
862 return psf->GetDisplayNameOf(pidl, dwFlags, strRet);
863}
864
865/**************************************************************************
866 * CDesktopFolder::SetNameOf
867 * Changes the name of a file object or subfolder, possibly changing its item
868 * identifier in the process.
869 *
870 * PARAMETERS
871 * HWND hwndOwner, //[in ] Owner window for output
872 * LPCITEMIDLIST pidl, //[in ] simple pidl of item to change
873 * LPCOLESTR lpszName, //[in ] the items new display name
874 * DWORD dwFlags, //[in ] SHGNO formatting flags
875 * LPITEMIDLIST* ppidlOut) //[out] simple pidl returned
876 */
878 HWND hwndOwner,
879 PCUITEMID_CHILD pidl, /* simple pidl */
880 LPCOLESTR lpName,
882 PITEMID_CHILD *pPidlOut)
883{
884 CComPtr<IShellFolder2> psf;
885 HRESULT hr = _GetSFFromPidl(pidl, &psf);
887 return hr;
888
889 return psf->SetNameOf(hwndOwner, pidl, lpName, dwFlags, pPidlOut);
890}
891
893{
894 FIXME ("(%p)\n", this);
895 return E_NOTIMPL;
896}
897
899{
900 FIXME ("(%p)\n", this);
901 return E_NOTIMPL;
902}
903
905{
906 TRACE ("(%p)\n", this);
907
908 if (pSort)
909 *pSort = 0;
910 if (pDisplay)
911 *pDisplay = 0;
912
913 return S_OK;
914}
915
917{
918 HRESULT hr;
919 TRACE ("(%p)\n", this);
920
921 if (!pcsFlags)
922 return E_INVALIDARG;
923
924 hr = CFSFolder::GetDefaultFSColumnState(iColumn, *pcsFlags);
925 /*
926 // CDesktopFolder may override the flags if desired (future)
927 switch(iColumn)
928 {
929 case SHFSF_COL_FATTS:
930 *pcsFlags &= ~SHCOLSTATE_ONBYDEFAULT;
931 break;
932 }
933 */
934 return hr;
935}
936
938 const SHCOLUMNID *pscid, VARIANT *pv)
939{
940 HRESULT hr;
941 CComPtr<IShellFolder2> psf;
942 if (FAILED_UNEXPECTEDLY(hr = _GetSFFromPidl(pidl, &psf)))
943 return hr;
944 return psf->GetDetailsEx(pidl, pscid, pv);
945}
946
947/*************************************************************************
948 * Column info functions.
949 * CFSFolder.h provides defaults for us.
950 */
952{
953 /* CDesktopFolder may override the flags and/or name if desired */
954 return CFSFolder::GetFSColumnDetails(iColumn, sd);
955}
956
958 PCUITEMID_CHILD pidl,
959 UINT iColumn,
960 SHELLDETAILS *psd)
961{
962 if (!psd)
963 return E_INVALIDARG;
964
965 if (!pidl)
966 {
967 return GetColumnDetails(iColumn, *psd);
968 }
969
970 CComPtr<IShellFolder2> psf;
971 HRESULT hr = _GetSFFromPidl(pidl, &psf);
973 return hr;
974
975 hr = psf->GetDetailsOf(pidl, iColumn, psd);
977 return hr;
978
979 return hr;
980}
981
983{
984 // Note: All these folders use the same SHFSF_COL mapping (m_regFolder only handles a subset).
986 return m_DesktopFSFolder->MapColumnToSCID(column, pscid);
988 return m_SharedDesktopFSFolder->MapColumnToSCID(column, pscid);
989 if (m_regFolder)
990 return m_regFolder->MapColumnToSCID(column, pscid);
991 return E_FAIL;
992}
993
995{
996 TRACE ("(%p)\n", this);
997
998 if (!lpClassId)
999 return E_POINTER;
1000
1001 *lpClassId = CLSID_ShellDesktop;
1002
1003 return S_OK;
1004}
1005
1007{
1008 TRACE ("(%p)->(%p)\n", this, pidl);
1009
1010 if (!pidl)
1011 return S_OK;
1012
1013 return E_INVALIDARG;
1014}
1015
1017{
1018 TRACE ("(%p)->(%p)\n", this, pidl);
1019
1020 if (!pidl)
1021 return E_INVALIDARG; /* xp doesn't have this check and crashes on NULL */
1022 *pidl = ILClone (pidlRoot);
1023 return S_OK;
1024}
1025
1027{
1028 enum { IDC_PROPERTIES };
1029 if (uMsg == DFM_INVOKECOMMAND && wParam == (pdtobj ? DFM_CMD_PROPERTIES : IDC_PROPERTIES))
1030 {
1031 if (pdtobj)
1032 {
1034 BOOL bIsSelf = _ILIsDesktop(pidl); // Context menu on Desktop item in the shell tree?
1035 ILFree(pidl);
1036 if (!bIsSelf)
1037 return SHELL32_ShowPropertiesDialog(pdtobj); // File selection
1038 }
1039 return SHELL_ExecuteControlPanelCPL(hwndOwner, L"desk.cpl") ? S_OK : E_FAIL; // Background
1040 }
1041 else if (uMsg == DFM_MERGECONTEXTMENU && !pdtobj) // Add Properties item when called for directory background
1042 {
1043 QCMINFO *pqcminfo = (QCMINFO *)lParam;
1044 HMENU hpopup = CreatePopupMenu();
1046 pqcminfo->idCmdFirst = Shell_MergeMenus(pqcminfo->hmenu, hpopup, pqcminfo->indexMenu, pqcminfo->idCmdFirst, pqcminfo->idCmdLast, MM_ADDSEPARATOR);
1047 DestroyMenu(hpopup);
1048 return S_OK;
1049 }
1050 return SHELL32_DefaultContextMenuCallBack(psf, pdtobj, uMsg);
1051}
1052
1053/*************************************************************************
1054 * CDesktopFolderViewCB
1055 */
1056
1058{
1060 return SUCCEEDED(psv->GetCurrentInfo(&settings)) && (settings.fFlags & FWF_DESKTOP);
1061}
1062
1064{
1065 enum { Uninitialized = 0, NotHosted, IsHosted };
1066 C_ASSERT(Uninitialized == 0);
1067 if (m_IsProgmanHosted == Uninitialized)
1069 return m_IsProgmanHosted == IsHosted;
1070}
1071
1073{
1074 const CLSID* pClsid;
1075 if (IsProgmanHostedBrowser() && (pClsid = IsRegItem(pidlItem)) != NULL)
1076 {
1077 const BOOL NewStart = SHELL_GetSetting(SSF_STARTPANELON, fStartPanelOn);
1078 LPCWSTR SubKey = NewStart ? L"HideDesktopIcons\\NewStartPanel" : L"HideDesktopIcons\\ClassicStartMenu";
1079 return SHELL32_IsShellFolderNamespaceItemHidden(SubKey, *pClsid) ? S_FALSE : S_OK;
1080 }
1081 return S_OK;
1082}
1083
1085{
1086 switch (uMsg)
1087 {
1088 #if ROSPOLICY_DESKTOPFOLDER_DEFLARGEICONS
1089 case SFVM_DEFVIEWMODE: // CDesktopBrowser always forces FVM_ICON.
1090 *((FOLDERVIEWMODE*)lParam) = FVM_ICON; // This sets the default for generic browsers.
1091 return S_OK;
1092 #endif
1093 case SFVM_VIEWRELEASE:
1095 return S_OK;
1096 case SFVM_GETCOMMANDDIR:
1097 {
1101 break;
1102 }
1103 }
1104 return E_NOTIMPL;
1105}
1106
1107/*************************************************************************
1108 * SHGetDesktopFolder [SHELL32.@]
1109 */
1111{
1112 HRESULT hres = S_OK;
1113 TRACE("\n");
1114
1115 if(!psf) return E_INVALIDARG;
1116 *psf = NULL;
1117 hres = CDesktopFolder::_CreatorClass::CreateInstance(NULL, IID_PPV_ARG(IShellFolder, psf));
1118
1119 TRACE("-- %p->(%p)\n",psf, *psf);
1120 return hres;
1121}
BOOL _ILIsDesktop(LPCITEMIDLIST pidl)
Definition: CBandSite.h:24
static const REGFOLDERINFO g_RegFolderInfo
static const CLSID * IsRegItem(LPCITEMIDLIST pidl)
HRESULT WINAPI SHCreateShellFolderView(const SFV_CREATE *pcsfv, IShellView **ppsv)
Definition: CDefView.cpp:4826
HRESULT WINAPI SHCreateDefaultContextMenu(const DEFCONTEXTMENU *pdcm, REFIID riid, void **ppv)
HRESULT WINAPI SHGetDesktopFolder(IShellFolder **psf)
HRESULT WINAPI IEParseDisplayNameWithBCW(DWORD codepage, LPCWSTR lpszDisplayName, LPBC pbc, LPITEMIDLIST *ppidl)
Definition: shdocvw_main.c:505
static const DWORD dwMyComputerAttributes
static const CLSID * IsRegItem(PCUITEMID_CHILD pidl)
BOOL SHELL32_IsShellFolderNamespaceItemHidden(LPCWSTR SubKey, REFCLSID Clsid)
static const REGFOLDERINFO g_RegFolderInfo
static BOOL IsSelf(UINT cidl, PCUITEMID_CHILD_ARRAY apidl)
static const DWORD dwDesktopAttributes
static DWORD dwMyNetPlacesAttributes
static void MarkAsCommonItem(LPITEMIDLIST pidl)
int SHELL_ConfirmMsgBox(HWND hWnd, LPWSTR lpszText, LPWSTR lpszCaption, HICON hIcon, BOOL bYesToAll)
Definition: shlfileop.cpp:247
static const REQUIREDREGITEM g_RequiredItems[]
static HRESULT SHELL32_CoCreateInitSF(LPCITEMIDLIST pidlRoot, PERSIST_FOLDER_TARGET_INFO *ppfti, LPCITEMIDLIST pidlChild, const GUID *clsid, REFIID riid, LPVOID *ppvOut)
Definition: CFindFolder.cpp:39
#define SHCIDS_ALLFIELDS
Definition: CFontExt.cpp:14
HRESULT IDataObject_Constructor(HWND hwndOwner, PCIDLIST_ABSOLUTE pMyPidl, PCUIDLIST_RELATIVE_ARRAY apidl, UINT cidl, BOOL bExtendedObject, IDataObject **dataObject)
HRESULT CRegFolder_CreateInstance(PREGFOLDERINITDATA pInit, LPCITEMIDLIST pidlRoot, REFIID riid, void **ppv)
Definition: CRegFolder.cpp:995
#define SFVM_GETCOMMANDDIR
#define SFVM_VIEWRELEASE
struct mke2fs_defaults settings[]
HWND hWnd
Definition: settings.c:17
#define WINE_DEFAULT_DEBUG_CHANNEL(t)
Definition: precomp.h:23
void shell(int argc, const char *argv[])
Definition: cmds.c:1231
#define FIXME(fmt,...)
Definition: precomp.h:53
#define WARN(fmt,...)
Definition: precomp.h:61
#define ERR(fmt,...)
Definition: precomp.h:57
#define IDS_PROPERTIES
Definition: resource.h:108
#define STDMETHODIMP
Definition: basetyps.h:43
HRESULT WINAPI Initialize(IShellFolder *pRegFolder, SHCONTF dwFlags, IEnumIDList *pRegEnumerator, IEnumIDList *pDesktopEnumerator, IEnumIDList *pCommonDesktopEnumerator)
STDMETHOD() MessageSFVCB(UINT uMsg, WPARAM wParam, LPARAM lParam) override
IShellView * m_pShellView
STDMETHOD() ShouldShow(IShellFolder *psf, PCIDLIST_ABSOLUTE pidlFolder, PCUITEMID_CHILD pidlItem) override
STDMETHOD() GetAttributesOf(UINT cidl, PCUITEMID_CHILD_ARRAY apidl, DWORD *rgfInOut) override
CComPtr< IShellFolder2 > m_SharedDesktopFSFolder
STDMETHOD() BindToObject(PCUIDLIST_RELATIVE pidl, LPBC pbcReserved, REFIID riid, LPVOID *ppvOut) override
HRESULT WINAPI FinalConstruct()
STDMETHOD() Initialize(PCIDLIST_ABSOLUTE pidl) override
STDMETHOD() GetDisplayNameOf(PCUITEMID_CHILD pidl, DWORD dwFlags, LPSTRRET strRet) override
STDMETHOD() CompareIDs(LPARAM lParam, PCUIDLIST_RELATIVE pidl1, PCUIDLIST_RELATIVE pidl2) override
static BOOL IsCommonItem(LPCITEMIDLIST pidl)
STDMETHOD() GetDefaultColumnState(UINT iColumn, DWORD *pcsFlags) override
STDMETHOD() SetNameOf(HWND hwndOwner, PCUITEMID_CHILD pidl, LPCOLESTR lpName, DWORD dwFlags, PITEMID_CHILD *pPidlOut) override
STDMETHOD() GetDefaultSearchGUID(GUID *pguid) override
STDMETHOD() CreateViewObject(HWND hwndOwner, REFIID riid, LPVOID *ppvOut) override
STDMETHOD() MapColumnToSCID(UINT column, SHCOLUMNID *pscid) override
STDMETHOD() GetDetailsEx(PCUITEMID_CHILD pidl, const SHCOLUMNID *pscid, VARIANT *pv) override
STDMETHOD() BindToStorage(PCUIDLIST_RELATIVE pidl, LPBC pbcReserved, REFIID riid, LPVOID *ppvOut) override
STDMETHOD() CallBack(IShellFolder *psf, HWND hwndOwner, IDataObject *pdtobj, UINT uMsg, WPARAM wParam, LPARAM lParam) override
HRESULT _GetSFFromPidl(LPCITEMIDLIST pidl, IShellFolder2 **psf)
CComPtr< IShellFolder2 > m_DesktopFSFolder
STDMETHODIMP HttpUrlParseDisplayName(HWND hwndOwner, LPBC pbc, LPOLESTR lpszDisplayName, DWORD *pchEaten, PIDLIST_RELATIVE *ppidl, DWORD *pdwAttributes)
STDMETHOD() ParseDisplayName(HWND hwndOwner, LPBC pbc, LPOLESTR lpszDisplayName, DWORD *pchEaten, PIDLIST_RELATIVE *ppidl, DWORD *pdwAttributes) override
STDMETHOD() GetDefaultColumn(DWORD dwRes, ULONG *pSort, ULONG *pDisplay) override
STDMETHOD() GetCurFolder(PIDLIST_ABSOLUTE *pidl) override
STDMETHOD() GetClassID(CLSID *lpClassId) override
STDMETHOD() EnumObjects(HWND hwndOwner, DWORD dwFlags, LPENUMIDLIST *ppEnumIDList) override
STDMETHOD() EnumSearches(IEnumExtraSearch **ppenum) override
LPITEMIDLIST pidlRoot
STDMETHOD() GetDetailsOf(PCUITEMID_CHILD pidl, UINT iColumn, SHELLDETAILS *psd) override
CComPtr< IShellFolder2 > m_regFolder
STDMETHODIMP ShellUrlParseDisplayName(HWND hwndOwner, LPBC pbc, LPOLESTR lpszDisplayName, DWORD *pchEaten, PIDLIST_RELATIVE *ppidl, DWORD *pdwAttributes)
STDMETHOD() GetUIObjectOf(HWND hwndOwner, UINT cidl, PCUITEMID_CHILD_ARRAY apidl, REFIID riid, UINT *prgfInOut, LPVOID *ppvOut) override
HRESULT _ParseDisplayNameByParent(HWND hwndOwner, LPBC pbc, LPOLESTR pszPath, DWORD *pchEaten, PIDLIST_RELATIVE *ppidl, DWORD *pdwAttributes)
static HRESULT GetColumnDetails(UINT iColumn, SHELLDETAILS &sd)
ENUMLIST * mpLast
ENUMLIST * mpFirst
HRESULT AppendItemsFromEnumerator(IEnumIDList *pEnum)
static HRESULT GetDefaultFSColumnState(UINT iColumn, SHCOLSTATEF &csFlags)
Definition: CFSFolder.cpp:605
static HRESULT GetFSColumnDetails(UINT iColumn, SHELLDETAILS &sd)
Definition: CFSFolder.cpp:595
WPARAM wParam
Definition: combotst.c:138
LPARAM lParam
Definition: combotst.c:139
wcscpy
#define E_OUTOFMEMORY
Definition: ddrawi.h:100
#define E_INVALIDARG
Definition: ddrawi.h:101
#define E_NOTIMPL
Definition: ddrawi.h:99
#define E_FAIL
Definition: ddrawi.h:102
void pdump(LPCITEMIDLIST pidl)
Definition: debughlp.cpp:322
const char * shdebugstr_guid(const struct _GUID *id)
Definition: debughlp.cpp:438
#define NULL
Definition: types.h:112
#define TRUE
Definition: types.h:120
#define FALSE
Definition: types.h:117
#define IDC_PROPERTIES
Definition: resource.h:32
#define SHCIDS_CANONICALONLY
Definition: shobjidl.idl:226
#define DFM_MERGECONTEXTMENU
Definition: precomp.h:44
#define DFM_INVOKECOMMAND
Definition: precomp.h:45
BOOL WINAPI _ILIsPidlSimple(LPCITEMIDLIST pidl)
#define MAX_PATH
Definition: compat.h:34
const UINT * keys
Definition: locale.c:416
HRESULT WINAPI ParseURLW(const WCHAR *url, PARSEDURLW *result)
Definition: path.c:2831
BOOL WINAPI PathIsUNCW(const WCHAR *path)
Definition: path.c:1013
HRESULT WINAPI PathCreateFromUrlW(const WCHAR *url, WCHAR *path, DWORD *pcchPath, DWORD dwReserved)
Definition: path.c:3073
BOOL WINAPI UrlIsW(const WCHAR *url, URLIS Urlis)
Definition: path.c:4812
#define SHELL_ExecuteControlPanelCPL(hwnd, cpl)
Definition: precomp.h:214
EXTERN_C INT Shell_ParseSpecialFolder(_In_ LPCWSTR pszStart, _Out_ LPWSTR *ppch, _Out_ INT *pcch)
Definition: shellpath.c:1986
HRESULT SHGetNameAndFlagsW(_In_ LPCITEMIDLIST pidl, _In_ DWORD dwFlags, _Out_opt_ LPWSTR pszText, _In_ UINT cchBuf, _Inout_opt_ DWORD *pdwAttributes)
Definition: utils.cpp:503
BOOL BindCtx_ContainsObject(_In_ IBindCtx *pBindCtx, _In_ LPCWSTR pszName)
Definition: utils.cpp:270
HRESULT SHIsFileSysBindCtx(_In_ IBindCtx *pBindCtx, _Out_opt_ WIN32_FIND_DATAW *pFindData)
Definition: utils.cpp:303
BOOL Shell_FailForceReturn(_In_ HRESULT hr)
Definition: utils.cpp:320
EXTERN_C HRESULT SHBindToObject(_In_opt_ IShellFolder *psf, _In_ LPCITEMIDLIST pidl, _In_ REFIID riid, _Out_ void **ppvObj)
Definition: utils.cpp:370
HRESULT SHELL32_DefaultContextMenuCallBack(IShellFolder *psf, IDataObject *pdo, UINT msg)
Definition: shlfolder.cpp:624
HRESULT Shell_TranslateIDListAlias(_In_ LPCITEMIDLIST pidl, _In_ HANDLE hToken, _Out_ LPITEMIDLIST *ppidlAlias, _In_ DWORD dwFlags)
Definition: utils.cpp:261
PIDLIST_ABSOLUTE SHELL_DataObject_ILCloneFullItem(_In_ IDataObject *pDO, _In_ UINT Index)
BOOL SHSkipJunctionBinding(_In_ IBindCtx *pbc, _In_ CLSID *pclsid)
Definition: utils.cpp:291
HRESULT SHELL32_ShowPropertiesDialog(IDataObject *pdtobj)
Definition: shlfolder.cpp:616
LPVOID WINAPI SHAlloc(SIZE_T len)
Definition: shellole.c:348
HRESULT WINAPI SHGetFolderLocation(HWND hwndOwner, int nFolder, HANDLE hToken, DWORD dwReserved, LPITEMIDLIST *ppidl)
Definition: shellpath.c:3277
BOOL WINAPI SHGetSpecialFolderPathW(HWND hwndOwner, LPWSTR szPath, int nFolder, BOOL bCreate)
Definition: shellpath.c:3219
#define FAILED_UNEXPECTEDLY
Definition: utils.cpp:30
return ret
Definition: mutex.c:146
#define L(x)
Definition: resources.c:13
unsigned int BOOL
Definition: ntddk_ex.h:94
unsigned long DWORD
Definition: ntddk_ex.h:95
GLenum GLuint GLenum GLsizei const GLchar * buf
Definition: glext.h:7751
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
Definition: glfuncs.h:248
_CRTIMP size_t __cdecl wcslen(_In_z_ const wchar_t *_Str)
REFIID riid
Definition: atlbase.h:39
HRESULT GetCurrentInfo([out] LPFOLDERSETTINGS lpfs)
HRESULT QueryInterface([in] REFIID riid, [out, iid_is(riid)] void **ppvObject)
#define S_OK
Definition: intsafe.h:52
#define SUCCEEDED(hr)
Definition: intsafe.h:50
#define FAILED(hr)
Definition: intsafe.h:51
#define C_ASSERT(e)
Definition: intsafe.h:73
#define debugstr_w
Definition: kernel32.h:32
#define BEGIN_COM_MAP(x)
Definition: atlcom.h:581
#define COM_INTERFACE_ENTRY_IID(iid, x)
Definition: atlcom.h:601
#define END_COM_MAP()
Definition: atlcom.h:592
#define PT_FS
Definition: lnktool.cpp:40
#define PT_DESKTOP_REGITEM
Definition: lnktool.cpp:38
LONG_PTR LPARAM
Definition: minwindef.h:175
UINT_PTR WPARAM
Definition: minwindef.h:174
#define pch(ap)
Definition: match.c:418
#define ASSERT(a)
Definition: mode.c:44
#define ERROR_FILE_NOT_FOUND
Definition: disk.h:79
LPCWSTR szPath
Definition: env.c:37
static HICON
Definition: imagelist.c:80
HRESULT hres
Definition: protocol.c:465
static const struct access_res create[16]
Definition: package.c:7505
static const WCHAR sd[]
Definition: suminfo.c:286
static LPOLESTR
Definition: stg_prop.c:27
static const CLSID *static CLSID *static const GUID VARIANT VARIANT *static IServiceProvider DWORD *static HMENU
Definition: ordinal.c:60
static SHCONTF
Definition: ordinal.c:61
HICON hIcon
Definition: msconfig.c:44
const CLSID * clsid
Definition: msctf.cpp:50
unsigned int UINT
Definition: ndis.h:50
_In_ LPWSTR _In_ DWORD _In_ DWORD _In_ DWORD dwFlags
Definition: netsh.h:141
#define STGM_CREATE
Definition: objbase.h:926
interface IBindCtx * LPBC
Definition: objfwd.h:18
HRESULT WINAPI CreateBindCtx(DWORD reserved, LPBC *ppbc)
Definition: bindctx.c:556
const GUID IID_IDataObject
LPITEMIDLIST _ILCreateMyComputer(void)
Definition: pidl.c:1799
LPITEMIDLIST WINAPI ILClone(LPCITEMIDLIST pidl)
Definition: pidl.c:238
void WINAPI ILFree(LPITEMIDLIST pidl)
Definition: pidl.c:1045
LPITEMIDLIST WINAPI ILCombine(LPCITEMIDLIST pidl1, LPCITEMIDLIST pidl2)
Definition: pidl.c:817
LPITEMIDLIST _ILCreateDesktop(void)
Definition: pidl.c:1788
BOOL _ILIsSpecialFolder(LPCITEMIDLIST pidl)
Definition: pidl.c:2120
LPITEMIDLIST _ILCreateNetwork(void)
Definition: pidl.c:1862
BOOL _ILIsMyComputer(LPCITEMIDLIST pidl)
Definition: pidl.c:2098
static BYTE _ILGetFSType(LPCITEMIDLIST pidl)
Definition: pidl.h:149
static BOOL _ILIsEmpty(LPCITEMIDLIST pidl)
Definition: pidl.h:282
#define IsEqualIID(riid1, riid2)
Definition: guiddef.h:95
#define REFIID
Definition: guiddef.h:118
#define REFCLSID
Definition: guiddef.h:117
@ URLIS_URL
Definition: shlwapi.h:597
@ URL_SCHEME_MSSHELLROOTED
Definition: shlwapi.h:564
@ URL_SCHEME_HTTPS
Definition: shlwapi.h:555
@ URL_SCHEME_MSSHELLIDLIST
Definition: shlwapi.h:565
@ URL_SCHEME_HTTP
Definition: shlwapi.h:546
@ URL_SCHEME_FILE
Definition: shlwapi.h:553
@ URL_SCHEME_SHELL
Definition: shlwapi.h:556
_In_ UINT _In_ UINT cch
Definition: shellapi.h:432
#define CSIDL_FLAG_CREATE
#define MAKE_COMPARE_HRESULT(x)
Definition: shellutils.h:678
#define SHELL_GetSetting(pss, ssf, field)
Definition: shellutils.h:902
#define IS_SHGDN_DESKTOPABSOLUTEPARSING(flags)
Definition: shfldr.h:79
HRESULT SHELL32_GetDisplayNameOfChild(IShellFolder2 *psf, LPCITEMIDLIST pidl, DWORD dwFlags, LPSTRRET strRet)
Definition: shlfolder.cpp:331
#define SHFSF_COL_NAME
Definition: shfldr.h:44
void AddFSClassKeysToArray(UINT cidl, PCUITEMID_CHILD_ARRAY apidl, HKEY *array, UINT *cKeys)
Definition: shlfolder.cpp:430
LSTATUS AddClsidKeyToArray(REFCLSID clsid, HKEY *array, UINT *cKeys)
Definition: shlfolder.cpp:423
LSTATUS AddClassKeyToArray(const WCHAR *szClass, HKEY *array, UINT *cKeys)
Definition: shlfolder.cpp:408
void WINAPI _InsertMenuItemW(HMENU hmenu, UINT indexMenu, BOOL fByPosition, UINT wID, UINT fType, LPCWSTR dwTypeData, UINT fState)
HRESULT hr
Definition: shlfolder.c:183
UINT WINAPI Shell_MergeMenus(HMENU hmDst, HMENU hmSrc, UINT uInsert, UINT uIDAdjust, UINT uIDAdjustMax, ULONG uFlags)
Definition: shlmenu.c:856
#define CSIDL_COMMON_DESKTOPDIRECTORY
Definition: shlobj.h:2203
_In_ int _In_ BOOL bCreate
Definition: shlobj.h:1525
#define CSIDL_DESKTOPDIRECTORY
Definition: shlobj.h:2194
#define SFVM_DEFVIEWMODE
Definition: shlobj.h:1323
#define SSF_STARTPANELON
Definition: shlobj.h:1630
#define MM_ADDSEPARATOR
Definition: shlobj.h:2534
#define DFM_CMD_PROPERTIES
Definition: shlobj.h:2618
@ FWF_DESKTOP
Definition: shobjidl.idl:647
FOLDERVIEWMODE
Definition: shobjidl.idl:677
@ FVM_ICON
Definition: shobjidl.idl:679
ITEMIDLIST UNALIGNED * LPITEMIDLIST
Definition: shtypes.idl:41
const PCUITEMID_CHILD * PCUITEMID_CHILD_ARRAY
Definition: shtypes.idl:71
const ITEMID_CHILD UNALIGNED * PCUITEMID_CHILD
Definition: shtypes.idl:70
const ITEMIDLIST_RELATIVE UNALIGNED * PCUIDLIST_RELATIVE
Definition: shtypes.idl:57
const ITEMIDLIST UNALIGNED * LPCITEMIDLIST
Definition: shtypes.idl:42
DWORD SHCOLSTATEF
Definition: shtypes.idl:142
#define _countof(array)
Definition: sndvol32.h:70
#define TRACE(s)
Definition: solgame.cpp:4
STRSAFEAPI StringCchCopyW(STRSAFE_LPWSTR pszDest, size_t cchDest, STRSAFE_LPCWSTR pszSrc)
Definition: strsafe.h:149
ENUMLIST * pNext
LPITEMIDLIST pidl
HMENU hmenu
Definition: shlobj.h:1395
UINT idCmdLast
Definition: shlobj.h:1398
UINT idCmdFirst
Definition: shlobj.h:1397
UINT indexMenu
Definition: shlobj.h:1396
LPCWSTR pszSuffix
Definition: shlwapi.h:619
UINT nScheme
Definition: shlwapi.h:621
uint16_t * PWSTR
Definition: typedefs.h:56
int32_t INT
Definition: typedefs.h:58
uint32_t ULONG
Definition: typedefs.h:59
int codepage
Definition: win_iconv.c:156
_In_ LPCSTR lpName
Definition: winbase.h:2543
#define WINAPI
Definition: msvc.h:6
#define S_FALSE
Definition: winerror.h:3451
static HRESULT HRESULT_FROM_WIN32(unsigned int x)
Definition: winerror.h:210
#define E_NOINTERFACE
Definition: winerror.h:3479
#define ERROR_PATH_NOT_FOUND
Definition: winerror.h:228
#define E_UNEXPECTED
Definition: winerror.h:3528
#define E_POINTER
Definition: winerror.h:3480
HMENU WINAPI CreatePopupMenu(void)
Definition: menu.c:838
#define MFS_ENABLED
Definition: winuser.h:761
BOOL WINAPI DestroyMenu(_In_ HMENU)
#define MFT_STRING
Definition: winuser.h:757
#define MAKEINTRESOURCEW(i)
Definition: winuser.h:582
#define IID_PPV_ARG(Itype, ppType)
const WCHAR * LPCWSTR
Definition: xmlstorage.h:185
__wchar_t WCHAR
Definition: xmlstorage.h:180
WCHAR * LPWSTR
Definition: xmlstorage.h:184