mirror of
https://github.com/tmux/tmux.git
synced 2025-04-10 11:08:49 +00:00
Add a dedicated function to convert a line into a string and use it to simplify the search window function.
This commit is contained in:
parent
f4b8f00255
commit
096cbf2ea5
12
grid-view.c
12
grid-view.c
@ -209,3 +209,15 @@ grid_view_delete_cells(struct grid *gd, u_int px, u_int py, u_int nx)
|
|||||||
|
|
||||||
grid_move_cells(gd, px, px + nx, py, (sx - 1) - (px + nx));
|
grid_move_cells(gd, px, px + nx, py, (sx - 1) - (px + nx));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Convert cells into a string. */
|
||||||
|
char *
|
||||||
|
grid_view_string_cells(struct grid *gd, u_int px, u_int py, u_int nx)
|
||||||
|
{
|
||||||
|
GRID_DEBUG(gd, "px=%u, py=%u, nx=%u", px, py, nx);
|
||||||
|
|
||||||
|
px = grid_view_x(gd, px);
|
||||||
|
py = grid_view_y(gd, py);
|
||||||
|
|
||||||
|
return (grid_string_cells(gd, px, py, nx));
|
||||||
|
}
|
||||||
|
46
grid.c
46
grid.c
@ -493,3 +493,49 @@ grid_move_cells(struct grid *gd, u_int dx, u_int px, u_int py, u_int nx)
|
|||||||
grid_put_cell(gd, xx, py, &grid_default_cell);
|
grid_put_cell(gd, xx, py, &grid_default_cell);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Convert cells into a string. */
|
||||||
|
char *
|
||||||
|
grid_string_cells(struct grid *gd, u_int px, u_int py, u_int nx)
|
||||||
|
{
|
||||||
|
const struct grid_cell *gc;
|
||||||
|
const struct grid_utf8 *gu;
|
||||||
|
char *buf;
|
||||||
|
size_t len, off;
|
||||||
|
u_int xx;
|
||||||
|
|
||||||
|
GRID_DEBUG(gd, "px=%u, py=%u, nx=%u", px, py, nx);
|
||||||
|
|
||||||
|
len = 128;
|
||||||
|
buf = xmalloc(len);
|
||||||
|
off = 0;
|
||||||
|
|
||||||
|
for (xx = px; xx < px + nx; xx++) {
|
||||||
|
gc = grid_peek_cell(gd, xx, py);
|
||||||
|
if (gc->flags & GRID_FLAG_PADDING)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (gc->flags & GRID_FLAG_UTF8) {
|
||||||
|
while (len < off + UTF8_SIZE + 1) {
|
||||||
|
buf = xrealloc(buf, 2, len);
|
||||||
|
len *= 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
gu = grid_peek_utf8(gd, xx, py);
|
||||||
|
memcpy(buf + off, gu->data, UTF8_SIZE);
|
||||||
|
off += UTF8_SIZE;
|
||||||
|
while (off > 0 && ((u_char) buf[off]) == 0xff)
|
||||||
|
off--;
|
||||||
|
} else {
|
||||||
|
while (len < off + 2) {
|
||||||
|
buf = xrealloc(buf, 2, len);
|
||||||
|
len *= 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
buf[off++] = gc->data;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
buf[off] = '\0';
|
||||||
|
return (buf);
|
||||||
|
}
|
||||||
|
2
tmux.h
2
tmux.h
@ -1327,6 +1327,7 @@ void grid_clear_lines(struct grid *, u_int, u_int);
|
|||||||
void grid_move_lines(struct grid *, u_int, u_int, u_int);
|
void grid_move_lines(struct grid *, u_int, u_int, u_int);
|
||||||
void grid_clear_cells(struct grid *, u_int, u_int, u_int);
|
void grid_clear_cells(struct grid *, u_int, u_int, u_int);
|
||||||
void grid_move_cells(struct grid *, u_int, u_int, u_int, u_int);
|
void grid_move_cells(struct grid *, u_int, u_int, u_int, u_int);
|
||||||
|
char *grid_string_cells(struct grid *, u_int, u_int, u_int);
|
||||||
|
|
||||||
/* grid-view.c */
|
/* grid-view.c */
|
||||||
const struct grid_cell *grid_view_peek_cell(struct grid *, u_int, u_int);
|
const struct grid_cell *grid_view_peek_cell(struct grid *, u_int, u_int);
|
||||||
@ -1348,6 +1349,7 @@ void grid_view_delete_lines_region(
|
|||||||
struct grid *, u_int, u_int, u_int, u_int);
|
struct grid *, u_int, u_int, u_int, u_int);
|
||||||
void grid_view_insert_cells(struct grid *, u_int, u_int, u_int);
|
void grid_view_insert_cells(struct grid *, u_int, u_int, u_int);
|
||||||
void grid_view_delete_cells(struct grid *, u_int, u_int, u_int);
|
void grid_view_delete_cells(struct grid *, u_int, u_int, u_int);
|
||||||
|
char *grid_view_string_cells(struct grid *, u_int, u_int, u_int);
|
||||||
|
|
||||||
/* screen-write.c */
|
/* screen-write.c */
|
||||||
void screen_write_start(
|
void screen_write_start(
|
||||||
|
51
window.c
51
window.c
@ -590,42 +590,21 @@ window_pane_mouse(
|
|||||||
char *
|
char *
|
||||||
window_pane_search(struct window_pane *wp, const char *searchstr)
|
window_pane_search(struct window_pane *wp, const char *searchstr)
|
||||||
{
|
{
|
||||||
const struct grid_cell *gc;
|
struct screen *s = &wp->base;
|
||||||
const struct grid_utf8 *gu;
|
char *line, *ptr;
|
||||||
char *buf, *s;
|
u_int i;
|
||||||
size_t off;
|
|
||||||
u_int i, j, k;
|
|
||||||
|
|
||||||
buf = xmalloc(1);
|
ptr = NULL;
|
||||||
|
for (i = 0; i < screen_size_y(s); i++) {
|
||||||
for (j = 0; j < screen_size_y(&wp->base); j++) {
|
line = grid_view_string_cells(s->grid, 0, i, screen_size_x(s));
|
||||||
off = 0;
|
log_debug("XXX %s", line);
|
||||||
for (i = 0; i < screen_size_x(&wp->base); i++) {
|
if ((ptr = strstr(line, searchstr)) != NULL)
|
||||||
gc = grid_view_peek_cell(wp->base.grid, i, j);
|
break;
|
||||||
if (gc->flags & GRID_FLAG_UTF8) {
|
xfree(line);
|
||||||
gu = grid_view_peek_utf8(wp->base.grid, i, j);
|
|
||||||
buf = xrealloc(buf, 1, off + 8);
|
|
||||||
for (k = 0; k < UTF8_SIZE; k++) {
|
|
||||||
if (gu->data[k] == 0xff)
|
|
||||||
break;
|
|
||||||
buf[off++] = gu->data[k];
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
buf = xrealloc(buf, 1, off + 1);
|
|
||||||
buf[off++] = gc->data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
while (off > 0 && buf[off - 1] == ' ')
|
|
||||||
off--;
|
|
||||||
buf[off] = '\0';
|
|
||||||
|
|
||||||
if ((s = strstr(buf, searchstr)) != NULL) {
|
|
||||||
s = section_string(buf, off, s - buf, 40);
|
|
||||||
xfree(buf);
|
|
||||||
return (s);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
if (ptr != NULL) {
|
||||||
xfree(buf);
|
ptr = section_string(line, strlen(ptr), ptr - line, 40);
|
||||||
return (NULL);
|
xfree(line);
|
||||||
|
}
|
||||||
|
return (ptr);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user