mirror of
https://github.com/MidnightCommander/mc
synced 2025-01-03 18:14:25 +03:00
(overwrite_query_dialog): redesign the overwrite query dialog.
Signed-off-by: Andrew Borodin <aborodin@vmail.ru>
This commit is contained in:
parent
67653322a3
commit
a07cb50069
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
|
@ -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 */
|
||||||
|
Loading…
Reference in New Issue
Block a user