(overwrite_query_dialog): redesign the overwrite query dialog.

Signed-off-by: Andrew Borodin <aborodin@vmail.ru>
This commit is contained in:
Andrew Borodin 2019-02-10 17:09:52 +03:00
parent 67653322a3
commit a07cb50069
3 changed files with 266 additions and 188 deletions

View File

@ -1035,7 +1035,7 @@ query_recursive (file_op_context_t * ctx, const char *s)
/* --------------------------------------------------------------------------------------------- */ /* --------------------------------------------------------------------------------------------- */
static FileProgressStatus static FileProgressStatus
query_replace (file_op_context_t * ctx, const char *dst, struct stat *src_stat, query_replace (file_op_context_t * ctx, const char *src, struct stat *src_stat, const char *dst,
struct stat *dst_stat) struct stat *dst_stat)
{ {
/* *INDENT-OFF* */ /* *INDENT-OFF* */
@ -1043,17 +1043,17 @@ query_replace (file_op_context_t * ctx, const char *dst, struct stat *src_stat,
{ {
void *p; void *p;
FileProgressStatus (*f) (file_op_context_t *, enum OperationMode, const char *, FileProgressStatus (*f) (file_op_context_t *, enum OperationMode, const char *,
struct stat *, struct stat *); struct stat *, const char *, struct stat *);
} pntr; } pntr;
/* *INDENT-ON* */ /* *INDENT-ON* */
pntr.f = file_progress_real_query_replace; pntr.f = file_progress_real_query_replace;
if (mc_global.we_are_background) if (mc_global.we_are_background)
return parent_call (pntr.p, ctx, 3, strlen (dst), dst, return parent_call (pntr.p, ctx, 4, strlen (src), src, sizeof (struct stat), src_stat,
sizeof (struct stat), src_stat, sizeof (struct stat), dst_stat); strlen (dst), dst, sizeof (struct stat), dst_stat);
else else
return file_progress_real_query_replace (ctx, Foreground, dst, src_stat, dst_stat); return file_progress_real_query_replace (ctx, Foreground, src, src_stat, dst, dst_stat);
} }
#else #else
@ -1076,10 +1076,10 @@ query_recursive (file_op_context_t * ctx, const char *s)
/* --------------------------------------------------------------------------------------------- */ /* --------------------------------------------------------------------------------------------- */
static FileProgressStatus static FileProgressStatus
query_replace (file_op_context_t * ctx, const char *dst, struct stat *src_stat, query_replace (file_op_context_t * ctx, const char *src, struct stat *src_stat, const char *dst,
struct stat *dst_stat) struct stat *dst_stat)
{ {
return file_progress_real_query_replace (ctx, Foreground, dst, src_stat, dst_stat); return file_progress_real_query_replace (ctx, Foreground, src, src_stat, dst, dst_stat);
} }
#endif /* !ENABLE_BACKGROUND */ #endif /* !ENABLE_BACKGROUND */
@ -1247,7 +1247,7 @@ move_file_file (const WPanel * panel, file_op_total_context_t * tctx, file_op_co
if (confirm_overwrite) if (confirm_overwrite)
{ {
return_status = query_replace (ctx, d, &src_stat, &dst_stat); return_status = query_replace (ctx, s, &src_stat, d, &dst_stat);
if (return_status != FILE_CONT) if (return_status != FILE_CONT)
goto ret; goto ret;
} }
@ -2272,7 +2272,7 @@ copy_file_file (file_op_total_context_t * tctx, file_op_context_t * ctx,
if (tctx->ask_overwrite) if (tctx->ask_overwrite)
{ {
ctx->do_reget = 0; ctx->do_reget = 0;
return_status = query_replace (ctx, dst_path, &src_stat, &dst_stat); return_status = query_replace (ctx, src_path, &src_stat, dst_path, &dst_stat);
if (return_status != FILE_CONT) if (return_status != FILE_CONT)
goto ret_fast; goto ret_fast;
} }

View File

@ -191,13 +191,13 @@ typedef enum
REPLACE_YES = B_USER, REPLACE_YES = B_USER,
REPLACE_NO, REPLACE_NO,
REPLACE_APPEND, REPLACE_APPEND,
REPLACE_ALWAYS, REPLACE_REGET,
REPLACE_ALL,
REPLACE_OLDER, REPLACE_OLDER,
REPLACE_NEVER, REPLACE_NONE,
REPLACE_ABORT,
REPLACE_SIZE,
REPLACE_SMALLER, REPLACE_SMALLER,
REPLACE_REGET REPLACE_SIZE,
REPLACE_ABORT
} replace_action_t; } replace_action_t;
/* This structure describes the UI and internal data required by a file /* This structure describes the UI and internal data required by a file
@ -229,7 +229,8 @@ typedef struct
/* Query replace dialog */ /* Query replace dialog */
WDialog *replace_dlg; WDialog *replace_dlg;
const char *replace_filename; const char *src_filename;
const char *tgt_filename;
replace_action_t replace_result; replace_action_t replace_result;
struct stat *src_stat, *dst_stat; struct stat *src_stat, *dst_stat;
@ -377,225 +378,297 @@ file_bps_prepare_for_show (char *buffer, long bps)
} }
/* --------------------------------------------------------------------------------------------- */ /* --------------------------------------------------------------------------------------------- */
/*
* FIXME: probably it is better to replace this with quick dialog machinery, /* The dialog layout:
* but actually I'm not familiar with it and have not much time :( *
* alex * +---------------------- File exists -----------------------+
* | New : /path/to/original_file_name | // 0, 1
* | 1234567 feb 4 2017 13:38 | // 2, 3
* | Existing: /path/to/target_file_name | // 4, 5
* | 1234567890 feb 4 2017 13:37 | // 6, 7
* +----------------------------------------------------------+
* | Overwrite this file? | // 8
* | [ Yes ] [ No ] [ Append ] [ Reget ] | // 9, 10, 11, 12
* +----------------------------------------------------------+
* | Overwrite all files? | // 13
* | [ All ] [ Older ] [None] [ Smaller ] [ Size differs ] | // 14, 15, 16, 17, 18
* +----------------------------------------------------------|
* | [ Abort ] | // 19
* +----------------------------------------------------------+
*/ */
static replace_action_t static replace_action_t
overwrite_query_dialog (file_op_context_t * ctx, enum OperationMode mode) overwrite_query_dialog (file_op_context_t * ctx, enum OperationMode mode)
{ {
#define ADD_RD_BUTTON(i, ypos) \ #define W(i) dlg_widgets[i].widget
add_widget_autopos (ui->replace_dlg, \ #define WX(i) W(i)->x
button_new (ypos, rd_widgets [i].xpos, rd_widgets [i].value, \ #define WCOLS(i) W(i)->cols
NORMAL_BUTTON, rd_widgets [i].text, NULL), \
rd_widgets [i].pos_flags, ui->replace_dlg->current->data)
#define ADD_RD_LABEL(i, p1, p2, ypos) \ #define NEW_LABEL(i, text) \
g_snprintf (buffer, sizeof (buffer), rd_widgets [i].text, p1, p2); \ W(i) = WIDGET (label_new (dlg_widgets[i].y, dlg_widgets[i].x, text))
label2 = WIDGET (label_new (ypos, rd_widgets [i].xpos, buffer)); \
add_widget_autopos (ui->replace_dlg, label2, rd_widgets [i].pos_flags, \ #define ADD_LABEL(i) \
add_widget_autopos (ui->replace_dlg, W(i), dlg_widgets[i].pos_flags, \
ui->replace_dlg->current != NULL ? ui->replace_dlg->current->data : NULL) ui->replace_dlg->current != NULL ? ui->replace_dlg->current->data : NULL)
#define NEW_BUTTON(i) \
W(i) = WIDGET (button_new (dlg_widgets[i].y, dlg_widgets[i].x, \
dlg_widgets[i].value, NORMAL_BUTTON, dlg_widgets[i].text, NULL))
#define ADD_BUTTON(i) \
add_widget_autopos (ui->replace_dlg, W(i), dlg_widgets[i].pos_flags, \
ui->replace_dlg->current->data)
/* dialog sizes */ /* dialog sizes */
const int rd_ylen = 1; const int dlg_height = 16;
int rd_xlen = 60; int dlg_width = 60;
int y = 2;
unsigned long yes_id, no_id;
struct struct
{ {
Widget *widget;
const char *text; const char *text;
int ypos, xpos; int y;
int x;
widget_pos_flags_t pos_flags; widget_pos_flags_t pos_flags;
int value; /* 0 for labels */ int value; /* 0 for labels and checkbox */
} rd_widgets[] = } dlg_widgets[] =
{ {
/* *INDENT-OFF* */ /* *INDENT-OFF* */
/* 0 */ /* 0 - label */
{ N_("Target file already exists!"), 3, 4, WPOS_KEEP_TOP | WPOS_CENTER_HORZ, 0 }, { NULL, N_("New :"), 2, 3, WPOS_KEEP_DEFAULT, 0 },
/* 1 */ /* 1 - label - name */
{ "%s", 4, 4, WPOS_KEEP_TOP | WPOS_CENTER_HORZ, 0 }, { NULL, NULL, 2, 14, WPOS_KEEP_DEFAULT, 0 },
/* 2 */ /* 2 - label - size */
{ N_("New : %s, size %s"), 6, 4, WPOS_KEEP_DEFAULT, 0 }, { NULL, NULL, 3, 3, WPOS_KEEP_DEFAULT, 0 },
/* 3 */ /* 3 - label - date & time */
{ N_("Existing: %s, size %s"), 7, 4, WPOS_KEEP_DEFAULT, 0 }, { NULL, NULL, 3, 43, WPOS_KEEP_TOP | WPOS_KEEP_RIGHT, 0 },
/* 4 */ /* 4 - label */
{ N_("Overwrite this target?"), 9, 4, WPOS_KEEP_DEFAULT, 0 }, { NULL, N_("Existing:"), 4, 3, WPOS_KEEP_DEFAULT, 0 },
/* 5 */ /* 5 - label - name */
{ N_("&Yes"), 9, 28, WPOS_KEEP_DEFAULT, REPLACE_YES }, { NULL, NULL, 4, 14, WPOS_KEEP_DEFAULT, 0 },
/* 6 */ /* 6 - label - size */
{ N_("&No"), 9, 37, WPOS_KEEP_DEFAULT, REPLACE_NO }, { NULL, NULL, 5, 3, WPOS_KEEP_DEFAULT, 0 },
/* 7 */ /* 7 - label - date & time */
{ N_("A&ppend"), 9, 45, WPOS_KEEP_DEFAULT, REPLACE_APPEND }, { NULL, NULL, 5, 43, WPOS_KEEP_TOP | WPOS_KEEP_RIGHT, 0 },
/* 8 */ /* --------------------------------------------------- */
{ N_("&Reget"), 10, 28, WPOS_KEEP_DEFAULT, REPLACE_REGET }, /* 8 - label */
/* 9 */ { NULL, N_("Overwrite this file?"), 7, 21, WPOS_KEEP_TOP | WPOS_CENTER_HORZ, 0 },
{ N_("Overwrite all targets?"), 11, 4, WPOS_KEEP_DEFAULT, 0 }, /* 9 - button */
/* 10 */ { NULL, N_("&Yes"), 8, 14, WPOS_KEEP_DEFAULT, REPLACE_YES },
{ N_("A&ll"), 11, 28, WPOS_KEEP_DEFAULT, REPLACE_ALWAYS }, /* 10 - button */
/* 11 */ { NULL, N_("&No"), 8, 22, WPOS_KEEP_DEFAULT, REPLACE_NO },
{ N_("If &older"), 11, 36, WPOS_KEEP_DEFAULT, REPLACE_OLDER }, /* 11 - button */
/* 12 */ { NULL, N_("A&ppend"), 8, 29, WPOS_KEEP_DEFAULT, REPLACE_APPEND },
{ N_("Non&e"), 11, 47, WPOS_KEEP_DEFAULT, REPLACE_NEVER }, /* 12 - button */
/* 13 */ { NULL, N_("&Reget"), 8, 40, WPOS_KEEP_DEFAULT, REPLACE_REGET },
{ N_("If &size differs"), 12, 28, WPOS_KEEP_DEFAULT, REPLACE_SIZE }, /* --------------------------------------------------- */
/* 14 */ /* 13 - label */
{ N_("If s&maller"), 12, 48, WPOS_KEEP_DEFAULT, REPLACE_SMALLER }, { NULL, N_("Overwrite all files?"), 10, 21, WPOS_KEEP_TOP | WPOS_CENTER_HORZ, 0 },
/* 15 */ /* 14 - button */
{ N_("&Abort"), 14, 25, WPOS_KEEP_TOP | WPOS_CENTER_HORZ, REPLACE_ABORT } { NULL, N_("A&ll"), 11, 12, WPOS_KEEP_DEFAULT, REPLACE_ALL },
/* 15 - button */
{ NULL, N_("&Older"), 11, 12, WPOS_KEEP_DEFAULT, REPLACE_OLDER },
/* 16 - button */
{ NULL, N_("Non&e"), 11, 12, WPOS_KEEP_DEFAULT, REPLACE_NONE },
/* 17 - button */
{ NULL, N_("S&maller"), 11, 25, WPOS_KEEP_DEFAULT, REPLACE_SMALLER },
/* 18 - button */
{ NULL, N_("&Size differs"), 11, 40, WPOS_KEEP_DEFAULT, REPLACE_SIZE },
/* --------------------------------------------------- */
/* 19 - button */
{ NULL, N_("&Abort"), 13, 27, WPOS_KEEP_TOP | WPOS_CENTER_HORZ, REPLACE_ABORT }
/* *INDENT-ON* */ /* *INDENT-ON* */
}; };
const size_t num = G_N_ELEMENTS (rd_widgets); const int gap = 1;
int *widgets_len;
file_op_context_ui_t *ui = ctx->ui; file_op_context_ui_t *ui = ctx->ui;
Widget *wd;
char buffer[BUF_SMALL];
char fsize_buffer[BUF_SMALL];
Widget *label1, *label2;
const char *title; const char *title;
vfs_path_t *stripped_vpath;
const char *stripped_name;
char *stripped_name_orig;
int result;
widgets_len = g_new0 (int, num); vfs_path_t *p;
char *s1;
char s2[BUF_SMALL];
int w, bw1, bw2;
unsigned short i;
gboolean do_append = FALSE, do_reget = FALSE;
unsigned long yes_id, no_id;
int result;
if (mode == Foreground) if (mode == Foreground)
title = _("File exists"); title = _("File exists");
else else
title = _("Background process: File exists"); title = _("Background process: File exists");
stripped_vpath = vfs_path_from_str (ui->replace_filename); #ifdef ENABLE_NLS
stripped_name = stripped_name_orig =
vfs_path_to_str_flags (stripped_vpath, 0, VPF_STRIP_HOME | VPF_STRIP_PASSWORD);
vfs_path_free (stripped_vpath);
{ {
size_t i; const unsigned short num = G_N_ELEMENTS (dlg_widgets);
int l1, l2, l, row;
int stripped_name_len;
for (i = 0; i < num; i++) for (i = 0; i < num; i++)
{ if (dlg_widgets[i].text != NULL)
#ifdef ENABLE_NLS dlg_widgets[i].text = _(dlg_widgets[i].text);
if (i != 1) /* skip filename */ }
rd_widgets[i].text = _(rd_widgets[i].text);
#endif /* ENABLE_NLS */ #endif /* ENABLE_NLS */
widgets_len[i] = str_term_width1 (rd_widgets[i].text);
}
/* /* create widgets to get their real widths */
* longest of "Overwrite..." labels /* new file */
* (assume "Target date..." are short enough) NEW_LABEL (0, dlg_widgets[0].text);
*/ /* new file name */
l1 = MAX (widgets_len[9], widgets_len[4]); p = vfs_path_from_str (ui->src_filename);
s1 = vfs_path_to_str_flags (p, 0, VPF_STRIP_HOME | VPF_STRIP_PASSWORD);
NEW_LABEL (1, s1);
vfs_path_free (p);
g_free (s1);
/* new file size */
size_trunc_len (s2, sizeof (s2), ui->src_stat->st_size, 0, panels_options.kilobyte_si);
NEW_LABEL (2, s2);
/* new file modification date & time */
s1 = (char *) file_date (ui->src_stat->st_mtime);
NEW_LABEL (3, s1);
/* longest of button rows */ /* existing file */
l = l2 = 0; NEW_LABEL (4, dlg_widgets[4].text);
row = 0; /* existing file name */
for (i = 1; i < num - 1; i++) p = vfs_path_from_str (ui->tgt_filename);
if (rd_widgets[i].value != 0) s1 = vfs_path_to_str_flags (p, 0, VPF_STRIP_HOME | VPF_STRIP_PASSWORD);
{ NEW_LABEL (5, s1);
if (row != rd_widgets[i].ypos) vfs_path_free (p);
{ g_free (s1);
row = rd_widgets[i].ypos; /* existing file size */
l2 = MAX (l2, l); size_trunc_len (s2, sizeof (s2), ui->dst_stat->st_size, 0, panels_options.kilobyte_si);
l = 0; NEW_LABEL (6, s2);
} /* existing file modification date & time */
l += widgets_len[i] + 4; s1 = (char *) file_date (ui->dst_stat->st_mtime);
} NEW_LABEL (7, s1);
l2 = MAX (l2, l); /* last row */ /* will "Append" and "Reget" buttons be in the dialog? */
rd_xlen = MAX (rd_xlen, l1 + l2 + 8); do_append = !S_ISDIR (ui->dst_stat->st_mode);
/* rd_xlen = MAX (rd_xlen, str_term_width1 (title) + 2); */ do_reget = do_append && ctx->operation == OP_COPY && ui->dst_stat->st_size != 0
stripped_name_len = str_term_width1 (stripped_name); && ui->src_stat->st_size > ui->dst_stat->st_size;
rd_xlen = MAX (rd_xlen, MIN (COLS, stripped_name_len + 8));
/* Now place widgets */ NEW_LABEL (8, dlg_widgets[8].text);
l1 += 5; /* start of first button in the row */ NEW_BUTTON (9);
l = l1; NEW_BUTTON (10);
row = 0; if (do_append)
for (i = 2; i < num - 1; i++) NEW_BUTTON (11);
if (rd_widgets[i].value != 0) if (do_reget)
{ NEW_BUTTON (12);
if (row != rd_widgets[i].ypos)
{
row = rd_widgets[i].ypos;
l = l1;
}
rd_widgets[i].xpos = l;
l += widgets_len[i] + 4;
}
}
/* FIXME - missing help node */ NEW_LABEL (13, dlg_widgets[13].text);
ui->replace_dlg = for (i = 14; i <= 19; i++)
dlg_create (TRUE, 0, 0, rd_ylen, rd_xlen, WPOS_CENTER, FALSE, alarm_colors, NULL, NULL, NEW_BUTTON (i);
"[Replace]", title);
/* prompt */ /* place widgets */
ADD_RD_LABEL (0, "", "", y++); dlg_width -= 2 * (2 + gap); /* inside frame */
/* file name */
ADD_RD_LABEL (1, "", "", y++);
label1 = label2;
add_widget (ui->replace_dlg, hline_new (y++, -1, -1)); /* perhaps longest line is buttons */
bw1 = WCOLS (9) + gap + WCOLS (10);
if (do_append)
bw1 += gap + WCOLS (11);
if (do_reget)
bw1 += gap + WCOLS (12);
dlg_width = MAX (dlg_width, bw1);
/* source date and size */ bw2 = WCOLS (14);
size_trunc_len (fsize_buffer, sizeof (fsize_buffer), ui->src_stat->st_size, 0, for (i = 15; i <= 18; i++)
panels_options.kilobyte_si); bw2 += gap + WCOLS (i);
ADD_RD_LABEL (2, file_date (ui->src_stat->st_mtime), fsize_buffer, y++); dlg_width = MAX (dlg_width, bw2);
rd_xlen = MAX (rd_xlen, label2->cols + 8);
/* destination date and size */
size_trunc_len (fsize_buffer, sizeof (fsize_buffer), ui->dst_stat->st_size, 0,
panels_options.kilobyte_si);
ADD_RD_LABEL (3, file_date (ui->dst_stat->st_mtime), fsize_buffer, y++);
rd_xlen = MAX (rd_xlen, label2->cols + 8);
add_widget (ui->replace_dlg, hline_new (y++, -1, -1)); dlg_width = MAX (dlg_width, WCOLS (8));
dlg_width = MAX (dlg_width, WCOLS (13));
ADD_RD_LABEL (4, 0, 0, y); /* Overwrite this target? */ /* truncate file names */
yes_id = ADD_RD_BUTTON (5, y); /* Yes */ w = WCOLS (0) + gap + WCOLS (1);
no_id = ADD_RD_BUTTON (6, y); /* No */ if (w > dlg_width)
/* "this target..." widgets */
if (!S_ISDIR (ui->dst_stat->st_mode))
{ {
ADD_RD_BUTTON (7, y++); /* Append */ WLabel *l = LABEL (W (1));
if ((ctx->operation == OP_COPY) && (ui->dst_stat->st_size != 0) w = dlg_width - gap - WCOLS (0);
&& (ui->src_stat->st_size > ui->dst_stat->st_size)) label_set_text (l, str_trunc (l->text, w));
ADD_RD_BUTTON (8, y++); /* Reget */
} }
add_widget (ui->replace_dlg, hline_new (y++, -1, -1)); w = WCOLS (4) + gap + WCOLS (5);
if (w > dlg_width)
{
WLabel *l = LABEL (W (5));
ADD_RD_LABEL (9, 0, 0, y); /* Overwrite all targets? */ w = dlg_width - gap - WCOLS (4);
ADD_RD_BUTTON (10, y); /* All" */ label_set_text (l, str_trunc (l->text, w));
ADD_RD_BUTTON (11, y); /* If older */ }
ADD_RD_BUTTON (12, y++); /* None */
ADD_RD_BUTTON (13, y); /* If size differs */
ADD_RD_BUTTON (14, y++); /* If smaller */
add_widget (ui->replace_dlg, hline_new (y++, -1, -1)); /* real dlalog width */
dlg_width += 2 * (2 + gap);
ADD_RD_BUTTON (15, y); /* Abort */ WX (1) = WX (0) + WCOLS (0) + gap;
WX (5) = WX (4) + WCOLS (4) + gap;
/* sizes: right alignment */
WX (2) = dlg_width / 2 - WCOLS (2);
WX (6) = dlg_width / 2 - WCOLS (6);
w = dlg_width - (2 + gap); /* right bound */
/* date & time */
WX (3) = w - WCOLS (3);
WX (7) = w - WCOLS (7);
/* buttons: center alignment */
WX (9) = dlg_width / 2 - bw1 / 2;
WX (10) = WX (9) + WCOLS (9) + gap;
if (do_append)
WX (11) = WX (10) + WCOLS (10) + gap;
if (do_reget)
WX (12) = WX (11) + WCOLS (11) + gap;
WX (14) = dlg_width / 2 - bw2 / 2;
for (i = 15; i <= 18; i++)
WX (i) = WX (i - 1) + WCOLS (i - 1) + gap;
/* TODO: write help (ticket #3970) */
ui->replace_dlg =
dlg_create (TRUE, 0, 0, dlg_height, dlg_width, WPOS_CENTER, FALSE, alarm_colors, NULL, NULL,
"[Replace]", title);
wd = WIDGET (ui->replace_dlg);
/* file info */
for (i = 0; i <= 7; i++)
ADD_LABEL (i);
add_widget (ui->replace_dlg, hline_new (W (7)->y - wd->y + 1, -1, -1));
/* label & buttons */
ADD_LABEL (8); /* Overwrite this file? */
yes_id = ADD_BUTTON (9); /* Yes */
no_id = ADD_BUTTON (10); /* No */
if (do_append)
ADD_BUTTON (11); /* Append */
if (do_reget)
ADD_BUTTON (12); /* Reget */
add_widget (ui->replace_dlg, hline_new (W (10)->y - wd->y + 1, -1, -1));
/* label & buttons */
ADD_LABEL (13); /* Overwrite all files? */
for (i = 14; i <= 18; i++)
ADD_BUTTON (i);
add_widget (ui->replace_dlg, hline_new (W (18)->y - wd->y + 1, -1, -1));
ADD_BUTTON (19); /* Abort */
label_set_text (LABEL (label1), str_trunc (stripped_name, rd_xlen - 8));
dlg_set_size (ui->replace_dlg, y + 3, rd_xlen);
dlg_select_by_id (ui->replace_dlg, safe_overwrite ? no_id : yes_id); dlg_select_by_id (ui->replace_dlg, safe_overwrite ? no_id : yes_id);
result = dlg_run (ui->replace_dlg); result = dlg_run (ui->replace_dlg);
dlg_destroy (ui->replace_dlg); dlg_destroy (ui->replace_dlg);
g_free (widgets_len);
g_free (stripped_name_orig);
return (result == B_CANCEL) ? REPLACE_ABORT : (replace_action_t) result; return (result == B_CANCEL) ? REPLACE_ABORT : (replace_action_t) result;
#undef ADD_RD_LABEL
#undef ADD_RD_BUTTON #undef ADD_BUTTON
#undef NEW_BUTTON
#undef ADD_LABEL
#undef NEW_LABEL
#undef WCOLS
#undef WX
#undef W
} }
/* --------------------------------------------------------------------------------------------- */ /* --------------------------------------------------------------------------------------------- */
@ -1099,9 +1172,9 @@ file_progress_show_deleting (file_op_context_t * ctx, const char *s, size_t * co
/* --------------------------------------------------------------------------------------------- */ /* --------------------------------------------------------------------------------------------- */
FileProgressStatus FileProgressStatus
file_progress_real_query_replace (file_op_context_t * ctx, file_progress_real_query_replace (file_op_context_t * ctx, enum OperationMode mode,
enum OperationMode mode, const char *dst, const char *src, struct stat *src_stat,
struct stat *src_stat, struct stat *dst_stat) const char *dst, struct stat *dst_stat)
{ {
file_op_context_ui_t *ui; file_op_context_ui_t *ui;
@ -1110,10 +1183,12 @@ file_progress_real_query_replace (file_op_context_t * ctx,
ui = ctx->ui; ui = ctx->ui;
if (ui->replace_result < REPLACE_ALWAYS) if (ui->replace_result == REPLACE_YES || ui->replace_result == REPLACE_NO
|| ui->replace_result == REPLACE_APPEND)
{ {
ui->replace_filename = dst; ui->src_filename = src;
ui->src_stat = src_stat; ui->src_stat = src_stat;
ui->tgt_filename = dst;
ui->dst_stat = dst_stat; ui->dst_stat = dst_stat;
ui->replace_result = overwrite_query_dialog (ctx, mode); ui->replace_result = overwrite_query_dialog (ctx, mode);
} }
@ -1151,13 +1226,15 @@ file_progress_real_query_replace (file_op_context_t * ctx,
MC_FALLTHROUGH; MC_FALLTHROUGH;
case REPLACE_YES: case REPLACE_YES:
case REPLACE_ALWAYS: case REPLACE_ALL:
do_refresh (); do_refresh ();
return FILE_CONT; return FILE_CONT;
case REPLACE_NO: case REPLACE_NO:
case REPLACE_NEVER: case REPLACE_NONE:
do_refresh (); do_refresh ();
return FILE_SKIP; return FILE_SKIP;
case REPLACE_ABORT: case REPLACE_ABORT:
default: default:
return FILE_ABORT; return FILE_ABORT;

View File

@ -191,8 +191,9 @@ void file_op_total_context_destroy (file_op_total_context_t * tctx);
/* The following functions are implemented separately by each port */ /* The following functions are implemented separately by each port */
FileProgressStatus file_progress_real_query_replace (file_op_context_t * ctx, FileProgressStatus file_progress_real_query_replace (file_op_context_t * ctx,
enum OperationMode mode, const char *dst, enum OperationMode mode, const char *src,
struct stat *src_stat, struct stat *dst_stat); struct stat *src_stat, const char *dst,
struct stat *dst_stat);
/*** inline functions ****************************************************************************/ /*** inline functions ****************************************************************************/
#endif /* MC__FILEOPCTX_H */ #endif /* MC__FILEOPCTX_H */