mirror of
https://github.com/tmux/tmux.git
synced 2025-01-07 08:18:48 +00:00
Add a flag to disable blocking while sending a SIXEL image (turned off when the
buffer hits 0 size).
This commit is contained in:
parent
e01df67ca1
commit
d2e3f3c1cc
1
tmux.h
1
tmux.h
@ -1204,6 +1204,7 @@ struct tty {
|
|||||||
#define TTY_OPENED 0x20
|
#define TTY_OPENED 0x20
|
||||||
#define TTY_FOCUS 0x40
|
#define TTY_FOCUS 0x40
|
||||||
#define TTY_BLOCK 0x80
|
#define TTY_BLOCK 0x80
|
||||||
|
#define TTY_NOBLOCK 0x100
|
||||||
int flags;
|
int flags;
|
||||||
|
|
||||||
struct tty_term *term;
|
struct tty_term *term;
|
||||||
|
8
tty.c
8
tty.c
@ -211,6 +211,11 @@ tty_block_maybe(struct tty *tty)
|
|||||||
size_t size = EVBUFFER_LENGTH(tty->out);
|
size_t size = EVBUFFER_LENGTH(tty->out);
|
||||||
struct timeval tv = { .tv_usec = TTY_BLOCK_INTERVAL };
|
struct timeval tv = { .tv_usec = TTY_BLOCK_INTERVAL };
|
||||||
|
|
||||||
|
if (size == 0)
|
||||||
|
tty->flags &= ~TTY_NOBLOCK;
|
||||||
|
else if (tty->flags & TTY_NOBLOCK)
|
||||||
|
return (0);
|
||||||
|
|
||||||
if (size < TTY_BLOCK_START(tty))
|
if (size < TTY_BLOCK_START(tty))
|
||||||
return (0);
|
return (0);
|
||||||
|
|
||||||
@ -1889,8 +1894,10 @@ tty_cmd_sixelimage(struct tty *tty, const struct tty_ctx *ctx)
|
|||||||
sx = wp->sx - cx;
|
sx = wp->sx - cx;
|
||||||
if (sy > wp->sy - cy)
|
if (sy > wp->sy - cy)
|
||||||
sy = wp->sy - cy;
|
sy = wp->sy - cy;
|
||||||
|
log_debug("%s: image is %ux%u", __func__, sx, sy);
|
||||||
if (!tty_clamp_area(tty, ctx, cx, cy, sx, sy, &i, &j, &x, &y, &rx, &ry))
|
if (!tty_clamp_area(tty, ctx, cx, cy, sx, sy, &i, &j, &x, &y, &rx, &ry))
|
||||||
return;
|
return;
|
||||||
|
log_debug("%s: clamping to section %u,%u-%u,%u", __func__, i, j, rx, ry);
|
||||||
|
|
||||||
new = sixel_scale(si, tty->xpixel, tty->ypixel, i, j, rx, ry);
|
new = sixel_scale(si, tty->xpixel, tty->ypixel, i, j, rx, ry);
|
||||||
if (new == NULL)
|
if (new == NULL)
|
||||||
@ -1901,6 +1908,7 @@ tty_cmd_sixelimage(struct tty *tty, const struct tty_ctx *ctx)
|
|||||||
log_debug("%s: %zu bytes: %s", __func__, size, data);
|
log_debug("%s: %zu bytes: %s", __func__, size, data);
|
||||||
tty_cursor(tty, x, y);
|
tty_cursor(tty, x, y);
|
||||||
|
|
||||||
|
tty->flags |= TTY_NOBLOCK;
|
||||||
tty_add(tty, data, size);
|
tty_add(tty, data, size);
|
||||||
tty_invalidate(tty);
|
tty_invalidate(tty);
|
||||||
free(data);
|
free(data);
|
||||||
|
Loading…
Reference in New Issue
Block a user