Ticket #4188 (closed defect: worksforme)

Opened 4 years ago

Last modified 2 months ago

Warning: Cannot change to <path>.. with Fish shell

Reported by: pronobis Owned by:
Priority: minor Milestone:
Component: mc-core Version: 4.8.26
Keywords: Cc: johannes
Blocked By: Blocking:
Branch state: no branch Votes for changeset:

Description (last modified by andrew_b) (diff)

With mc 4.8.26, the support for the Fish shell improved considerably. However, every time I start mc, for a split second, the following warning shows up:
Warning: Cannot change to <path>..

Yet, the panels are pointing to the correct <path> and the shell pwd is also correct. So, in summary, this just seems to be an annoying message.

GNU Midnight Commander 4.8.26
Built with GLib 2.56.4
Built with S-Lang 2.3.2 with terminfo database
With builtin Editor
With subshell support as default
With support for background operations
With mouse support on xterm and Linux console
With support for X11 events
With internationalization support
With multiple codepages support
With ext2fs attributes support
Virtual File Systems:
 cpiofs, tarfs, sfs, extfs, ftpfs, sftpfs, fish
Data types:
 char: 8; int: 32; long: 64; void *: 64; size_t: 64; off_t: 64;

Attachments

mc_fish_first_command.diff (2.2 KB) - added by pronobis 4 years ago.

Change History

comment:1 Changed 4 years ago by andrew_b

  • Version changed from master to 4.8.26
  • Description modified (diff)

comment:2 Changed 4 years ago by pronobis

To add some more information, a related problem occurs when a command from the user menu is executed. It will work sometimes, but do nothing the first time the command is executed after the active window is changed or the mc window is resized. This problem, as well as the "cannot change to" problem described above is worked around by the attached patch.

Changed 4 years ago by pronobis

comment:3 Changed 3 years ago by congest

The window resize bug that is referred to in this ticket is fixed by: http://midnight-commander.org/ticket/4372

mc_fish_first_command.diff​ doesn't seem to fix the "Cannot change..." error for me.

I poked around and eventually figured out why mc gives this error with fish. It seems like fish takes a second or two to start up, so it doesn't respond properly to mc at first. I tried to come up with a quick fix, but this quick fix has a side effect of making mc take a few seconds to start when running fish, which I think is much more annoying than a little error message.

comment:4 Changed 2 months ago by zaytsev

  • Cc johannes added

Another fish one... Johannes, let me know if it annoys you when I put you on CC for fish issues.

comment:5 Changed 2 months ago by johannes

I can't reproduce the "Cannot change directory" error.
This is what I tried:

diff --git a/src/filemanager/cd.c b/src/filemanager/cd.c
index 017d3ea81..6010f176b 100644
--- a/src/filemanager/cd.c
+++ b/src/filemanager/cd.c
@@ -303,6 +303,7 @@ cd_to (const char *path)
 void
 cd_error_message (const char *path)
 {
+            abort();
     message (D_ERROR, MSG_ERROR, _("Cannot change directory to\n%s\n%s"), path,
              unix_error_string (errno));
 }
diff --git a/src/subshell/common.c b/src/subshell/common.c
index 38cc11bcf..1151ffb58 100644
--- a/src/subshell/common.c
+++ b/src/subshell/common.c
@@ -430,7 +430,7 @@ init_subshell_child (const char *pty_name)
 
     case SHELL_FISH:
         execl (mc_global.shell->path, mc_global.shell->path,
-               "--init-command", "set --global __mc_csi_u 1", (char *) NULL);
+               "--init-command", "set --global __mc_csi_u 1; sleep 1", (char *) NULL);
         break;
 
     case SHELL_ASH_BUSYBOX:
@@ -1794,6 +1794,7 @@ do_subshell_chdir (const vfs_path_t *vpath, gboolean update_prompt)
             char *cwd;
 
             cwd = vfs_path_to_str_flags (subshell_get_cwd (), 0, VPF_STRIP_PASSWORD);
+            abort();
             vfs_print_message (_("Warning: Cannot change to %s.\n"), cwd);
             g_free (cwd);
         }

comment:6 Changed 2 months ago by zaytsev

  • Status changed from new to closed
  • Resolution set to worksforme
  • Milestone Future Releases deleted

Thank you, so closing!

Note: See TracTickets for help on using tickets.