Ensure buffer create/close hooks are run at appropriate times
They used to be ran before the buffer was added to the buffer list we now run them afterwards.
This commit is contained in:
parent
6bcfc7268f
commit
530ecf212e
|
@ -69,8 +69,6 @@ Buffer::Buffer(String name, Flags flags, StringView data,
|
||||||
m_last_save_undo_index(0),
|
m_last_save_undo_index(0),
|
||||||
m_fs_timestamp(fs_timestamp)
|
m_fs_timestamp(fs_timestamp)
|
||||||
{
|
{
|
||||||
options().register_watcher(*this);
|
|
||||||
|
|
||||||
ParsedLines parsed_lines = parse_lines(data);
|
ParsedLines parsed_lines = parse_lines(data);
|
||||||
|
|
||||||
if (parsed_lines.lines.empty())
|
if (parsed_lines.lines.empty())
|
||||||
|
@ -87,9 +85,24 @@ Buffer::Buffer(String name, Flags flags, StringView data,
|
||||||
|
|
||||||
apply_options(options(), parsed_lines);
|
apply_options(options(), parsed_lines);
|
||||||
|
|
||||||
if (flags & Flags::File)
|
// now we may begin to record undo data
|
||||||
|
if (not (flags & Flags::NoUndo))
|
||||||
|
m_flags &= ~Flags::NoUndo;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Buffer::on_registered()
|
||||||
{
|
{
|
||||||
if (flags & Flags::New)
|
// Ignore debug buffer, as it can be created in many
|
||||||
|
// corner cases (including while destroying the BufferManager
|
||||||
|
// if a BufClose hooks triggers writing to it.
|
||||||
|
if (m_flags & Flags::Debug)
|
||||||
|
return;
|
||||||
|
|
||||||
|
options().register_watcher(*this);
|
||||||
|
|
||||||
|
if (m_flags & Flags::File)
|
||||||
|
{
|
||||||
|
if (m_flags & Buffer::Flags::New)
|
||||||
run_hook_in_own_context("BufNew", m_name);
|
run_hook_in_own_context("BufNew", m_name);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -100,19 +113,21 @@ Buffer::Buffer(String name, Flags flags, StringView data,
|
||||||
|
|
||||||
run_hook_in_own_context("BufCreate", m_name);
|
run_hook_in_own_context("BufCreate", m_name);
|
||||||
|
|
||||||
// now we may begin to record undo data
|
|
||||||
if (not (flags & Flags::NoUndo))
|
|
||||||
m_flags &= ~Flags::NoUndo;
|
|
||||||
|
|
||||||
for (auto& option : options().flatten_options())
|
for (auto& option : options().flatten_options())
|
||||||
on_option_changed(*option);
|
on_option_changed(*option);
|
||||||
}
|
}
|
||||||
|
|
||||||
Buffer::~Buffer()
|
void Buffer::on_unregistered()
|
||||||
{
|
{
|
||||||
run_hook_in_own_context("BufClose", m_name);
|
if (m_flags & Flags::Debug)
|
||||||
|
return;
|
||||||
|
|
||||||
options().unregister_watcher(*this);
|
options().unregister_watcher(*this);
|
||||||
|
run_hook_in_own_context("BufClose", m_name);
|
||||||
|
}
|
||||||
|
|
||||||
|
Buffer::~Buffer()
|
||||||
|
{
|
||||||
m_values.clear();
|
m_values.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -200,6 +200,10 @@ public:
|
||||||
ConstArrayView<Change> changes_since(size_t timestamp) const;
|
ConstArrayView<Change> changes_since(size_t timestamp) const;
|
||||||
|
|
||||||
String debug_description() const;
|
String debug_description() const;
|
||||||
|
|
||||||
|
// Methods called by the buffer manager
|
||||||
|
void on_registered();
|
||||||
|
void on_unregistered();
|
||||||
private:
|
private:
|
||||||
|
|
||||||
void on_option_changed(const Option& option) override;
|
void on_option_changed(const Option& option) override;
|
||||||
|
|
|
@ -22,6 +22,9 @@ BufferManager::~BufferManager()
|
||||||
// hook while clearing m_buffers
|
// hook while clearing m_buffers
|
||||||
m_buffer_trash = std::move(m_buffers);
|
m_buffer_trash = std::move(m_buffers);
|
||||||
|
|
||||||
|
for (auto& buffer : m_buffer_trash)
|
||||||
|
buffer->on_unregistered();
|
||||||
|
|
||||||
// Make sure not clients exists
|
// Make sure not clients exists
|
||||||
ClientManager::instance().clear();
|
ClientManager::instance().clear();
|
||||||
}
|
}
|
||||||
|
@ -37,9 +40,12 @@ Buffer* BufferManager::create_buffer(String name, Buffer::Flags flags,
|
||||||
throw name_not_unique();
|
throw name_not_unique();
|
||||||
}
|
}
|
||||||
|
|
||||||
m_buffers.emplace(m_buffers.begin(), new Buffer{std::move(name), flags,
|
m_buffers.emplace(m_buffers.begin(),
|
||||||
data, fs_timestamp});
|
new Buffer{std::move(name), flags, data, fs_timestamp});
|
||||||
return m_buffers.front().get();
|
auto& buffer = *m_buffers.front();
|
||||||
|
buffer.on_registered();
|
||||||
|
|
||||||
|
return &buffer;
|
||||||
}
|
}
|
||||||
|
|
||||||
void BufferManager::delete_buffer(Buffer& buffer)
|
void BufferManager::delete_buffer(Buffer& buffer)
|
||||||
|
@ -48,10 +54,13 @@ void BufferManager::delete_buffer(Buffer& buffer)
|
||||||
{ return p.get() == &buffer; });
|
{ return p.get() == &buffer; });
|
||||||
kak_assert(it != m_buffers.end());
|
kak_assert(it != m_buffers.end());
|
||||||
|
|
||||||
|
|
||||||
ClientManager::instance().ensure_no_client_uses_buffer(buffer);
|
ClientManager::instance().ensure_no_client_uses_buffer(buffer);
|
||||||
|
|
||||||
m_buffer_trash.emplace_back(std::move(*it));
|
m_buffer_trash.emplace_back(std::move(*it));
|
||||||
m_buffers.erase(it);
|
m_buffers.erase(it);
|
||||||
|
|
||||||
|
buffer.on_unregistered();
|
||||||
}
|
}
|
||||||
|
|
||||||
Buffer* BufferManager::get_buffer_ifp(StringView name)
|
Buffer* BufferManager::get_buffer_ifp(StringView name)
|
||||||
|
|
|
@ -664,11 +664,11 @@ int run_filter(StringView keystr, StringView commands, ConstArrayView<StringView
|
||||||
}
|
}
|
||||||
if (not isatty(0))
|
if (not isatty(0))
|
||||||
{
|
{
|
||||||
Buffer* buffer = buffer_manager.create_buffer(
|
Buffer& buffer = *buffer_manager.create_buffer(
|
||||||
"*stdin*", Buffer::Flags::None, read_fd(0), InvalidTime);
|
"*stdin*", Buffer::Flags::None, read_fd(0), InvalidTime);
|
||||||
apply_to_buffer(*buffer);
|
apply_to_buffer(buffer);
|
||||||
write_buffer_to_fd(*buffer, 1);
|
write_buffer_to_fd(buffer, 1);
|
||||||
buffer_manager.delete_buffer(*buffer);
|
buffer_manager.delete_buffer(buffer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (Kakoune::runtime_error& err)
|
catch (Kakoune::runtime_error& err)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user