mirror of
https://github.com/MidnightCommander/mc
synced 2025-01-03 01:54:24 +03:00
Store start time of file transfer in the file operation context descriptor.
* (file_op_context_t): new member transfer_start. * (copy_file_file_display_progress): remove tv_transfer_start argument, use ctx->transfer_start instead. * (copy_file_file): sync with modified file_op_context_t and copy_file_file_display_progress(). Signed-off-by: Andrew Borodin <aborodin@vmail.ru>
This commit is contained in:
parent
f699e184ea
commit
31771bd332
@ -1132,8 +1132,7 @@ files_error (const char *format, const char *file1, const char *file2)
|
|||||||
|
|
||||||
static void
|
static void
|
||||||
copy_file_file_display_progress (file_op_total_context_t *tctx, file_op_context_t *ctx,
|
copy_file_file_display_progress (file_op_total_context_t *tctx, file_op_context_t *ctx,
|
||||||
gint64 tv_current, gint64 tv_transfer_start, off_t file_part,
|
gint64 tv_current, off_t file_part, off_t file_size)
|
||||||
off_t file_size)
|
|
||||||
{
|
{
|
||||||
gint64 dt;
|
gint64 dt;
|
||||||
|
|
||||||
@ -1141,7 +1140,7 @@ copy_file_file_display_progress (file_op_total_context_t *tctx, file_op_context_
|
|||||||
rotate_dash (TRUE);
|
rotate_dash (TRUE);
|
||||||
|
|
||||||
/* Compute ETA */
|
/* Compute ETA */
|
||||||
dt = (tv_current - tv_transfer_start) / G_USEC_PER_SEC;
|
dt = (tv_current - ctx->transfer_start) / G_USEC_PER_SEC;
|
||||||
|
|
||||||
if (file_part == 0)
|
if (file_part == 0)
|
||||||
ctx->eta_secs = 0.0;
|
ctx->eta_secs = 0.0;
|
||||||
@ -2277,7 +2276,6 @@ copy_file_file (file_op_total_context_t *tctx, file_op_context_t *ctx,
|
|||||||
gboolean dst_exists = FALSE, appending = FALSE;
|
gboolean dst_exists = FALSE, appending = FALSE;
|
||||||
off_t file_size = -1;
|
off_t file_size = -1;
|
||||||
FileProgressStatus return_status, temp_status;
|
FileProgressStatus return_status, temp_status;
|
||||||
gint64 tv_transfer_start;
|
|
||||||
dest_status_t dst_status = DEST_NONE;
|
dest_status_t dst_status = DEST_NONE;
|
||||||
int open_flags;
|
int open_flags;
|
||||||
vfs_path_t *src_vpath = NULL, *dst_vpath = NULL;
|
vfs_path_t *src_vpath = NULL, *dst_vpath = NULL;
|
||||||
@ -2524,7 +2522,7 @@ copy_file_file (file_op_total_context_t *tctx, file_op_context_t *ctx,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tv_transfer_start = g_get_monotonic_time ();
|
ctx->transfer_start = g_get_monotonic_time ();
|
||||||
|
|
||||||
while ((src_desc = mc_open (src_vpath, O_RDONLY | O_LINEAR)) < 0 && !ctx->ignore_all)
|
while ((src_desc = mc_open (src_vpath, O_RDONLY | O_LINEAR)) < 0 && !ctx->ignore_all)
|
||||||
{
|
{
|
||||||
@ -2685,7 +2683,7 @@ copy_file_file (file_op_total_context_t *tctx, file_op_context_t *ctx,
|
|||||||
const char *stalled_msg = "";
|
const char *stalled_msg = "";
|
||||||
gboolean is_first_time = TRUE;
|
gboolean is_first_time = TRUE;
|
||||||
|
|
||||||
tv_last_update = tv_transfer_start;
|
tv_last_update = ctx->transfer_start;
|
||||||
|
|
||||||
bufsize = io_blksize (dst_stat);
|
bufsize = io_blksize (dst_stat);
|
||||||
buf = g_malloc (bufsize);
|
buf = g_malloc (bufsize);
|
||||||
@ -2765,8 +2763,8 @@ copy_file_file (file_op_total_context_t *tctx, file_op_context_t *ctx,
|
|||||||
|
|
||||||
if (is_first_time || usecs > FILEOP_UPDATE_INTERVAL_US)
|
if (is_first_time || usecs > FILEOP_UPDATE_INTERVAL_US)
|
||||||
{
|
{
|
||||||
copy_file_file_display_progress (tctx, ctx, tv_current, tv_transfer_start,
|
copy_file_file_display_progress (tctx, ctx, tv_current, file_part,
|
||||||
file_part, file_size - ctx->do_reget);
|
file_size - ctx->do_reget);
|
||||||
tv_last_update = tv_current;
|
tv_last_update = tv_current;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -76,6 +76,9 @@ typedef struct
|
|||||||
/* Operation type (copy, move, delete) */
|
/* Operation type (copy, move, delete) */
|
||||||
FileOperation operation;
|
FileOperation operation;
|
||||||
|
|
||||||
|
/* Start of file transferring */
|
||||||
|
gint64 transfer_start;
|
||||||
|
|
||||||
/* The estimated time of arrival in seconds */
|
/* The estimated time of arrival in seconds */
|
||||||
double eta_secs;
|
double eta_secs;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user