6 #include "wine/obj_base.h"
7 #include "wine/obj_enumidlist.h"
8 #include "wine/obj_shellfolder.h"
12 #include "winversion.h"
13 #include "shell32_main.h"
17 DEFAULT_DEBUG_CHANNEL(shell)
19 BOOL WINAPI FileMenu_DeleteAllItems (HMENU hMenu);
21 /*************************************************************************
22 * FileMenu_Create [SHELL32.114]
25 HMENU WINAPI FileMenu_Create (
26 COLORREF crBorderColor,
32 HMENU ret = CreatePopupMenu();
34 FIXME(shell,"0x%08lx 0x%08x 0x%08x 0x%08x 0x%08x ret=0x%08x\n",
35 crBorderColor, nBorderWidth, hBorderBmp, nSelHeight, uFlags, ret);
40 /*************************************************************************
41 * FileMenu_Destroy [SHELL32.118]
46 void WINAPI FileMenu_Destroy (HMENU hMenu)
48 TRACE(shell,"0x%08x\n", hMenu);
49 FileMenu_DeleteAllItems (hMenu);
53 /*************************************************************************
54 * FileMenu_AppendItemAW [SHELL32.115]
57 BOOL WINAPI FileMenu_AppendItemAW(
65 LPSTR lpszText = (LPSTR)lpText;
67 ZeroMemory (&mii, sizeof(MENUITEMINFOA));
69 if (VERSION_OsIsUnicode() && (lpszText!=FM_SEPARATOR))
70 lpszText = HEAP_strdupWtoA ( GetProcessHeap(),0, lpText);
72 FIXME(shell,"0x%08x %s 0x%08x 0x%08x 0x%08x 0x%08x\n",
73 hMenu, (lpszText!=FM_SEPARATOR) ? lpszText: NULL,
74 uID, icon, hMenuPopup, nItemHeight);
76 mii.cbSize = sizeof(mii);
80 mii.fMask = MIIM_SUBMENU | MIIM_TYPE | MIIM_DATA;;
81 mii.hSubMenu = hMenuPopup;
82 mii.fType = MFT_STRING;
83 mii.dwTypeData = lpszText;
85 else if (lpText == FM_SEPARATOR )
86 { mii.fMask = MIIM_ID | MIIM_TYPE;
87 mii.fType = MFT_SEPARATOR;
91 mii.fMask = MIIM_ID | MIIM_TYPE | MIIM_STATE;
92 mii.dwTypeData = lpszText;
93 mii.fState = MFS_ENABLED | MFS_DEFAULT;
94 mii.fType = MFT_STRING;
98 InsertMenuItemA (hMenu, (UINT)-1, TRUE, &mii);
100 if (VERSION_OsIsUnicode())
101 HeapFree( GetProcessHeap(), 0, lpszText );
107 /*************************************************************************
108 * FileMenu_InsertUsingPidl [SHELL32.110]
111 * uEnumFlags any SHCONTF flag
113 int WINAPI FileMenu_InsertUsingPidl (
119 LPFNFMCALLBACK lpfnCallback)
121 IShellFolder *lpsf, *lpsf2;
124 LPITEMIDLIST pidlTemp=0;
126 char sTemp[MAX_PATH];
127 int NumberOfItems = 0;
129 FIXME(shell,"0x%08x 0x%08x %p 0x%08x 0x%08x %p\n",
130 hMenu, uID, pidl, uFlags, uEnumFlags, lpfnCallback);
133 if (SUCCEEDED (SHGetDesktopFolder(&lpsf)))
134 { if (SUCCEEDED(IShellFolder_BindToObject(lpsf, pidl,0,(REFIID)&IID_IShellFolder,(LPVOID *)&lpsf2)))
135 { if (SUCCEEDED (IShellFolder_EnumObjects(lpsf2, 0, uEnumFlags, &lpe )))
136 { while (NOERROR == IEnumIDList_Next(lpe,1,&pidlTemp,&ulFetched))
137 { if (SUCCEEDED (IShellFolder_GetAttributesOf(lpsf, 1, &pidlTemp, &ulItemAttr)))
138 { ILGetDisplayName( pidlTemp, sTemp);
139 if ( SFGAO_FOLDER & ulItemAttr)
140 { FileMenu_AppendItemAW (hMenu, sTemp, uID, FM_BLANK_ICON, CreatePopupMenu(), FM_DEFAULT_HEIGHT);
143 { FileMenu_AppendItemAW (hMenu, sTemp, uID, FM_BLANK_ICON, 0, FM_DEFAULT_HEIGHT);
146 TRACE(shell,"enter callback\n");
147 lpfnCallback ( pidl, pidlTemp);
148 TRACE(shell,"leave callback\n");
151 IEnumIDList_Release (lpe);
153 IShellFolder_Release(lpsf2);
155 IShellFolder_Release(lpsf);
158 return NumberOfItems;
161 /*************************************************************************
162 * FileMenu_ReplaceUsingPidl [SHELL32.113]
165 int WINAPI FileMenu_ReplaceUsingPidl(
170 LPFNFMCALLBACK lpfnCallback)
172 FIXME(shell,"0x%08x 0x%08x %p 0x%08x %p\n",
173 hMenu, uID, pidl, uEnumFlags, lpfnCallback);
177 /*************************************************************************
178 * FileMenu_Invalidate [SHELL32.111]
180 void WINAPI FileMenu_Invalidate (HMENU hMenu)
182 FIXME(shell,"0x%08x\n",hMenu);
185 /*************************************************************************
186 * FileMenu_FindSubMenuByPidl [SHELL32.106]
188 HMENU WINAPI FileMenu_FindSubMenuByPidl(
192 FIXME(shell,"0x%08x %p\n",hMenu, pidl);
196 /*************************************************************************
197 * FileMenu_AppendFilesForPidl [SHELL32.124]
199 HMENU WINAPI FileMenu_AppendFilesForPidl(
204 FIXME(shell,"0x%08x %p 0x%08x\n",hMenu, pidl,bAddSeperator);
207 /*************************************************************************
208 * FileMenu_AddFilesForPidl [SHELL32.125]
211 * uEnumFlags any SHCONTF flag
213 int WINAPI FileMenu_AddFilesForPidl (
220 LPFNFMCALLBACK lpfnCallback)
222 FIXME(shell,"0x%08x 0x%08x 0x%08x %p 0x%08x 0x%08x %p\n",
223 hMenu, uReserved, uID, pidl, uFlags, uEnumFlags, lpfnCallback);
230 /*************************************************************************
231 * FileMenu_TrackPopupMenuEx [SHELL32.116]
233 HRESULT WINAPI FileMenu_TrackPopupMenuEx (
241 FIXME(shell,"0x%08x 0x%08x 0x%x 0x%x 0x%08x %p stub\n",
242 hMenu, uFlags, x, y, hWnd, lptpm);
243 return TrackPopupMenuEx(hMenu, uFlags, x, y, hWnd, lptpm);
246 /*************************************************************************
247 * FileMenu_GetLastSelectedItemPidls [SHELL32.107]
249 BOOL WINAPI FileMenu_GetLastSelectedItemPidls(
251 LPCITEMIDLIST *ppidlFolder,
252 LPCITEMIDLIST *ppidlItem)
254 FIXME(shell,"0x%08x %p %p\n",uReserved, ppidlFolder, ppidlItem);
258 /*************************************************************************
259 * FileMenu_MeasureItem [SHELL32.112]
261 LRESULT WINAPI FileMenu_MeasureItem(
263 LPMEASUREITEMSTRUCT lpmis)
265 FIXME(shell,"0x%08x %p\n", hWnd, lpmis);
269 /*************************************************************************
270 * FileMenu_DrawItem [SHELL32.105]
272 LRESULT WINAPI FileMenu_DrawItem(
274 LPDRAWITEMSTRUCT lpdis)
276 FIXME(shell,"0x%08x %p\n", hWnd, lpdis);
280 /*************************************************************************
281 * FileMenu_InitMenuPopup [SHELL32.109]
284 * The filemenu is a ownerdrawn menu. Call this function responding to
288 HRESULT WINAPI FileMenu_InitMenuPopup (DWORD hmenu)
289 { FIXME(shell,"hmenu=0x%lx stub\n",hmenu);
293 /*************************************************************************
294 * FileMenu_HandleMenuChar [SHELL32.108]
296 LRESULT WINAPI FileMenu_HandleMenuChar(
300 FIXME(shell,"0x%08x 0x%08x\n",hMenu,wParam);
304 /*************************************************************************
305 * FileMenu_DeleteAllItems [SHELL32.104]
310 BOOL WINAPI FileMenu_DeleteAllItems (HMENU hMenu)
312 FIXME(shell,"0x%08x stub\n", hMenu);
317 /*************************************************************************
318 * FileMenu_DeleteItemByCmd [SHELL32.]
321 BOOL WINAPI FileMenu_DeleteItemByCmd (HMENU hMenu, UINT uID)
323 TRACE(shell,"0x%08x 0x%08x\n", hMenu, uID);
325 DeleteMenu(hMenu, MF_BYCOMMAND, uID);
329 /*************************************************************************
330 * FileMenu_DeleteItemByIndex [SHELL32.140]
332 BOOL WINAPI FileMenu_DeleteItemByIndex ( HMENU hMenu, UINT uPos)
334 TRACE(shell,"0x%08x 0x%08x\n", hMenu, uPos);
336 DeleteMenu(hMenu, MF_BYPOSITION, uPos);
340 /*************************************************************************
341 * FileMenu_DeleteItemByFirstID [SHELL32.141]
343 BOOL WINAPI FileMenu_DeleteItemByFirstID(
347 TRACE(shell,"0x%08x 0x%08x\n", hMenu, uID);
351 /*************************************************************************
352 * FileMenu_DeleteSeparator [SHELL32.142]
354 BOOL WINAPI FileMenu_DeleteSeparator(HMENU hMenu)
356 TRACE(shell,"0x%08x\n", hMenu);
360 /*************************************************************************
361 * FileMenu_EnableItemByCmd [SHELL32.143]
363 BOOL WINAPI FileMenu_EnableItemByCmd(
368 TRACE(shell,"0x%08x 0x%08x 0x%08x\n", hMenu, uID,bEnable);
372 /*************************************************************************
373 * FileMenu_GetItemExtent [SHELL32.144]
376 DWORD WINAPI FileMenu_GetItemExtent (HMENU hMenu, UINT uPos)
379 FIXME (shell,"0x%08x 0x%08x\n", hMenu, uPos);
381 if (GetMenuItemRect(0, hMenu, uPos, &rect))
382 { FIXME (shell,"0x%04x 0x%04x 0x%04x 0x%04x\n",
383 rect.right, rect.left, rect.top, rect.bottom);
384 return ((rect.right-rect.left)<<16) + (rect.top-rect.bottom);
386 return 0x00200020; /*fixme*/
389 /*************************************************************************
390 * FileMenu_AbortInitMenu [SHELL32.120]
393 void WINAPI FileMenu_AbortInitMenu (void)
407 /*************************************************************************
408 * SHFind_InitMenuPopup [SHELL32.149]
412 * hMenu [in] handel of menu previously created
413 * hWndParent [in] parent window
417 HRESULT WINAPI SHFind_InitMenuPopup (HMENU hMenu, HWND hWndParent, DWORD w, DWORD x)
418 { FIXME(shell,"hmenu=0x%08x hwnd=0x%08x 0x%08lx 0x%08lx stub\n",
419 hMenu,hWndParent,w,x);
423 /*************************************************************************
424 * Shell_MergeMenus [SHELL32.67]
427 BOOL _SHIsMenuSeparator(HMENU hm, int i)
431 mii.cbSize = sizeof(MENUITEMINFOA);
432 mii.fMask = MIIM_TYPE;
433 mii.cch = 0; /* WARNING: We MUST initialize it to 0*/
434 if (!GetMenuItemInfoA(hm, i, TRUE, &mii))
438 if (mii.fType & MFT_SEPARATOR)
444 #define MM_ADDSEPARATOR 0x00000001L
445 #define MM_SUBMENUSHAVEIDS 0x00000002L
446 HRESULT WINAPI Shell_MergeMenus (HMENU hmDst, HMENU hmSrc, UINT uInsert, UINT uIDAdjust, UINT uIDAdjustMax, ULONG uFlags)
449 BOOL bAlreadySeparated;
450 MENUITEMINFOA miiSrc;
452 UINT uTemp, uIDMax = uIDAdjust;
454 FIXME(shell,"hmenu1=0x%04x hmenu2=0x%04x 0x%04x 0x%04x 0x%04x 0x%04lx stub\n",
455 hmDst, hmSrc, uInsert, uIDAdjust, uIDAdjustMax, uFlags);
457 if (!hmDst || !hmSrc)
461 nItem = GetMenuItemCount(hmDst);
462 if (uInsert >= (UINT)nItem)
463 { uInsert = (UINT)nItem;
464 bAlreadySeparated = TRUE;
467 { bAlreadySeparated = _SHIsMenuSeparator(hmDst, uInsert);;
469 if ((uFlags & MM_ADDSEPARATOR) && !bAlreadySeparated)
470 { /* Add a separator between the menus */
471 InsertMenuA(hmDst, uInsert, MF_BYPOSITION | MF_SEPARATOR, 0, NULL);
472 bAlreadySeparated = TRUE;
476 /* Go through the menu items and clone them*/
477 for (nItem = GetMenuItemCount(hmSrc) - 1; nItem >= 0; nItem--)
478 { miiSrc.cbSize = sizeof(MENUITEMINFOA);
479 miiSrc.fMask = MIIM_STATE | MIIM_ID | MIIM_SUBMENU | MIIM_CHECKMARKS | MIIM_TYPE | MIIM_DATA;
480 /* We need to reset this every time through the loop in case
481 menus DON'T have IDs*/
482 miiSrc.fType = MFT_STRING;
483 miiSrc.dwTypeData = szName;
484 miiSrc.dwItemData = 0;
485 miiSrc.cch = sizeof(szName);
487 if (!GetMenuItemInfoA(hmSrc, nItem, TRUE, &miiSrc))
490 if (miiSrc.fType & MFT_SEPARATOR)
491 { /* This is a separator; don't put two of them in a row*/
492 if (bAlreadySeparated)
495 bAlreadySeparated = TRUE;
497 else if (miiSrc.hSubMenu)
498 { if (uFlags & MM_SUBMENUSHAVEIDS)
499 { /* Adjust the ID and check it*/
500 miiSrc.wID += uIDAdjust;
501 if (miiSrc.wID > uIDAdjustMax)
504 if (uIDMax <= miiSrc.wID)
505 { uIDMax = miiSrc.wID + 1;
509 { /* Don't set IDs for submenus that didn't have them already */
510 miiSrc.fMask &= ~MIIM_ID;
512 hmSubMenu = miiSrc.hSubMenu;
513 miiSrc.hSubMenu = CreatePopupMenu();
514 if (!miiSrc.hSubMenu)
517 uTemp = Shell_MergeMenus(miiSrc.hSubMenu, hmSubMenu, 0, uIDAdjust, uIDAdjustMax, uFlags&MM_SUBMENUSHAVEIDS);
521 bAlreadySeparated = FALSE;
524 { /* Adjust the ID and check it*/
525 miiSrc.wID += uIDAdjust;
526 if (miiSrc.wID > uIDAdjustMax)
529 if (uIDMax <= miiSrc.wID)
530 { uIDMax = miiSrc.wID + 1;
532 bAlreadySeparated = FALSE;
534 if (!InsertMenuItemA(hmDst, uInsert, TRUE, &miiSrc))
539 /* Ensure the correct number of separators at the beginning of the
540 inserted menu items*/
542 { if (bAlreadySeparated)
543 { DeleteMenu(hmDst, uInsert, MF_BYPOSITION);
547 { if (_SHIsMenuSeparator(hmDst, uInsert-1))
548 { if (bAlreadySeparated)
549 { DeleteMenu(hmDst, uInsert, MF_BYPOSITION);
553 { if ((uFlags & MM_ADDSEPARATOR) && !bAlreadySeparated)
554 { /* Add a separator between the menus*/
555 InsertMenuA(hmDst, uInsert, MF_BYPOSITION | MF_SEPARATOR, 0, NULL);