Re: [patch] Fix progress reporting for file move
- From: Hampa Hug <apmah gmx net>
- To: mc-devel gnome org
- Subject: Re: [patch] Fix progress reporting for file move
- Date: Sun, 21 May 2006 12:53:11 +0200
Roland Illig wrote:
> Hampa Hug wrote:
> > If a file is moved by copy/remove the progress bar is advanced twice. On
> > the other hand, if a file is moved by renaming the progress bar is never
> > updated. The attached patch fixes this.
>
> Thanks for identifying and fixing this long-known bug. Before committing
> the patch, I have one question left.
>
> > diff -ur mc-cvs/src/file.c mc-dev/src/file.c
> > --- mc-cvs/src/file.c 2006-04-25 05:05:17.000000000 +0200
> > +++ mc-dev/src/file.c 2006-05-03 07:09:36.000000000 +0200
> > @@ -1022,6 +1022,7 @@
> > {
> > struct stat src_stats, dst_stats;
> > int return_status = FILE_CONT;
> > + int copy = 0;
>
> This variable looks like it should be of type gboolean. I also find its
> name too generic; maybe copy_done would be more appropriate?
I made a new patch with those two changes.
Hampa
diff -ur mc-cvs/src/file.c mc-dev/src/file.c
--- mc-cvs/src/file.c 2006-04-25 05:05:17.000000000 +0200
+++ mc-dev/src/file.c 2006-05-21 12:35:20.000000000 +0200
@@ -1022,6 +1022,7 @@
{
struct stat src_stats, dst_stats;
int return_status = FILE_CONT;
+ gboolean copy_done = FALSE;
if (file_progress_show_source (ctx, s) == FILE_ABORT
|| file_progress_show_target (ctx, d) == FILE_ABORT)
@@ -1080,7 +1081,9 @@
}
if (mc_rename (s, d) == 0) {
- return FILE_CONT;
+ return progress_update_one (ctx, progress_count,
+ progress_bytes,
+ src_stats.st_size, 1);
}
}
#if 0
@@ -1107,6 +1110,8 @@
if (return_status != FILE_CONT)
return return_status;
+ copy_done = TRUE;
+
if ((return_status =
file_progress_show_source (ctx, NULL)) != FILE_CONT
|| (return_status = file_progress_show (ctx, 0, 0)) != FILE_CONT)
@@ -1123,11 +1128,12 @@
return return_status;
}
- if (return_status == FILE_CONT)
+ if (!copy_done) {
return_status = progress_update_one (ctx,
progress_count,
progress_bytes,
src_stats.st_size, 1);
+ }
return return_status;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]