mirror of
https://github.com/helix-editor/helix.git
synced 2024-11-25 19:03:30 +04:00
Move Keymaps from EditorView to Context structs
We'll need this value when attempting to execute keymaps for other Components. Previously it was only scoped to the EditorView.
This commit is contained in:
parent
6c6923c39e
commit
d6fc6a54b2
@ -63,6 +63,7 @@
|
||||
|
||||
pub struct Application {
|
||||
compositor: Compositor,
|
||||
keymaps: Keymaps,
|
||||
terminal: Terminal,
|
||||
pub editor: Editor,
|
||||
|
||||
@ -156,7 +157,8 @@ pub fn new(
|
||||
let keys = Box::new(Map::new(Arc::clone(&config), |config: &Config| {
|
||||
&config.keys
|
||||
}));
|
||||
let editor_view = Box::new(ui::EditorView::new(Keymaps::new(keys)));
|
||||
let keymaps = Keymaps::new(keys);
|
||||
let editor_view = Box::new(ui::EditorView::default());
|
||||
compositor.push(editor_view);
|
||||
|
||||
if args.load_tutor {
|
||||
@ -241,6 +243,7 @@ pub fn new(
|
||||
.context("build signal handler")?;
|
||||
|
||||
let app = Self {
|
||||
keymaps,
|
||||
compositor,
|
||||
terminal,
|
||||
editor,
|
||||
@ -261,6 +264,7 @@ pub fn new(
|
||||
|
||||
async fn render(&mut self) {
|
||||
let mut cx = crate::compositor::Context {
|
||||
keymaps: &mut self.keymaps,
|
||||
editor: &mut self.editor,
|
||||
jobs: &mut self.jobs,
|
||||
scroll: None,
|
||||
@ -521,6 +525,7 @@ pub async fn handle_signals(&mut self, signal: i32) -> bool {
|
||||
|
||||
pub async fn handle_idle_timeout(&mut self) {
|
||||
let mut cx = crate::compositor::Context {
|
||||
keymaps: &mut self.keymaps,
|
||||
editor: &mut self.editor,
|
||||
jobs: &mut self.jobs,
|
||||
scroll: None,
|
||||
@ -641,6 +646,7 @@ pub async fn handle_terminal_events(
|
||||
event: Result<CrosstermEvent, crossterm::ErrorKind>,
|
||||
) {
|
||||
let mut cx = crate::compositor::Context {
|
||||
keymaps: &mut self.keymaps,
|
||||
editor: &mut self.editor,
|
||||
jobs: &mut self.jobs,
|
||||
scroll: None,
|
||||
|
@ -53,7 +53,7 @@
|
||||
compositor::{self, Component, Compositor},
|
||||
filter_picker_entry,
|
||||
job::Callback,
|
||||
keymap::ReverseKeymap,
|
||||
keymap::{Keymaps, ReverseKeymap},
|
||||
ui::{
|
||||
self, editor::InsertEvent, lsp::SignatureHelp, overlay::overlaid, CompletionItem, Picker,
|
||||
Popup, Prompt, PromptEvent,
|
||||
@ -81,6 +81,8 @@
|
||||
pub type OnKeyCallback = Box<dyn FnOnce(&mut Context, KeyEvent)>;
|
||||
|
||||
pub struct Context<'a> {
|
||||
pub keymaps: &'a mut Keymaps,
|
||||
|
||||
pub register: Option<char>,
|
||||
pub count: Option<NonZeroUsize>,
|
||||
pub editor: &'a mut Editor,
|
||||
@ -196,6 +198,7 @@ pub fn execute(&self, cx: &mut Context) {
|
||||
let args: Vec<Cow<str>> = args.iter().map(Cow::from).collect();
|
||||
if let Some(command) = typed::TYPABLE_COMMAND_MAP.get(name.as_str()) {
|
||||
let mut cx = compositor::Context {
|
||||
keymaps: cx.keymaps,
|
||||
editor: cx.editor,
|
||||
jobs: cx.jobs,
|
||||
scroll: None,
|
||||
@ -2716,9 +2719,8 @@ pub fn command_palette(cx: &mut Context) {
|
||||
|
||||
cx.callback = Some(Box::new(
|
||||
move |compositor: &mut Compositor, cx: &mut compositor::Context| {
|
||||
let keymap = compositor.find::<ui::EditorView>().unwrap().keymaps.map()
|
||||
[&cx.editor.mode]
|
||||
.reverse_map();
|
||||
let keymap =
|
||||
cx.keymaps.map()[&crate::keymap::Domain::Mode(cx.editor.mode)].reverse_map();
|
||||
|
||||
let mut commands: Vec<MappableCommand> = MappableCommand::STATIC_COMMAND_LIST.into();
|
||||
commands.extend(typed::TYPABLE_COMMAND_LIST.iter().map(|cmd| {
|
||||
@ -2733,6 +2735,7 @@ pub fn command_palette(cx: &mut Context) {
|
||||
let mut ctx = Context {
|
||||
register,
|
||||
count,
|
||||
keymaps: cx.keymaps,
|
||||
editor: cx.editor,
|
||||
callback: None,
|
||||
on_next_key_callback: None,
|
||||
|
@ -15,12 +15,13 @@ pub enum EventResult {
|
||||
Consumed(Option<Callback>),
|
||||
}
|
||||
|
||||
use crate::job::Jobs;
|
||||
use crate::{job::Jobs, keymap::Keymaps};
|
||||
use helix_view::Editor;
|
||||
|
||||
pub use helix_view::input::Event;
|
||||
|
||||
pub struct Context<'a> {
|
||||
pub keymaps: &'a mut Keymaps,
|
||||
pub editor: &'a mut Editor,
|
||||
pub scroll: Option<usize>,
|
||||
pub jobs: &'a mut Jobs,
|
||||
|
@ -3,7 +3,7 @@
|
||||
compositor::{Component, Context, Event, EventResult},
|
||||
job::{self, Callback},
|
||||
key,
|
||||
keymap::{KeymapResult, Keymaps},
|
||||
keymap::KeymapResult,
|
||||
ui::{
|
||||
document::{render_document, LinePos, TextRenderer, TranslatedPosition},
|
||||
Completion, ProgressSpinners,
|
||||
@ -37,7 +37,6 @@
|
||||
use super::{document::LineDecoration, lsp::SignatureHelp};
|
||||
|
||||
pub struct EditorView {
|
||||
pub keymaps: Keymaps,
|
||||
on_next_key: Option<OnKeyCallback>,
|
||||
pseudo_pending: Vec<KeyEvent>,
|
||||
pub(crate) last_insert: (commands::MappableCommand, Vec<InsertEvent>),
|
||||
@ -58,14 +57,7 @@ pub enum InsertEvent {
|
||||
|
||||
impl Default for EditorView {
|
||||
fn default() -> Self {
|
||||
Self::new(Keymaps::default())
|
||||
}
|
||||
}
|
||||
|
||||
impl EditorView {
|
||||
pub fn new(keymaps: Keymaps) -> Self {
|
||||
Self {
|
||||
keymaps,
|
||||
on_next_key: None,
|
||||
pseudo_pending: Vec::new(),
|
||||
last_insert: (commands::MappableCommand::normal_mode, Vec::new()),
|
||||
@ -73,7 +65,9 @@ pub fn new(keymaps: Keymaps) -> Self {
|
||||
spinners: ProgressSpinners::default(),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl EditorView {
|
||||
pub fn spinners_mut(&mut self) -> &mut ProgressSpinners {
|
||||
&mut self.spinners
|
||||
}
|
||||
@ -786,7 +780,7 @@ pub fn highlight_cursorcolumn(
|
||||
}
|
||||
}
|
||||
|
||||
/// Handle events by looking them up in `self.keymaps`. Returns None
|
||||
/// Handle events by looking them up in `cxt.keymaps`. Returns None
|
||||
/// if event was handled (a command was executed or a subkeymap was
|
||||
/// activated). Only KeymapResult::{NotFound, Cancelled} is returned
|
||||
/// otherwise.
|
||||
@ -797,9 +791,9 @@ fn handle_keymap_event(
|
||||
event: KeyEvent,
|
||||
) -> Option<KeymapResult> {
|
||||
let mut last_mode = mode;
|
||||
self.pseudo_pending.extend(self.keymaps.pending());
|
||||
let key_result = self.keymaps.get(mode, event);
|
||||
cxt.editor.autoinfo = self.keymaps.sticky().map(|node| node.infobox());
|
||||
self.pseudo_pending.extend(cxt.keymaps.pending());
|
||||
let key_result = cxt.keymaps.get(mode, event);
|
||||
cxt.editor.autoinfo = cxt.keymaps.sticky().map(|node| node.infobox());
|
||||
|
||||
let mut execute_command = |command: &commands::MappableCommand| {
|
||||
command.execute(cxt);
|
||||
@ -864,7 +858,7 @@ fn insert_mode(&mut self, cx: &mut commands::Context, event: KeyEvent) {
|
||||
Some(ch) => commands::insert::insert_char(cx, ch),
|
||||
None => {
|
||||
if let KeymapResult::Matched(command) =
|
||||
self.keymaps.get(Mode::Insert, ev)
|
||||
cx.keymaps.get_by_mode(Mode::Insert, ev)
|
||||
{
|
||||
command.execute(cx);
|
||||
}
|
||||
@ -886,7 +880,7 @@ fn command_mode(&mut self, mode: Mode, cxt: &mut commands::Context, event: KeyEv
|
||||
std::num::NonZeroUsize::new(cxt.editor.count.map_or(i, |c| c.get() * 10 + i));
|
||||
}
|
||||
// special handling for repeat operator
|
||||
(key!('.'), _) if self.keymaps.pending().is_empty() => {
|
||||
(key!('.'), _) if cxt.keymaps.pending().is_empty() => {
|
||||
for _ in 0..cxt.editor.count.map_or(1, NonZeroUsize::into) {
|
||||
// first execute whatever put us into insert mode
|
||||
self.last_insert.0.execute(cxt);
|
||||
@ -944,7 +938,7 @@ fn command_mode(&mut self, mode: Mode, cxt: &mut commands::Context, event: KeyEv
|
||||
cxt.register = cxt.editor.selected_register.take();
|
||||
|
||||
self.handle_keymap_event(mode, cxt, event);
|
||||
if self.keymaps.pending().is_empty() {
|
||||
if cxt.keymaps.pending().is_empty() {
|
||||
cxt.editor.count = None
|
||||
} else {
|
||||
cxt.editor.selected_register = cxt.register.take();
|
||||
@ -1225,6 +1219,7 @@ fn handle_event(
|
||||
context: &mut crate::compositor::Context,
|
||||
) -> EventResult {
|
||||
let mut cx = commands::Context {
|
||||
keymaps: context.keymaps,
|
||||
editor: context.editor,
|
||||
count: None,
|
||||
register: None,
|
||||
@ -1280,6 +1275,7 @@ fn handle_event(
|
||||
let res = {
|
||||
// use a fake context here
|
||||
let mut cx = Context {
|
||||
keymaps: cx.keymaps,
|
||||
editor: cx.editor,
|
||||
jobs: cx.jobs,
|
||||
scroll: None,
|
||||
@ -1445,7 +1441,7 @@ fn render(&mut self, area: Rect, surface: &mut Surface, cx: &mut Context) {
|
||||
if let Some(count) = cx.editor.count {
|
||||
disp.push_str(&count.to_string())
|
||||
}
|
||||
for key in self.keymaps.pending() {
|
||||
for key in cx.keymaps.pending() {
|
||||
disp.push_str(&key.key_sequence_format());
|
||||
}
|
||||
for key in &self.pseudo_pending {
|
||||
|
Loading…
Reference in New Issue
Block a user