summaryrefslogtreecommitdiffstats
path: root/window-copy.c
diff options
context:
space:
mode:
authornicm <nicm>2020-06-04 10:24:14 +0000
committernicm <nicm>2020-06-04 10:24:14 +0000
commitdc74d2e0546f86f9745f730c21a286ddc0f3d6c1 (patch)
tree14de1d420de0d23eca4227bfa5f311e5e7448e64 /window-copy.c
parentd3c5202f50c28586a5a4e97b77332b57b798335b (diff)
Make the -no-clear command variants not clear the search marks either.
Diffstat (limited to 'window-copy.c')
-rw-r--r--window-copy.c154
1 files changed, 82 insertions, 72 deletions
diff --git a/window-copy.c b/window-copy.c
index 20f351aa..5ffe4dd1 100644
--- a/window-copy.c
+++ b/window-copy.c
@@ -177,6 +177,12 @@ enum window_copy_cmd_action {
WINDOW_COPY_CMD_CANCEL,
};
+enum window_copy_cmd_clear {
+ WINDOW_COPY_CMD_CLEAR_ALWAYS,
+ WINDOW_COPY_CMD_CLEAR_NEVER,
+ WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
+};
+
struct window_copy_cmd_state {
struct window_mode_entry *wme;
struct args *args;
@@ -2116,144 +2122,144 @@ static const struct {
const char *command;
int minargs;
int maxargs;
- int ismotion;
+ enum window_copy_cmd_clear clear;
enum window_copy_cmd_action (*f)(struct window_copy_cmd_state *);
} window_copy_cmd_table[] = {
- { "append-selection", 0, 0, 0,
+ { "append-selection", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_append_selection },
- { "append-selection-and-cancel", 0, 0, 0,
+ { "append-selection-and-cancel", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_append_selection_and_cancel },
- { "back-to-indentation", 0, 0, 0,
+ { "back-to-indentation", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_back_to_indentation },
- { "begin-selection", 0, 0, 0,
+ { "begin-selection", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_begin_selection },
- { "bottom-line", 0, 0, 1,
+ { "bottom-line", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_bottom_line },
- { "cancel", 0, 0, 0,
+ { "cancel", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_cancel },
- { "clear-selection", 0, 0, 0,
+ { "clear-selection", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_clear_selection },
- { "copy-end-of-line", 0, 1, 0,
+ { "copy-end-of-line", 0, 1, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_copy_end_of_line },
- { "copy-line", 0, 1, 0,
+ { "copy-line", 0, 1, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_copy_line },
- { "copy-pipe-no-clear", 0, 2, 0,
+ { "copy-pipe-no-clear", 0, 2, WINDOW_COPY_CMD_CLEAR_NEVER,
window_copy_cmd_copy_pipe_no_clear },
- { "copy-pipe", 0, 2, 0,
+ { "copy-pipe", 0, 2, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_copy_pipe },
- { "copy-pipe-and-cancel", 0, 2, 0,
+ { "copy-pipe-and-cancel", 0, 2, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_copy_pipe_and_cancel },
- { "copy-selection-no-clear", 0, 1, 0,
+ { "copy-selection-no-clear", 0, 1, WINDOW_COPY_CMD_CLEAR_NEVER,
window_copy_cmd_copy_selection_no_clear },
- { "copy-selection", 0, 1, 0,
+ { "copy-selection", 0, 1, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_copy_selection },
- { "copy-selection-and-cancel", 0, 1, 0,
+ { "copy-selection-and-cancel", 0, 1, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_copy_selection_and_cancel },
- { "cursor-down", 0, 0, 1,
+ { "cursor-down", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_cursor_down },
- { "cursor-down-and-cancel", 0, 0, 0,
+ { "cursor-down-and-cancel", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_cursor_down_and_cancel },
- { "cursor-left", 0, 0, 1,
+ { "cursor-left", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_cursor_left },
- { "cursor-right", 0, 0, 1,
+ { "cursor-right", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_cursor_right },
- { "cursor-up", 0, 0, 1,
+ { "cursor-up", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_cursor_up },
- { "end-of-line", 0, 0, 1,
+ { "end-of-line", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_end_of_line },
- { "goto-line", 1, 1, 1,
+ { "goto-line", 1, 1, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_goto_line },
- { "halfpage-down", 0, 0, 1,
+ { "halfpage-down", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_halfpage_down },
- { "halfpage-down-and-cancel", 0, 0, 0,
+ { "halfpage-down-and-cancel", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_halfpage_down_and_cancel },
- { "halfpage-up", 0, 0, 1,
+ { "halfpage-up", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_halfpage_up },
- { "history-bottom", 0, 0, 1,
+ { "history-bottom", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_history_bottom },
- { "history-top", 0, 0, 1,
+ { "history-top", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_history_top },
- { "jump-again", 0, 0, 1,
+ { "jump-again", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_jump_again },
- { "jump-backward", 1, 1, 1,
+ { "jump-backward", 1, 1, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_jump_backward },
- { "jump-forward", 1, 1, 1,
+ { "jump-forward", 1, 1, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_jump_forward },
- { "jump-reverse", 0, 0, 1,
+ { "jump-reverse", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_jump_reverse },
- { "jump-to-backward", 1, 1, 1,
+ { "jump-to-backward", 1, 1, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_jump_to_backward },
- { "jump-to-forward", 1, 1, 1,
+ { "jump-to-forward", 1, 1, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_jump_to_forward },
- { "jump-to-mark", 0, 0, 0,
+ { "jump-to-mark", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_jump_to_mark },
- { "middle-line", 0, 0, 1,
+ { "middle-line", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_middle_line },
- { "next-matching-bracket", 0, 0, 0,
+ { "next-matching-bracket", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_next_matching_bracket },
- { "next-paragraph", 0, 0, 1,
+ { "next-paragraph", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_next_paragraph },
- { "next-space", 0, 0, 1,
+ { "next-space", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_next_space },
- { "next-space-end", 0, 0, 1,
+ { "next-space-end", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_next_space_end },
- { "next-word", 0, 0, 1,
+ { "next-word", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_next_word },
- { "next-word-end", 0, 0, 1,
+ { "next-word-end", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_next_word_end },
- { "other-end", 0, 0, 1,
+ { "other-end", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_other_end },
- { "page-down", 0, 0, 1,
+ { "page-down", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_page_down },
- { "page-down-and-cancel", 0, 0, 0,
+ { "page-down-and-cancel", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_page_down_and_cancel },
- { "page-up", 0, 0, 1,
+ { "page-up", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_page_up },
- { "previous-matching-bracket", 0, 0, 0,
+ { "previous-matching-bracket", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_previous_matching_bracket },
- { "previous-paragraph", 0, 0, 1,
+ { "previous-paragraph", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_previous_paragraph },
- { "previous-space", 0, 0, 1,
+ { "previous-space", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_previous_space },
- { "previous-word", 0, 0, 1,
+ { "previous-word", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_previous_word },
- { "rectangle-toggle", 0, 0, 0,
+ { "rectangle-toggle", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_rectangle_toggle },
- { "refresh-from-pane", 0, 0, 0,
+ { "refresh-from-pane", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_refresh_from_pane },
- { "scroll-down", 0, 0, 1,
+ { "scroll-down", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_scroll_down },
- { "scroll-down-and-cancel", 0, 0, 0,
+ { "scroll-down-and-cancel", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_scroll_down_and_cancel },
- { "scroll-up", 0, 0, 1,
+ { "scroll-up", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_scroll_up },
- { "search-again", 0, 0, 0,
+ { "search-again", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_search_again },
- { "search-backward", 0, 1, 0,
+ { "search-backward", 0, 1, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_search_backward },
- { "search-backward-text", 0, 1, 0,
+ { "search-backward-text", 0, 1, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_search_backward_text },
- { "search-backward-incremental", 1, 1, 0,
+ { "search-backward-incremental", 1, 1, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_search_backward_incremental },
- { "search-forward", 0, 1, 0,
+ { "search-forward", 0, 1, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_search_forward },
- { "search-forward-text", 0, 1, 0,
+ { "search-forward-text", 0, 1, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_search_forward_text },
- { "search-forward-incremental", 1, 1, 0,
+ { "search-forward-incremental", 1, 1, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_search_forward_incremental },
- { "search-reverse", 0, 0, 0,
+ { "search-reverse", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_search_reverse },
- { "select-line", 0, 0, 0,
+ { "select-line", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_select_line },
- { "select-word", 0, 0, 0,
+ { "select-word", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_select_word },
- { "set-mark", 0, 0, 0,
+ { "set-mark", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_set_mark },
- { "start-of-line", 0, 0, 1,
+ { "start-of-line", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_start_of_line },
- { "stop-selection", 0, 0, 0,
+ { "stop-selection", 0, 0, WINDOW_COPY_CMD_CLEAR_ALWAYS,
window_copy_cmd_stop_selection },
- { "top-line", 0, 0, 1,
+ { "top-line", 0, 0, WINDOW_COPY_CMD_CLEAR_EMACS_ONLY,
window_copy_cmd_top_line },
};
@@ -2265,9 +2271,10 @@ window_copy_command(struct window_mode_entry *wme, struct client *c,
struct window_copy_mode_data *data = wme->data;
struct window_copy_cmd_state cs;
enum window_copy_cmd_action action;
+ enum window_copy_cmd_clear clear = WINDOW_COPY_CMD_CLEAR_NEVER;
const char *command;
u_int i;
- int ismotion = 0, keys;
+ int keys;
if (args->argc == 0)
return;
@@ -2290,7 +2297,7 @@ window_copy_command(struct window_mode_entry *wme, struct client *c,
if (args->argc - 1 < window_copy_cmd_table[i].minargs ||
args->argc - 1 > window_copy_cmd_table[i].maxargs)
break;
- ismotion = window_copy_cmd_table[i].ismotion;
+ clear = window_copy_cmd_table[i].clear;
action = window_copy_cmd_table[i].f (&cs);
break;
}
@@ -2298,7 +2305,10 @@ window_copy_command(struct window_mode_entry *wme, struct client *c,
if (strncmp(command, "search-", 7) != 0 && data->searchmark != NULL) {
keys = options_get_number(wme->wp->window->options, "mode-keys");
- if (keys != MODEKEY_VI || !ismotion) {
+ if (clear == WINDOW_COPY_CMD_CLEAR_EMACS_ONLY &&
+ keys == MODEKEY_VI)
+ clear = WINDOW_COPY_CMD_CLEAR_NEVER;
+ if (clear != WINDOW_COPY_CMD_CLEAR_NEVER) {
window_copy_clear_marks(wme);
data->searchx = data->searchy = -1;
} else if (data->searchthis != -1) {