1
0
mirror of https://github.com/weechat/weechat.git synced 2026-07-01 15:26:37 +02:00

core: add key ctrl+o to send command found and insert next one in input (issue #2040)

This commit is contained in:
Sébastien Helleu
2023-11-07 18:42:48 +01:00
parent b83b428c5c
commit 97a90ac65a
12 changed files with 74 additions and 2 deletions
+6 -1
View File
@@ -3593,6 +3593,8 @@ COMMAND_CALLBACK(input)
gui_input_history_global_previous (buffer);
else if (string_strcmp (argv[1], "history_global_next") == 0)
gui_input_history_global_next (buffer);
else if (string_strcmp (argv[1], "history_use_get_next") == 0)
gui_input_history_use_get_next (buffer);
else if (string_strcmp (argv[1], "grab_key") == 0)
{
gui_input_grab_key (buffer,
@@ -8524,6 +8526,9 @@ command_init ()
N_("> raw[history_next]: recall next command in current buffer history"),
N_("> raw[history_global_previous]: recall previous command in global history"),
N_("> raw[history_global_next]: recall next command in global history"),
N_("> raw[history_use_get_next]: send the current history entry "
"(found with search or recalled with \"up\"key) and insert the "
"next history entry in the command line without sending it"),
N_("> raw[grab_key]: grab a key (optional argument: delay for end of grab, "
"default is 500 milliseconds)"),
N_("> raw[grab_key_command]: grab a key with its associated command (optional "
@@ -8554,7 +8559,7 @@ command_init ()
"move_previous_char || move_next_char || move_previous_word || "
"move_next_word || move_previous_line || move_next_line || "
"history_previous || history_next || history_global_previous || "
"history_global_next || "
"history_global_next || history_use_get_next || "
"grab_key || grab_key_command || "
"grab_mouse || grab_mouse_area || "
"insert || send",
+5
View File
@@ -124,6 +124,7 @@ gui_key_default_bindings (int context, int create_option)
BIND("down", "/input history_next");
BIND("ctrl-up", "/input history_global_previous");
BIND("ctrl-down", "/input history_global_next");
BIND("ctrl-o", "/input history_use_get_next");
BIND("shift-up", "/input move_previous_line");
BIND("shift-down", "/input move_next_line");
BIND("meta-a", "/buffer jump smart");
@@ -219,6 +220,10 @@ gui_key_default_bindings (int context, int create_option)
BIND("up", "/input search_previous");
BIND("ctrl-s", "/input search_next");
BIND("down", "/input search_next");
if (context == GUI_KEY_CONTEXT_HISTSEARCH)
{
BIND("ctrl-o", "/input history_use_get_next");
}
}
else if (context == GUI_KEY_CONTEXT_CURSOR)
{
+48
View File
@@ -1803,6 +1803,54 @@ gui_input_history_global_next (struct t_gui_buffer *buffer)
}
}
/*
* Sends the current history entry (found with search or recalled with
* "up" key) and inserts the next one in the command line without sending it
* (default key: ctrl-o, in contexts "default" and "histsearch").
*/
void
gui_input_history_use_get_next (struct t_gui_buffer *buffer)
{
struct t_gui_window *window;
struct t_gui_history *ptr_history, **ptr_ptr_history;;
window = gui_window_search_with_buffer (buffer);
if (!window)
return;
ptr_history = NULL;
ptr_ptr_history = NULL;
if (window->buffer->text_search == GUI_BUFFER_SEARCH_HISTORY)
{
ptr_history = window->buffer->text_search_ptr_history;
if (!ptr_history)
return;
ptr_ptr_history = (window->buffer->text_search_history == GUI_BUFFER_SEARCH_HISTORY_LOCAL) ?
&(window->buffer->ptr_history) : &gui_history_ptr;
gui_window_search_stop (window, 1);
}
else if (window->buffer->ptr_history)
{
ptr_history = window->buffer->ptr_history;
ptr_ptr_history = &(window->buffer->ptr_history);
}
else if (gui_history_ptr)
{
ptr_history = gui_history_ptr;
ptr_ptr_history = &gui_history_ptr;
}
gui_input_return (buffer);
if (ptr_history && ptr_history->prev_history)
{
gui_input_insert_string (buffer, ptr_history->prev_history->text);
if (ptr_ptr_history)
*ptr_ptr_history = ptr_history->prev_history;
}
}
/*
* Initializes "grab key mode" (next key will be inserted into input buffer)
* (default key: alt-k).
+1
View File
@@ -80,6 +80,7 @@ extern void gui_input_history_local_previous (struct t_gui_buffer *buffer);
extern void gui_input_history_local_next (struct t_gui_buffer *buffer);
extern void gui_input_history_global_previous (struct t_gui_buffer *buffer);
extern void gui_input_history_global_next (struct t_gui_buffer *buffer);
extern void gui_input_history_use_get_next (struct t_gui_buffer *buffer);
extern void gui_input_grab_key (struct t_gui_buffer *buffer, int command,
const char *delay);
extern void gui_input_grab_mouse (struct t_gui_buffer *buffer, int area);