2 * The parameters of many functions changes between different OS versions
3 * (NT uses Unicode strings, 95 uses ASCII strings)
5 * Copyright 1997 Marcus Meissner
12 #include "debugtools.h"
19 #include "shell32_main.h"
20 #include "wine/undocshell.h"
22 DEFAULT_DEBUG_CHANNEL(shell);
24 /*************************************************************************
25 * ParseFieldA [internal]
27 * copys a field from a ',' delimited string
29 * first field is nField = 1
31 DWORD WINAPI ParseFieldA(
37 WARN("('%s',0x%08lx,%p,%ld) semi-stub.\n",src,nField,dst,len);
39 if (!src || !src[0] || !dst || !len)
42 /* skip n fields delimited by ',' */
45 if (*src=='\0') return FALSE;
46 if (*(src++)==',') nField--;
49 /* copy part till the next ',' to dst */
50 while ( *src!='\0' && *src!=',' && (len--)>0 ) *(dst++)=*(src++);
52 /* finalize the string */
58 /*************************************************************************
59 * ParseFieldW [internal]
61 * copys a field from a ',' delimited string
63 * first field is nField = 1
65 DWORD WINAPI ParseFieldW(LPCWSTR src, DWORD nField, LPWSTR dst, DWORD len)
67 FIXME("('%s',0x%08lx,%p,%ld) stub.\n",
68 debugstr_w(src), nField, dst, len);
72 /*************************************************************************
73 * ParseFieldAW [SHELL32.58]
75 DWORD WINAPI ParseFieldAW(LPCVOID src, DWORD nField, LPVOID dst, DWORD len)
77 if (SHELL_OsIsUnicode())
78 return ParseFieldW(src, nField, dst, len);
79 return ParseFieldA(src, nField, dst, len);
82 /*************************************************************************
83 * GetFileNameFromBrowse [SHELL32.63]
86 BOOL WINAPI GetFileNameFromBrowse(
90 LPCSTR lpstrInitialDir,
95 FIXME("(%04x,%s,%ld,%s,%s,%s,%s):stub.\n",
96 hwndOwner, lpstrFile, nMaxFile, lpstrInitialDir, lpstrDefExt,
97 lpstrFilter, lpstrTitle);
99 /* puts up a Open Dialog and requests input into targetbuf */
100 /* OFN_HIDEREADONLY|OFN_NOCHANGEDIR|OFN_FILEMUSTEXIST|OFN_unknown */
101 strcpy(lpstrFile,"x:\\dummy.exe");
105 /*************************************************************************
106 * SHGetSettings [SHELL32.68]
109 * the registry path are for win98 (tested)
110 * and possibly are the same in nt40
112 VOID WINAPI SHGetSettings(LPSHELLFLAGSTATE lpsfs, DWORD dwMask)
116 DWORD dwDataSize = sizeof (DWORD);
118 TRACE("(%p 0x%08lx)\n",lpsfs,dwMask);
120 if (RegCreateKeyExA(HKEY_CURRENT_USER, "Software\\Microsoft\\Windows\\CurrentVersion\\Explorer\\Advanced",
121 0, 0, 0, KEY_ALL_ACCESS, 0, &hKey, 0))
124 if ( (SSF_SHOWEXTENSIONS & dwMask) && !RegQueryValueExA(hKey, "HideFileExt", 0, 0, (LPBYTE)&dwData, &dwDataSize))
125 lpsfs->fShowExtensions = ((dwData == 0) ? 0 : 1);
127 if ( (SSF_SHOWINFOTIP & dwMask) && !RegQueryValueExA(hKey, "ShowInfoTip", 0, 0, (LPBYTE)&dwData, &dwDataSize))
128 lpsfs->fShowInfoTip = ((dwData == 0) ? 0 : 1);
130 if ( (SSF_DONTPRETTYPATH & dwMask) && !RegQueryValueExA(hKey, "DontPrettyPath", 0, 0, (LPBYTE)&dwData, &dwDataSize))
131 lpsfs->fDontPrettyPath = ((dwData == 0) ? 0 : 1);
133 if ( (SSF_HIDEICONS & dwMask) && !RegQueryValueExA(hKey, "HideIcons", 0, 0, (LPBYTE)&dwData, &dwDataSize))
134 lpsfs->fHideIcons = ((dwData == 0) ? 0 : 1);
136 if ( (SSF_MAPNETDRVBUTTON & dwMask) && !RegQueryValueExA(hKey, "MapNetDrvBtn", 0, 0, (LPBYTE)&dwData, &dwDataSize))
137 lpsfs->fMapNetDrvBtn = ((dwData == 0) ? 0 : 1);
139 if ( (SSF_SHOWATTRIBCOL & dwMask) && !RegQueryValueExA(hKey, "ShowAttribCol", 0, 0, (LPBYTE)&dwData, &dwDataSize))
140 lpsfs->fShowAttribCol = ((dwData == 0) ? 0 : 1);
142 if (((SSF_SHOWALLOBJECTS | SSF_SHOWSYSFILES) & dwMask) && !RegQueryValueExA(hKey, "Hidden", 0, 0, (LPBYTE)&dwData, &dwDataSize))
144 { if (SSF_SHOWALLOBJECTS & dwMask) lpsfs->fShowAllObjects = 0;
145 if (SSF_SHOWSYSFILES & dwMask) lpsfs->fShowSysFiles = 0;
147 else if (dwData == 1)
148 { if (SSF_SHOWALLOBJECTS & dwMask) lpsfs->fShowAllObjects = 1;
149 if (SSF_SHOWSYSFILES & dwMask) lpsfs->fShowSysFiles = 0;
151 else if (dwData == 2)
152 { if (SSF_SHOWALLOBJECTS & dwMask) lpsfs->fShowAllObjects = 0;
153 if (SSF_SHOWSYSFILES & dwMask) lpsfs->fShowSysFiles = 1;
158 TRACE("-- 0x%04x\n", *(WORD*)lpsfs);
161 /*************************************************************************
162 * SHShellFolderView_Message [SHELL32.73]
165 * hwndCabinet defines the explorer cabinet window that contains the
166 * shellview you need to communicate with
167 * uMsg identifying the SFVM enum to perform
171 * Message SFVM_REARRANGE = 1
172 * This message gets sent when a column gets clicked to instruct the
173 * shell view to re-sort the item list. lParam identifies the column
176 int WINAPI SHShellFolderView_Message(
181 FIXME("%04x %08lx %08lx stub\n",hwndCabinet, dwMessage, dwParam);
185 /*************************************************************************
186 * RegisterShellHook [SHELL32.181]
189 * hwnd [I] window handle
193 * exported by ordinal
195 BOOL WINAPI RegisterShellHook(
199 FIXME("(0x%08x,0x%08lx):stub.\n",hWnd, dwType);
202 /*************************************************************************
203 * ShellMessageBoxW [SHELL32.182]
205 * Format and output errormessage.
207 * idText resource ID of title or LPSTR
208 * idTitle resource ID of title or LPSTR
211 * exported by ordinal
213 int WINAPIV ShellMessageBoxW(
221 WCHAR szText[100],szTitle[100],szTemp[256];
222 LPCWSTR pszText = szText, pszTitle = szTitle;
224 va_start(args, uType);
225 /* wvsprintfA(buf,fmt, args); */
227 TRACE("(%08lx,%08lx,%p,%p,%08x)\n",
228 (DWORD)hInstance,(DWORD)hWnd,lpText,lpCaption,uType);
230 if (!HIWORD(lpCaption))
231 LoadStringW(hInstance, (DWORD)lpCaption, szTitle, 100);
233 pszTitle = lpCaption;
236 LoadStringW(hInstance, (DWORD)lpText, szText, 100);
240 FormatMessageW(FORMAT_MESSAGE_FROM_STRING | FORMAT_MESSAGE_ARGUMENT_ARRAY,
241 szText, 0, 0, szTemp, 256, (LPDWORD) args);
245 return MessageBoxW(hWnd,szTemp,szTitle,uType);
248 /*************************************************************************
249 * ShellMessageBoxA [SHELL32.183]
251 int WINAPIV ShellMessageBoxA(
259 char szText[100],szTitle[100],szTemp[256];
260 LPCSTR pszText = szText, pszTitle = szTitle;
262 va_start(args, uType);
263 /* wvsprintfA(buf,fmt, args); */
265 TRACE("(%08lx,%08lx,%p,%p,%08x)\n",
266 (DWORD)hInstance,(DWORD)hWnd,lpText,lpCaption,uType);
268 if (!HIWORD(lpCaption))
269 LoadStringA(hInstance, (DWORD)lpCaption, szTitle, 100);
271 pszTitle = lpCaption;
274 LoadStringA(hInstance, (DWORD)lpText, szText, 100);
278 FormatMessageA(FORMAT_MESSAGE_FROM_STRING | FORMAT_MESSAGE_ARGUMENT_ARRAY,
279 szText, 0, 0, szTemp, 256, (LPDWORD) args);
283 return MessageBoxA(hWnd,szTemp,szTitle,uType);
286 /*************************************************************************
287 * SHFree [SHELL32.195]
290 * free_ptr() - frees memory using IMalloc
291 * exported by ordinal
294 void WINAPI SHFree(LPVOID x)
297 WORD len = *(LPWORD)((LPBYTE)x-2);
299 if ( *(LPWORD)((LPBYTE)x+len) != 0x7384)
302 if ( (*(LPWORD)((LPBYTE)x-4)) != 0x8271)
305 memset((LPBYTE)x-4, 0xde, len+6);
307 TRACE("%p len=%u\n",x, len);
313 HeapFree(GetProcessHeap(), 0, x);
316 /*************************************************************************
317 * SHAlloc [SHELL32.196]
320 * void *task_alloc(DWORD len), uses SHMalloc allocator
321 * exported by ordinal
323 LPVOID WINAPI SHAlloc(DWORD len)
328 ret = (LPVOID) HeapAlloc(GetProcessHeap(),0,len+6);
330 ret = (LPVOID) HeapAlloc(GetProcessHeap(),0,len);
334 *(LPWORD)(ret) = 0x8271;
335 *(LPWORD)(ret+2) = (WORD)len;
336 *(LPWORD)(ret+4+len) = 0x7384;
338 memset(ret, 0xdf, len);
340 TRACE("%lu bytes at %p\n",len, ret);
344 /*************************************************************************
345 * SHRegisterDragDrop [SHELL32.86]
348 * exported by ordinal
350 HRESULT WINAPI SHRegisterDragDrop(
352 LPDROPTARGET pDropTarget)
354 FIXME("(0x%08x,%p):stub.\n", hWnd, pDropTarget);
355 if (GetShellOle()) return pRegisterDragDrop(hWnd, pDropTarget);
359 /*************************************************************************
360 * SHRevokeDragDrop [SHELL32.87]
363 * exported by ordinal
365 HRESULT WINAPI SHRevokeDragDrop(HWND hWnd)
367 FIXME("(0x%08x):stub.\n",hWnd);
371 /*************************************************************************
372 * SHDoDragDrop [SHELL32.88]
375 * exported by ordinal
377 HRESULT WINAPI SHDoDragDrop(
379 LPDATAOBJECT lpDataObject,
380 LPDROPSOURCE lpDropSource,
384 FIXME("(0x%04x %p %p 0x%08lx %p):stub.\n",
385 hWnd, lpDataObject, lpDropSource, dwOKEffect, pdwEffect);
389 /*************************************************************************
390 * ArrangeWindows [SHELL32.184]
393 WORD WINAPI ArrangeWindows(
400 FIXME("(0x%08x 0x%08lx %p 0x%04x %p):stub.\n",
401 hwndParent, dwReserved, lpRect, cKids, lpKids);
405 /*************************************************************************
406 * SignalFileOpen [SHELL32.103]
409 * exported by ordinal
412 SignalFileOpen (DWORD dwParam1)
414 FIXME("(0x%08lx):stub.\n", dwParam1);
419 /*************************************************************************
420 * SHAddToRecentDocs [SHELL32.234]
423 * uFlags [IN] SHARD_PATH or SHARD_PIDL
424 * pv [IN] string or pidl, NULL clears the list
429 DWORD WINAPI SHAddToRecentDocs (UINT uFlags,LPCVOID pv)
430 { if (SHARD_PIDL==uFlags)
431 { FIXME("(0x%08x,pidl=%p):stub.\n", uFlags,pv);
434 { FIXME("(0x%08x,%s):stub.\n", uFlags,(char*)pv);
438 /*************************************************************************
439 * SHCreateShellFolderViewEx [SHELL32.174]
442 * see IShellFolder::CreateViewObject
444 HRESULT WINAPI SHCreateShellFolderViewEx(
445 LPCSHELLFOLDERVIEWINFO psvcbi, /*[in ] shelltemplate struct*/
446 LPSHELLVIEW* ppv) /*[out] IShellView pointer*/
451 TRACE("sf=%p pidl=%p cb=%p mode=0x%08x parm=0x%08lx\n",
452 psvcbi->pshf, psvcbi->pidlFolder, psvcbi->lpfnCallback,
453 psvcbi->uViewMode, psvcbi->dwUser);
455 psf = IShellView_Constructor(psvcbi->pshf);
458 return E_OUTOFMEMORY;
460 IShellView_AddRef(psf);
461 hRes = IShellView_QueryInterface(psf, &IID_IShellView, (LPVOID *)ppv);
462 IShellView_Release(psf);
466 /*************************************************************************
467 * SHWinHelp [SHELL32.127]
470 HRESULT WINAPI SHWinHelp (DWORD v, DWORD w, DWORD x, DWORD z)
471 { FIXME("0x%08lx 0x%08lx 0x%08lx 0x%08lx stub\n",v,w,x,z);
474 /*************************************************************************
475 * SHRunControlPanel [SHELL32.161]
478 HRESULT WINAPI SHRunControlPanel (DWORD x, DWORD z)
479 { FIXME("0x%08lx 0x%08lx stub\n",x,z);
482 /*************************************************************************
483 * ShellExecuteEx [SHELL32.291]
486 BOOL WINAPI ShellExecuteExAW (LPVOID sei)
487 { if (SHELL_OsIsUnicode())
488 return ShellExecuteExW (sei);
489 return ShellExecuteExA (sei);
491 /*************************************************************************
492 * ShellExecuteExA [SHELL32.292]
494 * placeholder in the commandline:
499 * %I adress of a global item ID (explorer switch /idlist)
500 * %L ??? path/url/current file ???
502 * %* all following parameters (see batfile)
504 BOOL WINAPI ShellExecuteExA (LPSHELLEXECUTEINFOA sei)
505 { CHAR szApplicationName[MAX_PATH],szCommandline[MAX_PATH],szPidl[20];
508 STARTUPINFOA startup;
509 PROCESS_INFORMATION info;
511 WARN("mask=0x%08lx hwnd=0x%04x verb=%s file=%s parm=%s dir=%s show=0x%08x class=%s incomplete\n",
512 sei->fMask, sei->hwnd, sei->lpVerb, sei->lpFile,
513 sei->lpParameters, sei->lpDirectory, sei->nShow,
514 (sei->fMask & SEE_MASK_CLASSNAME) ? sei->lpClass : "not used");
516 ZeroMemory(szApplicationName,MAX_PATH);
518 strcpy(szApplicationName, sei->lpFile);
520 ZeroMemory(szCommandline,MAX_PATH);
521 if (sei->lpParameters)
522 strcpy(szCommandline, sei->lpParameters);
524 if (sei->fMask & (SEE_MASK_CLASSKEY | SEE_MASK_INVOKEIDLIST | SEE_MASK_ICON | SEE_MASK_HOTKEY |
525 SEE_MASK_CONNECTNETDRV | SEE_MASK_FLAG_DDEWAIT |
526 SEE_MASK_DOENVSUBST | SEE_MASK_FLAG_NO_UI | SEE_MASK_UNICODE |
527 SEE_MASK_NO_CONSOLE | SEE_MASK_ASYNCOK | SEE_MASK_HMONITOR ))
529 FIXME("flags ignored: 0x%08lx\n", sei->fMask);
532 /* launch a document by fileclass like 'Wordpad.Document.1' */
533 if (sei->fMask & SEE_MASK_CLASSNAME)
535 /* the commandline contains 'c:\Path\wordpad.exe "%1"' */
536 HCR_GetExecuteCommand(sei->lpClass, (sei->lpVerb) ? sei->lpVerb : "open", szCommandline, 256);
537 /* fixme: get the extension of lpFile, check if it fits to the lpClass */
538 TRACE("SEE_MASK_CLASSNAME->'%s'\n", szCommandline);
541 /* process the IDList */
542 if ( (sei->fMask & SEE_MASK_INVOKEIDLIST) == SEE_MASK_INVOKEIDLIST) /*0x0c*/
544 SHGetPathFromIDListA (sei->lpIDList,szApplicationName);
545 TRACE("-- idlist=%p (%s)\n", sei->lpIDList, szApplicationName);
549 if (sei->fMask & SEE_MASK_IDLIST )
551 pos = strstr(szCommandline, "%I");
555 HGLOBAL hmem = SHAllocShared ( sei->lpIDList, ILGetSize(sei->lpIDList), 0);
556 pv = SHLockShared(hmem,0);
557 sprintf(szPidl,":%p",pv );
560 gap = strlen(szPidl);
562 memmove(pos+gap,pos+2,len);
563 memcpy(pos,szPidl,gap);
569 TRACE("execute:'%s','%s'\n",szApplicationName, szCommandline);
571 strcat(szApplicationName, " ");
572 strcat(szApplicationName, szCommandline);
574 ZeroMemory(&startup,sizeof(STARTUPINFOA));
575 startup.cb = sizeof(STARTUPINFOA);
577 if (! CreateProcessA(NULL, szApplicationName,
578 NULL, NULL, FALSE, 0,
579 NULL, NULL, &startup, &info))
581 sei->hInstApp = GetLastError();
587 /* Give 30 seconds to the app to come up */
588 if ( WaitForInputIdle ( info.hProcess, 30000 ) == 0xFFFFFFFF )
589 ERR("WaitForInputIdle failed: Error %ld\n", GetLastError() );
591 if(sei->fMask & SEE_MASK_NOCLOSEPROCESS)
592 sei->hProcess = info.hProcess;
594 CloseHandle( info.hProcess );
595 CloseHandle( info.hThread );
598 /*************************************************************************
599 * ShellExecuteExW [SHELL32.293]
602 BOOL WINAPI ShellExecuteExW (LPSHELLEXECUTEINFOW sei)
603 { SHELLEXECUTEINFOA seiA;
608 memcpy(&seiA, sei, sizeof(SHELLEXECUTEINFOA));
611 seiA.lpVerb = HEAP_strdupWtoA( GetProcessHeap(), 0, sei->lpVerb);
614 seiA.lpFile = HEAP_strdupWtoA( GetProcessHeap(), 0, sei->lpFile);
616 if (sei->lpParameters)
617 seiA.lpParameters = HEAP_strdupWtoA( GetProcessHeap(), 0, sei->lpParameters);
619 if (sei->lpDirectory)
620 seiA.lpDirectory = HEAP_strdupWtoA( GetProcessHeap(), 0, sei->lpDirectory);
622 if ((sei->fMask & SEE_MASK_CLASSNAME) && sei->lpClass)
623 seiA.lpClass = HEAP_strdupWtoA( GetProcessHeap(), 0, sei->lpClass);
627 ret = ShellExecuteExA(&seiA);
629 if (seiA.lpVerb) HeapFree( GetProcessHeap(), 0, (LPSTR) seiA.lpVerb );
630 if (seiA.lpFile) HeapFree( GetProcessHeap(), 0, (LPSTR) seiA.lpFile );
631 if (seiA.lpParameters) HeapFree( GetProcessHeap(), 0, (LPSTR) seiA.lpParameters );
632 if (seiA.lpDirectory) HeapFree( GetProcessHeap(), 0, (LPSTR) seiA.lpDirectory );
633 if (seiA.lpClass) HeapFree( GetProcessHeap(), 0, (LPSTR) seiA.lpClass );
638 static LPUNKNOWN SHELL32_IExplorerInterface=0;
639 /*************************************************************************
640 * SHSetInstanceExplorer [SHELL32.176]
645 HRESULT WINAPI SHSetInstanceExplorer (LPUNKNOWN lpUnknown)
646 { TRACE("%p\n", lpUnknown);
647 SHELL32_IExplorerInterface = lpUnknown;
648 return (HRESULT) lpUnknown;
650 /*************************************************************************
651 * SHGetInstanceExplorer [SHELL32.256]
654 * gets the interface pointer of the explorer and a reference
656 HRESULT WINAPI SHGetInstanceExplorer (LPUNKNOWN * lpUnknown)
657 { TRACE("%p\n", lpUnknown);
659 *lpUnknown = SHELL32_IExplorerInterface;
661 if (!SHELL32_IExplorerInterface)
664 IUnknown_AddRef(SHELL32_IExplorerInterface);
667 /*************************************************************************
668 * SHFreeUnusedLibraries [SHELL32.123]
673 void WINAPI SHFreeUnusedLibraries (void)
677 /*************************************************************************
678 * DAD_SetDragImage [SHELL32.136]
683 BOOL WINAPI DAD_SetDragImage(
684 HIMAGELIST himlTrack,
687 FIXME("%p %p stub\n",himlTrack, lppt);
690 /*************************************************************************
691 * DAD_ShowDragImage [SHELL32.137]
696 BOOL WINAPI DAD_ShowDragImage(BOOL bShow)
698 FIXME("0x%08x stub\n",bShow);
701 /*************************************************************************
702 * ReadCabinetState [NT 4.0:SHELL32.651]
705 HRESULT WINAPI ReadCabinetState(DWORD u, DWORD v)
706 { FIXME("0x%04lx 0x%04lx stub\n",u,v);
709 /*************************************************************************
710 * WriteCabinetState [NT 4.0:SHELL32.652]
713 HRESULT WINAPI WriteCabinetState(DWORD u)
714 { FIXME("0x%04lx stub\n",u);
717 /*************************************************************************
718 * FileIconInit [SHELL32.660]
721 BOOL WINAPI FileIconInit(BOOL bFullInit)
722 { FIXME("(%s)\n", bFullInit ? "true" : "false");
725 /*************************************************************************
726 * IsUserAdmin [NT 4.0:SHELL32.680]
729 HRESULT WINAPI IsUserAdmin(void)
734 /*************************************************************************
735 * SHAllocShared [SHELL32.520]
738 * parameter1 is return value from HeapAlloc
739 * parameter2 is equal to the size allocated with HeapAlloc
740 * parameter3 is return value from GetCurrentProcessId
742 * the return value is posted as lParam with 0x402 (WM_USER+2) to somewhere
743 * WM_USER+2 could be the undocumented CWM_SETPATH
744 * the allocated memory contains a pidl
746 HGLOBAL WINAPI SHAllocShared(LPVOID psrc, DWORD size, DWORD procID)
750 TRACE("ptr=%p size=0x%04lx procID=0x%04lx\n",psrc,size,procID);
751 hmem = GlobalAlloc(GMEM_FIXED, size);
755 pmem = GlobalLock (hmem);
760 memcpy (pmem, psrc, size);
764 /*************************************************************************
765 * SHLockShared [SHELL32.521]
768 * parameter1 is return value from SHAllocShared
769 * parameter2 is return value from GetCurrentProcessId
770 * the receiver of (WM_USER+2) trys to lock the HANDLE (?)
771 * the returnvalue seems to be a memoryadress
773 LPVOID WINAPI SHLockShared(HANDLE hmem, DWORD procID)
774 { TRACE("handle=0x%04x procID=0x%04lx\n",hmem,procID);
775 return GlobalLock(hmem);
777 /*************************************************************************
778 * SHUnlockShared [SHELL32.522]
781 * parameter1 is return value from SHLockShared
783 BOOL WINAPI SHUnlockShared(LPVOID pv)
786 return GlobalUnlock((HANDLE)pv);
788 /*************************************************************************
789 * SHFreeShared [SHELL32.523]
792 * parameter1 is return value from SHAllocShared
793 * parameter2 is return value from GetCurrentProcessId
795 BOOL WINAPI SHFreeShared(
799 TRACE("handle=0x%04x 0x%04lx\n",hMem,pid);
800 return GlobalFree(hMem);
803 /*************************************************************************
804 * SetAppStartingCursor [SHELL32.99]
806 HRESULT WINAPI SetAppStartingCursor(HWND u, DWORD v)
807 { FIXME("hwnd=0x%04x 0x%04lx stub\n",u,v );
810 /*************************************************************************
811 * SHLoadOLE [SHELL32.151]
814 HRESULT WINAPI SHLoadOLE(DWORD u)
815 { FIXME("0x%04lx stub\n",u);
818 /*************************************************************************
819 * DriveType [SHELL32.64]
822 HRESULT WINAPI DriveType(DWORD u)
823 { FIXME("0x%04lx stub\n",u);
826 /*************************************************************************
827 * SHAbortInvokeCommand [SHELL32.198]
830 HRESULT WINAPI SHAbortInvokeCommand(void)
834 /*************************************************************************
835 * SHOutOfMemoryMessageBox [SHELL32.126]
838 int WINAPI SHOutOfMemoryMessageBox(
843 FIXME("0x%04x %s 0x%08x stub\n",hwndOwner, lpCaption, uType);
846 /*************************************************************************
847 * SHFlushClipboard [SHELL32.121]
850 HRESULT WINAPI SHFlushClipboard(void)
855 /*************************************************************************
856 * SHWaitForFileToOpen [SHELL32.97]
859 BOOL WINAPI SHWaitForFileToOpen(
864 FIXME("%p 0x%08lx 0x%08lx stub\n", pidl, dwFlags, dwTimeout);
867 /*************************************************************************
868 * Control_FillCache_RunDLL [SHELL32.8]
871 HRESULT WINAPI Control_FillCache_RunDLL(HWND hWnd, HANDLE hModule, DWORD w, DWORD x)
872 { FIXME("0x%04x 0x%04x 0x%04lx 0x%04lx stub\n",hWnd, hModule,w,x);
875 /*************************************************************************
876 * RunDLL_CallEntry16 [SHELL32.122]
877 * the name is propably wrong
879 HRESULT WINAPI RunDLL_CallEntry16(DWORD v, DWORD w, DWORD x, DWORD y, DWORD z)
880 { FIXME("0x%04lx 0x%04lx 0x%04lx 0x%04lx 0x%04lx stub\n",v,w,x,y,z);
884 /************************************************************************
885 * shell32_654 [SHELL32.654]
887 * NOTES: first parameter seems to be a pointer (same as passed to WriteCabinetState)
888 * second one could be a size (0x0c). The size is the same as the structure saved to
889 * HCU\Software\Microsoft\Windows\CurrentVersion\Explorer\CabinetState
890 * I'm (js) guessing: this one is just ReadCabinetState ;-)
892 HRESULT WINAPI shell32_654 (DWORD x, DWORD y)
893 { FIXME("0x%08lx 0x%08lx stub\n",x,y);
897 /************************************************************************
898 * RLBuildListOfPaths [SHELL32.146]
903 DWORD WINAPI RLBuildListOfPaths (void)
907 /************************************************************************
908 * SHValidateUNC [SHELL32.173]
911 HRESULT WINAPI SHValidateUNC (DWORD x, DWORD y, DWORD z)
913 FIXME("0x%08lx 0x%08lx 0x%08lx stub\n",x,y,z);
917 /************************************************************************
918 * DoEnvironmentSubstA [SHELL32.1222]
921 HRESULT WINAPI DoEnvironmentSubstA(LPSTR x, LPSTR y)
923 FIXME("(%s, %s) stub\n", debugstr_a(x), debugstr_a(y));
927 /************************************************************************
928 * DoEnvironmentSubstW [SHELL32.1223]
931 HRESULT WINAPI DoEnvironmentSubstW(LPWSTR x, LPWSTR y)
933 FIXME("(%s, %s): stub\n", debugstr_w(x), debugstr_w(y));
937 /************************************************************************
938 * DoEnvironmentSubst [SHELL32.53]
941 HRESULT WINAPI DoEnvironmentSubstAW(LPVOID x, LPVOID y)
943 if (SHELL_OsIsUnicode())
944 return DoEnvironmentSubstW(x, y);
945 return DoEnvironmentSubstA(x, y);
948 /*************************************************************************
949 * shell32_243 [SHELL32.243]
951 * Win98+ by-ordinal routine. In Win98 this routine returns zero and
952 * does nothing else. Possibly this does something in NT or SHELL32 5.0?
956 BOOL WINAPI shell32_243(DWORD a, DWORD b)
961 /*************************************************************************
962 * SHELL32_714 [SHELL32]
964 DWORD WINAPI SHELL32_714(LPVOID x)
966 FIXME("(%s)stub\n", debugstr_w(x));