get_other_type works; sort order box works; rescan works; filter

is enabled; virtual fs setup dialog box is up; save setup; mkdir

link command is hossed.  It is more than hossed for some stoopid
reason, the thing is selecting the first file in the panel
just after I talked to it.  No matter how argumentative I get
with the code.  Have to fix next.

Commit the bits I forgot to commit yesterday.
-miguel.
This commit is contained in:
Miguel de Icaza 1998-03-11 05:55:05 +00:00
parent df4a6d6a3e
commit d934dc4afe
13 changed files with 220 additions and 48 deletions

View File

@ -1,3 +1,19 @@
Tue Mar 10 23:46:29 1998 Miguel de Icaza <miguel@nuclecu.unam.mx>
* glayout.c
* gscreen.c (x_adjust_top_file): We no longer adjust the top
displayed filename.
(panel_build_selected_file_list): Fix for the transfered data.
(panel_drop_data_available): Now drop support uses the new
coords.x and coords.y fields from the DropDataAvailableEvent to
find out which directory receives the drop.
* glayout.c: added: configure_box, configure_vfs
(get_other_type): Return the correct value.
1998-03-10 Federico Mena Quintero <federico@nuclecu.unam.mx> 1998-03-10 Federico Mena Quintero <federico@nuclecu.unam.mx>
* gscreen.c (panel_file_list_size_allocate_hook): Now we * gscreen.c (panel_file_list_size_allocate_hook): Now we
@ -18,17 +34,6 @@
* gkey.c (find_select_closure_callback): Fix = -> == typo. * gkey.c (find_select_closure_callback): Fix = -> == typo.
Tue Mar 10 14:01:47 1998 Miguel de Icaza <miguel@nuclecu.unam.mx>
* gscreen.c (x_adjust_top_file): We no longer adjust the top
displayed filename.
(panel_build_selected_file_list): Fix for the transfered data.
(panel_drop_data_available): Now drop support uses the new
coords.x and coords.y fields from the DropDataAvailableEvent to
find out which directory receives the drop.
Tue Mar 10 00:10:32 1998 Miguel de Icaza <miguel@nuclecu.unam.mx> Tue Mar 10 00:10:32 1998 Miguel de Icaza <miguel@nuclecu.unam.mx>
* gscreen.c (panel_drop_data_available): Now drop support uses the * gscreen.c (panel_drop_data_available): Now drop support uses the

View File

@ -1,3 +1,4 @@
#include <config.h>
#include "x.h" #include "x.h"
#include <stdio.h> #include <stdio.h>
#include <sys/stat.h> #include <sys/stat.h>
@ -6,6 +7,7 @@
#include "gscreen.h" #include "gscreen.h"
#include "main.h" #include "main.h"
#include "cmd.h" #include "cmd.h"
#include "boxes.h"
#define UNDEFINED_INDEX -1 #define UNDEFINED_INDEX -1
@ -123,8 +125,7 @@ get_current_type (void)
int int
get_other_type (void) get_other_type (void)
{ {
/* FIXME: This is returning CURRENT panel */ return other_panel_ptr ? view_listing : view_nothing;
return view_nothing;
} }
int int
@ -165,7 +166,7 @@ gnome_listing_cmd (GtkWidget *widget, WPanel *panel)
int view_type, use_msformat; int view_type, use_msformat;
char *user, *status; char *user, *status;
view_type = display_box (panel, &user, &status, &use_msformat, index); view_type = display_box (panel, &user, &status, &use_msformat, get_current_index ());
if (view_type == -1) if (view_type == -1)
return; return;
@ -179,15 +180,19 @@ GnomeUIInfo gnome_panel_filemenu [] = {
{ GNOME_APP_UI_ITEM, "Network link...", NULL, netlink_cmd }, { GNOME_APP_UI_ITEM, "Network link...", NULL, netlink_cmd },
{ GNOME_APP_UI_ITEM, "FTP link...", NULL, ftplink_cmd }, { GNOME_APP_UI_ITEM, "FTP link...", NULL, ftplink_cmd },
{ GNOME_APP_UI_ITEM, "Display mode...", NULL, gnome_listing_cmd }, { GNOME_APP_UI_ITEM, "Display mode...", NULL, gnome_listing_cmd },
{ GNOME_APP_UI_ITEM, "Sort order...", NULL, NULL }, { GNOME_APP_UI_ITEM, "Sort order...", NULL, sort_cmd },
{ GNOME_APP_UI_ITEM, "Filter...", NULL, NULL }, { GNOME_APP_UI_ITEM, "Filter...", NULL, filter_cmd },
{ GNOME_APP_UI_ITEM, "Rescan", NULL, NULL }, { GNOME_APP_UI_ITEM, "Rescan", NULL, reread_cmd },
{ GNOME_APP_UI_ITEM, "Find", NULL, find_cmd }, { GNOME_APP_UI_ITEM, "Find", NULL, find_cmd },
{ GNOME_APP_UI_ITEM, "Hotlist", NULL, quick_chdir_cmd }, { GNOME_APP_UI_ITEM, "Hotlist", NULL, quick_chdir_cmd },
#ifdef USE_VFS #ifdef USE_VFS
{ GNOME_APP_UI_ITEM, "Active VFS", NULL, reselect_vfs }, { GNOME_APP_UI_ITEM, "Active VFS", NULL, reselect_vfs },
#endif #endif
{ GNOME_APP_UI_ITEM, "Confirmation", NULL, confirm_box },
{ GNOME_APP_UI_ITEM, "Options", NULL, configure_box }, { GNOME_APP_UI_ITEM, "Options", NULL, configure_box },
{ GNOME_APP_UI_ITEM, "Virtual FS", NULL, configure_vfs },
{ GNOME_APP_UI_ITEM, "Save setup", NULL, save_setup_cmd },
{ GNOME_APP_UI_ITEM, "Mkdir", NULL, mkdir_cmd },
{ GNOME_APP_UI_ENDOFINFO, 0, 0 } { GNOME_APP_UI_ENDOFINFO, 0, 0 }
}; };

