aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornicm <nicm>2017-05-12 10:45:38 +0000
committernicm <nicm>2017-05-12 10:45:38 +0000
commit7d3e2c83d4487c306fc77f22c2cc12f5842bd5ae (patch)
tree4df353e5a9af509af29767935a59ad0538f3fae6
parentc0d3f204b0b7557793f89535dd555258b3a4a85f (diff)
downloadrtmux-7d3e2c83d4487c306fc77f22c2cc12f5842bd5ae.tar.gz
rtmux-7d3e2c83d4487c306fc77f22c2cc12f5842bd5ae.tar.bz2
rtmux-7d3e2c83d4487c306fc77f22c2cc12f5842bd5ae.zip
Store copy mode search string in pane so search-again command works even
if you exit and reenter copy mode (it doesn't remember the position, just the search string), suggested by espie@.
-rw-r--r--format.c4
-rw-r--r--window-copy.c25
-rw-r--r--window.c1
3 files changed, 13 insertions, 17 deletions
diff --git a/format.c b/format.c
index d6bc9ceb..eb61a00a 100644
--- a/format.c
+++ b/format.c
@@ -1376,8 +1376,8 @@ format_defaults_pane(struct format_tree *ft, struct window_pane *wp)
format_add(ft, "pane_synchronized", "%d",
!!options_get_number(wp->window->options, "synchronize-panes"));
- format_add(ft, "pane_search_string", "%s",
- window_copy_search_string(wp));
+ if (wp->searchstr != NULL)
+ format_add(ft, "pane_search_string", "%s", wp->searchstr);
format_add(ft, "pane_tty", "%s", wp->tty);
format_add(ft, "pane_pid", "%ld", (long) wp->pid);
diff --git a/window-copy.c b/window-copy.c
index 8424bfa6..424ca28d 100644
--- a/window-copy.c
+++ b/window-copy.c
@@ -208,8 +208,13 @@ window_copy_init(struct window_pane *wp)
data->rectflag = 0;
data->scroll_exit = 0;
- data->searchtype = WINDOW_COPY_OFF;
- data->searchstr = NULL;
+ if (wp->searchstr != NULL) {
+ data->searchtype = WINDOW_COPY_SEARCHUP;
+ data->searchstr = xstrdup(wp->searchstr);
+ } else {
+ data->searchtype = WINDOW_COPY_OFF;
+ data->searchstr = NULL;
+ }
data->searchmark = NULL;
data->searchx = data->searchy = data->searcho = -1;
@@ -1134,6 +1139,9 @@ window_copy_search(struct window_pane *wp, int direction, int moveflag)
u_int fx, fy, endline;
int wrapflag, cis, found;
+ free(wp->searchstr);
+ wp->searchstr = xstrdup(data->searchstr);
+
fx = data->cx;
fy = screen_hsize(data->backing) - data->oy + data->cy;
@@ -2482,16 +2490,3 @@ window_copy_drag_update(__unused struct client *c, struct mouse_event *m)
if (window_copy_update_selection(wp, 1))
window_copy_redraw_selection(wp, old_cy);
}
-
-const char *
-window_copy_search_string(struct window_pane *wp)
-{
- struct window_copy_mode_data *data;
-
- if (wp->mode != &window_copy_mode)
- return ("");
- data = wp->modedata;
- if (data->searchtype == WINDOW_COPY_OFF || data->searchstr == NULL)
- return ("");
- return (data->searchstr);
-}
diff --git a/window.c b/window.c
index 297192b7..392a889e 100644
--- a/window.c
+++ b/window.c
@@ -828,6 +828,7 @@ static void
window_pane_destroy(struct window_pane *wp)
{
window_pane_reset_mode(wp);
+ free(wp->searchstr);
if (wp->fd != -1) {
bufferevent_free(wp->event);