mirror of
				https://github.com/tmux/tmux.git
				synced 2025-11-03 17:24:18 +00:00 
			
		
		
		
	Rewrite the code for reading and writing files. Now, if the client is
not attached, the server process asks it to open the file, similar to how works for stdin, stdout, stderr. This makes special files like /dev/fd/X work (used by some shells). stdin, stdout and stderr and control mode are now just special cases of the same mechanism. This will also make it easier to use for other commands that read files such as source-file.
This commit is contained in:
		
							
								
								
									
										34
									
								
								cmd-queue.c
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								cmd-queue.c
									
									
									
									
									
								
							@@ -475,13 +475,11 @@ void
 | 
			
		||||
cmdq_guard(struct cmdq_item *item, const char *guard, int flags)
 | 
			
		||||
{
 | 
			
		||||
	struct client	*c = item->client;
 | 
			
		||||
	long		 t = item->time;
 | 
			
		||||
	u_int		 number = item->number;
 | 
			
		||||
 | 
			
		||||
	if (c == NULL || !(c->flags & CLIENT_CONTROL))
 | 
			
		||||
		return;
 | 
			
		||||
 | 
			
		||||
	evbuffer_add_printf(c->stdout_data, "%%%s %ld %u %d\n", guard,
 | 
			
		||||
	    (long)item->time, item->number, flags);
 | 
			
		||||
	server_client_push_stdout(c);
 | 
			
		||||
	if (c != NULL && (c->flags & CLIENT_CONTROL))
 | 
			
		||||
		file_print(c, "%%%s %ld %u %d\n", guard, t, number, flags);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* Show message from command. */
 | 
			
		||||
@@ -495,20 +493,20 @@ cmdq_print(struct cmdq_item *item, const char *fmt, ...)
 | 
			
		||||
	char				*tmp, *msg;
 | 
			
		||||
 | 
			
		||||
	va_start(ap, fmt);
 | 
			
		||||
	xvasprintf(&msg, fmt, ap);
 | 
			
		||||
	va_end(ap);
 | 
			
		||||
 | 
			
		||||
	log_debug("%s: %s", __func__, msg);
 | 
			
		||||
 | 
			
		||||
	if (c == NULL)
 | 
			
		||||
		/* nothing */;
 | 
			
		||||
	else if (c->session == NULL || (c->flags & CLIENT_CONTROL)) {
 | 
			
		||||
		if (~c->flags & CLIENT_UTF8) {
 | 
			
		||||
			xvasprintf(&tmp, fmt, ap);
 | 
			
		||||
			tmp = msg;
 | 
			
		||||
			msg = utf8_sanitize(tmp);
 | 
			
		||||
			free(tmp);
 | 
			
		||||
			evbuffer_add(c->stdout_data, msg, strlen(msg));
 | 
			
		||||
			free(msg);
 | 
			
		||||
		} else
 | 
			
		||||
			evbuffer_add_vprintf(c->stdout_data, fmt, ap);
 | 
			
		||||
		evbuffer_add(c->stdout_data, "\n", 1);
 | 
			
		||||
		server_client_push_stdout(c);
 | 
			
		||||
		}
 | 
			
		||||
		file_print(c, "%s\n", msg);
 | 
			
		||||
	} else {
 | 
			
		||||
		wp = c->session->curw->window->active;
 | 
			
		||||
		wme = TAILQ_FIRST(&wp->modes);
 | 
			
		||||
@@ -517,7 +515,7 @@ cmdq_print(struct cmdq_item *item, const char *fmt, ...)
 | 
			
		||||
		window_copy_vadd(wp, fmt, ap);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	va_end(ap);
 | 
			
		||||
	free(msg);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* Show error from command. */
 | 
			
		||||
@@ -528,11 +526,10 @@ cmdq_error(struct cmdq_item *item, const char *fmt, ...)
 | 
			
		||||
	struct cmd	*cmd = item->cmd;
 | 
			
		||||
	va_list		 ap;
 | 
			
		||||
	char		*msg;
 | 
			
		||||
	size_t		 msglen;
 | 
			
		||||
	char		*tmp;
 | 
			
		||||
 | 
			
		||||
	va_start(ap, fmt);
 | 
			
		||||
	msglen = xvasprintf(&msg, fmt, ap);
 | 
			
		||||
	xvasprintf(&msg, fmt, ap);
 | 
			
		||||
	va_end(ap);
 | 
			
		||||
 | 
			
		||||
	log_debug("%s: %s", __func__, msg);
 | 
			
		||||
@@ -544,11 +541,8 @@ cmdq_error(struct cmdq_item *item, const char *fmt, ...)
 | 
			
		||||
			tmp = msg;
 | 
			
		||||
			msg = utf8_sanitize(tmp);
 | 
			
		||||
			free(tmp);
 | 
			
		||||
			msglen = strlen(msg);
 | 
			
		||||
		}
 | 
			
		||||
		evbuffer_add(c->stderr_data, msg, msglen);
 | 
			
		||||
		evbuffer_add(c->stderr_data, "\n", 1);
 | 
			
		||||
		server_client_push_stderr(c);
 | 
			
		||||
		file_error(c, "%s\n", msg);
 | 
			
		||||
		c->retval = 1;
 | 
			
		||||
	} else {
 | 
			
		||||
		*msg = toupper((u_char) *msg);
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user