summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorMaxime Coste <mawww@kakoune.org>2023-05-10 20:03:22 +1000
committerMaxime Coste <mawww@kakoune.org>2023-05-10 20:03:22 +1000
commit3d989af2deb76ed1b91b576404cc94d7f7cfe6e0 (patch)
treec9a300612386908ce3e30ee0307ba9f14f241070 /src
parent459007ae21f5a78950d2dc192113124825fd38c9 (diff)
parentcf94b310aa2ea343c619845b89c00d6cc5a10e5d (diff)
Merge remote-tracking branch 'krobelus/fix-crash-connecting-monitor'
Diffstat (limited to 'src')
-rw-r--r--src/file.cc10
-rw-r--r--src/file.hh5
-rw-r--r--src/terminal_ui.cc2
3 files changed, 11 insertions, 6 deletions
diff --git a/src/file.cc b/src/file.cc
index a2ad279b..58eb9284 100644
--- a/src/file.cc
+++ b/src/file.cc
@@ -252,13 +252,14 @@ bool regular_file_exists(StringView filename)
(st.st_mode & S_IFMT) == S_IFREG;
}
+template<bool atomic>
void write(int fd, StringView data)
{
const char* ptr = data.data();
ssize_t count = (int)data.length();
int flags = fcntl(fd, F_GETFL, 0);
- if (EventManager::has_instance())
+ if (not atomic and EventManager::has_instance())
fcntl(fd, F_SETFL, flags | O_NONBLOCK);
auto restore_flags = on_scope_end([&] { fcntl(fd, F_SETFL, flags); });
@@ -269,12 +270,15 @@ void write(int fd, StringView data)
ptr += written;
count -= written;
}
- else if (errno == EAGAIN and EventManager::has_instance())
+ else if (errno == EAGAIN and not atomic and EventManager::has_instance())
EventManager::instance().handle_next_events(EventMode::Urgent, nullptr, false);
else
throw file_access_error(format("fd: {}", fd), strerror(errno));
}
}
+template void write<true>(int fd, StringView data);
+template void write<false>(int fd, StringView data);
+
void write_to_file(StringView filename, StringView data)
{
@@ -295,7 +299,7 @@ void write_buffer_to_fd(Buffer& buffer, int fd)
eoldata = "\n";
- BufferedWriter writer{fd};
+ BufferedWriter<false> writer{fd};
if (buffer.options()["BOM"].get<ByteOrderMark>() == ByteOrderMark::Utf8)
writer.write("\xEF\xBB\xBF");
diff --git a/src/file.hh b/src/file.hh
index 1d9391fb..65abd3c8 100644
--- a/src/file.hh
+++ b/src/file.hh
@@ -39,6 +39,7 @@ bool fd_readable(int fd);
bool fd_writable(int fd);
String read_fd(int fd, bool text = false);
String read_file(StringView filename, bool text = false);
+template<bool force_blocking = false>
void write(int fd, StringView data);
void write_to_file(StringView filename, StringView data);
@@ -121,7 +122,7 @@ CandidateList complete_filename(StringView prefix, const Regex& ignore_regex,
CandidateList complete_command(StringView prefix, ByteCount cursor_pos = -1);
-template<int buffer_size = 4096>
+template<bool atomic, int buffer_size = 4096>
struct BufferedWriter
{
BufferedWriter(int fd)
@@ -149,7 +150,7 @@ struct BufferedWriter
void flush()
{
- Kakoune::write(m_fd, {m_buffer, m_pos});
+ Kakoune::write<atomic>(m_fd, {m_buffer, m_pos});
m_pos = 0;
}
diff --git a/src/terminal_ui.cc b/src/terminal_ui.cc
index d411dd67..9685129a 100644
--- a/src/terminal_ui.cc
+++ b/src/terminal_ui.cc
@@ -208,7 +208,7 @@ void TerminalUI::Window::draw(DisplayCoord pos,
lines[(int)pos.line].append({}, size.column - pos.column, default_face);
}
-struct Writer : BufferedWriter<>
+struct Writer : BufferedWriter<true>
{
using Writer::BufferedWriter::BufferedWriter;
~Writer() noexcept(false) = default;