+2004-11-01 Jan Dj\e,Ad\e(Brv <jan.h.d@swipnet.se>
+
+ * xlwmenu.c (find_first_selectable, find_next_selectable)
+ (find_prev_selectable): Rename parameter skip_no_call_data to
+ skip_titles. Recognize titles as having no call_data and no contents.
+ (Down, Up): Comment update.
+
2004-08-30 Jan Dj\e,Ad\e(Brv <jan.h.d@swipnet.se>
* lwlib.h (_widget_value): Added lname and lkey.
}
static widget_value *
-find_first_selectable (mw, item, skip_no_call_data)
+find_first_selectable (mw, item, skip_titles)
XlwMenuWidget mw;
widget_value *item;
- int skip_no_call_data;
+ int skip_titles;
{
widget_value *current = item;
enum menu_separator separator;
while (lw_separator_p (current->name, &separator, 0) || !current->enabled
- || (skip_no_call_data && !current->call_data))
+ || (skip_titles && !current->call_data && !current->contents))
if (current->next)
current=current->next;
else
- return NULL;
+ return NULL;
return current;
}
static widget_value *
-find_next_selectable (mw, item, skip_no_call_data)
+find_next_selectable (mw, item, skip_titles)
XlwMenuWidget mw;
widget_value *item;
{
while (current->next && (current=current->next) &&
(lw_separator_p (current->name, &separator, 0) || !current->enabled
- || (skip_no_call_data && !current->call_data)))
+ || (skip_titles && !current->call_data && !current->contents)))
;
if (current == item)
while (lw_separator_p (current->name, &separator, 0)
|| !current->enabled
- || (skip_no_call_data && !current->call_data))
+ || (skip_titles && !current->call_data
+ && !current->contents))
{
if (current->next)
current=current->next;
}
static widget_value *
-find_prev_selectable (mw, item, skip_no_call_data)
+find_prev_selectable (mw, item, skip_titles)
XlwMenuWidget mw;
widget_value *item;
{
widget_value *current = item;
widget_value *prev = item;
- while ((current=find_next_selectable (mw, current, skip_no_call_data))
+ while ((current=find_next_selectable (mw, current, skip_titles))
!= item)
{
if (prev == current)
if (mw->menu.old_depth == mw->menu.top_depth)
/* When <down> in the menu-bar is pressed, display the corresponding
sub-menu and select the first selectable menu item there.
- If this is a popup menu, skip items with zero call data (title of
- the popup). */
+ If this is a popup menu, skip title item of the popup. */
set_new_state (mw,
find_first_selectable (mw,
selected_item->contents,
last selectable item in the list. So we select the first
selectable one and find the previous selectable item. Is there
a better way? */
- /* If this is a popup menu, skip items with zero call data (title of
- the popup). */
+ /* If this is a popup menu, skip title item of the popup. */
set_new_state (mw,
find_first_selectable (mw,
selected_item->contents,