IconList changes for gmc
Этот коммит содержится в:
родитель
428265fbc5
Коммит
1a9c7f3274
@ -1,3 +1,11 @@
|
|||||||
|
1998-11-29 Miguel de Icaza <miguel@nuclecu.unam.mx>
|
||||||
|
|
||||||
|
* gscreen.c (x_create_panel): Add panel view. Put the views
|
||||||
|
inside a new table. Add tree view to the left.
|
||||||
|
(panel_create_icon_display): IconList no longer starts in frozen state.
|
||||||
|
|
||||||
|
Update Makefile.
|
||||||
|
|
||||||
1998-11-28 Miguel de Icaza <miguel@nuclecu.unam.mx>
|
1998-11-28 Miguel de Icaza <miguel@nuclecu.unam.mx>
|
||||||
|
|
||||||
* gwidget.c (x_update_input): Use gtk_editable_changed on the entry.
|
* gwidget.c (x_update_input): Use gtk_editable_changed on the entry.
|
||||||
|
@ -35,6 +35,7 @@ GNOMESRCS = \
|
|||||||
gprop.c \
|
gprop.c \
|
||||||
gscreen.c \
|
gscreen.c \
|
||||||
gtools.c \
|
gtools.c \
|
||||||
|
gtree.c \
|
||||||
gutil.c \
|
gutil.c \
|
||||||
gview.c \
|
gview.c \
|
||||||
gwidget.c
|
gwidget.c
|
||||||
@ -55,6 +56,7 @@ GNOMEHDRS = \
|
|||||||
gpopup.h \
|
gpopup.h \
|
||||||
gprop.h \
|
gprop.h \
|
||||||
gscreen.h \
|
gscreen.h \
|
||||||
|
gtree.h \
|
||||||
gwidget.h
|
gwidget.h
|
||||||
|
|
||||||
ICONS = \
|
ICONS = \
|
||||||
@ -106,6 +108,7 @@ OBJS = $(LOBJS) $(OOBJS) \
|
|||||||
gprop.o \
|
gprop.o \
|
||||||
gscreen.o \
|
gscreen.o \
|
||||||
gtools.o \
|
gtools.o \
|
||||||
|
gtree.o \
|
||||||
gutil.o \
|
gutil.o \
|
||||||
gview.o \
|
gview.o \
|
||||||
gwidget.o
|
gwidget.o
|
||||||
@ -119,7 +122,9 @@ PIXMAPS = \
|
|||||||
link.xpm \
|
link.xpm \
|
||||||
directory.xpm \
|
directory.xpm \
|
||||||
listing-list.xpm \
|
listing-list.xpm \
|
||||||
listing-iconic.xpm
|
listing-iconic.xpm \
|
||||||
|
dir-close.xpm \
|
||||||
|
dir-open.xpm
|
||||||
|
|
||||||
DISTGNOME = Makefile.in gnome.TODO layout $(PIXMAPS) $(ICONS) $(GNOMESRCS) $(GNOMEHDRS)
|
DISTGNOME = Makefile.in gnome.TODO layout $(PIXMAPS) $(ICONS) $(GNOMESRCS) $(GNOMEHDRS)
|
||||||
|
|
||||||
|
26
gnome/gdnd.c
26
gnome/gdnd.c
@ -60,9 +60,10 @@ get_action (void)
|
|||||||
return action;
|
return action;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Looks for a panel that has the specified window for its list display. It is used to figure out
|
/*
|
||||||
* if we are receiving a drop from a panel on this MC process. If no panel is found, it returns
|
* Looks for a panel that has the specified window for its list
|
||||||
* NULL.
|
* display. It is used to figure out if we are receiving a drop from
|
||||||
|
* a panel on this MC process. If no panel is found, it returns NULL.
|
||||||
*/
|
*/
|
||||||
static WPanel *
|
static WPanel *
|
||||||
find_panel_owning_window (GdkDragContext *context)
|
find_panel_owning_window (GdkDragContext *context)
|
||||||
@ -98,8 +99,10 @@ find_panel_owning_window (GdkDragContext *context)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Performs a drop action on the specified panel. Only supports copy and move operations. The
|
/*
|
||||||
* files are moved or copied to the specified destination directory.
|
* Performs a drop action on the specified panel. Only supports copy
|
||||||
|
* and move operations. The files are moved or copied to the
|
||||||
|
* specified destination directory.
|
||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
perform_action_on_panel (WPanel *source_panel, GdkDragAction action, char *destdir)
|
perform_action_on_panel (WPanel *source_panel, GdkDragAction action, char *destdir)
|
||||||
@ -123,8 +126,9 @@ perform_action_on_panel (WPanel *source_panel, GdkDragAction action, char *destd
|
|||||||
panel_update_contents (source_panel);
|
panel_update_contents (source_panel);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Performs handling of symlinks via drag and drop. This should go away when operation windows
|
/*
|
||||||
* support links.
|
* Performs handling of symlinks via drag and drop. This should go
|
||||||
|
* away when operation windows support links.
|
||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
perform_links (GList *names, char *destdir)
|
perform_links (GList *names, char *destdir)
|
||||||
@ -143,8 +147,10 @@ perform_links (GList *names, char *destdir)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Performs a drop action manually, by going through the list of files to operate on. The files are
|
/*
|
||||||
* copied or moved to the specified directory. This should also encompass symlinking when the file
|
* Performs a drop action manually, by going through the list of files
|
||||||
|
* to operate on. The files are copied or moved to the specified
|
||||||
|
* directory. This should also encompass symlinking when the file
|
||||||
* operations window supports links.
|
* operations window supports links.
|
||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
@ -234,7 +240,7 @@ gdnd_drop_on_directory (GdkDragContext *context, GtkSelectionData *selection_dat
|
|||||||
action = context->suggested_action;
|
action = context->suggested_action;
|
||||||
|
|
||||||
/* If we are dragging from a file panel, we can display a nicer status display */
|
/* If we are dragging from a file panel, we can display a nicer status display */
|
||||||
source_panel = find_panel_owning_window (context->source_window);
|
source_panel = find_panel_owning_window (context);
|
||||||
|
|
||||||
/* Symlinks do not use file.c */
|
/* Symlinks do not use file.c */
|
||||||
|
|
||||||
|
@ -339,7 +339,7 @@ GnomeUIInfo gnome_panel_desktop_menu [] = {
|
|||||||
GnomeUIInfo gnome_panel_about_menu [] = {
|
GnomeUIInfo gnome_panel_about_menu [] = {
|
||||||
{ GNOME_APP_UI_ITEM, N_("_About"), N_("Information on this program"), gnome_about_cmd, NULL, NULL,
|
{ GNOME_APP_UI_ITEM, N_("_About"), N_("Information on this program"), gnome_about_cmd, NULL, NULL,
|
||||||
GNOME_APP_PIXMAP_STOCK, GNOME_STOCK_MENU_ABOUT },
|
GNOME_APP_PIXMAP_STOCK, GNOME_STOCK_MENU_ABOUT },
|
||||||
GNOMEUIINFO_HELP ("midnight-commander"),
|
/* GNOMEUIINFO_HELP ("midnight-commander"), */
|
||||||
GNOMEUIINFO_END
|
GNOMEUIINFO_END
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -28,6 +28,7 @@
|
|||||||
#include "dialog.h"
|
#include "dialog.h"
|
||||||
#include "gdesktop.h"
|
#include "gdesktop.h"
|
||||||
#include "gdnd.h"
|
#include "gdnd.h"
|
||||||
|
#include "gtree.h"
|
||||||
#include "gpageprop.h"
|
#include "gpageprop.h"
|
||||||
#include "gcliplabel.h"
|
#include "gcliplabel.h"
|
||||||
#include "gblist.h"
|
#include "gblist.h"
|
||||||
@ -1055,7 +1056,7 @@ panel_drag_data_get (GtkWidget *widget,
|
|||||||
static void
|
static void
|
||||||
panel_drag_data_delete (GtkWidget *widget, GdkDragContext *context, WPanel *panel)
|
panel_drag_data_delete (GtkWidget *widget, GdkDragContext *context, WPanel *panel)
|
||||||
{
|
{
|
||||||
printf ("Destination request we delete the data we sent\n");
|
/* Things is: The File manager already handles file moving */
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1684,8 +1685,7 @@ panel_create_icon_display (WPanel *panel)
|
|||||||
GTK_SIGNAL_FUNC (panel_widget_motion),
|
GTK_SIGNAL_FUNC (panel_widget_motion),
|
||||||
panel);
|
panel);
|
||||||
|
|
||||||
gnome_icon_list_thaw (ilist);
|
9 return GTK_WIDGET (ilist);
|
||||||
return GTK_WIDGET (ilist);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -2064,6 +2064,15 @@ x_create_panel (Dlg_head *h, widget_data parent, WPanel *panel)
|
|||||||
|
|
||||||
panel->table = gtk_table_new (2, 1, 0);
|
panel->table = gtk_table_new (2, 1, 0);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Tree View
|
||||||
|
*/
|
||||||
|
panel->tree = gtk_dtree_new ();
|
||||||
|
gtk_widget_show (panel->tree);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Icon and Listing display
|
||||||
|
*/
|
||||||
panel->icons = panel_create_icon_display (panel);
|
panel->icons = panel_create_icon_display (panel);
|
||||||
panel->scrollbar = gtk_vscrollbar_new (GNOME_ICON_LIST (panel->icons)->adj);
|
panel->scrollbar = gtk_vscrollbar_new (GNOME_ICON_LIST (panel->icons)->adj);
|
||||||
gtk_widget_show (panel->scrollbar);
|
gtk_widget_show (panel->scrollbar);
|
||||||
@ -2077,13 +2086,30 @@ x_create_panel (Dlg_head *h, widget_data parent, WPanel *panel)
|
|||||||
else
|
else
|
||||||
display = panel->list;
|
display = panel->list;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Pane
|
||||||
|
*/
|
||||||
|
panel->pane = gtk_hpaned_new ();
|
||||||
|
gtk_widget_show (panel->pane);
|
||||||
|
|
||||||
|
gtk_paned_add1 (GTK_PANED (panel->pane), panel->tree);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Filter
|
||||||
|
*/
|
||||||
filter = panel_create_filter (h, panel, &panel->filter_w);
|
filter = panel_create_filter (h, panel, &panel->filter_w);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Current Working directory
|
||||||
|
*/
|
||||||
cwd = panel_create_cwd (h, panel, &panel->current_dir);
|
cwd = panel_create_cwd (h, panel, &panel->current_dir);
|
||||||
|
|
||||||
/* We do not want the focus by default (and the previos add_widget just gave it to us) */
|
/* We do not want the focus by default (and the previos add_widget just gave it to us) */
|
||||||
h->current = h->current->prev;
|
h->current = h->current->prev;
|
||||||
|
|
||||||
/* buttons */
|
/*
|
||||||
|
* History buttons, and updir.
|
||||||
|
*/
|
||||||
back_p = gnome_stock_pixmap_widget_new (panel->xwindow, GNOME_STOCK_MENU_BACK);
|
back_p = gnome_stock_pixmap_widget_new (panel->xwindow, GNOME_STOCK_MENU_BACK);
|
||||||
fwd_p = gnome_stock_pixmap_widget_new (panel->xwindow, GNOME_STOCK_MENU_FORWARD);
|
fwd_p = gnome_stock_pixmap_widget_new (panel->xwindow, GNOME_STOCK_MENU_FORWARD);
|
||||||
|
|
||||||
@ -2097,13 +2123,18 @@ x_create_panel (Dlg_head *h, widget_data parent, WPanel *panel)
|
|||||||
gtk_signal_connect (GTK_OBJECT (panel->up_b), "clicked", GTK_SIGNAL_FUNC(panel_up), panel);
|
gtk_signal_connect (GTK_OBJECT (panel->up_b), "clicked", GTK_SIGNAL_FUNC(panel_up), panel);
|
||||||
panel_update_marks (panel);
|
panel_update_marks (panel);
|
||||||
|
|
||||||
/* ministatus */
|
/*
|
||||||
|
* ministatus
|
||||||
|
*/
|
||||||
panel->ministatus = gtk_label_new (""); /* was a cliplabel */
|
panel->ministatus = gtk_label_new (""); /* was a cliplabel */
|
||||||
gtk_widget_set_usize (panel->ministatus, 0, -1);
|
gtk_widget_set_usize (panel->ministatus, 0, -1);
|
||||||
gtk_misc_set_alignment (GTK_MISC (panel->ministatus), 0.0, 0.0);
|
gtk_misc_set_alignment (GTK_MISC (panel->ministatus), 0.0, 0.0);
|
||||||
gtk_misc_set_padding (GTK_MISC (panel->ministatus), 3, 0);
|
gtk_misc_set_padding (GTK_MISC (panel->ministatus), 3, 0);
|
||||||
gtk_widget_show (panel->ministatus);
|
gtk_widget_show (panel->ministatus);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Status line and packing of all of the toys
|
||||||
|
*/
|
||||||
status_line = gtk_hbox_new (0, 0);
|
status_line = gtk_hbox_new (0, 0);
|
||||||
gtk_container_border_width (GTK_CONTAINER (status_line), 3);
|
gtk_container_border_width (GTK_CONTAINER (status_line), 3);
|
||||||
|
|
||||||
@ -2120,7 +2151,9 @@ x_create_panel (Dlg_head *h, widget_data parent, WPanel *panel)
|
|||||||
#endif
|
#endif
|
||||||
gtk_widget_show_all (status_line);
|
gtk_widget_show_all (status_line);
|
||||||
|
|
||||||
/* The statusbar */
|
/*
|
||||||
|
* The statusbar
|
||||||
|
*/
|
||||||
frame = gtk_frame_new (NULL);
|
frame = gtk_frame_new (NULL);
|
||||||
gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_IN);
|
gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_IN);
|
||||||
gtk_container_border_width (GTK_CONTAINER (frame), 3);
|
gtk_container_border_width (GTK_CONTAINER (frame), 3);
|
||||||
@ -2132,24 +2165,47 @@ x_create_panel (Dlg_head *h, widget_data parent, WPanel *panel)
|
|||||||
gtk_label_set_justify (GTK_LABEL (panel->status), GTK_JUSTIFY_LEFT);
|
gtk_label_set_justify (GTK_LABEL (panel->status), GTK_JUSTIFY_LEFT);
|
||||||
gtk_widget_show_all (frame);
|
gtk_widget_show_all (frame);
|
||||||
|
|
||||||
|
|
||||||
|
panel->view_table = gtk_table_new (1, 1, 0);
|
||||||
|
gtk_widget_show (panel->view_table);
|
||||||
|
|
||||||
/* Add both the icon view and the listing view */
|
/* Add both the icon view and the listing view */
|
||||||
gtk_table_attach (GTK_TABLE (panel->table), panel->icons, 0, 1, 1, 2,
|
gtk_table_attach (GTK_TABLE (panel->view_table), panel->icons, 0, 1, 0, 1,
|
||||||
GTK_EXPAND | GTK_FILL | GTK_SHRINK,
|
GTK_EXPAND | GTK_FILL | GTK_SHRINK,
|
||||||
GTK_EXPAND | GTK_FILL | GTK_SHRINK,
|
GTK_EXPAND | GTK_FILL | GTK_SHRINK,
|
||||||
0, 0);
|
0, 0);
|
||||||
gtk_table_attach (GTK_TABLE (panel->table), panel->scrollbar, 1, 2, 1, 2,
|
gtk_table_attach (GTK_TABLE (panel->view_table), panel->scrollbar, 1, 2, 0, 1,
|
||||||
0,
|
0,
|
||||||
GTK_EXPAND | GTK_FILL | GTK_SHRINK,
|
GTK_EXPAND | GTK_FILL | GTK_SHRINK,
|
||||||
0, 0);
|
0, 0);
|
||||||
gtk_table_attach (GTK_TABLE (panel->table), panel->list, 0, 1, 1, 2,
|
gtk_table_attach (GTK_TABLE (panel->view_table), panel->list, 0, 1, 0, 1,
|
||||||
GTK_EXPAND | GTK_FILL | GTK_SHRINK,
|
GTK_EXPAND | GTK_FILL | GTK_SHRINK,
|
||||||
GTK_EXPAND | GTK_FILL | GTK_SHRINK,
|
GTK_EXPAND | GTK_FILL | GTK_SHRINK,
|
||||||
0, 0);
|
0, 0);
|
||||||
gtk_widget_show (display);
|
gtk_widget_show (display);
|
||||||
|
|
||||||
|
gtk_table_attach (GTK_TABLE (panel->table), panel->pane, 0, 1, 1, 2,
|
||||||
|
GTK_EXPAND | GTK_FILL | GTK_SHRINK,
|
||||||
|
GTK_EXPAND | GTK_FILL | GTK_SHRINK,
|
||||||
|
0, 0);
|
||||||
|
|
||||||
|
gtk_paned_add2 (GTK_PANED (panel->pane), panel->view_table);
|
||||||
|
|
||||||
gtk_table_attach (GTK_TABLE (panel->table), status_line, 0, 1, 0, 1,
|
gtk_table_attach (GTK_TABLE (panel->table), status_line, 0, 1, 0, 1,
|
||||||
GTK_EXPAND | GTK_FILL, GTK_SHRINK, 0, 0);
|
GTK_EXPAND | GTK_FILL, GTK_SHRINK, 0, 0);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ministatus_box is a container created just to put the
|
||||||
|
* panel->ministatus inside.
|
||||||
|
*
|
||||||
|
* Then the resize mode for ministatus_box is changed to stop
|
||||||
|
* any size-changed messages to be propagated above.
|
||||||
|
*
|
||||||
|
* This is required as the panel->ministatus Label is changed
|
||||||
|
* very often (to display status information). If this hack
|
||||||
|
* is not made, then the resize is queued and the whole window
|
||||||
|
* flickers each time this changes
|
||||||
|
*/
|
||||||
ministatus_box = gtk_hbox_new (FALSE, 0);
|
ministatus_box = gtk_hbox_new (FALSE, 0);
|
||||||
gtk_container_add (GTK_CONTAINER (ministatus_box), panel->ministatus);
|
gtk_container_add (GTK_CONTAINER (ministatus_box), panel->ministatus);
|
||||||
gtk_widget_show (ministatus_box);
|
gtk_widget_show (ministatus_box);
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
#include <dirent.h>
|
#include <dirent.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include "../vfs/vfs.h"
|
||||||
#include "dir-open.xpm"
|
#include "dir-open.xpm"
|
||||||
#include "dir-close.xpm"
|
#include "dir-close.xpm"
|
||||||
|
|
||||||
@ -67,11 +67,11 @@ gtk_dtree_load_path (GtkDTree *dtree, char *path, GtkCTreeNode *parent, int leve
|
|||||||
g_assert (parent);
|
g_assert (parent);
|
||||||
g_assert (dtree);
|
g_assert (dtree);
|
||||||
|
|
||||||
dir = opendir (path);
|
dir = mc_opendir (path);
|
||||||
if (!dir)
|
if (!dir)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
for (; (dirent = readdir (dir)) != NULL; ){
|
for (; (dirent = mc_readdir (dir)) != NULL; ){
|
||||||
GtkCTreeNode *sibling;
|
GtkCTreeNode *sibling;
|
||||||
struct stat s;
|
struct stat s;
|
||||||
char *full_name;
|
char *full_name;
|
||||||
@ -87,7 +87,7 @@ gtk_dtree_load_path (GtkDTree *dtree, char *path, GtkCTreeNode *parent, int leve
|
|||||||
}
|
}
|
||||||
|
|
||||||
full_name = g_concat_dir_and_file (path, dirent->d_name);
|
full_name = g_concat_dir_and_file (path, dirent->d_name);
|
||||||
res = stat (full_name, &s);
|
res = mc_stat (full_name, &s);
|
||||||
|
|
||||||
if (res == -1){
|
if (res == -1){
|
||||||
g_free (full_name);
|
g_free (full_name);
|
||||||
@ -115,7 +115,7 @@ gtk_dtree_load_path (GtkDTree *dtree, char *path, GtkCTreeNode *parent, int leve
|
|||||||
g_free (full_name);
|
g_free (full_name);
|
||||||
}
|
}
|
||||||
|
|
||||||
closedir (dir);
|
mc_closedir (dir);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
Загрузка…
x
Ссылка в новой задаче
Block a user