1999-02-17 Federico Mena Quintero <federico@nuclecu.unam.mx>
* dir.c (if_link_is_exe): Made this function take in a directory argument as well -- the sought file may not be in the cwd, and file entries do not carry the directory the file refers to. * screen.c (do_enter_on_file_entry): Pass in the cpanel->cwd to if_link_is_exe(). 1999-02-17 Federico Mena Quintero <federico@nuclecu.unam.mx> * gdesktop.c (do_mount_umount): Removed unused variable. (do_eject): Return FALSE if there is no eject command. (setup_devices): Removed unused variable. * gdnd.c (drop_on_file): Pass the directory to if_link_is_exe(). (gdnd_validate_action): Likewise. (gdnd_perform_drop): Made consistent with the rest of the code by taking the directory name along with the file entry. (gdnd_validate_action): Likewise. * gdesktop.c (icon_drag_motion): Pass the directory to the gdnd functions. (icon_drag_data_received): Likewise. (desktop_drag_motion): Likewise. (desktop_drag_data_received): Likewise. (desktop_icon_info_open): Pass the directory to if_link_is_exe(). * gscreen.c (panel_icon_list_drag_data_received): Pass the directory to gdnd functions. (panel_clist_drag_data_received): Likewise. (panel_tree_drag_data_received): Likewise. (panel_clist_drag_motion): Likewise. (panel_icon_list_drag_motion): Likewise.
Этот коммит содержится в:
родитель
6eb9a08b29
Коммит
b683efeda3
@ -1,3 +1,29 @@
|
|||||||
|
1999-02-17 Federico Mena Quintero <federico@nuclecu.unam.mx>
|
||||||
|
|
||||||
|
* gdesktop.c (do_mount_umount): Removed unused variable.
|
||||||
|
(do_eject): Return FALSE if there is no eject command.
|
||||||
|
(setup_devices): Removed unused variable.
|
||||||
|
|
||||||
|
* gdnd.c (drop_on_file): Pass the directory to if_link_is_exe().
|
||||||
|
(gdnd_validate_action): Likewise.
|
||||||
|
(gdnd_perform_drop): Made consistent with the rest of the code by
|
||||||
|
taking the directory name along with the file entry.
|
||||||
|
(gdnd_validate_action): Likewise.
|
||||||
|
|
||||||
|
* gdesktop.c (icon_drag_motion): Pass the directory to the gdnd
|
||||||
|
functions.
|
||||||
|
(icon_drag_data_received): Likewise.
|
||||||
|
(desktop_drag_motion): Likewise.
|
||||||
|
(desktop_drag_data_received): Likewise.
|
||||||
|
(desktop_icon_info_open): Pass the directory to if_link_is_exe().
|
||||||
|
|
||||||
|
* gscreen.c (panel_icon_list_drag_data_received): Pass the
|
||||||
|
directory to gdnd functions.
|
||||||
|
(panel_clist_drag_data_received): Likewise.
|
||||||
|
(panel_tree_drag_data_received): Likewise.
|
||||||
|
(panel_clist_drag_motion): Likewise.
|
||||||
|
(panel_icon_list_drag_motion): Likewise.
|
||||||
|
|
||||||
1999-02-17 Miguel de Icaza <miguel@nuclecu.unam.mx>
|
1999-02-17 Miguel de Icaza <miguel@nuclecu.unam.mx>
|
||||||
|
|
||||||
* gdesktop.c (reload_desktop_icons): Load the information provided
|
* gdesktop.c (reload_desktop_icons): Load the information provided
|
||||||
|
@ -482,7 +482,9 @@ reload_desktop_icons (int user_pos, int xpos, int ypos)
|
|||||||
orig_xpos = orig_ypos = 0;
|
orig_xpos = orig_ypos = 0;
|
||||||
|
|
||||||
for (sl = need_position_list; sl; sl = sl->next) {
|
for (sl = need_position_list; sl; sl = sl->next) {
|
||||||
file_and_url_t *fau = sl->data;
|
file_and_url_t *fau;
|
||||||
|
|
||||||
|
fau = sl->data;
|
||||||
|
|
||||||
if (user_pos && sl == need_position_list) {
|
if (user_pos && sl == need_position_list) {
|
||||||
/* If we are on the first icon, place it "by hand".
|
/* If we are on the first icon, place it "by hand".
|
||||||
@ -503,40 +505,46 @@ reload_desktop_icons (int user_pos, int xpos, int ypos)
|
|||||||
get_icon_auto_pos (&xpos, &ypos);
|
get_icon_auto_pos (&xpos, &ypos);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/* If the file dropped was a .desktop file, pull the suggested
|
||||||
* If the file dropped was a .desktop file, pull the suggested
|
|
||||||
* title and icon from there
|
* title and icon from there
|
||||||
*/
|
*/
|
||||||
mime = gnome_mime_type_or_default (fau->filename, NULL);
|
mime = gnome_mime_type_or_default (fau->filename, NULL);
|
||||||
if (mime && strcmp (mime, "application/x-gnome-app-info") == 0){
|
if (mime && strcmp (mime, "application/x-gnome-app-info") == 0) {
|
||||||
GnomeDesktopEntry *entry;
|
GnomeDesktopEntry *entry;
|
||||||
char *fullname = g_concat_dir_and_file (desktop_directory, fau->filename);
|
char *fullname;
|
||||||
|
|
||||||
|
fullname = g_concat_dir_and_file (desktop_directory, fau->filename);
|
||||||
entry = gnome_desktop_entry_load (fullname);
|
entry = gnome_desktop_entry_load (fullname);
|
||||||
if (entry){
|
if (entry) {
|
||||||
if (entry->name){
|
if (entry->name) {
|
||||||
if (fau->caption)
|
if (fau->caption)
|
||||||
g_free (fau->caption);
|
g_free (fau->caption);
|
||||||
|
|
||||||
fau->caption = g_strdup (entry->name);
|
fau->caption = g_strdup (entry->name);
|
||||||
gnome_metadata_set (fullname, "icon-caption",
|
gnome_metadata_set (fullname, "icon-caption",
|
||||||
strlen (fau->caption)+1, fau->caption);
|
strlen (fau->caption) + 1,
|
||||||
|
fau->caption);
|
||||||
}
|
}
|
||||||
if (entry->icon){
|
|
||||||
|
if (entry->icon)
|
||||||
gnome_metadata_set (fullname, "icon-filename",
|
gnome_metadata_set (fullname, "icon-filename",
|
||||||
strlen (entry->icon)+1, entry->icon);
|
strlen (entry->icon) + 1,
|
||||||
}
|
entry->icon);
|
||||||
|
|
||||||
gnome_desktop_entry_free (entry);
|
gnome_desktop_entry_free (entry);
|
||||||
}
|
}
|
||||||
g_free (fullname);
|
g_free (fullname);
|
||||||
}
|
}
|
||||||
|
|
||||||
dii = desktop_icon_info_new (fau->filename, fau->url, fau->caption, xpos, ypos);
|
dii = desktop_icon_info_new (fau->filename, fau->url, fau->caption, xpos, ypos);
|
||||||
gtk_widget_show (dii->dicon);
|
gtk_widget_show (dii->dicon);
|
||||||
|
|
||||||
if (fau->url)
|
if (fau->url)
|
||||||
g_free (fau->url);
|
g_free (fau->url);
|
||||||
|
|
||||||
if (fau->caption)
|
if (fau->caption)
|
||||||
g_free (fau->caption);
|
g_free (fau->caption);
|
||||||
|
|
||||||
g_free (fau->filename);
|
g_free (fau->filename);
|
||||||
g_free (fau);
|
g_free (fau);
|
||||||
}
|
}
|
||||||
@ -914,7 +922,7 @@ do_mount_umount (char *filename, gboolean is_mount)
|
|||||||
{
|
{
|
||||||
static char *mount_command;
|
static char *mount_command;
|
||||||
static char *umount_command;
|
static char *umount_command;
|
||||||
char *command, *op;
|
char *op;
|
||||||
char buffer [128];
|
char buffer [128];
|
||||||
|
|
||||||
if (is_mount){
|
if (is_mount){
|
||||||
@ -979,9 +987,10 @@ do_eject (char *filename)
|
|||||||
char *eject_command = find_command (eject_known_locations);
|
char *eject_command = find_command (eject_known_locations);
|
||||||
char *command;
|
char *command;
|
||||||
FILE *f;
|
FILE *f;
|
||||||
|
|
||||||
if (!eject_command)
|
if (!eject_command)
|
||||||
return;
|
return FALSE;
|
||||||
|
|
||||||
command = g_strconcat (eject_command, " ", filename, NULL);
|
command = g_strconcat (eject_command, " ", filename, NULL);
|
||||||
open_error_pipe ();
|
open_error_pipe ();
|
||||||
f = popen (command, "r");
|
f = popen (command, "r");
|
||||||
@ -989,6 +998,7 @@ do_eject (char *filename)
|
|||||||
close_error_pipe (1, _("While running the eject command"));
|
close_error_pipe (1, _("While running the eject command"));
|
||||||
else
|
else
|
||||||
close_error_pipe (0, 0);
|
close_error_pipe (0, 0);
|
||||||
|
|
||||||
pclose (f);
|
pclose (f);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
@ -1029,8 +1039,8 @@ desktop_icon_info_open (DesktopIconInfo *dii)
|
|||||||
if (S_ISDIR (fe->buf.st_mode) || link_isdir (fe))
|
if (S_ISDIR (fe->buf.st_mode) || link_isdir (fe))
|
||||||
new_panel_at (filename);
|
new_panel_at (filename);
|
||||||
else {
|
else {
|
||||||
if (!try_to_mount (filename, fe)){
|
if (!try_to_mount (filename, fe)) {
|
||||||
if (is_exe (fe->buf.st_mode) && if_link_is_exe (fe))
|
if (is_exe (fe->buf.st_mode) && if_link_is_exe (desktop_directory, fe))
|
||||||
my_system (EXECUTE_AS_SHELL, shell, filename);
|
my_system (EXECUTE_AS_SHELL, shell, filename);
|
||||||
else
|
else
|
||||||
gmc_open_filename (filename, NULL);
|
gmc_open_filename (filename, NULL);
|
||||||
@ -1450,6 +1460,7 @@ icon_drag_motion (GtkWidget *widget, GdkDragContext *context, gint x, gint y, gu
|
|||||||
TRUE,
|
TRUE,
|
||||||
source_widget != NULL,
|
source_widget != NULL,
|
||||||
source_widget && is_desktop_icon,
|
source_widget && is_desktop_icon,
|
||||||
|
desktop_directory,
|
||||||
fe,
|
fe,
|
||||||
dii->selected);
|
dii->selected);
|
||||||
|
|
||||||
@ -1559,10 +1570,11 @@ icon_drag_data_received (GtkWidget *widget, GdkDragContext *context, gint x, gin
|
|||||||
|
|
||||||
full_name = g_concat_dir_and_file (desktop_directory, dii->filename);
|
full_name = g_concat_dir_and_file (desktop_directory, dii->filename);
|
||||||
fe = file_entry_from_file (full_name);
|
fe = file_entry_from_file (full_name);
|
||||||
|
g_free (full_name);
|
||||||
if (!fe)
|
if (!fe)
|
||||||
return; /* eeeek */
|
return; /* eeeek */
|
||||||
|
|
||||||
if (gdnd_perform_drop (context, data, fe, full_name))
|
if (gdnd_perform_drop (context, data, desktop_directory, fe))
|
||||||
reload_desktop_icons (FALSE, 0, 0);
|
reload_desktop_icons (FALSE, 0, 0);
|
||||||
|
|
||||||
file_entry_free (fe);
|
file_entry_free (fe);
|
||||||
@ -1783,8 +1795,6 @@ setup_devices (void)
|
|||||||
int count;
|
int count;
|
||||||
|
|
||||||
if (strncmp (short_dev_name, "fd", 2) == 0){
|
if (strncmp (short_dev_name, "fd", 2) == 0){
|
||||||
char *full;
|
|
||||||
|
|
||||||
format = _("floppy %d");
|
format = _("floppy %d");
|
||||||
count = floppy++;
|
count = floppy++;
|
||||||
} else if (strncmp (short_dev_name, "hd", 2) == 0 || strncmp (short_dev_name, "sd", 2) == 0){
|
} else if (strncmp (short_dev_name, "hd", 2) == 0 || strncmp (short_dev_name, "sd", 2) == 0){
|
||||||
@ -2028,6 +2038,7 @@ desktop_drag_motion (GtkWidget *widget, GdkDragContext *context, gint x, gint y,
|
|||||||
TRUE,
|
TRUE,
|
||||||
source_widget != NULL,
|
source_widget != NULL,
|
||||||
source_widget && is_desktop_icon,
|
source_widget && is_desktop_icon,
|
||||||
|
desktop_directory,
|
||||||
NULL,
|
NULL,
|
||||||
FALSE);
|
FALSE);
|
||||||
|
|
||||||
@ -2052,14 +2063,20 @@ desktop_drag_data_received (GtkWidget *widget, GdkDragContext *context, gint x,
|
|||||||
drop_desktop_icons (context, data, x, y);
|
drop_desktop_icons (context, data, x, y);
|
||||||
else {
|
else {
|
||||||
file_entry *desktop_fe;
|
file_entry *desktop_fe;
|
||||||
|
char *directory, *p;
|
||||||
|
|
||||||
desktop_fe = file_entry_from_file (desktop_directory);
|
desktop_fe = file_entry_from_file (desktop_directory);
|
||||||
if (!desktop_fe)
|
if (!desktop_fe)
|
||||||
return; /* eeek */
|
return; /* eeek */
|
||||||
|
|
||||||
if (gdnd_perform_drop (context, data, desktop_fe, desktop_directory))
|
p = strrchr (desktop_directory, PATH_SEP);
|
||||||
|
g_assert (p);
|
||||||
|
directory = g_strndup (desktop_directory, p - desktop_directory);
|
||||||
|
|
||||||
|
if (gdnd_perform_drop (context, data, directory, desktop_fe))
|
||||||
reload_desktop_icons (TRUE, x, y);
|
reload_desktop_icons (TRUE, x, y);
|
||||||
|
|
||||||
|
g_free (directory);
|
||||||
file_entry_free (desktop_fe);
|
file_entry_free (desktop_fe);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
69
gnome/gdnd.c
69
gnome/gdnd.c
@ -290,38 +290,52 @@ drop_url_on_directory (GdkDragContext *context, GtkSelectionData *selection_data
|
|||||||
/* Drop stuff on a directory */
|
/* Drop stuff on a directory */
|
||||||
static int
|
static int
|
||||||
drop_on_directory (GdkDragContext *context, GtkSelectionData *selection_data,
|
drop_on_directory (GdkDragContext *context, GtkSelectionData *selection_data,
|
||||||
GdkDragAction action, char *destdir)
|
GdkDragAction action, char *directory, file_entry *dest_fe)
|
||||||
{
|
{
|
||||||
if (gdnd_drag_context_has_target (context, TARGET_URI_LIST))
|
char *full_name;
|
||||||
drop_uri_list_on_directory (context, selection_data, action, destdir);
|
int retval;
|
||||||
else if (gdnd_drag_context_has_target (context, TARGET_URL))
|
|
||||||
drop_url_on_directory (context, selection_data, destdir);
|
|
||||||
else
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
return TRUE;
|
retval = FALSE;
|
||||||
|
full_name = g_concat_dir_and_file (directory, dest_fe->fname);
|
||||||
|
|
||||||
|
if (gdnd_drag_context_has_target (context, TARGET_URI_LIST)) {
|
||||||
|
drop_uri_list_on_directory (context, selection_data, action, full_name);
|
||||||
|
retval = TRUE;
|
||||||
|
} else if (gdnd_drag_context_has_target (context, TARGET_URL)) {
|
||||||
|
drop_url_on_directory (context, selection_data, full_name);
|
||||||
|
retval = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_free (full_name);
|
||||||
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Drop stuff on a non-directory file. This uses metadata and MIME as well. */
|
/* Drop stuff on a non-directory file. This uses metadata and MIME as well. */
|
||||||
static int
|
static int
|
||||||
drop_on_file (GdkDragContext *context, GtkSelectionData *selection_data,
|
drop_on_file (GdkDragContext *context, GtkSelectionData *selection_data,
|
||||||
file_entry *dest_fe, char *dest_name)
|
char *directory, file_entry *dest_fe)
|
||||||
{
|
{
|
||||||
int size;
|
int size;
|
||||||
char *buf;
|
char *buf;
|
||||||
const char *mime_type;
|
const char *mime_type;
|
||||||
|
char *full_name;
|
||||||
|
int retval;
|
||||||
|
|
||||||
|
retval = FALSE; /* assume we cannot drop */
|
||||||
|
full_name = g_concat_dir_and_file (directory, dest_fe->fname);
|
||||||
|
|
||||||
/* 1. Try to use a metadata-based drop action */
|
/* 1. Try to use a metadata-based drop action */
|
||||||
|
|
||||||
if (gnome_metadata_get (dest_name, "drop-action", &size, &buf) == 0) {
|
if (gnome_metadata_get (full_name, "drop-action", &size, &buf) == 0) {
|
||||||
/*action_drop (dest_name, buf, context, selection_data);*/ /* Fixme: i'm undefined */
|
/*action_drop (dest_name, buf, context, selection_data);*/ /* Fixme: i'm undefined */
|
||||||
g_free (buf);
|
g_free (buf);
|
||||||
return TRUE;
|
retval = TRUE;
|
||||||
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 2. Try a drop action from the MIME-type */
|
/* 2. Try a drop action from the MIME-type */
|
||||||
|
|
||||||
mime_type = gnome_mime_type_or_default (dest_name, NULL);
|
mime_type = gnome_mime_type_or_default (full_name, NULL);
|
||||||
if (mime_type) {
|
if (mime_type) {
|
||||||
char *action;
|
char *action;
|
||||||
|
|
||||||
@ -329,13 +343,14 @@ drop_on_file (GdkDragContext *context, GtkSelectionData *selection_data,
|
|||||||
if (action) {
|
if (action) {
|
||||||
/* Fixme: i'm undefined */
|
/* Fixme: i'm undefined */
|
||||||
/*action_drop (dest_name, action, context, selection_data);*/
|
/*action_drop (dest_name, action, context, selection_data);*/
|
||||||
return TRUE;
|
retval = TRUE;
|
||||||
|
goto out;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 3. If executable, try metadata keys for "open" */
|
/* 3. If executable, try metadata keys for "open" */
|
||||||
|
|
||||||
if (is_exe (dest_fe->buf.st_mode) && if_link_is_exe (dest_fe)) {
|
if (is_exe (dest_fe->buf.st_mode) && if_link_is_exe (directory, dest_fe)) {
|
||||||
GList *names, *l;
|
GList *names, *l;
|
||||||
int len, i;
|
int len, i;
|
||||||
char **drops;
|
char **drops;
|
||||||
@ -358,29 +373,34 @@ drop_on_file (GdkDragContext *context, GtkSelectionData *selection_data,
|
|||||||
}
|
}
|
||||||
drops[i] = NULL;
|
drops[i] = NULL;
|
||||||
|
|
||||||
if (gnome_metadata_get (dest_name, "open", &size, &buf) == 0)
|
if (gnome_metadata_get (full_name, "open", &size, &buf) == 0)
|
||||||
exec_extension (dest_name, buf, drops, NULL, 0);
|
exec_extension (full_name, buf, drops, NULL, 0);
|
||||||
else
|
else
|
||||||
exec_extension (dest_name, "%f %q", drops, NULL, 0);
|
exec_extension (full_name, "%f %q", drops, NULL, 0);
|
||||||
|
|
||||||
g_free (drops);
|
g_free (drops);
|
||||||
gnome_uri_list_free_strings (names);
|
gnome_uri_list_free_strings (names);
|
||||||
g_free (buf);
|
g_free (buf);
|
||||||
|
|
||||||
return TRUE;
|
retval = TRUE;
|
||||||
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
return FALSE; /* could not drop */
|
out:
|
||||||
|
|
||||||
|
g_free (full_name);
|
||||||
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
gdnd_perform_drop (GdkDragContext *context, GtkSelectionData *selection_data,
|
gdnd_perform_drop (GdkDragContext *context, GtkSelectionData *selection_data,
|
||||||
file_entry *dest_fe, char *dest_name)
|
char *directory, file_entry *dest_fe)
|
||||||
{
|
{
|
||||||
GdkDragAction action;
|
GdkDragAction action;
|
||||||
|
|
||||||
g_return_val_if_fail (context != NULL, FALSE);
|
g_return_val_if_fail (context != NULL, FALSE);
|
||||||
g_return_val_if_fail (selection_data != NULL, FALSE);
|
g_return_val_if_fail (selection_data != NULL, FALSE);
|
||||||
|
g_return_val_if_fail (directory != NULL, FALSE);
|
||||||
g_return_val_if_fail (dest_fe != NULL, FALSE);
|
g_return_val_if_fail (dest_fe != NULL, FALSE);
|
||||||
|
|
||||||
/* Get action */
|
/* Get action */
|
||||||
@ -393,9 +413,9 @@ gdnd_perform_drop (GdkDragContext *context, GtkSelectionData *selection_data,
|
|||||||
action = context->action;
|
action = context->action;
|
||||||
|
|
||||||
if (S_ISDIR (dest_fe->buf.st_mode) || dest_fe->f.link_to_dir)
|
if (S_ISDIR (dest_fe->buf.st_mode) || dest_fe->f.link_to_dir)
|
||||||
return drop_on_directory (context, selection_data, action, dest_name);
|
return drop_on_directory (context, selection_data, action, directory, dest_fe);
|
||||||
else
|
else
|
||||||
return drop_on_file (context, selection_data, dest_fe, dest_name);
|
return drop_on_file (context, selection_data, directory, dest_fe);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -480,12 +500,13 @@ gdnd_find_panel_by_drag_context (GdkDragContext *context, GtkWidget **source_wid
|
|||||||
GdkDragAction
|
GdkDragAction
|
||||||
gdnd_validate_action (GdkDragContext *context,
|
gdnd_validate_action (GdkDragContext *context,
|
||||||
int on_desktop, int same_process, int same_source,
|
int on_desktop, int same_process, int same_source,
|
||||||
file_entry *dest_fe, int dest_selected)
|
char *directory, file_entry *dest_fe, int dest_selected)
|
||||||
{
|
{
|
||||||
int on_directory;
|
int on_directory;
|
||||||
int on_exe;
|
int on_exe;
|
||||||
|
|
||||||
g_return_val_if_fail (context != NULL, 0);
|
g_return_val_if_fail (context != NULL, 0);
|
||||||
|
g_return_val_if_fail (directory != NULL, 0);
|
||||||
|
|
||||||
/* If we are dragging a desktop icon onto the desktop or onto a selected
|
/* If we are dragging a desktop icon onto the desktop or onto a selected
|
||||||
* desktop icon, unconditionally specify MOVE.
|
* desktop icon, unconditionally specify MOVE.
|
||||||
@ -499,7 +520,7 @@ gdnd_validate_action (GdkDragContext *context,
|
|||||||
|
|
||||||
if (dest_fe) {
|
if (dest_fe) {
|
||||||
on_directory = S_ISDIR (dest_fe->buf.st_mode) || dest_fe->f.link_to_dir;
|
on_directory = S_ISDIR (dest_fe->buf.st_mode) || dest_fe->f.link_to_dir;
|
||||||
on_exe = is_exe (dest_fe->buf.st_mode) && if_link_is_exe (dest_fe);
|
on_exe = is_exe (dest_fe->buf.st_mode) && if_link_is_exe (directory, dest_fe);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (gdnd_drag_context_has_target (context, TARGET_URI_LIST)) {
|
if (gdnd_drag_context_has_target (context, TARGET_URI_LIST)) {
|
||||||
|
@ -40,7 +40,7 @@ void gdnd_init (void);
|
|||||||
* Returns TRUE if an action was performed, FALSE otherwise (i.e. invalid drop).
|
* Returns TRUE if an action was performed, FALSE otherwise (i.e. invalid drop).
|
||||||
*/
|
*/
|
||||||
int gdnd_perform_drop (GdkDragContext *context, GtkSelectionData *selection_data,
|
int gdnd_perform_drop (GdkDragContext *context, GtkSelectionData *selection_data,
|
||||||
file_entry *dest_fe, char *dest_name);
|
char *directory, file_entry *dest_fe);
|
||||||
|
|
||||||
/* Test whether the specified context has a certain target type */
|
/* Test whether the specified context has a certain target type */
|
||||||
int gdnd_drag_context_has_target (GdkDragContext *context, TargetType type);
|
int gdnd_drag_context_has_target (GdkDragContext *context, TargetType type);
|
||||||
@ -53,7 +53,7 @@ WPanel *gdnd_find_panel_by_drag_context (GdkDragContext *context, GtkWidget **so
|
|||||||
*/
|
*/
|
||||||
GdkDragAction gdnd_validate_action (GdkDragContext *context,
|
GdkDragAction gdnd_validate_action (GdkDragContext *context,
|
||||||
int on_desktop, int same_process, int same_source,
|
int on_desktop, int same_process, int same_source,
|
||||||
file_entry *dest_fe, int dest_selected);
|
char *directory, file_entry *dest_fe, int dest_selected);
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -1,3 +1,10 @@
|
|||||||
|
/* Mount/umount support for the Midnight Commander
|
||||||
|
*
|
||||||
|
* Copyright (C) 1998-1999 The Free Software Foundation
|
||||||
|
*
|
||||||
|
* Author: Miguel de Icaza <miguel@nuclecu.unam.mx>
|
||||||
|
*/
|
||||||
|
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
|
|
||||||
#ifdef STDC_HEADERS
|
#ifdef STDC_HEADERS
|
||||||
|
@ -1,6 +1,15 @@
|
|||||||
|
/* Mount/umount support for the Midnight Commander
|
||||||
|
*
|
||||||
|
* Copyright (C) 1998-1999 The Free Software Foundation
|
||||||
|
*
|
||||||
|
* Author: Miguel de Icaza <miguel@nuclecu.unam.mx>
|
||||||
|
*/
|
||||||
|
|
||||||
#ifndef GMOUNT_H
|
#ifndef GMOUNT_H
|
||||||
#define GMOUNT_H
|
#define GMOUNT_H
|
||||||
|
|
||||||
|
#include <glib.h>
|
||||||
|
|
||||||
gboolean is_block_device_mountable (char *devname);
|
gboolean is_block_device_mountable (char *devname);
|
||||||
gboolean is_block_device_mounted (char *devname);
|
gboolean is_block_device_mounted (char *devname);
|
||||||
GList *get_list_of_mountable_devices (void);
|
GList *get_list_of_mountable_devices (void);
|
||||||
|
@ -805,7 +805,7 @@ panel_icon_list_drag_data_received (GtkWidget *widget,
|
|||||||
free_fe = FALSE;
|
free_fe = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
reload = gdnd_perform_drop (context, selection_data, fe, file);
|
reload = gdnd_perform_drop (context, selection_data, panel->cwd, fe);
|
||||||
|
|
||||||
if (free_file)
|
if (free_file)
|
||||||
g_free (file);
|
g_free (file);
|
||||||
@ -860,7 +860,7 @@ panel_clist_drag_data_received (GtkWidget *widget,
|
|||||||
free_fe = FALSE;
|
free_fe = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
reload = gdnd_perform_drop (context, selection_data, fe, file);
|
reload = gdnd_perform_drop (context, selection_data, panel->cwd, fe);
|
||||||
|
|
||||||
if (free_file)
|
if (free_file)
|
||||||
g_free (file);
|
g_free (file);
|
||||||
@ -908,7 +908,7 @@ panel_tree_drag_data_received (GtkWidget *widget,
|
|||||||
if (!fe)
|
if (!fe)
|
||||||
return; /* eeeek */
|
return; /* eeeek */
|
||||||
|
|
||||||
gdnd_perform_drop (context, selection_data, fe, path);
|
gdnd_perform_drop (context, selection_data, panel->cwd, fe);
|
||||||
|
|
||||||
file_entry_free (fe);
|
file_entry_free (fe);
|
||||||
g_free (path);
|
g_free (path);
|
||||||
@ -1117,6 +1117,7 @@ panel_clist_drag_motion (GtkWidget *widget, GdkDragContext *context, gint x, gin
|
|||||||
FALSE,
|
FALSE,
|
||||||
source_widget != NULL,
|
source_widget != NULL,
|
||||||
source_widget == widget,
|
source_widget == widget,
|
||||||
|
panel->cwd,
|
||||||
fe,
|
fe,
|
||||||
fe ? fe->f.marked : FALSE);
|
fe ? fe->f.marked : FALSE);
|
||||||
|
|
||||||
@ -1232,6 +1233,7 @@ panel_icon_list_drag_motion (GtkWidget *widget, GdkDragContext *context, gint x,
|
|||||||
FALSE,
|
FALSE,
|
||||||
source_widget != NULL,
|
source_widget != NULL,
|
||||||
source_widget == widget,
|
source_widget == widget,
|
||||||
|
panel->cwd,
|
||||||
fe,
|
fe,
|
||||||
fe ? fe->f.marked : FALSE);
|
fe ? fe->f.marked : FALSE);
|
||||||
|
|
||||||
|
@ -1,3 +1,12 @@
|
|||||||
|
1999-02-17 Federico Mena Quintero <federico@nuclecu.unam.mx>
|
||||||
|
|
||||||
|
* dir.c (if_link_is_exe): Made this function take in a directory
|
||||||
|
argument as well -- the sought file may not be in the cwd, and
|
||||||
|
file entries do not carry the directory the file refers to.
|
||||||
|
|
||||||
|
* screen.c (do_enter_on_file_entry): Pass in the cpanel->cwd to
|
||||||
|
if_link_is_exe().
|
||||||
|
|
||||||
1999-02-16 Miguel de Icaza <miguel@nuclecu.unam.mx>
|
1999-02-16 Miguel de Icaza <miguel@nuclecu.unam.mx>
|
||||||
|
|
||||||
* treestore.c (tree_store_rescan): Add code to skip scanning
|
* treestore.c (tree_store_rescan): Add code to skip scanning
|
||||||
|
54
src/dir.c
54
src/dir.c
@ -293,7 +293,8 @@ do_sort (dir_list *list, sortfn *sort, int top, int reverse_f, int case_sensitiv
|
|||||||
qsort (&(list->list) [1], top, sizeof (file_entry), sort);
|
qsort (&(list->list) [1], top, sizeof (file_entry), sort);
|
||||||
}
|
}
|
||||||
|
|
||||||
void clean_dir (dir_list *list, int count)
|
void
|
||||||
|
clean_dir (dir_list *list, int count)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
@ -357,16 +358,18 @@ add_dotdot_to_list (dir_list *list, int index)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Used to set up a directory list when there is no access to a directory */
|
/* Used to set up a directory list when there is no access to a directory */
|
||||||
int set_zero_dir (dir_list *list)
|
int
|
||||||
|
set_zero_dir (dir_list *list)
|
||||||
{
|
{
|
||||||
return (add_dotdot_to_list (list, 0));
|
return (add_dotdot_to_list (list, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If you change handle_dirent then check also handle_path. */
|
/* If you change handle_dirent then check also handle_path. */
|
||||||
/* Return values: -1 = failure, 0 = don't add, 1 = add to the list */
|
/* Return values: -1 = failure, 0 = don't add, 1 = add to the list */
|
||||||
int handle_dirent (dir_list *list, char *filter, struct dirent *dp,
|
int
|
||||||
struct stat *buf1, int next_free, int *link_to_dir,
|
handle_dirent (dir_list *list, char *filter, struct dirent *dp,
|
||||||
int *stalled_link)
|
struct stat *buf1, int next_free, int *link_to_dir,
|
||||||
|
int *stalled_link)
|
||||||
{
|
{
|
||||||
if (dp->d_name [0] == '.' && dp->d_name [1] == 0)
|
if (dp->d_name [0] == '.' && dp->d_name [1] == 0)
|
||||||
return 0;
|
return 0;
|
||||||
@ -417,9 +420,10 @@ int handle_dirent (dir_list *list, char *filter, struct dirent *dp,
|
|||||||
Moreover handle_path can't be used with a filemask.
|
Moreover handle_path can't be used with a filemask.
|
||||||
If you change handle_path then check also handle_dirent. */
|
If you change handle_path then check also handle_dirent. */
|
||||||
/* Return values: -1 = failure, 0 = don't add, 1 = add to the list */
|
/* Return values: -1 = failure, 0 = don't add, 1 = add to the list */
|
||||||
int handle_path (dir_list *list, char *path,
|
int
|
||||||
struct stat *buf1, int next_free, int *link_to_dir,
|
handle_path (dir_list *list, char *path,
|
||||||
int *stalled_link)
|
struct stat *buf1, int next_free, int *link_to_dir,
|
||||||
|
int *stalled_link)
|
||||||
{
|
{
|
||||||
if (path [0] == '.' && path [1] == 0)
|
if (path [0] == '.' && path [1] == 0)
|
||||||
return 0;
|
return 0;
|
||||||
@ -451,7 +455,8 @@ int handle_path (dir_list *list, char *path,
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int do_load_dir(dir_list *list, sortfn *sort, int reverse, int case_sensitive, char *filter)
|
int
|
||||||
|
do_load_dir (dir_list *list, sortfn *sort, int reverse, int case_sensitive, char *filter)
|
||||||
{
|
{
|
||||||
DIR *dirp;
|
DIR *dirp;
|
||||||
struct dirent *dp;
|
struct dirent *dp;
|
||||||
@ -504,7 +509,8 @@ int do_load_dir(dir_list *list, sortfn *sort, int reverse, int case_sensitive, c
|
|||||||
return next_free;
|
return next_free;
|
||||||
}
|
}
|
||||||
|
|
||||||
int link_isdir (file_entry *file)
|
int
|
||||||
|
link_isdir (file_entry *file)
|
||||||
{
|
{
|
||||||
if (file->f.link_to_dir)
|
if (file->f.link_to_dir)
|
||||||
return 1;
|
return 1;
|
||||||
@ -512,20 +518,25 @@ int link_isdir (file_entry *file)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int if_link_is_exe (file_entry *file)
|
int
|
||||||
|
if_link_is_exe (char *directory, file_entry *file)
|
||||||
{
|
{
|
||||||
struct stat b;
|
struct stat b;
|
||||||
|
char *full_name;
|
||||||
|
|
||||||
if (S_ISLNK (file->buf.st_mode)){
|
if (S_ISLNK (file->buf.st_mode)) {
|
||||||
mc_stat (file->fname, &b);
|
full_name = concat_dir_and_file (directory, file->fname);
|
||||||
|
mc_stat (full_name, &b);
|
||||||
|
g_free (full_name);
|
||||||
return is_exe (b.st_mode);
|
return is_exe (b.st_mode);
|
||||||
}
|
} else
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static dir_list dir_copy = { 0, 0 };
|
static dir_list dir_copy = { 0, 0 };
|
||||||
|
|
||||||
static void alloc_dir_copy (int size)
|
static void
|
||||||
|
alloc_dir_copy (int size)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
@ -549,8 +560,9 @@ static void alloc_dir_copy (int size)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* If filter is null, then it is a match */
|
/* If filter is null, then it is a match */
|
||||||
int do_reload_dir (dir_list *list, sortfn *sort, int count, int rev,
|
int
|
||||||
int case_sensitive, char *filter)
|
do_reload_dir (dir_list *list, sortfn *sort, int count, int rev,
|
||||||
|
int case_sensitive, char *filter)
|
||||||
{
|
{
|
||||||
DIR *dirp;
|
DIR *dirp;
|
||||||
struct dirent *dp;
|
struct dirent *dp;
|
||||||
@ -636,7 +648,8 @@ int do_reload_dir (dir_list *list, sortfn *sort, int count, int rev,
|
|||||||
return next_free;
|
return next_free;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *sort_type_to_name (sortfn *sort_fn)
|
char *
|
||||||
|
sort_type_to_name (sortfn *sort_fn)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
@ -647,7 +660,8 @@ char *sort_type_to_name (sortfn *sort_fn)
|
|||||||
return _("Unknown");
|
return _("Unknown");
|
||||||
}
|
}
|
||||||
|
|
||||||
sortfn *sort_name_to_type (char *sname)
|
sortfn *
|
||||||
|
sort_name_to_type (char *sname)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
@ -79,7 +79,7 @@ typedef struct {
|
|||||||
extern sort_orders_t sort_orders [SORT_TYPES_TOTAL];
|
extern sort_orders_t sort_orders [SORT_TYPES_TOTAL];
|
||||||
|
|
||||||
int link_isdir (file_entry *);
|
int link_isdir (file_entry *);
|
||||||
int if_link_is_exe (file_entry *file);
|
int if_link_is_exe (char *directory, file_entry *file);
|
||||||
|
|
||||||
extern int show_backups;
|
extern int show_backups;
|
||||||
extern int show_dot_files;
|
extern int show_dot_files;
|
||||||
|
@ -2036,9 +2036,8 @@ do_enter_on_file_entry (file_entry *fe)
|
|||||||
if (S_ISDIR (fe->buf.st_mode) || link_isdir (fe)) {
|
if (S_ISDIR (fe->buf.st_mode) || link_isdir (fe)) {
|
||||||
do_cd (fe->fname, cd_exact);
|
do_cd (fe->fname, cd_exact);
|
||||||
return 1;
|
return 1;
|
||||||
} else {
|
} else {
|
||||||
if (is_exe (fe->buf.st_mode) &&
|
if (is_exe (fe->buf.st_mode) && if_link_is_exe (cpanel->cwd, fe)) {
|
||||||
if_link_is_exe (fe)) {
|
|
||||||
#ifdef USE_VFS
|
#ifdef USE_VFS
|
||||||
if (vfs_current_is_local ())
|
if (vfs_current_is_local ())
|
||||||
#endif
|
#endif
|
||||||
|
Загрузка…
Ссылка в новой задаче
Block a user