You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
vim.fn.filereadable() hangs until the connection is reestablished, which is the normal behaviour of NFS mounts, because I have file paths of that remote location in my v:oldfiles.
I know this is not a very common use case, and it is the users fault if the mounted location is not available, but if that leads to infinite hangs although the location is not used by the user, this becomes an annoyance.
Would it be possible to implement an configurable option to simply remove that check? I could try to create a PR for that.
Neovim version
0.10.2
Steps to reproduce
mount remote location to /mnt/mymount
nvim -nu minimal.lua needs to only load mini.bracketed
:e /mnt/mymount/myfile.txt this should add the file path to v:oldfiles
:q
disconnect network connection without unmounting
nvim -nu minimal.lua (this hangs infinitely)
Expected behavior
Neovim should start normally at 5. above.
Actual behavior
Neovim hangs infinitely at 5.
The text was updated successfully, but these errors were encountered:
I don't have the means to reproduce this, so I'd have to ask for your help to find the best fix.
Could you, please, try replacing both instances of vim.fn.filereadable(path) == 1 (this and this) with vim.loop.fs_stat(path) ~= nil and see if it fixes the hanging issue?
As a side note, I'd also suggest creating an issue in vim/vim repo about this behavior of filereadable(). I don't think it should ever hang.
Hmm... Then there is either a complete redo of the tracking logic or declaring this as a known limitation. I'll take a closer look to try and reproduce this locally.
After some investigation, I think that removing that check is safe without even an option. As far as I understand/remember, it was there mostly for memory reasons (to not track entries from 'oldfiles' which are not already present on disk or were not there to begin with). This should help with indefinite hanging on require('mini.bracketed').setup(), but using oldfile target would still be affected, as it uses vim.fn.filereadable() for normalization.
I tried to reproduce locally (by mounting flash drive and removing it without first unmounting it), but could not reproduce. If indefinite hanging on vim.fn.filereadable() in described use case is still reproducible, please consider opening issue in 'vim/vim' repo (not even Neovim, as that part of code base is from Vim).
Contributing guidelines
Module(s)
bracketed
Description
I have a mounted remote location via NFS (Linux).
Whenever I disconnect Ethernet or Wifi without unmounting, Neovim is not starting anymore.
The issue is the first part of line 1751 in bracketed.lua (function
H.oldfile_ensure_initialized
) which is executed during startup of Neovim:vim.fn.filereadable()
hangs until the connection is reestablished, which is the normal behaviour of NFS mounts, because I have file paths of that remote location in myv:oldfiles
.I know this is not a very common use case, and it is the users fault if the mounted location is not available, but if that leads to infinite hangs although the location is not used by the user, this becomes an annoyance.
Would it be possible to implement an configurable option to simply remove that check? I could try to create a PR for that.
Neovim version
0.10.2
Steps to reproduce
/mnt/mymount
nvim -nu minimal.lua
needs to only load mini.bracketed:e /mnt/mymount/myfile.txt
this should add the file path tov:oldfiles
:q
nvim -nu minimal.lua
(this hangs infinitely)Expected behavior
Neovim should start normally at 5. above.
Actual behavior
Neovim hangs infinitely at 5.
The text was updated successfully, but these errors were encountered: