mirror of
https://github.com/neovim/neovim.git
synced 2024-12-31 17:13:26 -07:00
os_nodetype: Return NODE_NORMAL if os_stat fails.
Conforms to Vim's mch_nodetype. Regression by 7db4a15
.
buf_write() expects NODE_WRITABLE for character devices such as
/dev/stderr.
Closes #4772
This commit is contained in:
parent
849d61b551
commit
96f834a842
@ -111,8 +111,8 @@ int os_nodetype(const char *name)
|
||||
#endif
|
||||
|
||||
uv_stat_t statbuf;
|
||||
if (os_stat(name, &statbuf) == 0) {
|
||||
return NODE_NORMAL;
|
||||
if (0 != os_stat(name, &statbuf)) {
|
||||
return NODE_NORMAL; // File doesn't exist.
|
||||
}
|
||||
|
||||
#ifndef WIN32
|
||||
|
@ -14,6 +14,8 @@ local to_cstr = helpers.to_cstr
|
||||
local OK = helpers.OK
|
||||
local FAIL = helpers.FAIL
|
||||
local NULL = helpers.NULL
|
||||
local NODE_NORMAL = 0
|
||||
local NODE_WRITABLE = 1
|
||||
|
||||
cimport('unistd.h')
|
||||
cimport('./src/nvim/os/shell.h')
|
||||
@ -357,15 +359,12 @@ describe('fs function', function()
|
||||
local function os_file_exists(filename)
|
||||
return fs.os_file_exists((to_cstr(filename)))
|
||||
end
|
||||
|
||||
local function os_rename(path, new_path)
|
||||
return fs.os_rename((to_cstr(path)), (to_cstr(new_path)))
|
||||
end
|
||||
|
||||
local function os_remove(path)
|
||||
return fs.os_remove((to_cstr(path)))
|
||||
end
|
||||
|
||||
local function os_open(path, flags, mode)
|
||||
return fs.os_open((to_cstr(path)), flags, mode)
|
||||
end
|
||||
@ -484,6 +483,20 @@ describe('fs function', function()
|
||||
assert.is_true(0 <= (os_open(existing_file, ffi.C.kO_RDWR, 0)))
|
||||
end)
|
||||
end)
|
||||
|
||||
describe('os_nodetype', function()
|
||||
before_each(function()
|
||||
os.remove('non-existing-file')
|
||||
end)
|
||||
|
||||
it('returns NODE_NORMAL for non-existing file', function()
|
||||
eq(NODE_NORMAL, fs.os_nodetype(to_cstr('non-existing-file')))
|
||||
end)
|
||||
|
||||
it('returns NODE_WRITABLE for /dev/stderr', function()
|
||||
eq(NODE_WRITABLE, fs.os_nodetype(to_cstr('/dev/stderr')))
|
||||
end)
|
||||
end)
|
||||
end)
|
||||
|
||||
describe('folder operations', function()
|
||||
|
Loading…
Reference in New Issue
Block a user