diff options
| author | Maxime Coste <mawww@kakoune.org> | 2024-04-11 11:37:18 +1000 |
|---|---|---|
| committer | Maxime Coste <mawww@kakoune.org> | 2024-04-12 15:28:40 +1000 |
| commit | 3d7d0fecca885b00a7ae80180ea1841fab2c5993 (patch) | |
| tree | 94218f4a6dab3f448ceaff034e51079a0ecc2e3c /src/insert_completer.cc | |
| parent | b1c114bf6d950684df0524e450782a151e6a0323 (diff) | |
Introduce "local" scope in evaluate-commands
When using `eval` a new scope named 'local' gets pushed for the
whole evaluation, this makes it possible to temporarily set
an option/hook/alias...
Local scopes nest so nested evals do work as expected.
Remove the now trivial with-option command
Diffstat (limited to 'src/insert_completer.cc')
| -rw-r--r-- | src/insert_completer.cc | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/src/insert_completer.cc b/src/insert_completer.cc index c50fbe00..3e1bcd2d 100644 --- a/src/insert_completer.cc +++ b/src/insert_completer.cc @@ -403,7 +403,10 @@ InsertCompletion complete_line(const SelectionList& sels, } InsertCompleter::InsertCompleter(Context& context) - : m_context(context), m_options(context.options()), m_faces(context.faces()) + : m_context(context), + // local scopes might go away before completion ends, make sure to register on a long lived one + m_options(context.scope(false).options()), + m_faces(context.scope(false).faces()) { m_options.register_watcher(*this); } |
