summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--views/controls/menu/native_menu_gtk.cc33
-rw-r--r--views/controls/menu/native_menu_gtk.h2
2 files changed, 26 insertions, 9 deletions
diff --git a/views/controls/menu/native_menu_gtk.cc b/views/controls/menu/native_menu_gtk.cc
index ea18243..42284f9 100644
--- a/views/controls/menu/native_menu_gtk.cc
+++ b/views/controls/menu/native_menu_gtk.cc
@@ -4,6 +4,7 @@
#include "views/controls/menu/native_menu_gtk.h"
+#include <map>
#include <string>
#include "app/gfx/gtk_util.h"
@@ -102,13 +103,26 @@ void NativeMenuGtk::CancelMenu() {
void NativeMenuGtk::Rebuild() {
ResetMenu();
- GtkRadioMenuItem* last_radio_item = NULL;
+ std::map<int, GtkRadioMenuItem*> radio_groups_;
for (int i = 0; i < model_->GetItemCount(); ++i) {
Menu2Model::ItemType type = model_->GetTypeAt(i);
- if (type == Menu2Model::TYPE_SEPARATOR)
+ if (type == Menu2Model::TYPE_SEPARATOR) {
AddSeparatorAt(i);
- else
- AddMenuItemAt(i, &last_radio_item);
+ } else if (type == Menu2Model::TYPE_RADIO) {
+ const int radio_group_id = model_->GetGroupIdAt(i);
+ std::map<int, GtkRadioMenuItem*>::const_iterator iter
+ = radio_groups_.find(radio_group_id);
+ if (iter == radio_groups_.end()) {
+ GtkWidget* new_menu_item = AddMenuItemAt(i, NULL);
+ // |new_menu_item| is the first menu item for |radio_group_id| group.
+ radio_groups_.insert(
+ std::make_pair(radio_group_id, GTK_RADIO_MENU_ITEM(new_menu_item)));
+ } else {
+ AddMenuItemAt(i, iter->second);
+ }
+ } else {
+ AddMenuItemAt(i, NULL);
+ }
}
}
@@ -140,8 +154,8 @@ void NativeMenuGtk::AddSeparatorAt(int index) {
gtk_menu_append(menu_, separator);
}
-void NativeMenuGtk::AddMenuItemAt(int index,
- GtkRadioMenuItem** last_radio_item) {
+GtkWidget* NativeMenuGtk::AddMenuItemAt(int index,
+ GtkRadioMenuItem* radio_group) {
GtkWidget* menu_item = NULL;
std::string label = ConvertAcceleratorsFromWindowsStyle(UTF16ToUTF8(
model_->GetLabelAt(index)));
@@ -152,10 +166,11 @@ void NativeMenuGtk::AddMenuItemAt(int index,
menu_item = gtk_check_menu_item_new_with_mnemonic(label.c_str());
break;
case Menu2Model::TYPE_RADIO:
- if (*last_radio_item) {
+ if (radio_group) {
menu_item = gtk_radio_menu_item_new_with_mnemonic_from_widget(
- *last_radio_item, label.c_str());
+ radio_group, label.c_str());
} else {
+ // The item does not belong to any existing radio button groups.
menu_item = gtk_radio_menu_item_new_with_mnemonic(NULL, label.c_str());
}
break;
@@ -197,6 +212,8 @@ void NativeMenuGtk::AddMenuItemAt(int index,
this);
gtk_widget_show(menu_item);
gtk_menu_append(menu_, menu_item);
+
+ return menu_item;
}
void NativeMenuGtk::ResetMenu() {
diff --git a/views/controls/menu/native_menu_gtk.h b/views/controls/menu/native_menu_gtk.h
index 92c500d..b055f4f 100644
--- a/views/controls/menu/native_menu_gtk.h
+++ b/views/controls/menu/native_menu_gtk.h
@@ -31,7 +31,7 @@ class NativeMenuGtk : public MenuWrapper {
static void OnMenuHidden(GtkWidget* widget, NativeMenuGtk* menu);
void AddSeparatorAt(int index);
- void AddMenuItemAt(int index, GtkRadioMenuItem** last_radio_item);
+ GtkWidget* AddMenuItemAt(int index, GtkRadioMenuItem* radio_group);
void ResetMenu();