Ticket #3958: NOT FINISHED.

Signed-off-by: Andrew Borodin <aborodin@vmail.ru>
This commit is contained in:
Andrew Borodin 2019-01-13 12:43:32 +03:00
parent b52ff8c614
commit 51c515d3f9
2 changed files with 30 additions and 19 deletions

View File

@ -1397,8 +1397,12 @@ title_path_prepare (char **path, char **login)
struct passwd *pw = NULL; struct passwd *pw = NULL;
int res = 0; int res = 0;
if (current_panel == NULL || current_panel->cwd_vpath == NULL)
*path = NULL;
else
*path = *path =
vfs_path_to_str_flags (current_panel->cwd_vpath, 0, VPF_STRIP_HOME | VPF_STRIP_PASSWORD); vfs_path_to_str_flags (current_panel->cwd_vpath, 0,
VPF_STRIP_HOME | VPF_STRIP_PASSWORD);
res = gethostname (host, sizeof (host)); res = gethostname (host, sizeof (host));
if (res != 0) if (res != 0)
@ -1427,7 +1431,11 @@ update_xterm_title_path (void)
title_path_prepare (&path, &login); title_path_prepare (&path, &login);
if (path != NULL)
p = g_strdup_printf ("mc [%s]: %s", login, path); p = g_strdup_printf ("mc [%s]: %s", login, path);
else
p = g_strdup_printf ("mc [%s]", login);
g_free (login); g_free (login);
g_free (path); g_free (path);

View File

@ -441,7 +441,11 @@ midnight_get_title (const WDialog * h, size_t len)
title_path_prepare (&path, &login); title_path_prepare (&path, &login);
p = g_strdup_printf ("%s [%s]:%s", _("Panels:"), login, path); if (path != NULL)
p = g_strdup_printf ("%s: [%s]: %s", _("Panels"), login, path);
else
p = g_strdup_printf ("%s: [%s]", _("Panels"), login);
g_free (path); g_free (path);
g_free (login); g_free (login);
path = g_strdup (str_trunc (p, len - 4)); path = g_strdup (str_trunc (p, len - 4));
@ -568,7 +572,7 @@ print_vfs_message (const gchar * event_group_name, const gchar * event_name,
/* --------------------------------------------------------------------------------------------- */ /* --------------------------------------------------------------------------------------------- */
static void static void
create_panels (void) load_panels (void)
{ {
int current_index, other_index; int current_index, other_index;
panel_view_mode_t current_mode, other_mode; panel_view_mode_t current_mode, other_mode;
@ -679,7 +683,7 @@ create_panels (void)
} }
set_display_type (current_index, current_mode); set_display_type (current_index, current_mode);
if (startup_left_mode == view_listing) if (startup_left_mode == view_listing && boot_current_is_left)
current_panel = left_panel; current_panel = left_panel;
else if (right_panel != NULL) else if (right_panel != NULL)
current_panel = right_panel; current_panel = right_panel;
@ -687,13 +691,6 @@ create_panels (void)
current_panel = left_panel; current_panel = left_panel;
vfs_path_free (original_dir); vfs_path_free (original_dir);
#ifdef ENABLE_VFS
mc_event_add (MCEVENT_GROUP_CORE, "vfs_timestamp", check_other_panel_timestamp, NULL, NULL);
mc_event_add (MCEVENT_GROUP_CORE, "vfs_timestamp", check_current_panel_timestamp, NULL, NULL);
#endif /* ENABLE_VFS */
mc_event_add (MCEVENT_GROUP_CORE, "vfs_print_message", print_vfs_message, NULL, NULL);
} }
/* --------------------------------------------------------------------------------------------- */ /* --------------------------------------------------------------------------------------------- */
@ -919,8 +916,10 @@ create_file_manager (void)
add_widget (midnight_dlg, the_menubar); add_widget (midnight_dlg, the_menubar);
init_menu (); init_menu ();
create_panels (); /* create empty panels to construct file manager entirely before load panel contents */
set_display_type (0, view_listing);
add_widget (midnight_dlg, get_panel_widget (0)); add_widget (midnight_dlg, get_panel_widget (0));
set_display_type (1, view_listing);
add_widget (midnight_dlg, get_panel_widget (1)); add_widget (midnight_dlg, get_panel_widget (1));
the_hint = label_new (0, 0, 0); the_hint = label_new (0, 0, 0);
@ -939,6 +938,12 @@ create_file_manager (void)
the_bar = buttonbar_new (mc_global.keybar_visible); the_bar = buttonbar_new (mc_global.keybar_visible);
add_widget (midnight_dlg, the_bar); add_widget (midnight_dlg, the_bar);
midnight_set_buttonbar (the_bar); midnight_set_buttonbar (the_bar);
#ifdef ENABLE_VFS
mc_event_add (MCEVENT_GROUP_CORE, "vfs_timestamp", check_other_panel_timestamp, NULL, NULL);
mc_event_add (MCEVENT_GROUP_CORE, "vfs_timestamp", check_current_panel_timestamp, NULL, NULL);
#endif /* ENABLE_VFS */
mc_event_add (MCEVENT_GROUP_CORE, "vfs_print_message", print_vfs_message, NULL, NULL);
} }
/* --------------------------------------------------------------------------------------------- */ /* --------------------------------------------------------------------------------------------- */
@ -1464,13 +1469,11 @@ midnight_callback (Widget * w, Widget * sender, widget_msg_t msg, int parm, void
return MSG_HANDLED; return MSG_HANDLED;
case MSG_IDLE: case MSG_IDLE:
/* We only need the first idle event to show user menu after start */ /* We only need the first idle event to load panels and show user menu after start */
widget_idle (w, FALSE); widget_idle (w, FALSE);
if (boot_current_is_left) load_panels ();
widget_select (get_panel_widget (0)); widget_select (WIDGET (current_panel));
else
widget_select (get_panel_widget (1));
if (auto_menu) if (auto_menu)
midnight_execute_cmd (NULL, CK_UserMenu); midnight_execute_cmd (NULL, CK_UserMenu);