diff options
| author | bfredl <bjorn.linse@gmail.com> | 2023-04-25 13:39:28 +0200 | 
|---|---|---|
| committer | bfredl <bjorn.linse@gmail.com> | 2023-04-25 21:30:19 +0200 | 
| commit | 5e569a47031d2a5b94cfadd67d5e76ba4651ac4d (patch) | |
| tree | 4b60b1ea544dfeee77fa9dbb0c6e899b11347d28 /test/functional/lua/fs_spec.lua | |
| parent | 965ad7726f91c2597ef6eb7a740ae024da99ec9b (diff) | |
| download | rneovim-5e569a47031d2a5b94cfadd67d5e76ba4651ac4d.tar.gz rneovim-5e569a47031d2a5b94cfadd67d5e76ba4651ac4d.tar.bz2 rneovim-5e569a47031d2a5b94cfadd67d5e76ba4651ac4d.zip | |
refactor(fs): now it is time to get rid of fs_loop and fs_loop_mutex
Here's the headline: when run in sync mode (last argument cb=NULL),
these functions don't actually use the uv_loop_t.
An earlier version of this patch instead replaced fs_loop with
using main_loop.uv on the main thread and luv_loop() on luv worker
threads. However this made the code more complicated for no reason.
Also arbitrarily, half of these functions would attempt to handle
UV_ENOMEM by try_to_free_memory(). This would mostly happen
on windows because it needs to allocate a converted WCHAR buffer.
This should be a quite rare situation. Your system is pretty
much hosed already if you cannot allocate like 50 WCHAR:s.
Therefore, take the liberty of simply removing this fallback.
In addition, we tried to "recover" from ENOMEM in read()/readv()
this way which doesn't make any sense. The read buffer(s) are already
allocated at this point.
This would also be an issue when using these functions on a worker
thread, as try_to_free_memory() is not thread-safe. Currently
os_file_is_readable() and os_is_dir() is used by worker threads
(as part of nvim__get_runtime(), to implement require from 'rtp' in
threads).
In the end, these changes makes _all_ os/fs.c functions thread-safe,
and we thus don't need to document and maintain a thread-safe subset.
Diffstat (limited to 'test/functional/lua/fs_spec.lua')
0 files changed, 0 insertions, 0 deletions
