mirror of
				https://github.com/tmux/tmux.git
				synced 2025-11-04 00:56:10 +00:00 
			
		
		
		
	Merge SIXEL branch.
Squashed commit of the following: commit 6ebc3feb4671d9b25b3db99d3c16b2323b8e3d02 Author: topcat001 <anindya49@hotmail.com> Date: Sun Aug 20 16:09:51 2023 -0700 Remove redundant {}. commit 6f013fce39602c259a5be2d690d548c73e51cccc Author: topcat001 <anindya49@hotmail.com> Date: Sun Aug 20 16:02:15 2023 -0700 Revert "Do not defer redraw if it is just the status line (will need to do more here I" This reverts commit0a15bbf3f1. commit e6322b4196d73c975ba2e73633e6de9c46779059 Author: topcat001 <anindya49@hotmail.com> Date: Sun Aug 20 15:46:59 2023 -0700 Fix placeholder label and clean up. commit 5896ac52a1f72056a75480b3e1ada328f239df9b Merge: ad982330e3a8b843Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Fri Aug 18 17:00:03 2023 +0100 Merge branch 'master' into sixel commit ad98233066b72547aee7fa0c87838847ee7f1ece Author: topcat001 <anindya49@hotmail.com> Date: Tue Aug 15 13:57:08 2023 -0700 Better text placeholder. commit 312d83252c27fc4d09d09d121bf7573336e3cdca Merge: 14b8b5243d93b0c5Author: topcat001 <anindya49@hotmail.com> Date: Tue Aug 15 13:39:22 2023 -0700 Merge remote-tracking branch 'origin/master' into sixel commit 14b8b524523a7d5a4e42f7dfa346905c604c91e2 Merge: 4baf7642fda39377Author: topcat001 <anindya49@hotmail.com> Date: Sat Jul 22 17:29:10 2023 -0700 Merge branch 'master' into sixel commit 4baf76422fadb216bf27b47645b52da3379e7dea Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Wed Jun 21 07:43:53 2023 +0100 Both files can go on one line. commit4c92acf6ffAuthor: topcat001 <anindya49@hotmail.com> Date: Sat Jun 17 17:53:01 2023 -0700 Merge topcat001/tmux/sixel. commit6794facc82Merge: 7b85f5adf41c536fAuthor: topcat001 <anindya49@hotmail.com> Date: Sat Jun 17 17:21:02 2023 -0700 Merge remote-tracking branch 'origin/master' into sixel commit 7b85f5adf9a5094db580ca98e4d2231d8d5b5a4f Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Jun 8 12:55:03 2023 +0100 Do not require passthrough for SIXEL. commit a6ee55e0925cac35d011c188db2da0421fc09be1 Merge: 6da391f4fe385b18Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Jun 8 12:19:55 2023 +0100 Merge branch 'master' into sixel commit 6da391f460414ed3dde23e5ab6ca3fe8e988ce51 Merge: 0d71e5850eb5d254Author: topcat001 <anindya49@hotmail.com> Date: Sat May 20 17:05:55 2023 -0700 Merge branch 'master' into sixel commit 0d71e5853ffe797f90b815ac3af25ac0ad92ab07 Merge:64368a1afbe6fe7fAuthor: topcat001 <anindya49@hotmail.com> Date: Sat Apr 29 17:32:07 2023 -0700 Merge branch 'master' into sixel commit64368a1a63Merge:c630a56a22eb0334Author: topcat001 <anindya49@hotmail.com> Date: Thu Mar 30 14:21:09 2023 -0700 Merge branch 'master' into sixel commitc630a56a62Merge:34c96c4caaa043a2Author: topcat001 <anindya49@hotmail.com> Date: Thu Nov 10 18:53:01 2022 -0800 Merge branch 'master' into sixel commit34c96c4c4aMerge:2a1e16a250f4e0faAuthor: topcat001 <anindya49@hotmail.com> Date: Sat Nov 5 18:05:36 2022 -0700 Merge branch 'master' into sixel commit2a1e16a24dMerge:a82f14c7d001a94dAuthor: topcat001 <anindya49@hotmail.com> Date: Thu Oct 27 16:01:35 2022 -0700 Merge branch 'master' into sixel commita82f14c7b2Merge:742c0634f7b30ed3Author: topcat001 <anindya49@hotmail.com> Date: Sun Aug 28 13:43:07 2022 -0700 Merge branch 'master' into sixel commit742c063473Merge:906c92a587b248f3Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Fri Apr 1 10:14:15 2022 +0100 Merge branch 'master' into sixel commit906c92a5f4Merge:6680a024138ffc7cAuthor: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Wed Dec 8 10:37:33 2021 +0000 Merge branch 'master' into sixel commit6680a024beAuthor: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Oct 7 13:59:08 2021 +0100 Fix build. commitebd2c58593Merge:90dc0519fed7b29cAuthor: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Oct 7 13:19:48 2021 +0100 Merge branch 'master' into sixel commit90dc05191cMerge:a282439f4694afbeAuthor: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Feb 20 20:37:32 2020 +0000 Merge branch 'master' into sixel commita282439fcbAuthor: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Jan 30 09:12:53 2020 +0000 Add missing declarations. commit3a741aacd1Merge:40ad0107339832b9Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Jan 30 09:11:01 2020 +0000 Merge branch 'sixel-passthrough' into sixel commit339832b92cAuthor: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Jan 30 09:04:51 2020 +0000 Bad merge. commit92ed9fc0b2Merge:5bb0754832be954bAuthor: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Jan 30 09:03:38 2020 +0000 Merge branch 'master' into sixel-passthrough commit40ad01073dMerge:dd3c72f161b075a2Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Sun Jan 12 20:03:41 2020 +0000 Merge branch 'master' into sixel commit5bb075487fMerge:7c033a7454efe337Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Wed Dec 18 20:24:42 2019 +0000 Merge branch 'master' into sixel-passthrough commitdd3c72f132Merge:1a0e5fe954efe337Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Wed Dec 18 20:24:26 2019 +0000 Merge branch 'master' into sixel commit1a0e5fe933Merge:cf071ffe15d7e564Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Tue Dec 10 16:34:11 2019 +0000 Merge branch 'master' into sixel commitcf071ffecdAuthor: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Mon Dec 9 15:41:56 2019 +0000 Remove images when reflow happens. commit2006b7a563Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Dec 5 09:27:15 2019 +0000 More invalidation of images. commitb642eac450Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Dec 5 09:11:24 2019 +0000 Redraw and scroll images and part of invalidating them. commit7566e37a46Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Dec 5 08:51:24 2019 +0000 Call sixel_scale with the right number of arguments. commit62c0280b23Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Dec 5 08:48:58 2019 +0000 Correctly remove when not visible. commit86c5098a88Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Dec 5 08:32:25 2019 +0000 Add helpers to scroll image up and a flag to copy the colours. commit49f2f0a8f1Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Dec 5 00:02:55 2019 +0000 Store images, currently at most 10. commit3aebcc6709Merge:146ee3f692ecd611Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Wed Dec 4 19:27:16 2019 +0000 Merge branch 'master' into sixel commit7c033a74e2Merge:0a15bbf392ecd611Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Wed Dec 4 12:41:09 2019 +0000 Merge branch 'master' into sixel-passthrough commit146ee3f6f8Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Sat Nov 30 09:47:53 2019 +0000 Don't write image as text yet. commit0a15bbf3f1Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Sat Nov 30 09:15:35 2019 +0000 Do not defer redraw if it is just the status line (will need to do more here I think). commita5b1e20941Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Nov 28 14:20:22 2019 +0000 Add a flag to disable blocking while sending a SIXEL image (turned off when the buffer hits 0 size). commit968382aa6aAuthor: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Nov 28 12:35:18 2019 +0000 Pass through SIXEL DCS sequences (treat similarly to the passthrough escape sequence) if it appears the terminal outside supports them. commitb1904c9b8dAuthor: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Sat Nov 30 09:17:18 2019 +0000 Store SIXELs as a box for the moment. commit5d8dbcdf3dAuthor: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Sat Nov 30 09:15:35 2019 +0000 Do not defer redraw if it is just the status line (will need to do more here I think). commit0c999a402eMerge:28961dd5866b053fAuthor: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Fri Nov 29 18:54:09 2019 +0000 Merge branch 'master' into sixel commit28961dd5a3Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Nov 28 14:24:57 2019 +0000 Add an image. commitd2e3f3c1ccAuthor: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Nov 28 14:20:22 2019 +0000 Add a flag to disable blocking while sending a SIXEL image (turned off when the buffer hits 0 size). commite01df67ca1Author: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Nov 28 13:21:40 2019 +0000 Crop and scale images as needed when drawing them. commite24acc0b5cAuthor: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Nov 28 12:38:02 2019 +0000 Simple SIXEL parse and modify API. commitb34111b3daAuthor: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Thu Nov 28 12:35:18 2019 +0000 Pass through SIXEL DCS sequences (treat similarly to the passthrough escape sequence) if it appears the terminal outside supports them.
This commit is contained in:
		
							
								
								
									
										122
									
								
								tty.c
									
									
									
									
									
								
							
							
						
						
									
										122
									
								
								tty.c
									
									
									
									
									
								
							@@ -72,6 +72,11 @@ static int	tty_check_overlay(struct tty *, u_int, u_int);
 | 
			
		||||
