Compilation fixes + 3-button fixes
Этот коммит содержится в:
родитель
3ac4cfa567
Коммит
7071b26a27
@ -1,3 +1,10 @@
|
|||||||
|
1998-12-17 Miguel de Icaza <miguel@nuclecu.unam.mx>
|
||||||
|
|
||||||
|
* gscreen.c (panel_icon_list_select_icon): Show the popup menu on
|
||||||
|
button release here. This is what makes most sense.
|
||||||
|
(panel_widget_motion): Drags with button 3 now produce a popup
|
||||||
|
dialog box that asks
|
||||||
|
|
||||||
1998-12-16 Miguel de Icaza <miguel@nuclecu.unam.mx>
|
1998-12-16 Miguel de Icaza <miguel@nuclecu.unam.mx>
|
||||||
|
|
||||||
* gdialogs.c (create_op_win): Remove second spurious packing.
|
* gdialogs.c (create_op_win): Remove second spurious packing.
|
||||||
|
@ -54,7 +54,8 @@ GNOMESRCS = \
|
|||||||
gtree.c \
|
gtree.c \
|
||||||
gutil.c \
|
gutil.c \
|
||||||
gview.c \
|
gview.c \
|
||||||
gwidget.c
|
gwidget.c \
|
||||||
|
temp-hack.c
|
||||||
|
|
||||||
GNOMEHDRS = \
|
GNOMEHDRS = \
|
||||||
gblist.h \
|
gblist.h \
|
||||||
|
@ -67,7 +67,7 @@ file_progress_show_source (char *path)
|
|||||||
|
|
||||||
if (path == NULL){
|
if (path == NULL){
|
||||||
gtk_label_set (GTK_LABEL (op_source_label), "");
|
gtk_label_set (GTK_LABEL (op_source_label), "");
|
||||||
return;
|
return FILE_CONT;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!from_width){
|
if (!from_width){
|
||||||
@ -98,7 +98,7 @@ file_progress_show_target (char *path)
|
|||||||
|
|
||||||
if (path == NULL){
|
if (path == NULL){
|
||||||
gtk_label_set (GTK_LABEL (op_target_label), "");
|
gtk_label_set (GTK_LABEL (op_target_label), "");
|
||||||
return;
|
return FILE_CONT;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!to_width)
|
if (!to_width)
|
||||||
@ -120,6 +120,7 @@ FileProgressStatus
|
|||||||
file_progress_show_deleting (char *path)
|
file_progress_show_deleting (char *path)
|
||||||
{
|
{
|
||||||
g_warning ("memo: file_progress_show_deleting!\npath\t%s\n",path);
|
g_warning ("memo: file_progress_show_deleting!\npath\t%s\n",path);
|
||||||
|
return FILE_CONT;
|
||||||
}
|
}
|
||||||
|
|
||||||
FileProgressStatus
|
FileProgressStatus
|
||||||
@ -156,61 +157,15 @@ file_progress_show_bytes (double done, double total)
|
|||||||
return FILE_CONT;
|
return FILE_CONT;
|
||||||
}
|
}
|
||||||
|
|
||||||
FileProgressStatus
|
/*
|
||||||
file_progress_real_query_replace (enum OperationMode mode, char *destname, struct stat *_s_stat,
|
* I have placed the old code because it is importatn.
|
||||||
struct stat *_d_stat)
|
* It is in temp-hack for now.
|
||||||
{
|
*
|
||||||
g_warning ("memo: file_progress_real_query_replace!\n");
|
* When the new code for replace_dlg is done, we can
|
||||||
|
* kill it.
|
||||||
/* Better to have something than nothing at all */
|
* -miguel.
|
||||||
if (file_progress_replace_result < REPLACE_ALWAYS){
|
*/
|
||||||
file_progress_replace_filename = destname;
|
#include "temp-hack.c"
|
||||||
s_stat = _s_stat;
|
|
||||||
d_stat = _d_stat;
|
|
||||||
init_replace (mode);
|
|
||||||
run_dlg (replace_dlg);
|
|
||||||
file_progress_replace_result = replace_dlg->ret_value;
|
|
||||||
if (file_progress_replace_result == B_CANCEL)
|
|
||||||
file_progress_replace_result = REPLACE_ABORT;
|
|
||||||
destroy_dlg (replace_dlg);
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (file_progress_replace_result){
|
|
||||||
case REPLACE_UPDATE:
|
|
||||||
do_refresh ();
|
|
||||||
if (_s_stat->st_mtime > _d_stat->st_mtime)
|
|
||||||
return FILE_CONT;
|
|
||||||
else
|
|
||||||
return FILE_SKIP;
|
|
||||||
|
|
||||||
case REPLACE_SIZE:
|
|
||||||
do_refresh ();
|
|
||||||
if (_s_stat->st_size == _d_stat->st_size)
|
|
||||||
return FILE_SKIP;
|
|
||||||
else
|
|
||||||
return FILE_CONT;
|
|
||||||
|
|
||||||
case REPLACE_REGET:
|
|
||||||
/* Carefull: we fall through and set do_append */
|
|
||||||
file_progress_do_reget = _d_stat->st_size;
|
|
||||||
|
|
||||||
case REPLACE_APPEND:
|
|
||||||
file_progress_do_append = 1;
|
|
||||||
|
|
||||||
case REPLACE_YES:
|
|
||||||
case REPLACE_ALWAYS:
|
|
||||||
do_refresh ();
|
|
||||||
return FILE_CONT;
|
|
||||||
case REPLACE_NO:
|
|
||||||
case REPLACE_NEVER:
|
|
||||||
do_refresh ();
|
|
||||||
return FILE_SKIP;
|
|
||||||
case REPLACE_ABORT:
|
|
||||||
default:
|
|
||||||
return FILE_ABORT;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
file_progress_set_stalled_label (char *stalled_msg)
|
file_progress_set_stalled_label (char *stalled_msg)
|
||||||
|
@ -483,7 +483,6 @@ panel_file_list_select_row (GtkWidget *file_list, int row, int column, GdkEvent
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 3:
|
case 3:
|
||||||
/* FIXME: this should happen on button press, not button release */
|
|
||||||
gpopup_do_popup ((GdkEventButton *) event, panel, row, panel->dir.list[row].fname);
|
gpopup_do_popup ((GdkEventButton *) event, panel, row, panel->dir.list[row].fname);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -894,21 +893,23 @@ panel_widget_motion (GtkWidget *widget, GdkEventMotion *event, WPanel *panel)
|
|||||||
{
|
{
|
||||||
GtkTargetList *list;
|
GtkTargetList *list;
|
||||||
GdkDragContext *context;
|
GdkDragContext *context;
|
||||||
|
int action;
|
||||||
|
|
||||||
if (!panel->maybe_start_drag)
|
if (!panel->maybe_start_drag)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
if (panel->maybe_start_drag == 3)
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
if ((abs (event->x - panel->click_x) < 4) ||
|
if ((abs (event->x - panel->click_x) < 4) ||
|
||||||
(abs (event->y - panel->click_y) < 4))
|
(abs (event->y - panel->click_y) < 4))
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
list = gtk_target_list_new (drag_types, ELEMENTS (drag_types));
|
list = gtk_target_list_new (drag_types, ELEMENTS (drag_types));
|
||||||
|
|
||||||
context = gtk_drag_begin (widget, list,
|
if (panel->maybe_start_drag == 3)
|
||||||
GDK_ACTION_MOVE | GDK_ACTION_COPY | GDK_ACTION_LINK | GDK_ACTION_ASK,
|
action = GDK_ACTION_ASK;
|
||||||
|
else
|
||||||
|
action = GDK_ACTION_MOVE | GDK_ACTION_COPY | GDK_ACTION_LINK;
|
||||||
|
|
||||||
|
context = gtk_drag_begin (widget, list, action,
|
||||||
panel->maybe_start_drag, (GdkEvent *) event);
|
panel->maybe_start_drag, (GdkEvent *) event);
|
||||||
gtk_drag_set_icon_default (context);
|
gtk_drag_set_icon_default (context);
|
||||||
|
|
||||||
@ -1116,10 +1117,7 @@ panel_icon_list_select_icon (GtkWidget *widget, int index, GdkEvent *event, WPan
|
|||||||
|
|
||||||
switch (event->type){
|
switch (event->type){
|
||||||
case GDK_BUTTON_PRESS:
|
case GDK_BUTTON_PRESS:
|
||||||
if (event->button.button == 3) {
|
if (event->button.button == 2){
|
||||||
gpopup_do_popup ((GdkEventButton *) event, panel, index, panel->dir.list[index].fname);
|
|
||||||
return;
|
|
||||||
} else if (event->button.button == 2){
|
|
||||||
char *fullname;
|
char *fullname;
|
||||||
|
|
||||||
if (S_ISDIR (panel->dir.list [index].buf.st_mode) ||
|
if (S_ISDIR (panel->dir.list [index].buf.st_mode) ||
|
||||||
@ -1131,6 +1129,13 @@ panel_icon_list_select_icon (GtkWidget *widget, int index, GdkEvent *event, WPan
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case GDK_BUTTON_RELEASE:
|
||||||
|
if (event->button.button != 3)
|
||||||
|
return;
|
||||||
|
|
||||||
|
gpopup_do_popup ((GdkEventButton *) event, panel, index, panel->dir.list[index].fname);
|
||||||
|
return;
|
||||||
|
|
||||||
case GDK_2BUTTON_PRESS:
|
case GDK_2BUTTON_PRESS:
|
||||||
if (event->button.button == 1)
|
if (event->button.button == 1)
|
||||||
do_enter (panel);
|
do_enter (panel);
|
||||||
|
264
gnome/temp-hack.c
Обычный файл
264
gnome/temp-hack.c
Обычный файл
@ -0,0 +1,264 @@
|
|||||||
|
#include "global.h"
|
||||||
|
#include "color.h"
|
||||||
|
static struct stat *s_stat, *d_stat;
|
||||||
|
|
||||||
|
/* Used for button result values */
|
||||||
|
enum {
|
||||||
|
REPLACE_YES = B_USER,
|
||||||
|
REPLACE_NO,
|
||||||
|
REPLACE_APPEND,
|
||||||
|
REPLACE_ALWAYS,
|
||||||
|
REPLACE_UPDATE,
|
||||||
|
REPLACE_NEVER,
|
||||||
|
REPLACE_ABORT,
|
||||||
|
REPLACE_SIZE,
|
||||||
|
REPLACE_REGET
|
||||||
|
} FileReplaceCode;
|
||||||
|
|
||||||
|
static int
|
||||||
|
replace_callback (struct Dlg_head *h, int Id, int Msg)
|
||||||
|
{
|
||||||
|
#ifndef HAVE_X
|
||||||
|
|
||||||
|
switch (Msg){
|
||||||
|
case DLG_DRAW:
|
||||||
|
dialog_repaint (h, ERROR_COLOR, ERROR_COLOR);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef HAVE_X
|
||||||
|
#define X_TRUNC 128
|
||||||
|
#else
|
||||||
|
#define X_TRUNC 52
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* File operate window sizes */
|
||||||
|
#define WX 62
|
||||||
|
#define WY 10
|
||||||
|
#define BY 10
|
||||||
|
#define WX_ETA_EXTRA 12
|
||||||
|
|
||||||
|
static int replace_colors [4];
|
||||||
|
static Dlg_head *replace_dlg;
|
||||||
|
/*
|
||||||
|
* FIXME: probably it is better to replace this with quick dialog machinery,
|
||||||
|
* but actually I'm not familiar with it and have not much time :(
|
||||||
|
* alex
|
||||||
|
*/
|
||||||
|
static struct
|
||||||
|
{
|
||||||
|
char* text;
|
||||||
|
int ypos, xpos;
|
||||||
|
int value; /* 0 for labels */
|
||||||
|
char* tkname;
|
||||||
|
WLay layout;
|
||||||
|
}
|
||||||
|
rd_widgets [] =
|
||||||
|
{
|
||||||
|
{N_("Target file \"%s\" already exists!"),
|
||||||
|
3, 4, 0, "target-e", XV_WLAY_CENTERROW},
|
||||||
|
{N_("&Abort"), BY + 3, 25, REPLACE_ABORT, "abort", XV_WLAY_CENTERROW},
|
||||||
|
{N_("if &Size differs"),
|
||||||
|
BY + 1, 28, REPLACE_SIZE, "if-size", XV_WLAY_RIGHTOF},
|
||||||
|
{N_("non&E"), BY, 47, REPLACE_NEVER, "none", XV_WLAY_RIGHTOF},
|
||||||
|
{N_("&Update"), BY, 36, REPLACE_UPDATE, "update", XV_WLAY_RIGHTOF},
|
||||||
|
{N_("al&L"), BY, 28, REPLACE_ALWAYS, "all", XV_WLAY_RIGHTOF},
|
||||||
|
{N_("Overwrite all targets?"),
|
||||||
|
BY, 4, 0, "over-label", XV_WLAY_CENTERROW},
|
||||||
|
{N_("&Reget"), BY - 1, 28, REPLACE_REGET, "reget", XV_WLAY_RIGHTOF},
|
||||||
|
{N_("ap&Pend"), BY - 2, 45, REPLACE_APPEND, "append", XV_WLAY_RIGHTOF},
|
||||||
|
{N_("&No"), BY - 2, 37, REPLACE_NO, "no", XV_WLAY_RIGHTOF},
|
||||||
|
{N_("&Yes"), BY - 2, 28, REPLACE_YES, "yes", XV_WLAY_RIGHTOF},
|
||||||
|
{N_("Overwrite this target?"),
|
||||||
|
BY - 2, 4, 0, "overlab", XV_WLAY_CENTERROW},
|
||||||
|
{N_("Target date: %s, size %d"),
|
||||||
|
6, 4, 0, "target-date",XV_WLAY_CENTERROW},
|
||||||
|
{N_("Source date: %s, size %d"),
|
||||||
|
5, 4, 0, "source-date",XV_WLAY_CENTERROW}
|
||||||
|
};
|
||||||
|
|
||||||
|
#define ADD_RD_BUTTON(i)\
|
||||||
|
add_widgetl (replace_dlg,\
|
||||||
|
button_new (rd_widgets [i].ypos, rd_widgets [i].xpos, rd_widgets [i].value,\
|
||||||
|
NORMAL_BUTTON, rd_widgets [i].text, 0, 0, rd_widgets [i].tkname), \
|
||||||
|
rd_widgets [i].layout)
|
||||||
|
|
||||||
|
#define ADD_RD_LABEL(i,p1,p2)\
|
||||||
|
sprintf (buffer, rd_widgets [i].text, p1, p2);\
|
||||||
|
add_widgetl (replace_dlg,\
|
||||||
|
label_new (rd_widgets [i].ypos, rd_widgets [i].xpos, buffer, rd_widgets [i].tkname),\
|
||||||
|
rd_widgets [i].layout)
|
||||||
|
|
||||||
|
static void
|
||||||
|
init_replace (enum OperationMode mode)
|
||||||
|
{
|
||||||
|
char buffer [128];
|
||||||
|
static int rd_xlen = 60, rd_trunc = X_TRUNC;
|
||||||
|
|
||||||
|
#ifdef ENABLE_NLS
|
||||||
|
static int i18n_flag;
|
||||||
|
if (!i18n_flag)
|
||||||
|
{
|
||||||
|
int l1, l2, l, row;
|
||||||
|
register int i = sizeof (rd_widgets) / sizeof (rd_widgets [0]);
|
||||||
|
while (i--)
|
||||||
|
rd_widgets [i].text = _(rd_widgets [i].text);
|
||||||
|
|
||||||
|
/*
|
||||||
|
*longest of "Overwrite..." labels
|
||||||
|
* (assume "Target date..." are short enough)
|
||||||
|
*/
|
||||||
|
l1 = max (strlen (rd_widgets [6].text), strlen (rd_widgets [11].text));
|
||||||
|
|
||||||
|
/* longest of button rows */
|
||||||
|
i = sizeof (rd_widgets) / sizeof (rd_widgets [0]);
|
||||||
|
for (row = l = l2 = 0; i--;)
|
||||||
|
{
|
||||||
|
if (rd_widgets [i].value != 0)
|
||||||
|
{
|
||||||
|
if (row != rd_widgets [i].ypos)
|
||||||
|
{
|
||||||
|
row = rd_widgets [i].ypos;
|
||||||
|
l2 = max (l2, l);
|
||||||
|
l = 0;
|
||||||
|
}
|
||||||
|
l += strlen (rd_widgets [i].text) + 4;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
l2 = max (l2, l); /* last row */
|
||||||
|
rd_xlen = max (rd_xlen, l1 + l2 + 8);
|
||||||
|
rd_trunc = rd_xlen - 6;
|
||||||
|
|
||||||
|
/* Now place buttons */
|
||||||
|
l1 += 5; /* start of first button in the row */
|
||||||
|
i = sizeof (rd_widgets) / sizeof (rd_widgets [0]);
|
||||||
|
|
||||||
|
for (l = l1, row = 0; --i > 1;)
|
||||||
|
{
|
||||||
|
if (rd_widgets [i].value != 0)
|
||||||
|
{
|
||||||
|
if (row != rd_widgets [i].ypos)
|
||||||
|
{
|
||||||
|
row = rd_widgets [i].ypos;
|
||||||
|
l = l1;
|
||||||
|
}
|
||||||
|
rd_widgets [i].xpos = l;
|
||||||
|
l += strlen (rd_widgets [i].text) + 4;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* Abort button is centered */
|
||||||
|
rd_widgets [1].xpos = (rd_xlen - strlen (rd_widgets [1].text) - 3) / 2;
|
||||||
|
|
||||||
|
}
|
||||||
|
#endif /* ENABLE_NLS */
|
||||||
|
|
||||||
|
replace_colors [0] = ERROR_COLOR;
|
||||||
|
replace_colors [1] = COLOR_NORMAL;
|
||||||
|
replace_colors [2] = ERROR_COLOR;
|
||||||
|
replace_colors [3] = COLOR_NORMAL;
|
||||||
|
|
||||||
|
replace_dlg = create_dlg (0, 0, 16, rd_xlen, replace_colors, replace_callback,
|
||||||
|
"[ Replace ]", "replace", DLG_CENTER);
|
||||||
|
|
||||||
|
x_set_dialog_title (replace_dlg,
|
||||||
|
mode == Foreground ? _(" File exists ") : _(" Background process: File exists "));
|
||||||
|
|
||||||
|
|
||||||
|
ADD_RD_LABEL(0, name_trunc (file_progress_replace_filename, rd_trunc - strlen (rd_widgets [0].text)), 0 );
|
||||||
|
ADD_RD_BUTTON(1);
|
||||||
|
|
||||||
|
ADD_RD_BUTTON(2);
|
||||||
|
ADD_RD_BUTTON(3);
|
||||||
|
ADD_RD_BUTTON(4);
|
||||||
|
ADD_RD_BUTTON(5);
|
||||||
|
ADD_RD_LABEL(6,0,0);
|
||||||
|
|
||||||
|
/* "this target..." widgets */
|
||||||
|
if (!S_ISDIR (d_stat->st_mode)){
|
||||||
|
if ((d_stat->st_size && s_stat->st_size > d_stat->st_size))
|
||||||
|
ADD_RD_BUTTON(7);
|
||||||
|
|
||||||
|
ADD_RD_BUTTON(8);
|
||||||
|
}
|
||||||
|
ADD_RD_BUTTON(9);
|
||||||
|
ADD_RD_BUTTON(10);
|
||||||
|
ADD_RD_LABEL(11,0,0);
|
||||||
|
|
||||||
|
ADD_RD_LABEL(12, file_date (d_stat->st_mtime), (int) d_stat->st_size);
|
||||||
|
ADD_RD_LABEL(13, file_date (s_stat->st_mtime), (int) s_stat->st_size);
|
||||||
|
}
|
||||||
|
|
||||||
|
FileProgressStatus
|
||||||
|
file_progress_real_query_replace (enum OperationMode mode, char *destname, struct stat *_s_stat,
|
||||||
|
struct stat *_d_stat)
|
||||||
|
{
|
||||||
|
g_warning ("memo: file_progress_real_query_replace!\n");
|
||||||
|
g_warning ("memo: file_progress_real_query_replace!\n");
|
||||||
|
g_warning ("memo: file_progress_real_query_replace!\n");
|
||||||
|
g_warning ("memo: file_progress_real_query_replace!\n");
|
||||||
|
g_warning ("memo: file_progress_real_query_replace!\n");
|
||||||
|
g_warning ("memo: file_progress_real_query_replace!\n");
|
||||||
|
g_warning ("memo: file_progress_real_query_replace!\n");
|
||||||
|
g_warning ("memo: file_progress_real_query_replace!\n");
|
||||||
|
g_warning ("memo: file_progress_real_query_replace!\n");
|
||||||
|
g_warning ("memo: file_progress_real_query_replace!\n");
|
||||||
|
g_warning ("memo: file_progress_real_query_replace!\n");
|
||||||
|
g_warning ("memo: file_progress_real_query_replace!\n");
|
||||||
|
g_warning ("memo: file_progress_real_query_replace!\n");
|
||||||
|
g_warning ("memo: file_progress_real_query_replace!\n");
|
||||||
|
g_warning ("memo: file_progress_real_query_replace!\n");
|
||||||
|
g_warning ("memo: file_progress_real_query_replace!\n");
|
||||||
|
|
||||||
|
/* Better to have something than nothing at all */
|
||||||
|
if (file_progress_replace_result < REPLACE_ALWAYS){
|
||||||
|
file_progress_replace_filename = destname;
|
||||||
|
s_stat = _s_stat;
|
||||||
|
d_stat = _d_stat;
|
||||||
|
init_replace (mode);
|
||||||
|
run_dlg (replace_dlg);
|
||||||
|
file_progress_replace_result = replace_dlg->ret_value;
|
||||||
|
if (file_progress_replace_result == B_CANCEL)
|
||||||
|
file_progress_replace_result = REPLACE_ABORT;
|
||||||
|
destroy_dlg (replace_dlg);
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (file_progress_replace_result){
|
||||||
|
case REPLACE_UPDATE:
|
||||||
|
do_refresh ();
|
||||||
|
if (_s_stat->st_mtime > _d_stat->st_mtime)
|
||||||
|
return FILE_CONT;
|
||||||
|
else
|
||||||
|
return FILE_SKIP;
|
||||||
|
|
||||||
|
case REPLACE_SIZE:
|
||||||
|
do_refresh ();
|
||||||
|
if (_s_stat->st_size == _d_stat->st_size)
|
||||||
|
return FILE_SKIP;
|
||||||
|
else
|
||||||
|
return FILE_CONT;
|
||||||
|
|
||||||
|
case REPLACE_REGET:
|
||||||
|
/* Carefull: we fall through and set do_append */
|
||||||
|
file_progress_do_reget = _d_stat->st_size;
|
||||||
|
|
||||||
|
case REPLACE_APPEND:
|
||||||
|
file_progress_do_append = 1;
|
||||||
|
|
||||||
|
case REPLACE_YES:
|
||||||
|
case REPLACE_ALWAYS:
|
||||||
|
do_refresh ();
|
||||||
|
return FILE_CONT;
|
||||||
|
case REPLACE_NO:
|
||||||
|
case REPLACE_NEVER:
|
||||||
|
do_refresh ();
|
||||||
|
return FILE_SKIP;
|
||||||
|
case REPLACE_ABORT:
|
||||||
|
default:
|
||||||
|
return FILE_ABORT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
4309
po/de.po
4309
po/de.po
Разница между файлами не показана из-за своего большого размера
Загрузить разницу
2779
po/es.po
2779
po/es.po
Разница между файлами не показана из-за своего большого размера
Загрузить разницу
2587
po/fr.po
2587
po/fr.po
Разница между файлами не показана из-за своего большого размера
Загрузить разницу
4356
po/it.po
4356
po/it.po
Разница между файлами не показана из-за своего большого размера
Загрузить разницу
6346
po/ko.po
6346
po/ko.po
Разница между файлами не показана из-за своего большого размера
Загрузить разницу
1079
po/no.po
1079
po/no.po
Разница между файлами не показана из-за своего большого размера
Загрузить разницу
4783
po/pl.po
4783
po/pl.po
Разница между файлами не показана из-за своего большого размера
Загрузить разницу
4128
po/ru.po
4128
po/ru.po
Разница между файлами не показана из-за своего большого размера
Загрузить разницу
Загрузка…
Ссылка в новой задаче
Block a user