Coverage Report

Created: 2026-04-12 06:58

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/tmux/cmd-find-window.c
Line
Count
Source
1
/* $OpenBSD$ */
2
3
/*
4
 * Copyright (c) 2009 Nicholas Marriott <nicholas.marriott@gmail.com>
5
 *
6
 * Permission to use, copy, modify, and distribute this software for any
7
 * purpose with or without fee is hereby granted, provided that the above
8
 * copyright notice and this permission notice appear in all copies.
9
 *
10
 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11
 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12
 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13
 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14
 * WHATSOEVER RESULTING FROM LOSS OF MIND, USE, DATA OR PROFITS, WHETHER
15
 * IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
16
 * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17
 */
18
19
#include <sys/types.h>
20
21
#include <stdlib.h>
22
23
#include "tmux.h"
24
25
/*
26
 * Find window containing text.
27
 */
28
29
static enum cmd_retval  cmd_find_window_exec(struct cmd *, struct cmdq_item *);
30
31
const struct cmd_entry cmd_find_window_entry = {
32
  .name = "find-window",
33
  .alias = "findw",
34
35
  .args = { "CiNrt:TZ", 1, 1, NULL },
36
  .usage = "[-CiNrTZ] " CMD_TARGET_PANE_USAGE " match-string",
37
38
  .target = { 't', CMD_FIND_PANE, 0 },
39
40
  .flags = 0,
41
  .exec = cmd_find_window_exec
42
};
43
44
static enum cmd_retval
45
cmd_find_window_exec(struct cmd *self, struct cmdq_item *item)
46
0
{
47
0
  struct args   *args = cmd_get_args(self), *new_args;
48
0
  struct cmd_find_state *target = cmdq_get_target(item);
49
0
  struct window_pane  *wp = target->wp;
50
0
  const char    *s = args_string(args, 0), *suffix = "";
51
0
  const char    *star = "*";
52
0
  struct args_value *filter;
53
0
  int      C, N, T;
54
55
0
  C = args_has(args, 'C');
56
0
  N = args_has(args, 'N');
57
0
  T = args_has(args, 'T');
58
59
0
  if (args_has(args, 'r'))
60
0
    star = "";
61
0
  if (args_has(args, 'r') && args_has(args, 'i'))
62
0
    suffix = "/ri";
63
0
  else if (args_has(args, 'r'))
64
0
    suffix = "/r";
65
0
  else if (args_has(args, 'i'))
66
0
    suffix = "/i";
67
68
0
  if (!C && !N && !T)
69
0
    C = N = T = 1;
70
71
0
  filter = xcalloc(1, sizeof *filter);
72
0
  filter->type = ARGS_STRING;
73
74
0
  if (C && N && T) {
75
0
    xasprintf(&filter->string,
76
0
        "#{||:"
77
0
        "#{C%s:%s},#{||:#{m%s:%s%s%s,#{window_name}},"
78
0
        "#{m%s:%s%s%s,#{pane_title}}}}",
79
0
        suffix, s, suffix, star, s, star, suffix, star, s, star);
80
0
  } else if (C && N) {
81
0
    xasprintf(&filter->string,
82
0
        "#{||:#{C%s:%s},#{m%s:%s%s%s,#{window_name}}}",
83
0
        suffix, s, suffix, star, s, star);
84
0
  } else if (C && T) {
85
0
    xasprintf(&filter->string,
86
0
        "#{||:#{C%s:%s},#{m%s:%s%s%s,#{pane_title}}}",
87
0
        suffix, s, suffix, star, s, star);
88
0
  } else if (N && T) {
89
0
    xasprintf(&filter->string,
90
0
        "#{||:#{m%s:%s%s%s,#{window_name}},"
91
0
        "#{m%s:%s%s%s,#{pane_title}}}",
92
0
        suffix, star, s, star, suffix, star, s, star);
93
0
  } else if (C) {
94
0
    xasprintf(&filter->string,
95
0
        "#{C%s:%s}",
96
0
        suffix, s);
97
0
  } else if (N) {
98
0
    xasprintf(&filter->string,
99
0
        "#{m%s:%s%s%s,#{window_name}}",
100
0
        suffix, star, s, star);
101
0
  } else {
102
0
    xasprintf(&filter->string,
103
0
        "#{m%s:%s%s%s,#{pane_title}}",
104
0
        suffix, star, s, star);
105
0
  }
106
107
0
  new_args = args_create();
108
0
  if (args_has(args, 'Z'))
109
0
    args_set(new_args, 'Z', NULL, 0);
110
0
  args_set(new_args, 'f', filter, 0);
111
112
0
  window_pane_set_mode(wp, NULL, &window_tree_mode, target, new_args);
113
0
  args_free(new_args);
114
115
0
  return (CMD_RETURN_NORMAL);
116
0
}