View File

@ -331,6 +331,7 @@ static struct {
{ "Copy...", (context_menu_callback) copy_cmd }, { "Copy...", (context_menu_callback) copy_cmd },
{ "Rename/move..", (context_menu_callback) ren_cmd }, { "Rename/move..", (context_menu_callback) ren_cmd },
{ "Delete...", (context_menu_callback) delete_cmd }, { "Delete...", (context_menu_callback) delete_cmd },
{ "Link...", (context_menu_callback) link_cmd },
{ NULL, NULL }, { NULL, NULL },
}; };
@ -448,6 +449,7 @@ internal_select_item (GtkWidget *file_list, WPanel *panel, int row)
{ {
unselect_item (panel); unselect_item (panel);
panel->selected = row; panel->selected = row;
gtk_signal_handler_block_by_data (GTK_OBJECT (file_list), panel); gtk_signal_handler_block_by_data (GTK_OBJECT (file_list), panel);
printf ("Selecttionando\n"); printf ("Selecttionando\n");
select_item (panel); select_item (panel);
@ -786,7 +788,6 @@ panel_create_file_list (WPanel *panel)
gtk_signal_connect_after (GTK_OBJECT (file_list), "size_allocate", gtk_signal_connect_after (GTK_OBJECT (file_list), "size_allocate",
GTK_SIGNAL_FUNC (panel_file_list_size_allocate_hook), GTK_SIGNAL_FUNC (panel_file_list_size_allocate_hook),
panel); panel);
gtk_signal_connect (GTK_OBJECT (file_list), "realize", gtk_signal_connect (GTK_OBJECT (file_list), "realize",
GTK_SIGNAL_FUNC (panel_realized), GTK_SIGNAL_FUNC (panel_realized),
panel); panel);

View File

@ -487,3 +487,107 @@ flags=
[mfind-Widget-button-chdir] [mfind-Widget-button-chdir]
geometry=0,4,1,1 geometry=0,4,1,1
flags= flags=
[quick_confirm-Widget-c]
geometry=3,2,1,1
flags=ew
[quick_confirm-Widget-o]
geometry=3,1,1,1
flags=ew
[quick_confirm-Widget-x]
geometry=1,3,1,1
flags=w
[quick_confirm-Widget-de]
geometry=1,1,1,1
flags=w
[quick_confirm-Widget-ov]
geometry=1,2,1,1
flags=w
[quick_confirm-Widget-e]
geometry=1,4,1,1
flags=w
[quick_vfs-Widget-label-vfs]
geometry=1,1,1,1
flags=w
[quick_vfs-Widget-input-timo-vfs]
geometry=2,1,1,1
flags=
[quick_vfs-Widget-label-pass]
geometry=1,4,1,1
flags=
[quick_vfs-Widget-button-ok]
geometry=5,1,1,1
flags=ew
[quick_vfs-Widget-input-limit]
geometry=2,3,1,1
flags=s
[quick_vfs-Widget-input-ftp-proxy]
geometry=2,6,1,1
flags=
[quick_vfs-Widget-label-tar]
geometry=1,2,1,1
flags=w
[quick_vfs-Widget-label-cache]
geometry=1,5,1,1
flags=w
[quick_vfs-Widget-input-timeout]
geometry=2,5,1,1
flags=
[quick_vfs-Widget-check-ftp-proxy]
geometry=1,6,1,1
flags=
[quick_vfs-Widget-input-passwd]
geometry=2,4,1,1
flags=
[quick_vfs-Widget-label-sec]
geometry=3,5,1,1
flags=
[quick_vfs-Widget-button-cancel]
geometry=5,2,1,1
flags=
[quick_vfs-Widget-label-sec2]
geometry=3,1,1,1
flags=
[quick_vfs-Widget-radio]
geometry=1,3,1,1
flags=e
[sort-Widget-case-check]
geometry=3,2,1,1
flags=w
[sort-Widget-ok-button]
geometry=4,1,1,1
flags=ew
[sort-Widget-reverse-check]
geometry=3,1,1,1
flags=w
[sort-Widget-cancel-button]
geometry=4,2,1,1
flags=
[sort-Widget-radio-1]
geometry=1,1,1,6
flags=n

View File

@ -1,3 +1,14 @@
Tue Mar 10 20:41:45 1998 Miguel de Icaza <miguel@nuclecu.unam.mx>
* cmd.c (unselect_cmd_panel, select_cmd_panel): To avoid races on
the X11 version, these routines now take a panel argument at
invocation time.
* widget.c (radio_callback): Call x_radio_focus for FOCUS/UNFOCUS
events.
(button_callback): Fallback to default_msg on WIDGET_FOCUS
messages.
1998-03-10 Federico Mena Quintero <federico@nuclecu.unam.mx> 1998-03-10 Federico Mena Quintero <federico@nuclecu.unam.mx>
* xslint.c (getch): Added missing "return". * xslint.c (getch): Added missing "return".

View File

@ -475,7 +475,7 @@ void reverse_selection_cmd (void)
paint_panel (cpanel); paint_panel (cpanel);
} }
void select_cmd (void) void select_cmd_panel (WPanel *panel)
{ {
char *reg_exp, *reg_exp_t; char *reg_exp, *reg_exp_t;
int i; int i;
@ -498,31 +498,36 @@ void select_cmd (void)
reg_exp_t [strlen(reg_exp_t) - 1] = 0; reg_exp_t [strlen(reg_exp_t) - 1] = 0;
} }
for (i = 0; i < cpanel->count; i++){ for (i = 0; i < panel->count; i++){
if (!strcmp( cpanel->dir.list [i].fname, "..")) if (!strcmp (panel->dir.list [i].fname, ".."))
continue; continue;
if (S_ISDIR (cpanel->dir.list [i].buf.st_mode)){ if (S_ISDIR (panel->dir.list [i].buf.st_mode)){
if (!dirflag) if (!dirflag)
continue; continue;
} else { } else {
if (dirflag) if (dirflag)
continue; continue;
} }
c = regexp_match (reg_exp_t, cpanel->dir.list [i].fname, match_file); c = regexp_match (reg_exp_t, panel->dir.list [i].fname, match_file);
if (c == -1){ if (c == -1){
message (1, " Error ", " Malformed regular expression "); message (1, " Error ", " Malformed regular expression ");
free (reg_exp); free (reg_exp);
return; return;
} }
if (c){ if (c){
do_file_mark (cpanel, i, 1); do_file_mark (panel, i, 1);
} }
} }
paint_panel (cpanel); paint_panel (panel);
free (reg_exp); free (reg_exp);
} }
void unselect_cmd (void) void select_cmd (void)
{
select_cmd_panel (cpanel);
}
void unselect_cmd_panel (WPanel *panel)
{ {
char *reg_exp, *reg_exp_t; char *reg_exp, *reg_exp_t;
int i; int i;
@ -544,30 +549,35 @@ void unselect_cmd (void)
dirflag = 1; dirflag = 1;
reg_exp_t [strlen(reg_exp_t) - 1] = 0; reg_exp_t [strlen(reg_exp_t) - 1] = 0;
} }
for (i = 0; i < cpanel->count; i++){ for (i = 0; i < panel->count; i++){
if (!strcmp( cpanel->dir.list [i].fname, "..")) if (!strcmp (panel->dir.list [i].fname, ".."))
continue; continue;
if (S_ISDIR (cpanel->dir.list [i].buf.st_mode)){ if (S_ISDIR (panel->dir.list [i].buf.st_mode)){
if (!dirflag) if (!dirflag)
continue; continue;
} else { } else {
if (dirflag) if (dirflag)
continue; continue;
} }
c = regexp_match (reg_exp_t, cpanel->dir.list [i].fname, match_file); c = regexp_match (reg_exp_t, panel->dir.list [i].fname, match_file);
if (c == -1){ if (c == -1){
message (1, " Error ", " Malformed regular expression "); message (1, " Error ", " Malformed regular expression ");
free (reg_exp); free (reg_exp);
return; return;
} }
if (c){ if (c){
do_file_mark (cpanel, i, 0); do_file_mark (panel, i, 0);
} }
} }
paint_panel (cpanel); paint_panel (panel);
free (reg_exp); free (reg_exp);
} }
void unselect_cmd (void)
{
unselect_cmd_panel (cpanel);
}
/* Check if the file exists */ /* Check if the file exists */
/* If not copy the default */ /* If not copy the default */
static int check_for_default(char *default_file, char *file) static int check_for_default(char *default_file, char *file)

