| Index: Source/web/ExternalPopupMenu.cpp
|
| diff --git a/Source/web/ExternalPopupMenu.cpp b/Source/web/ExternalPopupMenu.cpp
|
| index 9aac7ee8538ca85d22f6f952881863049e6cb1e7..49c2e0fca187c748c16a6fc7afef08dc84ecd208 100644
|
| --- a/Source/web/ExternalPopupMenu.cpp
|
| +++ b/Source/web/ExternalPopupMenu.cpp
|
| @@ -71,7 +71,7 @@ void ExternalPopupMenu::show(const FloatQuad& controlPosition, const IntSize&, i
|
| }
|
|
|
| WebPopupMenuInfo info;
|
| - getPopupMenuInfo(&info);
|
| + getPopupMenuInfo(info, *m_popupMenuClient);
|
| if (info.items.isEmpty())
|
| return;
|
| WebLocalFrameImpl* webframe = WebLocalFrameImpl::fromFrame(m_localFrame.get());
|
| @@ -126,7 +126,7 @@ void ExternalPopupMenu::disconnectClient()
|
| void ExternalPopupMenu::didChangeSelection(int index)
|
| {
|
| if (m_popupMenuClient)
|
| - m_popupMenuClient->selectionChanged(toPopupMenuItemIndex(index));
|
| + m_popupMenuClient->selectionChanged(toPopupMenuItemIndex(index, *m_popupMenuClient));
|
| }
|
|
|
| void ExternalPopupMenu::didAcceptIndex(int index)
|
| @@ -134,7 +134,7 @@ void ExternalPopupMenu::didAcceptIndex(int index)
|
| // Calling methods on the PopupMenuClient might lead to this object being
|
| // derefed. This ensures it does not get deleted while we are running this
|
| // method.
|
| - int popupMenuItemIndex = toPopupMenuItemIndex(index);
|
| + int popupMenuItemIndex = toPopupMenuItemIndex(index, *m_popupMenuClient);
|
| RefPtr<ExternalPopupMenu> guard(this);
|
|
|
| if (m_popupMenuClient) {
|
| @@ -160,7 +160,7 @@ void ExternalPopupMenu::didAcceptIndices(const WebVector<int>& indices)
|
| m_popupMenuClient->valueChanged(static_cast<unsigned>(-1), true);
|
| else {
|
| for (size_t i = 0; i < indices.size(); ++i)
|
| - m_popupMenuClient->listBoxSelectItem(toPopupMenuItemIndex(indices[i]), (i > 0), false, (i == indices.size() - 1));
|
| + m_popupMenuClient->listBoxSelectItem(toPopupMenuItemIndex(indices[i], *m_popupMenuClient), (i > 0), false, (i == indices.size() - 1));
|
| }
|
|
|
| // The call to valueChanged above might have lead to a call to
|
| @@ -181,49 +181,51 @@ void ExternalPopupMenu::didCancel()
|
| m_webExternalPopupMenu = 0;
|
| }
|
|
|
| -void ExternalPopupMenu::getPopupMenuInfo(WebPopupMenuInfo* info)
|
| +void ExternalPopupMenu::getPopupMenuInfo(WebPopupMenuInfo& info, PopupMenuClient& popupMenuClient)
|
| {
|
| - int itemCount = m_popupMenuClient->listSize();
|
| + int itemCount = popupMenuClient.listSize();
|
| int count = 0;
|
| Vector<WebMenuItemInfo> items(static_cast<size_t>(itemCount));
|
| for (int i = 0; i < itemCount; ++i) {
|
| - PopupMenuStyle style = m_popupMenuClient->itemStyle(i);
|
| + PopupMenuStyle style = popupMenuClient.itemStyle(i);
|
| if (style.isDisplayNone())
|
| continue;
|
|
|
| WebMenuItemInfo& popupItem = items[count++];
|
| - popupItem.label = m_popupMenuClient->itemText(i);
|
| - popupItem.toolTip = m_popupMenuClient->itemToolTip(i);
|
| - if (m_popupMenuClient->itemIsSeparator(i))
|
| + popupItem.label = popupMenuClient.itemText(i);
|
| + popupItem.toolTip = popupMenuClient.itemToolTip(i);
|
| + if (popupMenuClient.itemIsSeparator(i))
|
| popupItem.type = WebMenuItemInfo::Separator;
|
| - else if (m_popupMenuClient->itemIsLabel(i))
|
| + else if (popupMenuClient.itemIsLabel(i))
|
| popupItem.type = WebMenuItemInfo::Group;
|
| else
|
| popupItem.type = WebMenuItemInfo::Option;
|
| - popupItem.enabled = m_popupMenuClient->itemIsEnabled(i);
|
| - popupItem.checked = m_popupMenuClient->itemIsSelected(i);
|
| + popupItem.enabled = popupMenuClient.itemIsEnabled(i);
|
| + popupItem.checked = popupMenuClient.itemIsSelected(i);
|
| popupItem.textDirection = toWebTextDirection(style.textDirection());
|
| popupItem.hasTextDirectionOverride = style.hasTextDirectionOverride();
|
| }
|
|
|
| - info->itemHeight = m_popupMenuClient->menuStyle().font().fontMetrics().height();
|
| - info->itemFontSize = static_cast<int>(m_popupMenuClient->menuStyle().font().fontDescription().computedSize());
|
| - info->selectedIndex = toExternalPopupMenuItemIndex(m_popupMenuClient->selectedIndex());
|
| - info->rightAligned = m_popupMenuClient->menuStyle().textDirection() == RTL;
|
| - info->allowMultipleSelection = m_popupMenuClient->multiple();
|
| - info->items = items;
|
| + info.itemHeight = popupMenuClient.menuStyle().font().fontMetrics().height();
|
| + info.itemFontSize = static_cast<int>(popupMenuClient.menuStyle().font().fontDescription().computedSize());
|
| + info.selectedIndex = toExternalPopupMenuItemIndex(popupMenuClient.selectedIndex(), popupMenuClient);
|
| + info.rightAligned = popupMenuClient.menuStyle().textDirection() == RTL;
|
| + info.allowMultipleSelection = popupMenuClient.multiple();
|
| + if (count < itemCount)
|
| + items.shrink(count);
|
| + info.items = items;
|
| +
|
| }
|
|
|
| -int ExternalPopupMenu::toPopupMenuItemIndex(int externalPopupMenuItemIndex)
|
| +int ExternalPopupMenu::toPopupMenuItemIndex(int externalPopupMenuItemIndex, PopupMenuClient& popupMenuClient)
|
| {
|
| - ASSERT(m_popupMenuClient);
|
| if (externalPopupMenuItemIndex < 0)
|
| return externalPopupMenuItemIndex;
|
|
|
| - int itemCount = m_popupMenuClient->listSize();
|
| + int itemCount = popupMenuClient.listSize();
|
| int indexTracker = 0;
|
| for (int i = 0; i < itemCount ; ++i) {
|
| - if (m_popupMenuClient->itemStyle(i).isDisplayNone())
|
| + if (popupMenuClient.itemStyle(i).isDisplayNone())
|
| continue;
|
| if (indexTracker++ == externalPopupMenuItemIndex)
|
| return i;
|
| @@ -231,16 +233,15 @@ int ExternalPopupMenu::toPopupMenuItemIndex(int externalPopupMenuItemIndex)
|
| return -1;
|
| }
|
|
|
| -int ExternalPopupMenu::toExternalPopupMenuItemIndex(int popupMenuItemIndex)
|
| +int ExternalPopupMenu::toExternalPopupMenuItemIndex(int popupMenuItemIndex, PopupMenuClient& popupMenuClient)
|
| {
|
| - ASSERT(m_popupMenuClient);
|
| if (popupMenuItemIndex < 0)
|
| return popupMenuItemIndex;
|
|
|
| - int itemCount = m_popupMenuClient->listSize();
|
| + int itemCount = popupMenuClient.listSize();
|
| int indexTracker = 0;
|
| for (int i = 0; i < itemCount; ++i) {
|
| - if (m_popupMenuClient->itemStyle(i).isDisplayNone())
|
| + if (popupMenuClient.itemStyle(i).isDisplayNone())
|
| continue;
|
| if (popupMenuItemIndex == i)
|
| return indexTracker;
|
|
|