1
1

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.
Этот коммит содержится в:
Miguel de Icaza 1999-02-18 00:07:26 +00:00
родитель 6eb9a08b29
Коммит b683efeda3
11 изменённых файлов: 179 добавлений и 75 удалений

Просмотреть файл

@ -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);
} }
} }

Просмотреть файл

@ -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

Просмотреть файл

@ -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