import android.os.Build;
+import android.view.ContextMenu;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
}
};
+ /* List of menu items contained in this menu. */
public List<Item> menuItems;
+
+ /* The parent context menu, or NULL if none. */
private EmacsContextMenu parent;
+ /* The title of this context menu, or NULL if none. */
+ private String title;
+
+\f
+
/* Create a context menu with no items inside and the title TITLE,
which may be NULL. */
public static EmacsContextMenu
- createContextMenu ()
+ createContextMenu (String title)
{
EmacsContextMenu menu;
menu = new EmacsContextMenu ();
+ menu.title = title;
menu.menuItems = new ArrayList<Item> ();
return menu;
item.itemID = 0;
item.itemName = itemName;
item.tooltip = tooltip;
- item.subMenu = createContextMenu ();
+ item.subMenu = createContextMenu (itemName);
item.subMenu.parent = this;
menuItems.add (item);
/* Enter the items in this context menu to MENU.
Assume that MENU will be displayed in VIEW; this may lead to
- popupMenu being called on VIEW if a submenu is selected. */
+ popupMenu being called on VIEW if a submenu is selected.
+
+ If MENU is a ContextMenu, set its header title to the one
+ contained in this object. */
public void
expandTo (Menu menu, EmacsView view)
{
inflateMenuItems (menu, view);
+
+ /* See if menu is a ContextMenu and a title is set. */
+ if (title == null || !(menu instanceof ContextMenu))
+ return;
+
+ /* Set its title to this.title. */
+ ((ContextMenu) menu).setHeaderTitle (title);
}
/* Return the parent or NULL. */
eassert (menu_class.c_name);
FIND_METHOD_STATIC (create_context_menu, "createContextMenu",
- "()Lorg/gnu/emacs/EmacsContextMenu;");
+ "(Ljava/lang/String;)"
+ "Lorg/gnu/emacs/EmacsContextMenu;");
FIND_METHOD (add_item, "addItem", "(ILjava/lang/String;ZZZ"
"Ljava/lang/String;Z)V");
/* Push the first local frame. */
android_push_local_frame ();
+ /* Set title_string to a Java string containing TITLE if non-nil.
+ If the menu consists of more than one pane, replace the title
+ with the pane header item so that the menu looks consistent. */
+
+ title_string = NULL;
+ if (STRINGP (title) && menu_items_n_panes < 2)
+ title_string = android_build_string (title);
+
/* Push the first local frame for the context menu. */
method = menu_class.create_context_menu;
current_context_menu = context_menu
= (*android_java_env)->CallStaticObjectMethod (android_java_env,
menu_class.class,
- method);
+ method,
+ title_string);
+
+ /* Delete the unused title reference. */
+
+ if (title_string)
+ ANDROID_DELETE_LOCAL_REF (title_string);
/* Push the second local frame for temporaries. */
count1 = SPECPDL_INDEX ();
i += 1;
else if (EQ (AREF (menu_items, i), Qt))
{
+ /* If the menu contains a single pane, then the pane is
+ actually TITLE. Don't duplicate the text within the
+ context menu title. */
+
+ if (menu_items_n_panes < 2)
+ goto next_item;
+
/* This is a new pane. Switch back to the topmost context
menu. */
if (current_context_menu != context_menu)
android_exception_check ();
ANDROID_DELETE_LOCAL_REF (temp);
+ next_item:
i += MENU_ITEMS_PANE_LENGTH;
}
else