static void	tty_check_overlay_range(struct tty *, u_int, u_int, u_int,
 | 
			
		||||
		    struct overlay_ranges *);
 | 
			
		||||
 | 
			
		||||
#ifdef ENABLE_SIXEL
 | 
			
		||||
static void	tty_write_one(void (*)(struct tty *, const struct tty_ctx *),
 | 
			
		||||
		    struct client *, struct tty_ctx *);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#define tty_use_margin(tty) \
 | 
			
		||||
	(tty->term->flags & TERM_DECSLRM)
 | 
			
		||||
#define tty_full_width(tty, ctx) \
 | 
			
		||||
@@ -1582,6 +1587,58 @@ tty_draw_line(struct tty *tty, struct screen *s, u_int px, u_int py, u_int nx,
 | 
			
		||||
	tty_update_mode(tty, tty->mode, s);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#ifdef ENABLE_SIXEL
 | 
			
		||||
/* Update context for client. */
 | 
			
		||||
static int
 | 
			
		||||
tty_set_client_cb(struct tty_ctx *ttyctx, struct client *c)
 | 
			
		||||
{
 | 
			
		||||
	struct window_pane	*wp = ttyctx->arg;
 | 
			
		||||
 | 
			
		||||
	if (c->session->curw->window != wp->window)
 | 
			
		||||
		return (0);
 | 
			
		||||
	if (wp->layout_cell == NULL)
 | 
			
		||||
		return (0);
 | 
			
		||||
 | 
			
		||||
	/* Set the properties relevant to the current client. */
 | 
			
		||||
	ttyctx->bigger = tty_window_offset(&c->tty, &ttyctx->wox, &ttyctx->woy,
 | 
			
		||||
	    &ttyctx->wsx, &ttyctx->wsy);
 | 
			
		||||
 | 
			
		||||
	ttyctx->yoff = ttyctx->ryoff = wp->yoff;
 | 
			
		||||
	if (status_at_line(c) == 0)
 | 
			
		||||
		ttyctx->yoff += status_line_size(c);
 | 
			
		||||
 | 
			
		||||
	return (1);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
tty_draw_images(struct client *c, struct window_pane *wp, struct screen *s)
 | 
			
		||||
{
 | 
			
		||||
	struct image	*im;
 | 
			
		||||
	struct tty_ctx	 ttyctx;
 | 
			
		||||
 | 
			
		||||
	TAILQ_FOREACH(im, &s->images, entry) {
 | 
			
		||||
		memset(&ttyctx, 0, sizeof ttyctx);
 | 
			
		||||
 | 
			
		||||
		/* Set the client independent properties. */
 | 
			
		||||
		ttyctx.ocx = im->px;
 | 
			
		||||
		ttyctx.ocy = im->py;
 | 
			
		||||
 | 
			
		||||
		ttyctx.orlower = s->rlower;
 | 
			
		||||
		ttyctx.orupper = s->rupper;
 | 
			
		||||
 | 
			
		||||
		ttyctx.xoff = ttyctx.rxoff = wp->xoff;
 | 
			
		||||
		ttyctx.sx = wp->sx;
 | 
			
		||||
		ttyctx.sy = wp->sy;
 | 
			
		||||
 | 
			
		||||
		ttyctx.ptr = im;
 | 
			
		||||
		ttyctx.arg = wp;
 | 
			
		||||
		ttyctx.set_client_cb = tty_set_client_cb;
 | 
			
		||||
		ttyctx.allow_invisible_panes = 1;
 | 
			
		||||
		tty_write_one(tty_cmd_sixelimage, c, &ttyctx);
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
tty_sync_start(struct tty *tty)
 | 
			
		||||
{
 | 
			
		||||
@@ -1655,6 +1712,19 @@ tty_write(void (*cmdfn)(struct tty *, const struct tty_ctx *),
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#ifdef ENABLE_SIXEL
 | 
			
		||||
/* Only write to the incoming tty instead of every client. */
 | 
			
		||||
static void
 | 
			
		||||
tty_write_one(void (*cmdfn)(struct tty *, const struct tty_ctx *),
 | 
			
		||||
    struct client *c, struct tty_ctx *ctx)
 | 
			
		||||
{
 | 
			
		||||
	if (ctx->set_client_cb == NULL)
 | 
			
		||||
		return;
 | 
			
		||||
	if ((ctx->set_client_cb(ctx, c)) == 1)
 | 
			
		||||
		cmdfn(&c->tty, ctx);
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
tty_cmd_insertcharacter(struct tty *tty, const struct tty_ctx *ctx)
 | 
			
		||||
{
 | 
			
		||||
@@ -2156,6 +2226,58 @@ tty_cmd_rawstring(struct tty *tty, const struct tty_ctx *ctx)
 | 
			
		||||
	tty_invalidate(tty);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#ifdef ENABLE_SIXEL
 | 
			
		||||
void
 | 
			
		||||
tty_cmd_sixelimage(struct tty *tty, const struct tty_ctx *ctx)
 | 
			
		||||
{
 | 
			
		||||
	struct image		*im = ctx->ptr;
 | 
			
		||||
	struct sixel_image	*si = im->data;
 | 
			
		||||
	struct sixel_image	*new;
 | 
			
		||||
	char			*data;
 | 
			
		||||
	size_t			 size;
 | 
			
		||||
	u_int			 cx = ctx->ocx, cy = ctx->ocy, sx, sy;
 | 
			
		||||
	u_int			 i, j, x, y, rx, ry;
 | 
			
		||||
	int			 fallback = 0;
 | 
			
		||||
 | 
			
		||||
	if ((~tty->term->flags & TERM_SIXEL) &&
 | 
			
		||||
            !tty_term_has(tty->term, TTYC_SXL))
 | 
			
		||||
		fallback = 1;
 | 
			
		||||
	if (tty->xpixel == 0 || tty->ypixel == 0)
 | 
			
		||||
		fallback = 1;
 | 
			
		||||
 | 
			
		||||
	sixel_size_in_cells(si, &sx, &sy);
 | 
			
		||||
	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))
 | 
			
		||||
		return;
 | 
			
		||||
	log_debug("%s: clamping to %u,%u-%u,%u", __func__, i, j, rx, ry);
 | 
			
		||||
 | 
			
		||||
	if (fallback == 1) {
 | 
			
		||||
		data = xstrdup(im->fallback);
 | 
			
		||||
		size = strlen(data);
 | 
			
		||||
	} else {
 | 
			
		||||
		new = sixel_scale(si, tty->xpixel, tty->ypixel, i, j, rx, ry, 0);
 | 
			
		||||
		if (new == NULL)
 | 
			
		||||
			return;
 | 
			
		||||
 | 
			
		||||
		data = sixel_print(new, si, &size);
 | 
			
		||||
	}
 | 
			
		||||
	if (data != NULL) {
 | 
			
		||||
		log_debug("%s: %zu bytes: %s", __func__, size, data);
 | 
			
		||||
		tty_region_off(tty);
 | 
			
		||||
		tty_margin_off(tty);
 | 
			
		||||
		tty_cursor(tty, x, y);
 | 
			
		||||
 | 
			
		||||
		tty->flags |= TTY_NOBLOCK;
 | 
			
		||||
		tty_add(tty, data, size);
 | 
			
		||||
		tty_invalidate(tty);
 | 
			
		||||
		free(data);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	if (fallback == 0)
 | 
			
		||||
		sixel_free(new);
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
tty_cmd_syncstart(struct tty *tty, const struct tty_ctx *ctx)
 | 
			
		||||
{
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user