mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-14 22:14:53 +00:00
reader_data_t to become enable_shared_from_this
For background operations such as autosuggestions, we need a way for the completion handler to keep the reader_data alive.
This commit is contained in:
parent
c334a41f96
commit
b014c327a2
1 changed files with 3 additions and 3 deletions
|
@ -305,7 +305,7 @@ class reader_history_search_t {
|
||||||
|
|
||||||
/// A struct describing the state of the interactive reader. These states can be stacked, in case
|
/// A struct describing the state of the interactive reader. These states can be stacked, in case
|
||||||
/// reader_readline() calls are nested. This happens when the 'read' builtin is used.
|
/// reader_readline() calls are nested. This happens when the 'read' builtin is used.
|
||||||
class reader_data_t {
|
class reader_data_t : public std::enable_shared_from_this<reader_data_t> {
|
||||||
public:
|
public:
|
||||||
/// String containing the whole current commandline.
|
/// String containing the whole current commandline.
|
||||||
editable_line_t command_line;
|
editable_line_t command_line;
|
||||||
|
@ -435,7 +435,7 @@ class reader_data_t {
|
||||||
static void reader_set_buffer_maintaining_pager(reader_data_t *data, const wcstring &b, size_t pos);
|
static void reader_set_buffer_maintaining_pager(reader_data_t *data, const wcstring &b, size_t pos);
|
||||||
|
|
||||||
/// The stack of current interactive reading contexts.
|
/// The stack of current interactive reading contexts.
|
||||||
static std::vector<std::unique_ptr<reader_data_t>> reader_data_stack;
|
static std::vector<std::shared_ptr<reader_data_t>> reader_data_stack;
|
||||||
|
|
||||||
/// Access the top level reader data.
|
/// Access the top level reader data.
|
||||||
static reader_data_t *current_data_or_null() {
|
static reader_data_t *current_data_or_null() {
|
||||||
|
@ -2102,7 +2102,7 @@ void reader_change_history(const wcstring &name) {
|
||||||
|
|
||||||
void reader_push(const wcstring &name) {
|
void reader_push(const wcstring &name) {
|
||||||
history_t *hist = &history_t::history_with_name(name);
|
history_t *hist = &history_t::history_with_name(name);
|
||||||
reader_data_stack.push_back(make_unique<reader_data_t>(hist));
|
reader_data_stack.push_back(std::make_shared<reader_data_t>(hist));
|
||||||
reader_data_t *data = current_data();
|
reader_data_t *data = current_data();
|
||||||
data->command_line_changed(&data->command_line);
|
data->command_line_changed(&data->command_line);
|
||||||
if (reader_data_stack.size() == 1) {
|
if (reader_data_stack.size() == 1) {
|
||||||
|
|
Loading…
Reference in a new issue