diff options
author | Richard M. Stallman <rms@gnu.org> | 2002-12-23 18:06:42 +0000 |
---|---|---|
committer | Richard M. Stallman <rms@gnu.org> | 2002-12-23 18:06:42 +0000 |
commit | 37dc84ffa8ea944866ab062e23c78dd9d2671b3e (patch) | |
tree | 80454ea4de48fef8631a4c6b63a85512fe8d6519 /src/xmenu.c | |
parent | 07ce8b53eae95f8bc5ca40e99cf781966e9a71aa (diff) | |
download | emacs-37dc84ffa8ea944866ab062e23c78dd9d2671b3e.tar.gz emacs-37dc84ffa8ea944866ab062e23c78dd9d2671b3e.tar.bz2 emacs-37dc84ffa8ea944866ab062e23c78dd9d2671b3e.zip |
(parse_single_submenu): Use individual keymap's prompt
string as pane name, if there is one.
(set_frame_menubar): Save menu_items_n_panes from each call to
parse_single_submenu and use it when calling digest_single_submenu.
Diffstat (limited to 'src/xmenu.c')
-rw-r--r-- | src/xmenu.c | 21 |
1 files changed, 15 insertions, 6 deletions
diff --git a/src/xmenu.c b/src/xmenu.c index 196b38334d0..4724b2e7ff4 100644 --- a/src/xmenu.c +++ b/src/xmenu.c @@ -1434,7 +1434,13 @@ parse_single_submenu (item_key, item_name, maps) Qnil, Qnil, Qnil, Qnil); } else - single_keymap_panes (mapvec[i], item_name, item_key, 0, 10); + { + Lisp_Object prompt; + prompt = Fkeymap_prompt (mapvec[i]); + single_keymap_panes (mapvec[i], + !NILP (prompt) ? prompt : item_name, + item_key, 0, 10); + } } return top_level_items; @@ -1465,10 +1471,10 @@ digest_single_submenu (start, end, top_level_items) save_wv = 0; prev_wv = 0; - /* Loop over all panes and items made during this call - and construct a tree of widget_value objects. - Ignore the panes and items made by previous calls to - single_submenu, even though those are also in menu_items. */ + /* Loop over all panes and items made by the preceding call + to parse_single_submenu and construct a tree of widget_value objects. + Ignore the panes and items used by previous calls to + digest_single_submenu, even though those are also in menu_items. */ i = start; while (i < end) { @@ -1674,7 +1680,7 @@ set_frame_menubar (f, first_time, deep_p) widget_value *wv, *first_wv, *prev_wv = 0; int i, last_i; int *submenu_start, *submenu_end; - int *submenu_top_level_items; + int *submenu_top_level_items, *submenu_n_panes; LWLIB_ID id; @@ -1752,6 +1758,7 @@ set_frame_menubar (f, first_time, deep_p) menu_items_allocated = VECTORP (menu_items) ? ASIZE (menu_items) : 0; submenu_start = (int *) alloca (XVECTOR (items)->size * sizeof (int *)); submenu_end = (int *) alloca (XVECTOR (items)->size * sizeof (int *)); + submenu_n_panes = (int *) alloca (XVECTOR (items)->size * sizeof (int)); submenu_top_level_items = (int *) alloca (XVECTOR (items)->size * sizeof (int *)); init_menu_items (); @@ -1772,6 +1779,7 @@ set_frame_menubar (f, first_time, deep_p) menu_items_n_panes = 0; submenu_top_level_items[i] = parse_single_submenu (key, string, maps); + submenu_n_panes[i] = menu_items_n_panes; submenu_end[i] = menu_items_used; } @@ -1791,6 +1799,7 @@ set_frame_menubar (f, first_time, deep_p) for (i = 0; i < last_i; i += 4) { + menu_items_n_panes = submenu_n_panes[i]; wv = digest_single_submenu (submenu_start[i], submenu_end[i], submenu_top_level_items[i]); if (prev_wv) |