Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(327)

Unified Diff: Source/web/ExternalPopupMenu.cpp

Issue 475723002: Remove blank items from ExternalPopupMenu (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@validityCheck
Patch Set: Add unit tests Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: Source/web/ExternalPopupMenu.cpp
diff --git a/Source/web/ExternalPopupMenu.cpp b/Source/web/ExternalPopupMenu.cpp
index f2252ba3bd196b8381782cf01892fa21aef8d734..a4f971b46409644cde810bea2318c5dc10d58b5f 100644
--- a/Source/web/ExternalPopupMenu.cpp
+++ b/Source/web/ExternalPopupMenu.cpp
@@ -72,7 +72,7 @@ void ExternalPopupMenu::show(const FloatQuad& controlPosition, const IntSize&, i
}
WebPopupMenuInfo info;
- getPopupMenuInfo(&info);
+ getPopupMenuInfo(&info, m_popupMenuClient);
if (info.items.isEmpty())
return;
m_webExternalPopupMenu = m_webView.client()->createExternalPopupMenu(info, this);
@@ -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,27 +181,28 @@ void ExternalPopupMenu::didCancel()
m_webExternalPopupMenu = 0;
}
-void ExternalPopupMenu::getPopupMenuInfo(WebPopupMenuInfo* info)
+void ExternalPopupMenu::getPopupMenuInfo(WebPopupMenuInfo* info, PopupMenuClient* popupMenuClient)
{
- int itemCount = m_popupMenuClient->listSize();
+ ASSERT(popupMenuClient);
+ 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);
if (style.textDirection() == blink::RTL)
popupItem.textDirection = WebTextDirectionRightToLeft;
else
@@ -209,24 +210,26 @@ void ExternalPopupMenu::getPopupMenuInfo(WebPopupMenuInfo* info)
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() == blink::RTL;
- info->allowMultipleSelection = m_popupMenuClient->multiple();
+ 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() == blink::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);
+ ASSERT(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;
@@ -234,16 +237,16 @@ int ExternalPopupMenu::toPopupMenuItemIndex(int externalPopupMenuItemIndex)
return -1;
}
-int ExternalPopupMenu::toExternalPopupMenuItemIndex(int popupMenuItemIndex)
+int ExternalPopupMenu::toExternalPopupMenuItemIndex(int popupMenuItemIndex, PopupMenuClient* popupMenuClient)
{
- ASSERT(m_popupMenuClient);
+ ASSERT(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;

Powered by Google App Engine
This is Rietveld 408576698