2 * Copyright (C) 2006, 2007 Apple Inc. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
13 * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY
14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR
17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 #include "ContextMenuItem.h"
29 #include "ContextMenu.h"
33 #define MFS_DISABLED MF_GRAYED
36 #define MIIM_FTYPE MIIM_TYPE
45 ContextMenuItem::ContextMenuItem(const MENUITEMINFO& info)
47 if (info.fMask & MIIM_FTYPE)
48 m_type = info.fType == MFT_SEPARATOR ? SeparatorType : ActionType;
50 m_type = SeparatorType;
52 if (m_type == ActionType && info.fMask & MIIM_STRING)
53 m_title = String(info.dwTypeData, info.cch);
55 if ((info.fMask & MIIM_SUBMENU) && info.hSubMenu) {
57 ContextMenu::getContextMenuItems(info.hSubMenu, m_subMenuItems);
60 if (info.fMask & MIIM_ID)
61 m_action = static_cast<ContextMenuAction>(info.wID);
63 m_action = ContextMenuItemTagNoAction;
65 if (info.fMask & MIIM_STATE) {
66 m_checked = info.fState & MFS_CHECKED;
67 m_enabled = !(info.fState & MFS_DISABLED);
74 // ContextMenuItem::nativeMenuItem doesn't set the info.dwTypeData. This is
75 // done to make the lifetime handling of the returned MENUITEMINFO easier on
76 // callers. Callers can set dwTypeData themselves (and make their own decisions
77 // about its lifetime) if they need it.
78 MENUITEMINFO ContextMenuItem::nativeMenuItem() const
80 MENUITEMINFO info = {0};
81 info.cbSize = sizeof(MENUITEMINFO);
83 if (m_type == SeparatorType) {
84 info.fMask = MIIM_FTYPE;
85 info.fType = MFT_SEPARATOR;
89 info.fMask = MIIM_FTYPE | MIIM_ID | MIIM_STATE;
90 info.fType = MFT_STRING;
94 if (m_type == SubmenuType) {
95 info.fMask |= MIIM_SUBMENU;
96 info.hSubMenu = ContextMenu::createNativeMenuFromItems(m_subMenuItems);
99 info.fState |= m_enabled ? MFS_ENABLED : MFS_DISABLED;
100 info.fState |= m_checked ? MFS_CHECKED : MFS_UNCHECKED;