mirror of
https://github.com/MidnightCommander/mc
synced 2025-01-05 19:14:27 +03:00
Resort swapped panels in according with its sort options.
Signed-off-by: Andrew Borodin <aborodin@vmail.ru>
This commit is contained in:
parent
2ebfd4e293
commit
2a98492e77
@ -1091,22 +1091,22 @@ set_display_type (int num, panel_view_mode_t type)
|
|||||||
void
|
void
|
||||||
swap_panels (void)
|
swap_panels (void)
|
||||||
{
|
{
|
||||||
Widget tmp;
|
|
||||||
Widget *tmp_widget;
|
|
||||||
WPanel panel;
|
|
||||||
WPanel *panel1, *panel2;
|
WPanel *panel1, *panel2;
|
||||||
int tmp_type;
|
Widget *tmp_widget;
|
||||||
|
|
||||||
|
panel1 = (WPanel *) panels[0].widget;
|
||||||
|
panel2 = (WPanel *) panels[1].widget;
|
||||||
|
|
||||||
|
if (panels[0].type == view_listing && panels[1].type == view_listing)
|
||||||
|
{
|
||||||
|
WPanel panel;
|
||||||
|
|
||||||
#define panelswap(x) panel.x = panel1->x; panel1->x = panel2->x; panel2->x = panel.x;
|
#define panelswap(x) panel.x = panel1->x; panel1->x = panel2->x; panel2->x = panel.x;
|
||||||
|
|
||||||
#define panelswapstr(e) strcpy (panel.e, panel1->e); \
|
#define panelswapstr(e) strcpy (panel.e, panel1->e); \
|
||||||
strcpy (panel1->e, panel2->e); \
|
strcpy (panel1->e, panel2->e); \
|
||||||
strcpy (panel2->e, panel.e);
|
strcpy (panel2->e, panel.e);
|
||||||
panel1 = (WPanel *) panels[0].widget;
|
/* Change content and related stuff */
|
||||||
panel2 = (WPanel *) panels[1].widget;
|
|
||||||
if (panels[0].type == view_listing && panels[1].type == view_listing)
|
|
||||||
{
|
|
||||||
/* Change everything except format/sort/panel_name etc. */
|
|
||||||
panelswap (dir);
|
panelswap (dir);
|
||||||
panelswap (active);
|
panelswap (active);
|
||||||
panelswapstr (cwd);
|
panelswapstr (cwd);
|
||||||
@ -1119,14 +1119,24 @@ swap_panels (void)
|
|||||||
panelswap (selected);
|
panelswap (selected);
|
||||||
panelswap (is_panelized);
|
panelswap (is_panelized);
|
||||||
panelswap (dir_stat);
|
panelswap (dir_stat);
|
||||||
|
#undef panelswapstr
|
||||||
|
#undef panelswap
|
||||||
|
|
||||||
panel1->searching = FALSE;
|
panel1->searching = FALSE;
|
||||||
panel2->searching = FALSE;
|
panel2->searching = FALSE;
|
||||||
|
|
||||||
if (current_panel == panel1)
|
if (current_panel == panel1)
|
||||||
current_panel = panel2;
|
current_panel = panel2;
|
||||||
else
|
else
|
||||||
current_panel = panel1;
|
current_panel = panel1;
|
||||||
|
|
||||||
|
/* if sort options are different -> resort panels */
|
||||||
|
if (memcmp (&panel1->sort_info, &panel2->sort_info, sizeof (panel_sort_info_t)) != 0)
|
||||||
|
{
|
||||||
|
panel_re_sort (other_panel);
|
||||||
|
panel_re_sort (current_panel);
|
||||||
|
}
|
||||||
|
|
||||||
if (dlg_widget_active (panels[0].widget))
|
if (dlg_widget_active (panels[0].widget))
|
||||||
dlg_select_widget (panels[1].widget);
|
dlg_select_widget (panels[1].widget);
|
||||||
else if (dlg_widget_active (panels[1].widget))
|
else if (dlg_widget_active (panels[1].widget))
|
||||||
@ -1135,6 +1145,8 @@ swap_panels (void)
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
WPanel *tmp_panel;
|
WPanel *tmp_panel;
|
||||||
|
int x, y, cols, lines;
|
||||||
|
int tmp_type;
|
||||||
|
|
||||||
tmp_panel = right_panel;
|
tmp_panel = right_panel;
|
||||||
right_panel = left_panel;
|
right_panel = left_panel;
|
||||||
@ -1142,7 +1154,7 @@ swap_panels (void)
|
|||||||
|
|
||||||
if (panels[0].type == view_listing)
|
if (panels[0].type == view_listing)
|
||||||
{
|
{
|
||||||
if (!strcmp (panel1->panel_name, get_nth_panel_name (0)))
|
if (strcmp (panel1->panel_name, get_nth_panel_name (0)) == 0)
|
||||||
{
|
{
|
||||||
g_free (panel1->panel_name);
|
g_free (panel1->panel_name);
|
||||||
panel1->panel_name = g_strdup (get_nth_panel_name (1));
|
panel1->panel_name = g_strdup (get_nth_panel_name (1));
|
||||||
@ -1150,27 +1162,27 @@ swap_panels (void)
|
|||||||
}
|
}
|
||||||
if (panels[1].type == view_listing)
|
if (panels[1].type == view_listing)
|
||||||
{
|
{
|
||||||
if (!strcmp (panel2->panel_name, get_nth_panel_name (1)))
|
if (strcmp (panel2->panel_name, get_nth_panel_name (1)) == 0)
|
||||||
{
|
{
|
||||||
g_free (panel2->panel_name);
|
g_free (panel2->panel_name);
|
||||||
panel2->panel_name = g_strdup (get_nth_panel_name (0));
|
panel2->panel_name = g_strdup (get_nth_panel_name (0));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tmp.x = panels[0].widget->x;
|
x = panels[0].widget->x;
|
||||||
tmp.y = panels[0].widget->y;
|
y = panels[0].widget->y;
|
||||||
tmp.cols = panels[0].widget->cols;
|
cols = panels[0].widget->cols;
|
||||||
tmp.lines = panels[0].widget->lines;
|
lines = panels[0].widget->lines;
|
||||||
|
|
||||||
panels[0].widget->x = panels[1].widget->x;
|
panels[0].widget->x = panels[1].widget->x;
|
||||||
panels[0].widget->y = panels[1].widget->y;
|
panels[0].widget->y = panels[1].widget->y;
|
||||||
panels[0].widget->cols = panels[1].widget->cols;
|
panels[0].widget->cols = panels[1].widget->cols;
|
||||||
panels[0].widget->lines = panels[1].widget->lines;
|
panels[0].widget->lines = panels[1].widget->lines;
|
||||||
|
|
||||||
panels[1].widget->x = tmp.x;
|
panels[1].widget->x = x;
|
||||||
panels[1].widget->y = tmp.y;
|
panels[1].widget->y = y;
|
||||||
panels[1].widget->cols = tmp.cols;
|
panels[1].widget->cols = cols;
|
||||||
panels[1].widget->lines = tmp.lines;
|
panels[1].widget->lines = lines;
|
||||||
|
|
||||||
tmp_widget = panels[0].widget;
|
tmp_widget = panels[0].widget;
|
||||||
panels[0].widget = panels[1].widget;
|
panels[0].widget = panels[1].widget;
|
||||||
|
Loading…
Reference in New Issue
Block a user