mirror of
				https://github.com/tmux/tmux.git
				synced 2025-11-03 08:16:08 +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:
		
							
								
								
									
										64
									
								
								tmux.h
									
									
									
									
									
								
							
							
						
						
									
										64
									
								
								tmux.h
									
									
									
									
									
								
							@@ -64,6 +64,11 @@ struct screen_write_citem;
 | 
			
		||||
struct screen_write_cline;
 | 
			
		||||
struct screen_write_ctx;
 | 
			
		||||
struct session;
 | 
			
		||||
 | 
			
		||||
#ifdef ENABLE_SIXEL
 | 
			
		||||
struct sixel_image;
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
struct tty_ctx;
 | 
			
		||||
struct tty_code;
 | 
			
		||||
struct tty_key;
 | 
			
		||||
@@ -839,6 +844,24 @@ struct style {
 | 
			
		||||
	enum style_default_type	default_type;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
#ifdef ENABLE_SIXEL
 | 
			
		||||
/* Image. */
 | 
			
		||||
struct image {
 | 
			
		||||
	struct screen		*s;
 | 
			
		||||
	struct sixel_image	*data;
 | 
			
		||||
	char			*fallback;
 | 
			
		||||
 | 
			
		||||
	u_int			 px;
 | 
			
		||||
	u_int			 py;
 | 
			
		||||
	u_int			 sx;
 | 
			
		||||
	u_int			 sy;
 | 
			
		||||
 | 
			
		||||
	TAILQ_ENTRY (image)	 all_entry;
 | 
			
		||||
	TAILQ_ENTRY (image)	 entry;
 | 
			
		||||
};
 | 
			
		||||
TAILQ_HEAD(images, image);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
/* Cursor style. */
 | 
			
		||||
enum screen_cursor_style {
 | 
			
		||||
	SCREEN_CURSOR_DEFAULT,
 | 
			
		||||
@@ -880,6 +903,10 @@ struct screen {
 | 
			
		||||
	bitstr_t			*tabs;
 | 
			
		||||
	struct screen_sel		*sel;
 | 
			
		||||
 | 
			
		||||
#ifdef ENABLE_SIXEL
 | 
			
		||||
	struct images			 images;
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
	struct screen_write_cline	*write_list;
 | 
			
		||||
 | 
			
		||||
	struct hyperlinks		*hyperlinks;
 | 
			
		||||
@@ -1382,6 +1409,7 @@ struct tty {
 | 
			
		||||
 | 
			
		||||
	u_int		 sx;
 | 
			
		||||
	u_int		 sy;
 | 
			
		||||
        /* Cell size in pixels. */
 | 
			
		||||
	u_int		 xpixel;
 | 
			
		||||
	u_int		 ypixel;
 | 
			
		||||
 | 
			
		||||
@@ -1390,6 +1418,8 @@ struct tty {
 | 
			
		||||
	enum screen_cursor_style cstyle;
 | 
			
		||||
	int		 ccolour;
 | 
			
		||||
 | 
			
		||||
        /* Properties of the area being drawn on. */
 | 
			
		||||
        /* When true, the drawing area is bigger than the terminal. */
 | 
			
		||||
	int		 oflag;
 | 
			
		||||
	u_int		 oox;
 | 
			
		||||
	u_int		 ooy;
 | 
			
		||||
@@ -2332,6 +2362,11 @@ void	tty_set_path(struct tty *, const char *);
 | 
			
		||||
void	tty_update_mode(struct tty *, int, struct screen *);
 | 
			
		||||
void	tty_draw_line(struct tty *, struct screen *, u_int, u_int, u_int,
 | 
			
		||||
	    u_int, u_int, const struct grid_cell *, struct colour_palette *);
 | 
			
		||||
 | 
			
		||||
#ifdef ENABLE_SIXEL
 | 
			
		||||
void	tty_draw_images(struct client *, struct window_pane *, struct screen *);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void	tty_sync_start(struct tty *);
 | 
			
		||||
void	tty_sync_end(struct tty *);
 | 
			
		||||
int	tty_open(struct tty *, char **);
 | 
			
		||||
@@ -2362,6 +2397,11 @@ void	tty_cmd_scrolldown(struct tty *, const struct tty_ctx *);
 | 
			
		||||
void	tty_cmd_reverseindex(struct tty *, const struct tty_ctx *);
 | 
			
		||||
void	tty_cmd_setselection(struct tty *, const struct tty_ctx *);
 | 
			
		||||
void	tty_cmd_rawstring(struct tty *, const struct tty_ctx *);
 | 
			
		||||
 | 
			
		||||
#ifdef ENABLE_SIXEL
 | 
			
		||||
void	tty_cmd_sixelimage(struct tty *, const struct tty_ctx *);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void	tty_cmd_syncstart(struct tty *, const struct tty_ctx *);
 | 
			
		||||
void	tty_default_colours(struct grid_cell *, struct window_pane *);
 | 
			
		||||
 | 
			
		||||
@@ -2946,6 +2986,10 @@ void	 screen_write_setselection(struct screen_write_ctx *, const char *,
 | 
			
		||||
	     u_char *, u_int);
 | 
			
		||||
void	 screen_write_rawstring(struct screen_write_ctx *, u_char *, u_int,
 | 
			
		||||
	     int);
 | 
			
		||||
#ifdef ENABLE_SIXEL
 | 
			
		||||
void	 screen_write_sixelimage(struct screen_write_ctx *,
 | 
			
		||||
	     struct sixel_image *, u_int);
 | 
			
		||||
#endif
 | 
			
		||||
void	 screen_write_alternateon(struct screen_write_ctx *,
 | 
			
		||||
	     struct grid_cell *, int);
 | 
			
		||||
void	 screen_write_alternateoff(struct screen_write_ctx *,
 | 
			
		||||
@@ -3365,6 +3409,26 @@ struct window_pane *spawn_pane(struct spawn_context *, char **);
 | 
			
		||||
/* regsub.c */
 | 
			
		||||
char		*regsub(const char *, const char *, const char *, int);
 | 
			
		||||
 | 
			
		||||
#ifdef ENABLE_SIXEL
 | 
			
		||||
/* image.c */
 | 
			
		||||
int		 image_free_all(struct screen *);
 | 
			
		||||
struct image	*image_store(struct screen *, struct sixel_image *);
 | 
			
		||||
int		 image_check_line(struct screen *, u_int, u_int);
 | 
			
		||||
int		 image_check_area(struct screen *, u_int, u_int, u_int, u_int);
 | 
			
		||||
int		 image_scroll_up(struct screen *, u_int);
 | 
			
		||||
 | 
			
		||||
/* image-sixel.c */
 | 
			
		||||
struct sixel_image *sixel_parse(const char *, size_t, u_int, u_int);
 | 
			
		||||
void		 sixel_free(struct sixel_image *);
 | 
			
		||||
void		 sixel_log(struct sixel_image *);
 | 
			
		||||
void		 sixel_size_in_cells(struct sixel_image *, u_int *, u_int *);
 | 
			
		||||
struct sixel_image *sixel_scale(struct sixel_image *, u_int, u_int, u_int,
 | 
			
		||||
		     u_int, u_int, u_int, int);
 | 
			
		||||
char		*sixel_print(struct sixel_image *, struct sixel_image *,
 | 
			
		||||
		     size_t *);
 | 
			
		||||
struct screen	*sixel_to_screen(struct sixel_image *);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
/* server-acl.c */
 | 
			
		||||
void			 server_acl_init(void);
 | 
			
		||||
struct server_acl_user	*server_acl_user_find(uid_t);
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user