b683efeda3
* 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.
60 строки
1.8 KiB
C
60 строки
1.8 KiB
C
/* Drag and Drop functionality for the Midnight Commander
|
|
*
|
|
* Copyright (C) 1998 The Free Software Foundation
|
|
*
|
|
* Authors: Federico Mena <federico@nuclecu.unam.mx>
|
|
* Miguel de Icaza <miguel@nuclecu.unam.mx>
|
|
*/
|
|
|
|
#ifndef GDND_H
|
|
#define GDND_H
|
|
|
|
#include <gtk/gtk.h>
|
|
#include "panel.h"
|
|
|
|
|
|
/* Standard DnD types */
|
|
typedef enum {
|
|
TARGET_MC_DESKTOP_ICON,
|
|
TARGET_URI_LIST,
|
|
TARGET_TEXT_PLAIN,
|
|
TARGET_URL,
|
|
TARGET_NTARGETS
|
|
} TargetType;
|
|
|
|
/* DnD target names */
|
|
#define TARGET_MC_DESKTOP_ICON_TYPE "application/x-mc-desktop-icon"
|
|
#define TARGET_URI_LIST_TYPE "text/uri-list"
|
|
#define TARGET_TEXT_PLAIN_TYPE "text/plain"
|
|
#define TARGET_URL_TYPE "_NETSCAPE_URL"
|
|
|
|
/* Atoms for the DnD types, indexed per the enum above */
|
|
extern GdkAtom dnd_target_atoms[];
|
|
|
|
|
|
/* Initializes drag and drop by interning the target convenience atoms */
|
|
void gdnd_init (void);
|
|
|
|
/* Perform a drop on the specified file entry. This function takes care of
|
|
* determining how to drop the stuff epending on the type of the file entry.
|
|
* Returns TRUE if an action was performed, FALSE otherwise (i.e. invalid drop).
|
|
*/
|
|
int gdnd_perform_drop (GdkDragContext *context, GtkSelectionData *selection_data,
|
|
char *directory, file_entry *dest_fe);
|
|
|
|
/* Test whether the specified context has a certain target type */
|
|
int gdnd_drag_context_has_target (GdkDragContext *context, TargetType type);
|
|
|
|
/* Look for a panel that corresponds to the specified drag context */
|
|
WPanel *gdnd_find_panel_by_drag_context (GdkDragContext *context, GtkWidget **source_widget);
|
|
|
|
/* Computes the final drag action based on the suggested actions and the
|
|
* specified conditions.
|
|
*/
|
|
GdkDragAction gdnd_validate_action (GdkDragContext *context,
|
|
int on_desktop, int same_process, int same_source,
|
|
char *directory, file_entry *dest_fe, int dest_selected);
|
|
|
|
|
|
#endif
|