mirror of
				https://github.com/tmux/tmux.git
				synced 2025-10-26 12:27:15 +00:00 
			
		
		
		
	Add argument to refresh-client -l to forward clipboard to a pane. GitHub
issue 3068.
This commit is contained in:
		| @@ -34,7 +34,7 @@ const struct cmd_entry cmd_refresh_client_entry = { | ||||
| 	.name = "refresh-client", | ||||
| 	.alias = "refresh", | ||||
|  | ||||
| 	.args = { "A:B:cC:Df:F:lLRSt:U", 0, 1, NULL }, | ||||
| 	.args = { "A:B:cC:Df:F:l::LRSt:U", 0, 1, NULL }, | ||||
| 	.usage = "[-cDlLRSU] [-A pane:state] [-B name:what:format] " | ||||
| 		 "[-C XxY] [-f flags] " CMD_TARGET_CLIENT_USAGE " [adjustment]", | ||||
|  | ||||
| @@ -162,6 +162,37 @@ out: | ||||
| 	free(copy); | ||||
| } | ||||
|  | ||||
| static enum cmd_retval | ||||
| cmd_refresh_client_clipboard(struct cmd *self, struct cmdq_item *item) | ||||
| { | ||||
| 	struct args		*args = cmd_get_args(self); | ||||
| 	struct client		*tc = cmdq_get_target_client(item); | ||||
| 	const char		*p; | ||||
| 	u_int			 i; | ||||
| 	struct cmd_find_state	 fs; | ||||
|  | ||||
| 	p = args_get(args, 'l'); | ||||
| 	if (p == NULL) { | ||||
| 		if (tc->flags & CLIENT_CLIPBOARDBUFFER) | ||||
| 			return (CMD_RETURN_NORMAL); | ||||
| 		tc->flags |= CLIENT_CLIPBOARDBUFFER; | ||||
| 	} else { | ||||
| 		if (cmd_find_target(&fs, item, p, CMD_FIND_PANE, 0) != 0) | ||||
| 			return (CMD_RETURN_ERROR); | ||||
| 		for (i = 0; i < tc->clipboard_npanes; i++) { | ||||
| 			if (tc->clipboard_panes[i] == fs.wp->id) | ||||
| 				break; | ||||
| 		} | ||||
| 		if (i != tc->clipboard_npanes) | ||||
| 			return (CMD_RETURN_NORMAL); | ||||
| 		tc->clipboard_panes = xreallocarray (tc->clipboard_panes, | ||||
| 		    tc->clipboard_npanes + 1, sizeof *tc->clipboard_panes); | ||||
| 		tc->clipboard_panes[tc->clipboard_npanes++] = fs.wp->id; | ||||
| 	} | ||||
| 	tty_clipboard_query(&tc->tty); | ||||
| 	return (CMD_RETURN_NORMAL); | ||||
| } | ||||
|  | ||||
| static enum cmd_retval | ||||
| cmd_refresh_client_exec(struct cmd *self, struct cmdq_item *item) | ||||
| { | ||||
| @@ -224,10 +255,8 @@ cmd_refresh_client_exec(struct cmd *self, struct cmdq_item *item) | ||||
| 		return (CMD_RETURN_NORMAL); | ||||
| 	} | ||||
|  | ||||
| 	if (args_has(args, 'l')) { | ||||
| 		tty_send_osc52_query(&tc->tty); | ||||
| 		return (CMD_RETURN_NORMAL); | ||||
| 	} | ||||
| 	if (args_has(args, 'l')) | ||||
| 		return (cmd_refresh_client_clipboard(self, item)); | ||||
|  | ||||
| 	if (args_has(args, 'F')) /* -F is an alias for -f */ | ||||
| 		server_client_set_flags(tc, args_get(args, 'F')); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 nicm
					nicm