View File

@ -57,6 +57,7 @@ void source_routing (void);
void info_cmd (void); void info_cmd (void);
void tree_cmd (void); void tree_cmd (void);
void listing_cmd (void); void listing_cmd (void);
void sort_cmd (void);
void switch_to_listing (int panel_index); void switch_to_listing (int panel_index);
void quick_cmd_no_menu (void); void quick_cmd_no_menu (void);
void info_cmd_no_menu (void); void info_cmd_no_menu (void);

View File

@ -631,8 +631,11 @@ void dlg_key_event (Dlg_head *h, int d_key)
int handled; int handled;
/* TAB used to cycle */ /* TAB used to cycle */
if (!h->raw && d_key == '\t') if (!h->raw && (d_key == '\t' || d_key == KEY_BACKTAB))
if (d_key == '\t')
dlg_one_down (h); dlg_one_down (h);
else
dlg_one_up (h);
else { else {
/* first can dlg_callback handle the key */ /* first can dlg_callback handle the key */

View File

@ -1068,7 +1068,7 @@ set_sort_to (WPanel *p, sortfn *sort_order)
do_re_sort (p); do_re_sort (p);
} }
static void void
sort_cmd (void) sort_cmd (void)
{ {
WPanel *p; WPanel *p;

View File

@ -11,7 +11,7 @@ enum {
KEY_BACKSPACE = 400, KEY_BACKSPACE = 400,
KEY_END, KEY_UP, KEY_DOWN, KEY_LEFT, KEY_RIGHT, KEY_END, KEY_UP, KEY_DOWN, KEY_LEFT, KEY_RIGHT,
KEY_HOME, KEY_A1, KEY_C1, KEY_NPAGE, KEY_PPAGE, KEY_IC, KEY_HOME, KEY_A1, KEY_C1, KEY_NPAGE, KEY_PPAGE, KEY_IC,
KEY_ENTER, KEY_DC, KEY_SCANCEL KEY_ENTER, KEY_DC, KEY_SCANCEL, KEY_BACKTAB
}; };
#define KEY_F(x) 1000+x #define KEY_F(x) 1000+x

View File

@ -112,6 +112,18 @@ int panel_event (Gpm_Event *event, WPanel *panel);
#define llines(p) (p->widget.lines) #define llines(p) (p->widget.lines)
#endif #endif
#ifdef PORT_NOT_FOCUS_SELECT_ITEM
# define focus_select_item(x)
#else
# define focus_select_item(x) select_item(x)
#endif
#ifdef PORT_NOT_UNFOCUS_UNSELECT_ITEM
# define unfocus_unselect_item(x)
#else
# define unfocus_unselect_item(x) unselect_item(x)
#endif
#ifdef HAVE_X #ifdef HAVE_X
# define set_colors(x) # define set_colors(x)
#else #else
@ -2042,6 +2054,15 @@ static key_map panel_keymap [] = {
{ XCTRL('t'), mark_file }, { XCTRL('t'), mark_file },
{ ALT('o'), chdir_other_panel }, { ALT('o'), chdir_other_panel },
{ ALT('l'), chdir_to_readlink }, { ALT('l'), chdir_to_readlink },
#ifdef HAVE_GNOME
{ '+', select_cmd },
{ '\\', unselect_cmd },
{ '-', unselect_cmd },
{ XCTRL('r'), reread_cmd },
{ ALT('o'), view_other_cmd },
#endif
#ifndef HAVE_X #ifndef HAVE_X
{ KEY_DC, delete_cmd}, { KEY_DC, delete_cmd},
#endif #endif
@ -2135,7 +2156,7 @@ panel_callback (Dlg_head *h, WPanel *panel, int msg, int par)
subshell_chdir (panel->cwd); subshell_chdir (panel->cwd);
show_dir (panel); show_dir (panel);
select_item (panel); focus_select_item (panel);
#ifndef HAVE_X #ifndef HAVE_X
define_label (h, (Widget *)panel, 1, "Help", help_cmd); define_label (h, (Widget *)panel, 1, "Help", help_cmd);
define_label (h, (Widget *)panel, 2, "Menu", user_menu_cmd); define_label (h, (Widget *)panel, 2, "Menu", user_menu_cmd);
@ -2157,7 +2178,7 @@ panel_callback (Dlg_head *h, WPanel *panel, int msg, int par)
} }
#ifdef HAVE_X #ifdef HAVE_X
show_dir (panel); show_dir (panel);
unselect_item (panel); unfocus_unselect_item (panel);
panel->active = 0; panel->active = 0;
#else #else
panel->active = 0; panel->active = 0;

