mirror of
https://github.com/MidnightCommander/mc
synced 2025-01-10 13:32:31 +03:00
* widget.h: Eliminate listbox_cback. Call listbox callback
whenever it's defined. Adjust all users.
This commit is contained in:
parent
58545e65c2
commit
bd4a76ebb3
@ -1,5 +1,8 @@
|
||||
2003-09-01 Pavel Roskin <proski@gnu.org>
|
||||
|
||||
* widget.h: Eliminate listbox_cback. Call listbox callback
|
||||
whenever it's defined. Adjust all users.
|
||||
|
||||
* widget.h: Use exact type in the listbox callback. Adjust all
|
||||
legitimate users, remove all unused callbacks.
|
||||
|
||||
|
@ -642,7 +642,7 @@ init_hotlist (int list_type)
|
||||
/* get new listbox */
|
||||
l_hotlist =
|
||||
listbox_new (UY + 1, UX + 1, COLS - 2 * UX - 8, LINES - 14,
|
||||
listbox_cback, l_call);
|
||||
listbox_nothing, l_call);
|
||||
|
||||
/* Fill the hotlist with the active VFS or the hotlist */
|
||||
#ifdef USE_VFS
|
||||
@ -690,7 +690,7 @@ init_movelist (int list_type, struct hotlist *item)
|
||||
/* get new listbox */
|
||||
l_movelist =
|
||||
listbox_new (UY + 1, UX + 1, movelist_dlg->cols - 2 * UX - 2,
|
||||
movelist_dlg->lines - 8, listbox_cback, l_call);
|
||||
movelist_dlg->lines - 8, listbox_nothing, l_call);
|
||||
|
||||
fill_listbox ();
|
||||
|
||||
|
67
src/widget.c
67
src/widget.c
@ -1966,36 +1966,33 @@ listbox_key (WListbox *l, int key)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int listbox_event (Gpm_Event *event, WListbox *l);
|
||||
static int
|
||||
listbox_callback (WListbox *l, int msg, int par)
|
||||
{
|
||||
WLEntry *e;
|
||||
WLEntry *e;
|
||||
/* int selected_color; Never used */
|
||||
int ret_code;
|
||||
|
||||
switch (msg){
|
||||
|
||||
switch (msg) {
|
||||
case WIDGET_INIT:
|
||||
return 1;
|
||||
|
||||
|
||||
case WIDGET_HOTKEY:
|
||||
if ((e = listbox_check_hotkey (l, par)) != NULL){
|
||||
if ((e = listbox_check_hotkey (l, par)) != NULL) {
|
||||
listbox_select_entry (l, e);
|
||||
|
||||
if (l->cback)
|
||||
l->action = (*l->cback) (l);
|
||||
|
||||
/* Take the appropriate action */
|
||||
if (l->action == listbox_finish){
|
||||
l->widget.parent->running = 0;
|
||||
if (l->action == listbox_finish) {
|
||||
l->widget.parent->running = 0;
|
||||
l->widget.parent->ret_value = B_ENTER;
|
||||
} else if (l->action == listbox_cback){
|
||||
if ((*l->cback)(l) == listbox_finish){
|
||||
l->widget.parent->running = 0;
|
||||
l->widget.parent->ret_value = B_ENTER;
|
||||
}
|
||||
}
|
||||
return 1;
|
||||
} else
|
||||
return 0;
|
||||
|
||||
|
||||
case WIDGET_KEY:
|
||||
if ((ret_code = listbox_key (l, par)))
|
||||
listbox_draw (l, 1);
|
||||
@ -2004,7 +2001,7 @@ listbox_callback (WListbox *l, int msg, int par)
|
||||
case WIDGET_CURSOR:
|
||||
widget_move (&l->widget, l->cursor_y, 0);
|
||||
return 1;
|
||||
|
||||
|
||||
case WIDGET_FOCUS:
|
||||
case WIDGET_UNFOCUS:
|
||||
case WIDGET_DRAW:
|
||||
@ -2018,15 +2015,15 @@ static int
|
||||
listbox_event (Gpm_Event *event, WListbox *l)
|
||||
{
|
||||
int i;
|
||||
|
||||
|
||||
Dlg_head *h = l->widget.parent;
|
||||
|
||||
|
||||
/* Single click */
|
||||
if (event->type & GPM_DOWN)
|
||||
dlg_select_widget (l->widget.parent, l);
|
||||
if (!l->list)
|
||||
return MOU_NORMAL;
|
||||
if (event->type & (GPM_DOWN|GPM_DRAG)){
|
||||
if (event->type & (GPM_DOWN | GPM_DRAG)) {
|
||||
if (event->x < 0 || event->x >= l->width)
|
||||
return MOU_REPEAT;
|
||||
if (event->y < 1)
|
||||
@ -2036,9 +2033,10 @@ listbox_event (Gpm_Event *event, WListbox *l)
|
||||
for (i = event->y - l->height; i > 0; i--)
|
||||
listbox_fwd (l);
|
||||
else
|
||||
listbox_select_entry (l, listbox_select_pos (l, l->top,
|
||||
event->y - 1));
|
||||
|
||||
listbox_select_entry (l,
|
||||
listbox_select_pos (l, l->top,
|
||||
event->y - 1));
|
||||
|
||||
/* We need to refresh ourselves since the dialog manager doesn't */
|
||||
/* know about this event */
|
||||
listbox_callback (l, WIDGET_DRAW, 0);
|
||||
@ -2047,27 +2045,24 @@ listbox_event (Gpm_Event *event, WListbox *l)
|
||||
}
|
||||
|
||||
/* Double click */
|
||||
if ((event->type & (GPM_DOUBLE|GPM_UP)) == (GPM_UP|GPM_DOUBLE)){
|
||||
if (event->x < 0 || event->x >= l->width)
|
||||
return MOU_NORMAL;
|
||||
if (event->y < 1 || event->y > l->height)
|
||||
return MOU_NORMAL;
|
||||
|
||||
if ((event->type & (GPM_DOUBLE | GPM_UP)) == (GPM_UP | GPM_DOUBLE)) {
|
||||
if (event->x < 0 || event->x >= l->width)
|
||||
return MOU_NORMAL;
|
||||
if (event->y < 1 || event->y > l->height)
|
||||
return MOU_NORMAL;
|
||||
|
||||
dlg_select_widget (l->widget.parent, l);
|
||||
listbox_select_entry (l, listbox_select_pos (l, l->top, event->y - 1));
|
||||
listbox_select_entry (l,
|
||||
listbox_select_pos (l, l->top,
|
||||
event->y - 1));
|
||||
|
||||
switch (l->action){
|
||||
case listbox_nothing:
|
||||
break;
|
||||
if (l->cback)
|
||||
l->action = (*l->cback) (l);
|
||||
|
||||
case listbox_finish:
|
||||
if (l->action == listbox_finish) {
|
||||
h->ret_value = B_ENTER;
|
||||
dlg_stop (h);
|
||||
return MOU_NORMAL;
|
||||
|
||||
case listbox_cback:
|
||||
if ((*l->cback)(l) == listbox_finish)
|
||||
return MOU_NORMAL;
|
||||
}
|
||||
}
|
||||
return MOU_NORMAL;
|
||||
|
@ -94,9 +94,8 @@ typedef struct WLEntry {
|
||||
/* Listbox actions when selecting an option: */
|
||||
enum {
|
||||
listbox_nothing,
|
||||
listbox_finish, /* finish dialog */
|
||||
listbox_cback /* call the callback routine */
|
||||
} /* listbox_action */;
|
||||
listbox_finish /* finish dialog automatically */
|
||||
};
|
||||
|
||||
struct WListbox;
|
||||
typedef struct WListbox WListbox;
|
||||
|
Loading…
Reference in New Issue
Block a user