1
1

1998-12-30 Federico Mena Quintero <federico@nuclecu.unam.mx>

* gdesktop.c (find_icon_by_drag_context): Made static.

	* gdesktop.h (DesktopIconInfo): Now that this type is public,
	renamed it from struct desktop_icon_info, for consistency.
Этот коммит содержится в:
Miguel de Icaza 1998-12-31 01:43:11 +00:00
родитель 0319fd33d5
Коммит 3491af5408
8 изменённых файлов: 152 добавлений и 146 удалений

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

@ -1,3 +1,10 @@
1998-12-30 Federico Mena Quintero <federico@nuclecu.unam.mx>
* gdesktop.c (find_icon_by_drag_context): Made static.
* gdesktop.h (DesktopIconInfo): Now that this type is public,
renamed it from struct desktop_icon_info, for consistency.
1998-12-30 Jeff Garzik <jgarzik@pobox.com>
* gprop.c, gpopup.c: s/g_copy_strings/g_strconcat/

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

@ -76,7 +76,7 @@ static struct layout_slot *layout_slots;
#define l_slots(u, v) (layout_slots[(u) * layout_rows + (v)])
/* The last icon to be selected */
static struct desktop_icon_info *last_selected_icon;
static DesktopIconInfo *last_selected_icon;
/* Drag and drop sources and targets */
@ -129,7 +129,7 @@ static int click_current_y;
static int click_dragging;
static struct desktop_icon_info *desktop_icon_info_new (char *filename, int auto_pos, int xpos, int ypos);
static DesktopIconInfo *desktop_icon_info_new (char *filename, int auto_pos, int xpos, int ypos);
/* Looks for a free slot in the layout_slots array and returns the coordinates that coorespond to
@ -205,7 +205,7 @@ get_icon_snap_pos (int *x, int *y)
/* Removes an icon from the slot it is in, if any */
static void
remove_from_slot (struct desktop_icon_info *dii)
remove_from_slot (DesktopIconInfo *dii)
{
if (dii->slot == -1)
return;
@ -224,7 +224,7 @@ remove_from_slot (struct desktop_icon_info *dii)
* desktop_snap_icons flag is set.
*/
static void
desktop_icon_info_place (struct desktop_icon_info *dii, int auto_pos, int xpos, int ypos)
desktop_icon_info_place (DesktopIconInfo *dii, int auto_pos, int xpos, int ypos)
{
int u, v;
char *filename;
@ -279,7 +279,7 @@ icon_exists (char *filename)
{
int i;
GList *l;
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
for (i = 0; i < (layout_cols * layout_rows); i++)
for (l = layout_slots[i].icons; l; l = l->next) {
@ -295,13 +295,15 @@ static GList *
icon_exists_in_list (GList *list, char *filename)
{
GList *l;
DesktopIconInfo *dii;
for (l = list; l; l = l->next){
struct desktop_icon_info *dii = l->data;
for (l = list; l; l = l->next) {
dii = l->data;
if (strcmp (filename, dii->filename) == 0)
return l;
}
return NULL;
}
@ -336,7 +338,7 @@ load_desktop_icons (int incremental, int xpos, int ypos)
DIR *dir;
char *full_name;
int have_pos, x, y;
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
GSList *need_position_list, *l;
GList *all_icons;
@ -399,7 +401,7 @@ load_desktop_icons (int incremental, int xpos, int ypos)
GList *l;
for (l = all_icons; l; l = l->next){
struct desktop_icon_info *dii = l->data;
DesktopIconInfo *dii = l->data;
desktop_icon_destroy (dii);
}
@ -428,7 +430,7 @@ destroy_desktop_icons (void)
{
int i;
GList *l;
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
for (i = 0; i < (layout_cols * layout_rows); i++) {
l = layout_slots[i].icons;
@ -459,11 +461,11 @@ reload_desktop_icons (int incremental, int x, int y)
/* Unselects all the desktop icons except the one in exclude */
static void
unselect_all (struct desktop_icon_info *exclude)
unselect_all (DesktopIconInfo *exclude)
{
int i;
GList *l;
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
for (i = 0; i < (layout_cols * layout_rows); i++)
for (l = layout_slots[i].icons; l; l = l->next) {
@ -480,16 +482,16 @@ unselect_all (struct desktop_icon_info *exclude)
* last_selected_icon and ends at the specified icon.
*/
static void
select_range (struct desktop_icon_info *dii, int sel)
select_range (DesktopIconInfo *dii, int sel)
{
int du, dv, lu, lv;
int min_u, min_v;
int max_u, max_v;
int u, v;
GList *l;
struct desktop_icon_info *ldii;
struct desktop_icon_info *min_udii, *min_vdii;
struct desktop_icon_info *max_udii, *max_vdii;
DesktopIconInfo *ldii;
DesktopIconInfo *min_udii, *min_vdii;
DesktopIconInfo *max_udii, *max_vdii;
/* Find out the selection range */
@ -548,7 +550,7 @@ select_range (struct desktop_icon_info *dii, int sel)
* event_state is the state field of the event.
*/
static void
select_icon (struct desktop_icon_info *dii, int event_state)
select_icon (DesktopIconInfo *dii, int event_state)
{
int range;
int additive;
@ -626,7 +628,7 @@ file_entry_free (file_entry *fe)
static int
text_changed (GnomeIconTextItem *iti, gpointer data)
{
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
char *new_name;
char *source;
char *dest;
@ -659,7 +661,7 @@ text_changed (GnomeIconTextItem *iti, gpointer data)
static void
editing_started (GnomeIconTextItem *iti, gpointer data)
{
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
GdkCursor *ibeam;
dii = data;
@ -690,7 +692,7 @@ editing_started (GnomeIconTextItem *iti, gpointer data)
/* Sets up the specified icon as a drag source, but does not connect the signals */
static void
setup_icon_dnd_actions (struct desktop_icon_info *dii)
setup_icon_dnd_actions (DesktopIconInfo *dii)
{
gtk_drag_source_set (DESKTOP_ICON (dii->dicon)->canvas,
GDK_BUTTON1_MASK | GDK_BUTTON2_MASK,
@ -706,7 +708,7 @@ setup_icon_dnd_actions (struct desktop_icon_info *dii)
static void
editing_stopped (GnomeIconTextItem *iti, gpointer data)
{
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
dii = data;
@ -721,7 +723,7 @@ editing_stopped (GnomeIconTextItem *iti, gpointer data)
/* Used to open a desktop icon when the user double-clicks on it */
void
desktop_icon_open (struct desktop_icon_info *dii)
desktop_icon_open (DesktopIconInfo *dii)
{
char *filename;
file_entry *fe;
@ -739,7 +741,7 @@ desktop_icon_open (struct desktop_icon_info *dii)
}
void
desktop_icon_delete (struct desktop_icon_info *dii)
desktop_icon_delete (DesktopIconInfo *dii)
{
char *full_name;
struct stat s;
@ -765,7 +767,7 @@ desktop_icon_delete (struct desktop_icon_info *dii)
/* Used to execute the popup menu for desktop icons */
static void
do_popup_menu (struct desktop_icon_info *dii, GdkEventButton *event)
do_popup_menu (DesktopIconInfo *dii, GdkEventButton *event)
{
char *filename;
@ -783,7 +785,7 @@ do_popup_menu (struct desktop_icon_info *dii, GdkEventButton *event)
static gint
window_button_press (GtkWidget *widget, GdkEventButton *event, gpointer data)
{
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
GtkWidget *parent;
dii = data;
@ -815,7 +817,7 @@ window_button_press (GtkWidget *widget, GdkEventButton *event, gpointer data)
static gint
icon_button_press (GtkWidget *widget, GdkEventButton *event, gpointer data)
{
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
int retval;
dii = data;
@ -880,7 +882,7 @@ icon_button_press (GtkWidget *widget, GdkEventButton *event, gpointer data)
static gint
icon_button_release (GtkWidget *widget, GdkEventButton *event, gpointer data)
{
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
dii = data;
@ -902,7 +904,7 @@ icon_button_release (GtkWidget *widget, GdkEventButton *event, gpointer data)
static gint
icon_button_release_after (GtkWidget *widget, GdkEventButton *event, gpointer data)
{
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
dii = data;
@ -935,7 +937,7 @@ icon_button_release_after (GtkWidget *widget, GdkEventButton *event, gpointer da
static void
drag_begin (GtkWidget *widget, GdkDragContext *context, gpointer data)
{
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
DesktopIcon *dicon;
GtkArg args[3];
GdkImlibImage *im;
@ -986,7 +988,7 @@ build_selected_icons_uri_list (int *len)
{
int i;
GList *l;
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
char *filelist, *p;
int desktop_dir_len;
@ -1041,7 +1043,7 @@ static void
drag_data_get (GtkWidget *widget, GdkDragContext *context, GtkSelectionData *selection_data,
guint info, guint32 time, gpointer data)
{
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
char *filelist;
int len;
GList *files;
@ -1081,7 +1083,7 @@ drag_data_get (GtkWidget *widget, GdkDragContext *context, GtkSelectionData *sel
/* Set up a desktop icon as a DnD source */
static void
setup_icon_dnd_source (struct desktop_icon_info *dii)
setup_icon_dnd_source (DesktopIconInfo *dii)
{
setup_icon_dnd_actions (dii);
@ -1097,9 +1099,7 @@ setup_icon_dnd_source (struct desktop_icon_info *dii)
* drop_on_file_entry
*/
static void
desktop_icon_drop_uri_list (struct desktop_icon_info *dii,
GdkDragContext *context,
GtkSelectionData *data)
desktop_icon_drop_uri_list (DesktopIconInfo *dii, GdkDragContext *context, GtkSelectionData *data)
{
char *filename;
file_entry *fe;
@ -1159,7 +1159,7 @@ static void
icon_drag_data_received (GtkWidget *widget, GdkDragContext *context, gint x, gint y,
GtkSelectionData *data, guint info, guint time, gpointer user_data)
{
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
dii = user_data;
@ -1175,7 +1175,7 @@ icon_drag_data_received (GtkWidget *widget, GdkDragContext *context, gint x, gin
/* Set up a desktop icon as a DnD destination */
static void
setup_icon_dnd_dest (struct desktop_icon_info *dii)
setup_icon_dnd_dest (DesktopIconInfo *dii)
{
char *filename;
file_entry *fe;
@ -1222,10 +1222,10 @@ setup_icon_dnd_dest (struct desktop_icon_info *dii)
* positioning trying to start at the specified coordinates. It does
* not show the icon.
*/
static struct desktop_icon_info *
static DesktopIconInfo *
desktop_icon_info_new (char *filename, int auto_pos, int xpos, int ypos)
{
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
file_entry *fe;
char *full_name;
GdkImlibImage *icon_im;
@ -1236,7 +1236,7 @@ desktop_icon_info_new (char *filename, int auto_pos, int xpos, int ypos)
fe = file_entry_from_file (full_name);
icon_im = gicon_get_icon_for_file_speed (fe, FALSE);
dii = g_new (struct desktop_icon_info, 1);
dii = g_new (DesktopIconInfo, 1);
dii->dicon = desktop_icon_new (icon_im, filename);
dii->x = 0;
dii->y = 0;
@ -1290,7 +1290,7 @@ desktop_icon_info_new (char *filename, int auto_pos, int xpos, int ypos)
* widget. Does not remove the structure from the desktop_icons list!
*/
void
desktop_icon_destroy (struct desktop_icon_info *dii)
desktop_icon_destroy (DesktopIconInfo *dii)
{
gtk_widget_destroy (dii->dicon);
remove_from_slot (dii);
@ -1450,13 +1450,13 @@ setup_xdnd_proxy (guint32 xid, GdkWindow *proxy_window)
}
/* Returns the desktop icon that started the drag from the specified context */
struct desktop_icon_info *
static DesktopIconInfo *
find_icon_by_drag_context (GdkDragContext *context)
{
GtkWidget *source;
int i;
GList *l;
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
source = gtk_drag_get_source_widget (context);
if (!source)
@ -1482,7 +1482,7 @@ find_icon_by_drag_context (GdkDragContext *context)
static void
drop_desktop_icons (GdkDragContext *context, GtkSelectionData *data, int x, int y)
{
struct desktop_icon_info *source_dii, *dii;
DesktopIconInfo *source_dii, *dii;
int dx, dy;
int i;
GList *l;
@ -1698,7 +1698,7 @@ store_temp_selection (void)
{
int i;
GList *l;
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
for (i = 0; i < (layout_cols * layout_rows); i++)
for (l = layout_slots[i].icons; l; l = l->next) {
@ -1716,7 +1716,7 @@ store_temp_selection (void)
* area, or FALSE otherwise.
*/
static int
icon_is_in_area (struct desktop_icon_info *dii, int x1, int y1, int x2, int y2)
icon_is_in_area (DesktopIconInfo *dii, int x1, int y1, int x2, int y2)
{
DesktopIcon *dicon;
@ -1756,7 +1756,7 @@ update_drag_selection (int x, int y)
int x1, y1, x2, y2;
int i;
GList *l;
struct desktop_icon_info *dii;
DesktopIconInfo *dii;
int additive, invert, in_area;
if (click_start_x < x) {

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

@ -9,8 +9,6 @@
#ifndef GDESKTOP_H
#define GDESKTOP_H
#if 1
/* Snap granularity for desktop icons -- maybe these should be calculated in terms of the font size? */
#define DESKTOP_SNAP_X 80
@ -34,7 +32,7 @@ void desktop_destroy (void);
/* This structure defines the information carried by a desktop icon */
typedef struct desktop_icon_info {
typedef struct {
GtkWidget *dicon; /* The desktop icon widget */
int x, y; /* Position in the desktop */
int slot; /* Index of the slot the icon is in, or -1 for none */
@ -44,11 +42,11 @@ typedef struct desktop_icon_info {
int finishing_selection : 1; /* Flag set while we are releasing
* button after selecting in the text
*/
} desktop_icon_info;
} DesktopIconInfo;
void desktop_icon_destroy (struct desktop_icon_info *dii);
void desktop_icon_open (struct desktop_icon_info *dii);
void desktop_icon_delete (struct desktop_icon_info *dii);
void desktop_icon_destroy (DesktopIconInfo *dii);
void desktop_icon_open (DesktopIconInfo *dii);
void desktop_icon_delete (DesktopIconInfo *dii);
typedef enum {
application,
@ -66,75 +64,5 @@ typedef struct {
char *pathname;
} desktop_icon_t;
#else
#define MC_LIB_DESKTOP "mc.desktop"
/* Drag and drop types recognized by us */
enum {
TARGET_URI_LIST,
TARGET_TEXT_PLAIN,
};
/* Types of desktop icons:
*
* o Application: Double click: start up application;
* Dropping: start up program with arguments.
*
* o Directory: Double click: opens the directory in a panel.
* Double click: copies/moves files.
*
* o File: Opens the application according to regex_command
*/
typedef enum {
application,
directory,
file
} icon_t;
/* A structure that describes each icon on the desktop */
typedef struct {
GnomeDesktopEntry *dentry;
GtkWidget *widget;
icon_t type;
int x, y;
int grid_x, grid_y;
char *pathname;
} desktop_icon_t;
/* size of the snap to grid size */
#define SNAP_X 80
#define SNAP_Y 80
/* gtrans.c */
extern int want_transparent_icons;
extern int want_transparent_text;
GtkWidget *make_transparent_window (char *file);
/* gdesktop.c */
void drop_on_directory (GtkSelectionData *sel_data, GdkDragContext *context,
GdkDragAction action, char *dest, int force_manually);
#if 0
void drop_on_directory (GdkEventDropDataAvailable *event, char *dest, int force_manually);
void artificial_drag_start (GdkWindow *source_window, int x, int y);
#endif
void gnome_arrange_icons (void);
void start_desktop (void);
void stop_desktop (void);
/* These get invoked by the context sensitive popup menu in gscreen.c */
void desktop_icon_properties (GtkWidget *widget, desktop_icon_t *di);
void desktop_icon_execute (GtkWidget *widget, desktop_icon_t *di);
void desktop_icon_delete (GtkWidget *widget, desktop_icon_t *di);
/* Pops up the context sensitive menu for a WPanel or a desktop_icon_t */
void file_popup (GdkEventButton *event, void *WPanel_pointer, void *desktop_icon_t_pointer, int row, char *filename);
#endif
#endif

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

@ -48,7 +48,7 @@ kill_toplevel ()
}
int
item_properties (GtkWidget *parent, char *fname, desktop_icon_info *di)
item_properties (GtkWidget *parent, char *fname, DesktopIconInfo *dii)
{
GtkWidget *parent_window;
GdkCursor *cursor;
@ -89,7 +89,7 @@ item_properties (GtkWidget *parent, char *fname, desktop_icon_info *di)
name = gprop_filename_new (fname, base);
gtk_box_pack_start (GTK_BOX (vbox), name->top, FALSE, FALSE, 0);
if(di) {
if (dii) {
gene = gprop_general_new(fname, base);
gtk_box_pack_start (GTK_BOX (vbox), gene->top, FALSE, FALSE, 0);
}
@ -208,9 +208,9 @@ item_properties (GtkWidget *parent, char *fname, desktop_icon_info *di)
move_file_file (fname, full_target, &count, &bytes);
destroy_op_win ();
if (di) {
free (di->filename);
di->filename = full_target;
if (dii) {
free (dii->filename);
dii->filename = full_target;
} else
free (full_target);
@ -219,9 +219,9 @@ item_properties (GtkWidget *parent, char *fname, desktop_icon_info *di)
/* Check and change title and icon -- change is handled by caller */
if (di) {
if (dii) {
gprop_general_get_data (gene, &new_title, NULL);
desktop_icon_set_text(DESKTOP_ICON(di->dicon), new_title);
desktop_icon_set_text(DESKTOP_ICON(dii->dicon), new_title);
g_free(new_title);
retval |= GPROP_TITLE;

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

@ -28,7 +28,7 @@ typedef enum {
/* Returns a mask of the above specifying what changed.
*/
int item_properties (GtkWidget *parent, char *fname, desktop_icon_info *di);
int item_properties (GtkWidget *parent, char *fname, DesktopIconInfo *di);
#endif

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

@ -79,14 +79,14 @@ panel_action_edit (GtkWidget *widget, WPanel *panel)
}
static void
desktop_icon_view(GtkWidget *widget, desktop_icon_info *dii)
desktop_icon_view(GtkWidget *widget, DesktopIconInfo *dii)
{
g_warning ("Not yet implemented\n");
}
/* Pops up the icon properties pages */
void
desktop_icon_properties (GtkWidget *widget, desktop_icon_info *dii)
desktop_icon_properties (GtkWidget *widget, DesktopIconInfo *dii)
{
int retval;
char *path;
@ -99,7 +99,7 @@ desktop_icon_properties (GtkWidget *widget, desktop_icon_info *dii)
}
void
desktop_icon_execute (GtkWidget *ignored, desktop_icon_info *dii)
desktop_icon_execute (GtkWidget *ignored, DesktopIconInfo *dii)
{
desktop_icon_open (dii);
}
@ -117,19 +117,19 @@ panel_action_properties (GtkWidget *widget, WPanel *panel)
}
static void
dicon_move (GtkWidget *widget, desktop_icon_info *dii)
dicon_move (GtkWidget *widget, DesktopIconInfo *dii)
{
g_warning ("Implement this function!");
}
static void
dicon_copy (GtkWidget *widget, desktop_icon_info *dii)
dicon_copy (GtkWidget *widget, DesktopIconInfo *dii)
{
g_warning ("Implement this function!");
}
static void
dicon_delete (GtkWidget *widget, desktop_icon_info *dii)
dicon_delete (GtkWidget *widget, DesktopIconInfo *dii)
{
desktop_icon_delete (dii);
}
@ -245,7 +245,7 @@ static GnomeUIInfo desktop_icon_actions[] = {
*/
static int
create_actions (GtkWidget *menu, WPanel *panel,
desktop_icon_info *dii,
DesktopIconInfo *dii,
int panel_row, char *filename)
{
gpointer closure;
@ -393,7 +393,7 @@ mime_command_from_desktop_icon (GtkMenuItem *item, char *filename)
*/
static void
create_regexp_actions (GtkWidget *menu, WPanel *panel,
desktop_icon_info *dii,
DesktopIconInfo *dii,
int panel_row, char *filename, int insert_pos)
{
gpointer closure, regex_closure;
@ -503,11 +503,9 @@ get_active_index (GtkMenu *menu)
* be set to NULL.
*/
int
gpopup_do_popup (GdkEventButton *event,
WPanel *from_panel,
struct desktop_icon_info *dii,
int panel_row,
char *filename)
gpopup_do_popup (GdkEventButton *event, WPanel *from_panel,
DesktopIconInfo *dii,
int panel_row, char *filename)
{
GtkWidget *menu;
int pos;

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

@ -15,7 +15,7 @@
#include "gdesktop.h"
int gpopup_do_popup (GdkEventButton *event, WPanel *from_panel,
desktop_icon_info *dii,
DesktopIconInfo *dii,
int panel_row, char *filename);

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

@ -1,3 +1,76 @@
#ifdef OLD_DND
/* This was in the old gdesktop.h */
#define MC_LIB_DESKTOP "mc.desktop"
/* Drag and drop types recognized by us */
enum {
TARGET_URI_LIST,
TARGET_TEXT_PLAIN,
};
/* Types of desktop icons:
*
* o Application: Double click: start up application;
* Dropping: start up program with arguments.
*
* o Directory: Double click: opens the directory in a panel.
* Double click: copies/moves files.
*
* o File: Opens the application according to regex_command
*/
typedef enum {
application,
directory,
file
} icon_t;
/* A structure that describes each icon on the desktop */
typedef struct {
GnomeDesktopEntry *dentry;
GtkWidget *widget;
icon_t type;
int x, y;
int grid_x, grid_y;
char *pathname;
} desktop_icon_t;
/* size of the snap to grid size */
#define SNAP_X 80
#define SNAP_Y 80
/* gtrans.c */
extern int want_transparent_icons;
extern int want_transparent_text;
GtkWidget *make_transparent_window (char *file);
/* gdesktop.c */
void drop_on_directory (GtkSelectionData *sel_data, GdkDragContext *context,
GdkDragAction action, char *dest, int force_manually);
#if 0
void drop_on_directory (GdkEventDropDataAvailable *event, char *dest, int force_manually);
void artificial_drag_start (GdkWindow *source_window, int x, int y);
#endif
void gnome_arrange_icons (void);
void start_desktop (void);
void stop_desktop (void);
/* These get invoked by the context sensitive popup menu in gscreen.c */
void desktop_icon_properties (GtkWidget *widget, desktop_icon_t *di);
void desktop_icon_execute (GtkWidget *widget, desktop_icon_t *di);
void desktop_icon_delete (GtkWidget *widget, desktop_icon_t *di);
/* Pops up the context sensitive menu for a WPanel or a desktop_icon_t */
void file_popup (GdkEventButton *event, void *WPanel_pointer, void *desktop_icon_t_pointer, int row, char *filename);
#endif
#ifdef OLD_DND
/*
* Handler for text/plain and url:ALL drag types