keep the overwrite confirmation around for an entire job, so we don't

2008-03-28  Jens Granseuer  <jensgr@gmx.net>

	* file-transfer-dialog.c: (file_transfer_job_destroy),
	(file_transfer_dialog_overwrite), (file_transfer_job_schedule): keep
	the overwrite confirmation around for an entire job, so we don't reset
	the window position all the time

svn path=/trunk/; revision=8606
This commit is contained in:
Jens Granseuer 2008-03-28 22:03:09 +00:00 committed by Jens Granseuer
parent eb420a2cbb
commit a12ed153f0
2 changed files with 37 additions and 15 deletions

View file

@ -1,3 +1,10 @@
2008-03-28 Jens Granseuer <jensgr@gmx.net>
* file-transfer-dialog.c: (file_transfer_job_destroy),
(file_transfer_dialog_overwrite), (file_transfer_job_schedule): keep
the overwrite confirmation around for an entire job, so we don't reset
the window position all the time
2008-03-27 Jens Granseuer <jensgr@gmx.net>
* file-transfer-dialog.c: (file_transfer_dialog_set_prop),

View file

@ -66,6 +66,7 @@ struct _FileTransferDialogPrivate
typedef struct _FileTransferJob
{
FileTransferDialog *dialog;
GtkDialog *overwrite_dialog;
GSList *source_uris;
GSList *target_uris;
FileTransferDialogOptions options;
@ -81,6 +82,7 @@ typedef struct {
goffset current_bytes;
goffset total_bytes;
gint response;
GtkDialog *overwrite_dialog;
} FileTransferData;
static GObjectClass *parent_class;
@ -436,6 +438,8 @@ file_transfer_job_destroy (FileTransferJob *job)
g_slist_foreach (job->target_uris, (GFunc) g_free, NULL);
g_slist_free (job->source_uris);
g_slist_free (job->target_uris);
if (job->overwrite_dialog != NULL)
gtk_widget_destroy (GTK_WIDGET (job->overwrite_dialog));
g_free (job);
}
@ -462,6 +466,11 @@ file_transfer_dialog_overwrite (gpointer user_data)
{
FileTransferData *data = user_data;
GtkDialog *dialog;
dialog = data->overwrite_dialog;
if (dialog != NULL) {
} else {
GtkWidget *button;
dialog = GTK_DIALOG (gtk_message_dialog_new (GTK_WINDOW (data->dialog),
@ -480,9 +489,12 @@ file_transfer_dialog_overwrite (gpointer user_data)
gtk_dialog_add_action_widget (dialog, button, GTK_RESPONSE_YES);
gtk_widget_show (button);
data->overwrite_dialog = dialog;
}
data->response = gtk_dialog_run (dialog);
gtk_widget_destroy (GTK_WIDGET (dialog));
gtk_widget_hide (GTK_WIDGET (dialog));
return FALSE;
}
@ -501,6 +513,7 @@ file_transfer_job_schedule (GIOSchedulerJob *io_job,
/* take the first file from the list and copy it */
data.dialog = job->dialog;
data.overwrite_dialog = job->overwrite_dialog;
data.current_file = job->dialog->priv->nth + 1;
data.total_files = job->dialog->priv->total;
data.source = job->source_uris->data;
@ -553,6 +566,8 @@ file_transfer_job_schedule (GIOSchedulerJob *io_job,
} else {
success = TRUE;
}
job->overwrite_dialog = data.overwrite_dialog;
}
g_error_free (error);
}