* Patch from Graham McDonald to skip separators in menus

* Hooked menu.c into documentation system
* s/ecore/e/ in some places


SVN revision: 5548
This commit is contained in:
cpk 2001-10-21 22:16:00 +00:00 committed by cpk
parent 79ef2ccbe9
commit 6e3d8783ca
2 changed files with 77 additions and 20 deletions

View File

@ -125,6 +125,7 @@
<section id="code"> <section id="code">
<title>Code Documentation</title> <title>Code Documentation</title>
!Isrc/iconbar.c !Isrc/iconbar.c
!Isrc/menu.c
</section> </section>
</chapter> </chapter>

View File

@ -1,12 +1,12 @@
#include "menu.h" #include "menu.h"
#include "config.h" #include "config.h"
static Evas_List open_menus = NULL; static Evas_List open_menus = NULL; /* List of all open menus */
static Evas_List menus = NULL; static Evas_List menus = NULL;
static Window menu_event_win = 0; static Window menu_event_win = 0; /* Window which originated event */
static int screen_w, screen_h; static int screen_w, screen_h; /* Screen width and height */
static int mouse_x, mouse_y; static int mouse_x, mouse_y; /* Mouse coordinates */
static int keyboard_nav = 0; static int keyboard_nav = 0; /* If non-zero, navigating with keyboard */
static void ecore_idle(void *data); static void ecore_idle(void *data);
static void e_wheel(Ecore_Event * ev); static void e_wheel(Ecore_Event * ev);
@ -125,7 +125,7 @@ e_scroller_timer(int val, void *data)
} }
static void static void
ecore_idle(void *data) e_idle(void *data)
{ {
Evas_List l; Evas_List l;
@ -182,7 +182,7 @@ e_wheel(Ecore_Event * ev)
} }
static void static void
ecore_key_down(Ecore_Event * ev) e_key_down(Ecore_Event * ev)
{ {
Ecore_Event_Key_Down *e; Ecore_Event_Key_Down *e;
int ok; int ok;
@ -276,7 +276,7 @@ ecore_key_down(Ecore_Event * ev)
} }
static void static void
ecore_key_up(Ecore_Event * ev) e_key_up(Ecore_Event * ev)
{ {
Ecore_Event_Key_Up *e; Ecore_Event_Key_Up *e;
@ -425,7 +425,7 @@ e_mouse_out(Ecore_Event * ev)
/* handling expose events */ /* handling expose events */
static void static void
ecore_window_expose(Ecore_Event * ev) e_window_expose(Ecore_Event * ev)
{ {
Ecore_Event_Window_Expose *e; Ecore_Event_Window_Expose *e;
@ -505,13 +505,22 @@ e_menu_item_set_callback(E_Menu_Item *mi, void (*func) (E_Menu *m, E_Menu_Item *
mi->func_select_data = data; mi->func_select_data = data;
} }
/**
* e_menu_hide_submenus - Hide all menus except @menus_after.
* Assumes all menus after @menus_after in the list open_menus
* are submenus of @menus_after.
*
* @menus_after: All menus after this are hidden.
*/
void void
e_menu_hide_submenus(E_Menu *menus_after) e_menu_hide_submenus(E_Menu *menus_after)
{ {
Evas_List l; Evas_List l;
/* Loop thru all open menus: */
for (l = open_menus; l; l = l->next) for (l = open_menus; l; l = l->next)
{ {
/* Found submenu, so now hide all remaining menus: */
if (l->data == menus_after) if (l->data == menus_after)
{ {
l = l->next; l = l->next;
@ -527,34 +536,72 @@ e_menu_hide_submenus(E_Menu *menus_after)
} }
} }
/**
* e_menu_select - Attempt to select the menu entry @dx entries across,
* and @dy entries down.
*
* @dx: Horizontal offset of new menu entry.
* @dy: Vertical offset of new menu entry.
*/
void void
e_menu_select(int dx, int dy) e_menu_select(int dx, int dy)
{ {
Evas_List l, ll; Evas_List l, ll;
int done = 0; int done = 0;
/* Loop through all open menus, tile done or reached end */
for (l = open_menus; (l) && (!done); l = l->next) for (l = open_menus; (l) && (!done); l = l->next)
{ {
E_Menu *m; E_Menu *m;
m = l->data; m = l->data;
/* If this is the selected menu: */
if (m->selected) if (m->selected)
{ {
/* Go through the menu entries: */
for (ll = m->entries; (ll) && (!done); ll = ll->next) for (ll = m->entries; (ll) && (!done); ll = ll->next)
{ {
E_Menu_Item *mi; E_Menu_Item *mi;
mi = ll->data; mi = ll->data;
/* Found the currently selected entry: */
if (mi->selected) if (mi->selected)
{ {
/* Vertical movement, up and down menu: */
if (dy != 0) if (dy != 0)
{ {
int ok = 0; int ok = 0;
if ((dy < 0) && (ll->prev)) ok = 1; /* Only go up or down if entry exists to do so, */
else if ((dy > 0) && (ll->next)) ok = 1; /* and skip over separators: */
if (dy < 0)
{
for ( ; ll->prev; ll = ll->prev )
{
mi = ll->prev->data;
if (!mi->separator)
{
ok = 1;
break;
}
}
}
else if (dy > 0)
{
for ( ; ll->next; ll = ll->next )
{
mi = ll->next->data;
if (!mi->separator)
{
ok = 1;
break;
}
}
}
if (ok) if (ok)
{ {
/* Unselect the old selected entry: */
if (m->selected) if (m->selected)
{ {
m->selected->selected = 0; m->selected->selected = 0;
@ -562,13 +609,14 @@ e_menu_select(int dx, int dy)
m->changed = 1; m->changed = 1;
m->selected = NULL; m->selected = NULL;
} }
if (dy < 0) mi = ll->prev->data;
else mi = ll->next->data; /* Select the new entry: */
m->selected = mi; m->selected = mi;
mi->selected = 1; mi->selected = 1;
mi->menu->redo_sel = 1; mi->menu->redo_sel = 1;
mi->menu->changed = 1; mi->menu->changed = 1;
e_menu_hide_submenus(mi->menu); e_menu_hide_submenus(mi->menu);
/* If submenu, display it: */
if (mi->submenu) if (mi->submenu)
{ {
e_menu_move_to(mi->submenu, e_menu_move_to(mi->submenu,
@ -581,10 +629,12 @@ e_menu_select(int dx, int dy)
done = 1; done = 1;
} }
} }
/* Horizontal movement, into and out of submenus: */
if (dx != 0) if (dx != 0)
{ {
int ok = 0; int ok = 0;
/* Only carry on if appropriate submenus exist: */
if ((dx < 0) && (l->prev)) ok = 1; if ((dx < 0) && (l->prev)) ok = 1;
else if ((dx > 0) && (l->next)) ok = 1; else if ((dx > 0) && (l->next)) ok = 1;
if (ok) if (ok)
@ -592,6 +642,7 @@ e_menu_select(int dx, int dy)
E_Menu_Item *mi = NULL; E_Menu_Item *mi = NULL;
E_Menu *mm; E_Menu *mm;
/* Moving out of a submenu: */
if (dx < 0) if (dx < 0)
{ {
Evas_List ll; Evas_List ll;
@ -605,6 +656,7 @@ e_menu_select(int dx, int dy)
if (mmi->submenu == m) mi = mmi; if (mmi->submenu == m) mi = mmi;
} }
} }
/* Moving into a submenu: */
else else
{ {
mm = l->next->data; mm = l->next->data;
@ -613,6 +665,7 @@ e_menu_select(int dx, int dy)
} }
if (mi) if (mi)
{ {
/* Unselect old selected entry: */
if (m->selected) if (m->selected)
{ {
m->selected->selected = 0; m->selected->selected = 0;
@ -620,11 +673,13 @@ e_menu_select(int dx, int dy)
m->changed = 1; m->changed = 1;
m->selected = NULL; m->selected = NULL;
} }
/* Select new entry: */
mm->selected = mi; mm->selected = mi;
mi->selected = 1; mi->selected = 1;
mi->menu->redo_sel = 1; mi->menu->redo_sel = 1;
mi->menu->changed = 1; mi->menu->changed = 1;
e_menu_hide_submenus(mi->menu); e_menu_hide_submenus(mi->menu);
/* If new entry is a submenu, display it: */
if (mi->submenu) if (mi->submenu)
{ {
e_menu_move_to(mi->submenu, e_menu_move_to(mi->submenu,
@ -640,6 +695,7 @@ e_menu_select(int dx, int dy)
e_menu_update_visibility(m); e_menu_update_visibility(m);
} }
} }
/* If opened a new submenu, position it and display it: */
if (!done) if (!done)
{ {
if (open_menus) if (open_menus)
@ -673,11 +729,11 @@ e_menu_init(void)
ecore_event_filter_handler_add(ECORE_EVENT_MOUSE_MOVE, e_mouse_move); ecore_event_filter_handler_add(ECORE_EVENT_MOUSE_MOVE, e_mouse_move);
ecore_event_filter_handler_add(ECORE_EVENT_MOUSE_IN, e_mouse_in); ecore_event_filter_handler_add(ECORE_EVENT_MOUSE_IN, e_mouse_in);
ecore_event_filter_handler_add(ECORE_EVENT_MOUSE_OUT, e_mouse_out); ecore_event_filter_handler_add(ECORE_EVENT_MOUSE_OUT, e_mouse_out);
ecore_event_filter_handler_add(ECORE_EVENT_WINDOW_EXPOSE, ecore_window_expose); ecore_event_filter_handler_add(ECORE_EVENT_WINDOW_EXPOSE, e_window_expose);
ecore_event_filter_handler_add(ECORE_EVENT_KEY_DOWN, ecore_key_down); ecore_event_filter_handler_add(ECORE_EVENT_KEY_DOWN, e_key_down);
ecore_event_filter_handler_add(ECORE_EVENT_KEY_UP, ecore_key_up); ecore_event_filter_handler_add(ECORE_EVENT_KEY_UP, e_key_up);
ecore_event_filter_handler_add(ECORE_EVENT_MOUSE_WHEEL, e_wheel); ecore_event_filter_handler_add(ECORE_EVENT_MOUSE_WHEEL, e_wheel);
ecore_event_filter_idle_handler_add(ecore_idle, NULL); ecore_event_filter_idle_handler_add(e_idle, NULL);
} }
void void