On 02.06.2017 17:24, Aric Stewart wrote:
Presently the wine file explorer has a create shortcut entry that does nothing. This implements the FCIDM_SHVIEW_CREATELINK command.
Signed-off-by: Aric Stewart aric@codeweavers.com
dlls/shell32/shlview_cmenu.c | 50 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+)
- if (!SUCCEEDED(CoCreateInstance( &CLSID_ShellLink, NULL, CLSCTX_INPROC_SERVER,
&IID_IShellLinkW, (LPVOID*)&shelllink)))
- {
ERR("couldn't create ShellLink object\n");
return;
- }
This should be FAILED(). You can use IShellLink_Constructor() instead of going through generic object creation.
- SHGetSpecialFolderPathW(NULL, root, CSIDL_STARTMENU, TRUE);
- lnkfile=HeapAlloc(GetProcessHeap(), 0, (lstrlenW(root)+1+lstrlenW(wszFilename)+5) * sizeof(*lnkfile));
- lstrcpyW(lnkfile, root);
- lstrcatW(lnkfile, backslashW);
- lstrcatW(lnkfile, wszFilename);
- lstrcatW(lnkfile, lnkW);
Why is it created in Start Menu dir? I think usual behavior is to create it in target directory.
- if (!SUCCEEDED(IShellLinkW_QueryInterface(shelllink, &IID_IPersistFile, (LPVOID*)&persistfile)))
- {
ERR("couldn't get IPersistFile interface\n");
IShellLinkW_Release(shelllink);
HeapFree(GetProcessHeap(), 0, lnkfile);
return;
- }
FAILED() again, but really it can't fail. Also please LPVOID -> void*.