Close fd before notifiying buffer of modification when writing to file
This commit is contained in:
parent
b2e90fe21e
commit
7f23d4b756
14
src/file.cc
14
src/file.cc
|
@ -194,13 +194,15 @@ void write_buffer_to_file(Buffer& buffer, StringView filename)
|
||||||
{
|
{
|
||||||
buffer.run_hook_in_own_context("BufWritePre", buffer.name());
|
buffer.run_hook_in_own_context("BufWritePre", buffer.name());
|
||||||
|
|
||||||
int fd = open(parse_filename(filename).c_str(),
|
{
|
||||||
O_CREAT | O_WRONLY | O_TRUNC, 0644);
|
int fd = open(parse_filename(filename).c_str(),
|
||||||
if (fd == -1)
|
O_CREAT | O_WRONLY | O_TRUNC, 0644);
|
||||||
throw file_access_error(filename, strerror(errno));
|
if (fd == -1)
|
||||||
auto close_fd = on_scope_end([fd]{ close(fd); });
|
throw file_access_error(filename, strerror(errno));
|
||||||
|
auto close_fd = on_scope_end([fd]{ close(fd); });
|
||||||
|
|
||||||
write_buffer_to_fd(buffer, fd);
|
write_buffer_to_fd(buffer, fd);
|
||||||
|
}
|
||||||
|
|
||||||
if ((buffer.flags() & Buffer::Flags::File) and
|
if ((buffer.flags() & Buffer::Flags::File) and
|
||||||
real_path(filename) == real_path(buffer.name()))
|
real_path(filename) == real_path(buffer.name()))
|
||||||
|
|
Loading…
Reference in New Issue
Block a user