mirror of
https://github.com/MidnightCommander/mc
synced 2025-01-08 20:41:59 +03:00
Merge branch '2429_fileop_counters_overflow'
* 2429_fileop_counters_overflow: Adjust formatting output of source and destination file sizes Unification of ctx and ctx->ui checks. Removed unneeded checks. Optimization of verbose operations with several files. Use size_t instead of off_t for file counters during file operations. Ticket #2429: overflow of file operation counters.
This commit is contained in:
commit
f8207591bd
28
lib/util.c
28
lib/util.c
@ -326,30 +326,30 @@ path_trunc (const char *path, size_t trunc_len)
|
||||
/* --------------------------------------------------------------------------------------------- */
|
||||
|
||||
const char *
|
||||
size_trunc (double size, gboolean use_si)
|
||||
size_trunc (uintmax_t size, gboolean use_si)
|
||||
{
|
||||
static char x[BUF_TINY];
|
||||
long int divisor = 1;
|
||||
uintmax_t divisor = 1;
|
||||
const char *xtra = "";
|
||||
|
||||
if (size > 999999999L)
|
||||
if (size > 999999999UL)
|
||||
{
|
||||
divisor = use_si ? 1000 : 1024;
|
||||
xtra = use_si ? "k" : "K";
|
||||
if (size / divisor > 999999999L)
|
||||
if (size / divisor > 999999999UL)
|
||||
{
|
||||
divisor = use_si ? (1000 * 1000) : (1024 * 1024);
|
||||
xtra = use_si ? "m" : "M";
|
||||
}
|
||||
}
|
||||
g_snprintf (x, sizeof (x), "%.0f%s", (size / divisor), xtra);
|
||||
g_snprintf (x, sizeof (x), "%.0f%s", 1.0 * size / divisor, xtra);
|
||||
return x;
|
||||
}
|
||||
|
||||
/* --------------------------------------------------------------------------------------------- */
|
||||
|
||||
const char *
|
||||
size_trunc_sep (double size, gboolean use_si)
|
||||
size_trunc_sep (uintmax_t size, gboolean use_si)
|
||||
{
|
||||
static char x[60];
|
||||
int count;
|
||||
@ -359,7 +359,7 @@ size_trunc_sep (double size, gboolean use_si)
|
||||
p = y = size_trunc (size, use_si);
|
||||
p += strlen (p) - 1;
|
||||
d = x + sizeof (x) - 1;
|
||||
*d-- = 0;
|
||||
*d-- = '\0';
|
||||
while (p >= y && isalpha ((unsigned char) *p))
|
||||
*d-- = *p--;
|
||||
for (count = 0; p >= y; count++)
|
||||
@ -389,11 +389,12 @@ size_trunc_sep (double size, gboolean use_si)
|
||||
*/
|
||||
|
||||
void
|
||||
size_trunc_len (char *buffer, unsigned int len, off_t size, int units, gboolean use_si)
|
||||
size_trunc_len (char *buffer, unsigned int len, uintmax_t size, int units, gboolean use_si)
|
||||
{
|
||||
/* Avoid taking power for every file. */
|
||||
static const off_t power10[] = { 1, 10, 100, 1000, 10000, 100000, 1000000, 10000000, 100000000,
|
||||
1000000000
|
||||
static const uintmax_t power10[] =
|
||||
{
|
||||
1, 10, 100, 1000, 10000, 100000, 1000000, 10000000, 100000000, 1000000000
|
||||
};
|
||||
static const char *const suffix[] = { "", "K", "M", "G", "T", "P", "E", "Z", "Y", NULL };
|
||||
static const char *const suffix_lc[] = { "", "k", "m", "g", "t", "p", "e", "z", "y", NULL };
|
||||
@ -408,8 +409,7 @@ size_trunc_len (char *buffer, unsigned int len, off_t size, int units, gboolean
|
||||
* We can't just multiply by 1024 - that might cause overflow
|
||||
* if off_t type is too small
|
||||
*/
|
||||
if (units && use_si)
|
||||
{
|
||||
if (use_si)
|
||||
for (j = 0; j < units; j++)
|
||||
{
|
||||
size_remain = ((size % 125) * 1024) / 1000; /* size mod 125, recalculated */
|
||||
@ -417,7 +417,6 @@ size_trunc_len (char *buffer, unsigned int len, off_t size, int units, gboolean
|
||||
size = size * 128; /* This will convert size from multiple of 1024 to multiple of 1000 */
|
||||
size += size_remain; /* Re-add remainder lost by division/multiplication */
|
||||
}
|
||||
}
|
||||
|
||||
for (j = units; suffix[j] != NULL; j++)
|
||||
{
|
||||
@ -438,8 +437,7 @@ size_trunc_len (char *buffer, unsigned int len, off_t size, int units, gboolean
|
||||
|
||||
if (size < power10[len - (j > 0)])
|
||||
{
|
||||
g_snprintf (buffer, len + 1, "%lu%s", (unsigned long) size,
|
||||
use_si ? suffix_lc[j] : suffix[j]);
|
||||
g_snprintf (buffer, len + 1, "%ju%s", size, use_si ? suffix_lc[j] : suffix[j]);
|
||||
break;
|
||||
}
|
||||
|
||||
|
@ -9,6 +9,7 @@
|
||||
|
||||
#include <sys/types.h>
|
||||
#include <sys/stat.h>
|
||||
#include <inttypes.h> /* uintmax_t */
|
||||
#include <unistd.h>
|
||||
|
||||
/*** typedefs(not structures) and defined constants **********************************************/
|
||||
@ -70,18 +71,18 @@ const char *path_trunc (const char *path, size_t trunc_len);
|
||||
/* return a static string representing size, appending "K" or "M" for
|
||||
* big sizes.
|
||||
* NOTE: uses the same static buffer as size_trunc_sep. */
|
||||
const char *size_trunc (double size, gboolean use_si);
|
||||
const char *size_trunc (uintmax_t size, gboolean use_si);
|
||||
|
||||
/* return a static string representing size, appending "K" or "M" for
|
||||
* big sizes. Separates every three digits by ",".
|
||||
* NOTE: uses the same static buffer as size_trunc. */
|
||||
const char *size_trunc_sep (double size, gboolean use_si);
|
||||
const char *size_trunc_sep (uintmax_t size, gboolean use_si);
|
||||
|
||||
/* Print file SIZE to BUFFER, but don't exceed LEN characters,
|
||||
* not including trailing 0. BUFFER should be at least LEN+1 long.
|
||||
*
|
||||
* Units: size units (0=bytes, 1=Kbytes, 2=Mbytes, etc.) */
|
||||
void size_trunc_len (char *buffer, unsigned int len, off_t size, int units, gboolean use_si);
|
||||
void size_trunc_len (char *buffer, unsigned int len, uintmax_t size, int units, gboolean use_si);
|
||||
const char *string_perm (mode_t mode_bits);
|
||||
|
||||
/* @modifies path. @returns pointer into path. */
|
||||
|
@ -1492,16 +1492,15 @@ single_dirsize_cmd (void)
|
||||
{
|
||||
WPanel *panel = current_panel;
|
||||
file_entry *entry;
|
||||
off_t marked;
|
||||
double total;
|
||||
ComputeDirSizeUI *ui;
|
||||
|
||||
entry = &(panel->dir.list[panel->selected]);
|
||||
if (S_ISDIR (entry->st.st_mode) && strcmp (entry->fname, "..") != 0)
|
||||
{
|
||||
ui = compute_dir_size_create_ui ();
|
||||
size_t marked = 0;
|
||||
uintmax_t total = 0;
|
||||
ComputeDirSizeUI *ui;
|
||||
|
||||
total = 0.0;
|
||||
ui = compute_dir_size_create_ui ();
|
||||
|
||||
if (compute_dir_size (entry->fname, ui, compute_dir_size_update_ui,
|
||||
&marked, &total, TRUE) == FILE_CONT)
|
||||
@ -1531,8 +1530,6 @@ dirsizes_cmd (void)
|
||||
{
|
||||
WPanel *panel = current_panel;
|
||||
int i;
|
||||
off_t marked;
|
||||
double total;
|
||||
ComputeDirSizeUI *ui;
|
||||
|
||||
ui = compute_dir_size_create_ui ();
|
||||
@ -1542,7 +1539,8 @@ dirsizes_cmd (void)
|
||||
&& ((panel->dirs_marked && panel->dir.list[i].f.marked)
|
||||
|| !panel->dirs_marked) && strcmp (panel->dir.list[i].fname, "..") != 0)
|
||||
{
|
||||
total = 0.0l;
|
||||
size_t marked = 0;
|
||||
uintmax_t total = 0;
|
||||
|
||||
if (compute_dir_size (panel->dir.list[i].fname,
|
||||
ui, compute_dir_size_update_ui, &marked, &total,
|
||||
|
@ -421,7 +421,7 @@ progress_update_one (FileOpTotalContext * tctx, FileOpContext * ctx, off_t add,
|
||||
if (is_toplevel_file || ctx->progress_totals_computed)
|
||||
{
|
||||
tctx->progress_count++;
|
||||
tctx->progress_bytes += add;
|
||||
tctx->progress_bytes += (uintmax_t) add;
|
||||
}
|
||||
if (tv_start.tv_sec == 0)
|
||||
{
|
||||
@ -429,9 +429,12 @@ progress_update_one (FileOpTotalContext * tctx, FileOpContext * ctx, off_t add,
|
||||
}
|
||||
gettimeofday (&tv_current, (struct timezone *) NULL);
|
||||
if ((tv_current.tv_sec - tv_start.tv_sec) > FILEOP_UPDATE_INTERVAL)
|
||||
{
|
||||
if (verbose && ctx->dialog_type == FILEGUI_DIALOG_MULTI_ITEM)
|
||||
{
|
||||
file_progress_show_count (ctx, tctx->progress_count, ctx->progress_count);
|
||||
file_progress_show_total (tctx, ctx, tctx->progress_bytes, TRUE);
|
||||
}
|
||||
tv_start.tv_sec = tv_current.tv_sec;
|
||||
}
|
||||
|
||||
@ -516,7 +519,7 @@ copy_file_file_display_progress (FileOpTotalContext * tctx, FileOpContext * ctx,
|
||||
/* 5. Compute total ETA and BPS */
|
||||
if (ctx->progress_bytes != 0)
|
||||
{
|
||||
double remain_bytes;
|
||||
uintmax_t remain_bytes;
|
||||
tctx->copyed_bytes = tctx->progress_bytes + n_read_total + ctx->do_reget;
|
||||
remain_bytes = ctx->progress_bytes - tctx->copyed_bytes;
|
||||
#if 1
|
||||
@ -668,23 +671,22 @@ erase_file (FileOpTotalContext * tctx, FileOpContext * ctx, const char *s,
|
||||
return FILE_ABORT;
|
||||
mc_refresh ();
|
||||
|
||||
if (tctx->progress_count && mc_lstat (s, &buf))
|
||||
if (tctx->progress_count != 0 && mc_lstat (s, &buf) != 0)
|
||||
{
|
||||
/* ignore, most likely the mc_unlink fails, too */
|
||||
buf.st_size = 0;
|
||||
}
|
||||
|
||||
while (mc_unlink (s))
|
||||
while (mc_unlink (s) != 0)
|
||||
{
|
||||
return_status = file_error (_("Cannot delete file \"%s\"\n%s"), s);
|
||||
if (return_status != FILE_RETRY)
|
||||
return return_status;
|
||||
}
|
||||
|
||||
if (tctx->progress_count)
|
||||
return progress_update_one (tctx, ctx, buf.st_size, is_toplevel_file);
|
||||
else
|
||||
if (tctx->progress_count == 0)
|
||||
return FILE_CONT;
|
||||
return progress_update_one (tctx, ctx, buf.st_size, is_toplevel_file);
|
||||
}
|
||||
|
||||
/* --------------------------------------------------------------------------------------------- */
|
||||
@ -858,12 +860,12 @@ panel_get_file (WPanel * panel, struct stat *stat_buf)
|
||||
static FileProgressStatus
|
||||
panel_compute_totals (const WPanel * panel, const void *ui,
|
||||
compute_dir_size_callback cback,
|
||||
off_t * ret_marked, double *ret_total, gboolean compute_symlinks)
|
||||
size_t * ret_marked, uintmax_t *ret_total, gboolean compute_symlinks)
|
||||
{
|
||||
int i;
|
||||
|
||||
*ret_marked = 0;
|
||||
*ret_total = 0.0;
|
||||
*ret_total = 0;
|
||||
|
||||
for (i = 0; i < panel->count; i++)
|
||||
{
|
||||
@ -877,8 +879,8 @@ panel_compute_totals (const WPanel * panel, const void *ui,
|
||||
if (S_ISDIR (s->st_mode))
|
||||
{
|
||||
char *dir_name;
|
||||
off_t subdir_count = 0;
|
||||
double subdir_bytes = 0;
|
||||
size_t subdir_count = 0;
|
||||
uintmax_t subdir_bytes = 0;
|
||||
FileProgressStatus status;
|
||||
|
||||
dir_name = concat_dir_and_file (panel->cwd, panel->dir.list[i].fname);
|
||||
@ -896,7 +898,7 @@ panel_compute_totals (const WPanel * panel, const void *ui,
|
||||
else
|
||||
{
|
||||
(*ret_marked)++;
|
||||
*ret_total += s->st_size;
|
||||
*ret_total += (uintmax_t) s->st_size;
|
||||
}
|
||||
}
|
||||
|
||||
@ -1508,13 +1510,18 @@ copy_file_file (FileOpTotalContext * tctx, FileOpContext * ctx,
|
||||
}
|
||||
|
||||
{
|
||||
gboolean force_update =
|
||||
gboolean force_update;
|
||||
|
||||
force_update =
|
||||
(tv_current.tv_sec - tctx->transfer_start.tv_sec) > FILEOP_UPDATE_INTERVAL;
|
||||
|
||||
if (verbose && ctx->dialog_type == FILEGUI_DIALOG_MULTI_ITEM)
|
||||
{
|
||||
file_progress_show_count (ctx, tctx->progress_count, ctx->progress_count);
|
||||
file_progress_show_total (tctx, ctx,
|
||||
tctx->progress_bytes + n_read_total + ctx->do_reget,
|
||||
force_update);
|
||||
|
||||
}
|
||||
|
||||
file_progress_show (ctx, n_read_total + ctx->do_reget, file_size, stalled_msg,
|
||||
force_update);
|
||||
@ -2116,7 +2123,7 @@ compute_dir_size_update_ui (const void *ui, const char *dirname)
|
||||
FileProgressStatus
|
||||
compute_dir_size (const char *dirname, const void *ui,
|
||||
compute_dir_size_callback cback,
|
||||
off_t * ret_marked, double *ret_total, gboolean compute_symlinks)
|
||||
size_t * ret_marked, uintmax_t *ret_total, gboolean compute_symlinks)
|
||||
{
|
||||
int res;
|
||||
struct stat s;
|
||||
@ -2134,7 +2141,7 @@ compute_dir_size (const char *dirname, const void *ui,
|
||||
if (S_ISLNK (s.st_mode))
|
||||
{
|
||||
(*ret_marked)++;
|
||||
*ret_total += s.st_size;
|
||||
*ret_total += (uintmax_t) s.st_size;
|
||||
return ret;
|
||||
}
|
||||
}
|
||||
@ -2169,8 +2176,8 @@ compute_dir_size (const char *dirname, const void *ui,
|
||||
|
||||
if (S_ISDIR (s.st_mode))
|
||||
{
|
||||
off_t subdir_count = 0;
|
||||
double subdir_bytes = 0;
|
||||
size_t subdir_count = 0;
|
||||
uintmax_t subdir_bytes = 0;
|
||||
|
||||
ret =
|
||||
compute_dir_size (fullname, ui, cback, &subdir_count, &subdir_bytes,
|
||||
@ -2188,7 +2195,7 @@ compute_dir_size (const char *dirname, const void *ui,
|
||||
else
|
||||
{
|
||||
(*ret_marked)++;
|
||||
*ret_total += s.st_size;
|
||||
*ret_total += (uintmax_t) s.st_size;
|
||||
}
|
||||
|
||||
g_free (fullname);
|
||||
@ -2589,15 +2596,14 @@ panel_operate (void *source_panel, FileOperation operation, gboolean force_singl
|
||||
if (value == FILE_CONT)
|
||||
do_file_mark (panel, i, 0);
|
||||
|
||||
file_progress_show_count (ctx, tctx->progress_count, ctx->progress_count);
|
||||
|
||||
if (verbose)
|
||||
if (verbose && ctx->dialog_type == FILEGUI_DIALOG_MULTI_ITEM)
|
||||
{
|
||||
file_progress_show_count (ctx, tctx->progress_count, ctx->progress_count);
|
||||
file_progress_show_total (tctx, ctx, tctx->progress_bytes, FALSE);
|
||||
}
|
||||
|
||||
if (operation != OP_DELETE)
|
||||
file_progress_show (ctx, 0, 0, "", FALSE);
|
||||
}
|
||||
|
||||
if (check_progress_buttons (ctx) == FILE_ABORT)
|
||||
break;
|
||||
|
@ -5,8 +5,7 @@
|
||||
#ifndef MC__FILE_H
|
||||
#define MC__FILE_H
|
||||
|
||||
#include <sys/types.h> /* off_t */
|
||||
#include <sys/time.h>
|
||||
#include <inttypes.h> /* off_t, uintmax_t */
|
||||
|
||||
#include "lib/global.h"
|
||||
#include "lib/widget.h"
|
||||
@ -56,10 +55,9 @@ FileProgressStatus file_error (const char *format, const char *file);
|
||||
/* return value is FILE_CONT or FILE_ABORT */
|
||||
FileProgressStatus compute_dir_size (const char *dirname, const void *ui,
|
||||
compute_dir_size_callback cback,
|
||||
off_t * ret_marked, double *ret_total,
|
||||
size_t * ret_marked, uintmax_t *ret_total,
|
||||
gboolean compute_symlinks);
|
||||
|
||||
|
||||
ComputeDirSizeUI *compute_dir_size_create_ui (void);
|
||||
void compute_dir_size_destroy_ui (ComputeDirSizeUI * ui);
|
||||
FileProgressStatus compute_dir_size_update_ui (const void *ui, const char *dirname);
|
||||
|
@ -290,8 +290,7 @@ overwrite_query_dialog (FileOpContext * ctx, enum OperationMode mode)
|
||||
|
||||
#define ADD_RD_LABEL(i, p1, p2) \
|
||||
g_snprintf (buffer, sizeof (buffer), rd_widgets [i].text, p1, p2); \
|
||||
add_widget (ui->replace_dlg,\
|
||||
label_new (rd_widgets [i].ypos, rd_widgets [i].xpos, buffer))
|
||||
add_widget (ui->replace_dlg, label_new (rd_widgets [i].ypos, rd_widgets [i].xpos, buffer))
|
||||
|
||||
/* dialog sizes */
|
||||
const int rd_ylen = 17;
|
||||
@ -309,17 +308,10 @@ overwrite_query_dialog (FileOpContext * ctx, enum OperationMode mode)
|
||||
{ N_("Target file already exists!"), 3, 4, 0 },
|
||||
/* 1 */
|
||||
{ "%s", 4, 4, 0 },
|
||||
#if (defined(_FILE_OFFSET_BITS) && _FILE_OFFSET_BITS == 64) || (defined _LARGE_FILES && _LARGE_FILES)
|
||||
/* 2 */
|
||||
{ N_("Source date: %s, size %llu"), 6, 4, 0 },
|
||||
{ N_("Source date: %s, size %ju"), 6, 4, 0 },
|
||||
/* 3 */
|
||||
{ N_("Target date: %s, size %llu"), 7, 4, 0 },
|
||||
#else
|
||||
/* 2 */
|
||||
{ N_("Source date: %s, size %u"), 6, 4, 0 },
|
||||
/* 3 */
|
||||
{ N_("Target date: %s, size %u"), 7, 4, 0 },
|
||||
#endif
|
||||
{ N_("Target date: %s, size %ju"), 7, 4, 0 },
|
||||
/* 4 */
|
||||
{ N_("&Abort"), 14, 25, REPLACE_ABORT },
|
||||
/* 5 */
|
||||
@ -436,10 +428,10 @@ overwrite_query_dialog (FileOpContext * ctx, enum OperationMode mode)
|
||||
add_widget (ui->replace_dlg,
|
||||
label_new (rd_widgets[1].ypos, (rd_xlen - stripped_name_len) / 2, stripped_name));
|
||||
|
||||
/* source date */
|
||||
ADD_RD_LABEL (2, file_date (ui->s_stat->st_mtime), (off_t) ui->s_stat->st_size);
|
||||
/* destination date */
|
||||
ADD_RD_LABEL (3, file_date (ui->d_stat->st_mtime), (off_t) ui->d_stat->st_size);
|
||||
/* source date and size */
|
||||
ADD_RD_LABEL (2, file_date (ui->s_stat->st_mtime), (uintmax_t) ui->s_stat->st_size);
|
||||
/* destination date and size */
|
||||
ADD_RD_LABEL (3, file_date (ui->d_stat->st_mtime), (uintmax_t) ui->d_stat->st_size);
|
||||
|
||||
ADD_RD_BUTTON (4); /* Abort */
|
||||
ADD_RD_BUTTON (5); /* If size differs */
|
||||
@ -497,8 +489,7 @@ check_progress_buttons (FileOpContext * ctx)
|
||||
Gpm_Event event;
|
||||
FileOpContextUI *ui;
|
||||
|
||||
if (ctx->ui == NULL)
|
||||
return FILE_CONT;
|
||||
g_return_val_if_fail (ctx->ui != NULL, FILE_CONT);
|
||||
|
||||
ui = ctx->ui;
|
||||
|
||||
@ -655,22 +646,19 @@ file_op_context_create_ui (FileOpContext * ctx, gboolean with_eta,
|
||||
void
|
||||
file_op_context_destroy_ui (FileOpContext * ctx)
|
||||
{
|
||||
FileOpContextUI *ui;
|
||||
|
||||
g_return_if_fail (ctx != NULL);
|
||||
|
||||
if (ctx->ui)
|
||||
if (ctx->ui != NULL)
|
||||
{
|
||||
ui = ctx->ui;
|
||||
FileOpContextUI *ui = (FileOpContextUI *) ctx->ui;
|
||||
|
||||
dlg_run_done (ui->op_dlg);
|
||||
destroy_dlg (ui->op_dlg);
|
||||
g_free (ui);
|
||||
ctx->ui = NULL;
|
||||
}
|
||||
|
||||
the_hint->widget.y = last_hint_line;
|
||||
|
||||
ctx->ui = NULL;
|
||||
}
|
||||
|
||||
/* --------------------------------------------------------------------------------------------- */
|
||||
@ -687,16 +675,14 @@ file_progress_show (FileOpContext * ctx, off_t done, off_t total,
|
||||
char buffer2[BUF_TINY];
|
||||
char buffer3[BUF_TINY];
|
||||
|
||||
g_return_if_fail (ctx != NULL);
|
||||
|
||||
if (ctx->ui == NULL)
|
||||
return;
|
||||
|
||||
ui = ctx->ui;
|
||||
|
||||
if (!verbose)
|
||||
return;
|
||||
|
||||
g_return_if_fail (ctx != NULL);
|
||||
g_return_if_fail (ctx->ui != NULL);
|
||||
|
||||
ui = ctx->ui;
|
||||
|
||||
if (total == 0)
|
||||
{
|
||||
gauge_show (ui->progress_file_gauge, 0);
|
||||
@ -726,32 +712,24 @@ file_progress_show (FileOpContext * ctx, off_t done, off_t total,
|
||||
/* --------------------------------------------------------------------------------------------- */
|
||||
|
||||
void
|
||||
file_progress_show_count (FileOpContext * ctx, off_t done, off_t total)
|
||||
file_progress_show_count (FileOpContext * ctx, size_t done, size_t total)
|
||||
{
|
||||
char buffer[BUF_TINY];
|
||||
FileOpContextUI *ui;
|
||||
|
||||
g_return_if_fail (ctx != NULL);
|
||||
|
||||
if (ctx->dialog_type != FILEGUI_DIALOG_MULTI_ITEM || ctx->ui == NULL)
|
||||
return;
|
||||
g_return_if_fail (ctx->ui != NULL);
|
||||
|
||||
ui = ctx->ui;
|
||||
|
||||
if (!verbose)
|
||||
return;
|
||||
|
||||
g_snprintf (buffer, BUF_TINY, _("Files processed: %llu of %llu"),
|
||||
(unsigned long long) done, (unsigned long long) total);
|
||||
|
||||
g_snprintf (buffer, BUF_TINY, _("Files processed: %zu of %zu"), done, total);
|
||||
label_set_text (ui->total_files_processed_label, buffer);
|
||||
}
|
||||
|
||||
/* --------------------------------------------------------------------------------------------- */
|
||||
|
||||
void
|
||||
file_progress_show_total (FileOpTotalContext * tctx, FileOpContext * ctx, double copyed_bytes,
|
||||
gboolean need_show_total_summary)
|
||||
file_progress_show_total (FileOpTotalContext * tctx, FileOpContext * ctx, uintmax_t copyed_bytes,
|
||||
gboolean show_summary)
|
||||
{
|
||||
char buffer[BUF_TINY];
|
||||
char buffer2[BUF_TINY];
|
||||
@ -760,15 +738,12 @@ file_progress_show_total (FileOpTotalContext * tctx, FileOpContext * ctx, double
|
||||
struct timeval tv_current;
|
||||
FileOpContextUI *ui;
|
||||
|
||||
if (!verbose)
|
||||
return;
|
||||
|
||||
if (ctx->dialog_type != FILEGUI_DIALOG_MULTI_ITEM || ctx->ui == NULL)
|
||||
return;
|
||||
g_return_if_fail (ctx != NULL);
|
||||
g_return_if_fail (ctx->ui != NULL);
|
||||
|
||||
ui = ctx->ui;
|
||||
|
||||
if (ctx->progress_bytes > 0)
|
||||
if (ctx->progress_bytes != 0)
|
||||
{
|
||||
gauge_set_value (ui->progress_total_gauge, 1024,
|
||||
(int) (1024 * copyed_bytes / ctx->progress_bytes));
|
||||
@ -777,8 +752,7 @@ file_progress_show_total (FileOpTotalContext * tctx, FileOpContext * ctx, double
|
||||
else
|
||||
gauge_show (ui->progress_total_gauge, 0);
|
||||
|
||||
|
||||
if (!need_show_total_summary && tctx->bps == 0)
|
||||
if (!show_summary && tctx->bps == 0)
|
||||
return;
|
||||
|
||||
gettimeofday (&tv_current, NULL);
|
||||
@ -795,7 +769,6 @@ file_progress_show_total (FileOpTotalContext * tctx, FileOpContext * ctx, double
|
||||
g_snprintf (buffer, BUF_TINY, _("Total: %s of %s"), buffer2, buffer3);
|
||||
|
||||
label_set_text (ui->total_bytes_label, buffer);
|
||||
|
||||
}
|
||||
|
||||
/* }}} */
|
||||
@ -808,23 +781,21 @@ file_progress_show_source (FileOpContext * ctx, const char *s)
|
||||
FileOpContextUI *ui;
|
||||
|
||||
g_return_if_fail (ctx != NULL);
|
||||
|
||||
if (ctx->ui == NULL)
|
||||
return;
|
||||
g_return_if_fail (ctx->ui != NULL);
|
||||
|
||||
ui = ctx->ui;
|
||||
|
||||
if (s != NULL)
|
||||
{
|
||||
#ifdef WITH_FULL_PATHS
|
||||
int i = strlen (current_panel->cwd);
|
||||
size_t i;
|
||||
|
||||
i = strlen (current_panel->cwd);
|
||||
|
||||
/* We remove the full path we have added before */
|
||||
if (!strncmp (s, current_panel->cwd, i))
|
||||
{
|
||||
if (strncmp (s, current_panel->cwd, i) == 0)
|
||||
if (s[i] == PATH_SEP)
|
||||
s += i + 1;
|
||||
}
|
||||
#endif /* WITH_FULL_PATHS */
|
||||
|
||||
label_set_text (ui->file_label[0], _("Source"));
|
||||
@ -845,9 +816,7 @@ file_progress_show_target (FileOpContext * ctx, const char *s)
|
||||
FileOpContextUI *ui;
|
||||
|
||||
g_return_if_fail (ctx != NULL);
|
||||
|
||||
if (ctx->ui == NULL)
|
||||
return;
|
||||
g_return_if_fail (ctx->ui != NULL);
|
||||
|
||||
ui = ctx->ui;
|
||||
|
||||
@ -871,9 +840,7 @@ file_progress_show_deleting (FileOpContext * ctx, const char *s)
|
||||
FileOpContextUI *ui;
|
||||
|
||||
g_return_if_fail (ctx != NULL);
|
||||
|
||||
if (ctx->ui == NULL)
|
||||
return;
|
||||
g_return_if_fail (ctx->ui != NULL);
|
||||
|
||||
ui = ctx->ui;
|
||||
label_set_text (ui->file_label[0], _("Deleting"));
|
||||
|
@ -10,13 +10,6 @@
|
||||
|
||||
/*** typedefs(not structures) and defined constants **********************************************/
|
||||
|
||||
typedef enum
|
||||
{
|
||||
FILEGUI_DIALOG_ONE_ITEM,
|
||||
FILEGUI_DIALOG_MULTI_ITEM,
|
||||
FILEGUI_DIALOG_DELETE_ITEM
|
||||
} filegui_dialog_type_t;
|
||||
|
||||
/*** enums ***************************************************************************************/
|
||||
|
||||
/*** structures declarations (and typedefs of structures)*****************************************/
|
||||
@ -31,7 +24,6 @@ void file_op_context_create_ui_without_init (FileOpContext * ctx, gboolean with_
|
||||
filegui_dialog_type_t dialog_type);
|
||||
void file_op_context_destroy_ui (FileOpContext * ctx);
|
||||
|
||||
|
||||
char *file_mask_dialog (FileOpContext * ctx, FileOperation operation,
|
||||
gboolean only_one,
|
||||
const char *format, const void *text,
|
||||
@ -41,9 +33,9 @@ FileProgressStatus check_progress_buttons (FileOpContext * ctx);
|
||||
|
||||
void file_progress_show (FileOpContext * ctx, off_t done, off_t total,
|
||||
const char *stalled_msg, gboolean force_update);
|
||||
void file_progress_show_count (FileOpContext * ctx, off_t done, off_t total);
|
||||
void file_progress_show_count (FileOpContext * ctx, size_t done, size_t total);
|
||||
void file_progress_show_total (FileOpTotalContext * tctx, FileOpContext * ctx,
|
||||
double copyed_bytes, gboolean need_show_total_summary);
|
||||
uintmax_t copyed_bytes, gboolean show_summary);
|
||||
void file_progress_show_source (FileOpContext * ctx, const char *path);
|
||||
void file_progress_show_target (FileOpContext * ctx, const char *path);
|
||||
void file_progress_show_deleting (FileOpContext * ctx, const char *path);
|
||||
|
@ -70,7 +70,7 @@ file_op_context_new (FileOperation op)
|
||||
ctx = g_new0 (FileOpContext, 1);
|
||||
ctx->operation = op;
|
||||
ctx->eta_secs = 0.0;
|
||||
ctx->progress_bytes = 0.0;
|
||||
ctx->progress_bytes = 0;
|
||||
ctx->op_preserve = TRUE;
|
||||
ctx->do_reget = 1;
|
||||
ctx->stat_func = mc_lstat;
|
||||
@ -96,13 +96,9 @@ file_op_context_destroy (FileOpContext * ctx)
|
||||
{
|
||||
g_return_if_fail (ctx != NULL);
|
||||
|
||||
if (ctx->ui)
|
||||
file_op_context_destroy_ui (ctx);
|
||||
|
||||
mc_search_free (ctx->search_handle);
|
||||
|
||||
/** \todo FIXME: do we need to free ctx->dest_mask? */
|
||||
|
||||
g_free (ctx);
|
||||
}
|
||||
|
||||
@ -123,7 +119,6 @@ file_op_total_context_new (void)
|
||||
void
|
||||
file_op_total_context_destroy (FileOpTotalContext * tctx)
|
||||
{
|
||||
g_return_if_fail (tctx != NULL);
|
||||
g_free (tctx);
|
||||
}
|
||||
|
||||
|
@ -17,6 +17,7 @@
|
||||
#include <sys/stat.h>
|
||||
#include <sys/types.h>
|
||||
#include <sys/time.h>
|
||||
#include <inttypes.h> /* uintmax_t */
|
||||
|
||||
#include "lib/global.h"
|
||||
|
||||
@ -27,6 +28,13 @@ typedef int (*mc_stat_fn) (const char *filename, struct stat * buf);
|
||||
|
||||
/*** enums ***************************************************************************************/
|
||||
|
||||
typedef enum
|
||||
{
|
||||
FILEGUI_DIALOG_ONE_ITEM,
|
||||
FILEGUI_DIALOG_MULTI_ITEM,
|
||||
FILEGUI_DIALOG_DELETE_ITEM
|
||||
} filegui_dialog_type_t;
|
||||
|
||||
typedef enum
|
||||
{
|
||||
OP_COPY = 0,
|
||||
@ -81,11 +89,11 @@ typedef struct FileOpContext
|
||||
|
||||
/* Whether the panel total has been computed */
|
||||
gboolean progress_totals_computed;
|
||||
int dialog_type;
|
||||
filegui_dialog_type_t dialog_type;
|
||||
|
||||
/* Counters for progress indicators */
|
||||
off_t progress_count;
|
||||
double progress_bytes;
|
||||
size_t progress_count;
|
||||
uintmax_t progress_bytes;
|
||||
|
||||
/* The value of the "preserve Attributes" checkbox in the copy file dialog.
|
||||
* We can't use the value of "ctx->preserve" because it can change in order
|
||||
@ -153,9 +161,9 @@ typedef struct FileOpContext
|
||||
|
||||
typedef struct
|
||||
{
|
||||
off_t progress_count;
|
||||
double progress_bytes;
|
||||
double copyed_bytes;
|
||||
size_t progress_count;
|
||||
uintmax_t progress_bytes;
|
||||
uintmax_t copyed_bytes;
|
||||
size_t bps;
|
||||
size_t bps_count;
|
||||
struct timeval transfer_start;
|
||||
@ -163,7 +171,6 @@ typedef struct
|
||||
|
||||
gboolean ask_overwrite;
|
||||
gboolean is_toplevel_file;
|
||||
|
||||
} FileOpTotalContext;
|
||||
|
||||
/*** global variables defined in .c file *********************************************************/
|
||||
|
@ -975,7 +975,7 @@ display_total_marked_size (WPanel * panel, int y, int x, gboolean size_only)
|
||||
* First make "N bytes", then insert it into "X in M files".
|
||||
*/
|
||||
g_snprintf (b_bytes, sizeof (b_bytes),
|
||||
ngettext ("%s byte", "%s bytes", (unsigned long) panel->total),
|
||||
ngettext ("%s byte", "%s bytes", panel->total),
|
||||
size_trunc_sep (panel->total, panels_options.kilobyte_si));
|
||||
if (!size_only)
|
||||
g_snprintf (buffer, sizeof (buffer),
|
||||
@ -3791,7 +3791,7 @@ do_file_mark (WPanel * panel, int idx, int mark)
|
||||
return;
|
||||
|
||||
/* Only '..' can't be marked, '.' isn't visible */
|
||||
if (!strcmp (panel->dir.list[idx].fname, ".."))
|
||||
if (strcmp (panel->dir.list[idx].fname, "..") == 0)
|
||||
return;
|
||||
|
||||
file_mark (panel, idx, mark);
|
||||
@ -3801,11 +3801,11 @@ do_file_mark (WPanel * panel, int idx, int mark)
|
||||
if (S_ISDIR (panel->dir.list[idx].st.st_mode))
|
||||
{
|
||||
if (panel->dir.list[idx].f.dir_size_computed)
|
||||
panel->total += panel->dir.list[idx].st.st_size;
|
||||
panel->total += (uintmax_t) panel->dir.list[idx].st.st_size;
|
||||
panel->dirs_marked++;
|
||||
}
|
||||
else
|
||||
panel->total += panel->dir.list[idx].st.st_size;
|
||||
panel->total += (uintmax_t) panel->dir.list[idx].st.st_size;
|
||||
set_colors (panel);
|
||||
}
|
||||
else
|
||||
@ -3813,11 +3813,11 @@ do_file_mark (WPanel * panel, int idx, int mark)
|
||||
if (S_ISDIR (panel->dir.list[idx].st.st_mode))
|
||||
{
|
||||
if (panel->dir.list[idx].f.dir_size_computed)
|
||||
panel->total -= panel->dir.list[idx].st.st_size;
|
||||
panel->total -= (uintmax_t) panel->dir.list[idx].st.st_size;
|
||||
panel->dirs_marked--;
|
||||
}
|
||||
else
|
||||
panel->total -= panel->dir.list[idx].st.st_size;
|
||||
panel->total -= (uintmax_t) panel->dir.list[idx].st.st_size;
|
||||
panel->marked--;
|
||||
}
|
||||
}
|
||||
|
@ -5,6 +5,8 @@
|
||||
#ifndef MC__PANEL_H
|
||||
#define MC__PANEL_H
|
||||
|
||||
#include <inttypes.h> /* uintmax_t */
|
||||
|
||||
#include "lib/global.h" /* gboolean */
|
||||
#include "lib/fs.h" /* MC_MAXPATHLEN */
|
||||
#include "lib/strutil.h"
|
||||
@ -84,7 +86,7 @@ typedef struct WPanel
|
||||
int count; /* Number of files in dir structure */
|
||||
int marked; /* Count of marked files */
|
||||
int dirs_marked; /* Count of marked directories */
|
||||
double total; /* Bytes in marked files */
|
||||
uintmax_t total; /* Bytes in marked files */
|
||||
int top_file; /* The file showed on the top of the panel */
|
||||
int selected; /* Index to the selected file */
|
||||
int reverse; /* Show listing in reverse? */
|
||||
|
Loading…
Reference in New Issue
Block a user