View File

@ -62,6 +62,10 @@
# define x_destroy_cmd(w) # define x_destroy_cmd(w)
#endif #endif
#ifndef HAVE_GNOME
# define x_radio_focus_item(r)
#endif
static int button_event (Gpm_Event *event, WButton *b); static int button_event (Gpm_Event *event, WButton *b);
int quote = 0; int quote = 0;
@ -152,7 +156,11 @@ button_callback (Dlg_head *h, WButton *b, int Msg, int Par)
widget_move (&b->widget, 0, b->hotpos+off); widget_move (&b->widget, 0, b->hotpos+off);
addch (b->text [b->hotpos]); addch (b->text [b->hotpos]);
} }
if (Msg == WIDGET_FOCUS)
break;
else
return 1; return 1;
break;
#endif #endif
#endif /* !HAVE_XVIEW */ #endif /* !HAVE_XVIEW */
} }
@ -302,6 +310,7 @@ radio_callback (Dlg_head *h, WRadio *r, int Msg, int Par)
case KEY_LEFT: case KEY_LEFT:
if (r->pos > 0){ if (r->pos > 0){
r->pos--; r->pos--;
x_radio_focus_item (r);
return 1; return 1;
} }
return 0; return 0;
@ -310,21 +319,17 @@ radio_callback (Dlg_head *h, WRadio *r, int Msg, int Par)
case KEY_RIGHT: case KEY_RIGHT:
if (r->count - 1 > r->pos) { if (r->count - 1 > r->pos) {
r->pos++; r->pos++;
x_radio_focus_item (r);
return 1; return 1;
} }
} }
return 0; return 0;
#ifdef HAVE_TK #ifdef HAVE_X
/* We manage a group of widgets, while Tk manages independent
* ones, so we have to do the focusing manually
*/
case WIDGET_FOCUS: case WIDGET_FOCUS:
case WIDGET_CURSOR: case WIDGET_CURSOR:
tk_evalf ("focus %s.%d", (char *)(r->widget.wdata)+1, r->pos); x_radio_focus_item (r);
/* Do not call default_proc: we did the tk focus command */
return 1; return 1;
#endif #endif
#endif #endif

View File

@ -155,6 +155,12 @@ tk_radio_callback (ClientData cd, Tcl_Interp *interp, int argc, char *argv [])
return TCL_OK; return TCL_OK;
} }
void
x_radio_focus_item (WRadio *r)
{
tk_evalf ("focus %s.%d", (char *)(r->widget.wdata)+1, r->pos);
}
int int
x_create_radio (Dlg_head *h, widget_data parent, WRadio *r) x_create_radio (Dlg_head *h, widget_data parent, WRadio *r)
{ {