mirror of
				https://github.com/tmux/tmux.git
				synced 2025-11-04 09:26:05 +00:00 
			
		
		
		
	Sync OpenBSD patchset 485:
Add an activity time for clients, like for sessions, and change session and client lookup to pick the most recently used rather than the most recently created - this is much more useful when used interactively and (because the activity time is set at creation) should have no effect on source-file. Based on a problem reported by Jan Johansson.
This commit is contained in:
		
							
								
								
									
										57
									
								
								cmd.c
									
									
									
									
									
								
							
							
						
						
									
										57
									
								
								cmd.c
									
									
									
									
									
								
							@@ -1,4 +1,4 @@
 | 
			
		||||
/* $Id: cmd.c,v 1.129 2009-11-04 22:44:01 tcunha Exp $ */
 | 
			
		||||
/* $Id: cmd.c,v 1.130 2009-11-04 22:46:25 tcunha Exp $ */
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
			
		||||
@@ -109,8 +109,8 @@ const struct cmd_entry *cmd_table[] = {
 | 
			
		||||
	NULL
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
struct session	*cmd_newest_session(struct sessions *);
 | 
			
		||||
struct client	*cmd_newest_client(struct clients *);
 | 
			
		||||
struct session	*cmd_choose_session(struct sessions *);
 | 
			
		||||
struct client	*cmd_choose_client(struct clients *);
 | 
			
		||||
struct client	*cmd_lookup_client(const char *);
 | 
			
		||||
struct session	*cmd_lookup_session(const char *, int *);
 | 
			
		||||
struct winlink	*cmd_lookup_window(struct session *, const char *, int *);
 | 
			
		||||
@@ -284,9 +284,10 @@ cmd_print(struct cmd *cmd, char *buf, size_t len)
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Figure out the current session. Use: 1) the current session, if the command
 | 
			
		||||
 * context has one; 2) the session containing the pty of the calling client, if
 | 
			
		||||
 * any 3) the session specified in the TMUX variable from the environment (as
 | 
			
		||||
 * passed from the client); 3) the newest session.
 | 
			
		||||
 * context has one; 2) the most recently used session containing the pty of the
 | 
			
		||||
 * calling client, if any; 3) the session specified in the TMUX variable from
 | 
			
		||||
 * the environment (as passed from the client); 4) the most recently used
 | 
			
		||||
 * session from all sessions.
 | 
			
		||||
 */
 | 
			
		||||
struct session *
 | 
			
		||||
cmd_current_session(struct cmd_ctx *ctx)
 | 
			
		||||
@@ -328,7 +329,7 @@ cmd_current_session(struct cmd_ctx *ctx)
 | 
			
		||||
				ARRAY_ADD(&ss, s);
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		s = cmd_newest_session(&ss);
 | 
			
		||||
		s = cmd_choose_session(&ss);
 | 
			
		||||
		ARRAY_FREE(&ss);
 | 
			
		||||
		if (s != NULL)
 | 
			
		||||
			return (s);
 | 
			
		||||
@@ -345,35 +346,35 @@ cmd_current_session(struct cmd_ctx *ctx)
 | 
			
		||||
		return (s);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return (cmd_newest_session(&sessions));
 | 
			
		||||
	return (cmd_choose_session(&sessions));
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* Find the newest session. */
 | 
			
		||||
/* Find the most recently used session from a list. */
 | 
			
		||||
struct session *
 | 
			
		||||
cmd_newest_session(struct sessions *ss)
 | 
			
		||||
cmd_choose_session(struct sessions *ss)
 | 
			
		||||
{
 | 
			
		||||
	struct session	*s, *snewest;
 | 
			
		||||
	struct session	*s, *sbest;
 | 
			
		||||
	struct timeval	*tv = NULL;
 | 
			
		||||
	u_int		 i;
 | 
			
		||||
 | 
			
		||||
	snewest = NULL;
 | 
			
		||||
	sbest = NULL;
 | 
			
		||||
	for (i = 0; i < ARRAY_LENGTH(ss); i++) {
 | 
			
		||||
		if ((s = ARRAY_ITEM(ss, i)) == NULL)
 | 
			
		||||
			continue;
 | 
			
		||||
 | 
			
		||||
		if (tv == NULL || timercmp(&s->creation_time, tv, >)) {
 | 
			
		||||
			snewest = s;
 | 
			
		||||
			tv = &s->creation_time;
 | 
			
		||||
		if (tv == NULL || timercmp(&s->activity_time, tv, >)) {
 | 
			
		||||
			sbest = s;
 | 
			
		||||
			tv = &s->activity_time;
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return (snewest);
 | 
			
		||||
	return (sbest);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Find the current client. First try the current client if set, then pick the
 | 
			
		||||
 * newest of the clients attached to the current session if any, then the
 | 
			
		||||
 * newest client.
 | 
			
		||||
 * most recently used of the clients attached to the current session if any,
 | 
			
		||||
 * then of all clients.
 | 
			
		||||
 */
 | 
			
		||||
struct client *
 | 
			
		||||
cmd_current_client(struct cmd_ctx *ctx)
 | 
			
		||||
@@ -400,37 +401,37 @@ cmd_current_client(struct cmd_ctx *ctx)
 | 
			
		||||
				ARRAY_ADD(&cc, c);
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		c = cmd_newest_client(&cc);
 | 
			
		||||
		c = cmd_choose_client(&cc);
 | 
			
		||||
		ARRAY_FREE(&cc);
 | 
			
		||||
		if (c != NULL)
 | 
			
		||||
			return (c);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return (cmd_newest_client(&clients));
 | 
			
		||||
	return (cmd_choose_client(&clients));
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* Find the newest client. */
 | 
			
		||||
/* Choose the most recently used client from a list. */
 | 
			
		||||
struct client *
 | 
			
		||||
cmd_newest_client(struct clients *cc)
 | 
			
		||||
cmd_choose_client(struct clients *cc)
 | 
			
		||||
{
 | 
			
		||||
	struct client	*c, *cnewest;
 | 
			
		||||
	struct client	*c, *cbest;
 | 
			
		||||
	struct timeval	*tv = NULL;
 | 
			
		||||
	u_int		 i;
 | 
			
		||||
 | 
			
		||||
	cnewest = NULL;
 | 
			
		||||
	cbest = NULL;
 | 
			
		||||
	for (i = 0; i < ARRAY_LENGTH(cc); i++) {
 | 
			
		||||
		if ((c = ARRAY_ITEM(cc, i)) == NULL)
 | 
			
		||||
			continue;
 | 
			
		||||
		if (c->session == NULL)
 | 
			
		||||
			continue;
 | 
			
		||||
 | 
			
		||||
		if (tv == NULL || timercmp(&c->creation_time, tv, >)) {
 | 
			
		||||
			cnewest = c;
 | 
			
		||||
			tv = &c->creation_time;
 | 
			
		||||
		if (tv == NULL || timercmp(&c->activity_time, tv, >)) {
 | 
			
		||||
			cbest = c;
 | 
			
		||||
			tv = &c->activity_time;
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return (cnewest);
 | 
			
		||||
	return (cbest);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* Find the target client or report an error and return NULL. */
 | 
			
		||||
 
 | 
			
		||||
@@ -1,4 +1,4 @@
 | 
			
		||||
/* $Id: server-client.c,v 1.11 2009-11-04 22:42:31 tcunha Exp $ */
 | 
			
		||||
/* $Id: server-client.c,v 1.12 2009-11-04 22:46:25 tcunha Exp $ */
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Copyright (c) 2009 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
			
		||||
@@ -62,6 +62,7 @@ server_client_create(int fd)
 | 
			
		||||
	
 | 
			
		||||
	if (gettimeofday(&c->creation_time, NULL) != 0)
 | 
			
		||||
		fatal("gettimeofday failed");
 | 
			
		||||
	memcpy(&c->activity_time, &c->creation_time, sizeof c->activity_time);
 | 
			
		||||
 | 
			
		||||
	ARRAY_INIT(&c->prompt_hdata);
 | 
			
		||||
 | 
			
		||||
@@ -286,6 +287,7 @@ server_client_handle_data(struct client *c)
 | 
			
		||||
		oo = &c->session->options;
 | 
			
		||||
 | 
			
		||||
		/* Update activity timer. */
 | 
			
		||||
		memcpy(&c->activity_time, &tv_now, sizeof c->activity_time);
 | 
			
		||||
		memcpy(&c->session->activity_time,
 | 
			
		||||
		    &tv_now, sizeof c->session->activity_time);
 | 
			
		||||
 | 
			
		||||
@@ -582,9 +584,13 @@ server_client_msg_dispatch(struct client *c)
 | 
			
		||||
				break;
 | 
			
		||||
			c->flags &= ~CLIENT_SUSPENDED;
 | 
			
		||||
 | 
			
		||||
			if (c->session != NULL &&
 | 
			
		||||
			    gettimeofday(&c->session->activity_time, NULL) != 0)
 | 
			
		||||
				fatal("gettimeofday failed");
 | 
			
		||||
			if (gettimeofday(&c->activity_time, NULL) != 0)
 | 
			
		||||
				fatal("gettimeofday");
 | 
			
		||||
			if (c->session != NULL) {
 | 
			
		||||
				memcpy(&c->session->activity_time,
 | 
			
		||||
				    &c->activity_time,
 | 
			
		||||
				    sizeof c->session->activity_time);
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
			tty_start_tty(&c->tty);
 | 
			
		||||
			server_redraw_client(c);
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										4
									
								
								tmux.1
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								tmux.1
									
									
									
									
									
								
							@@ -1,4 +1,4 @@
 | 
			
		||||
.\" $Id: tmux.1,v 1.198 2009-11-04 22:38:16 tcunha Exp $
 | 
			
		||||
.\" $Id: tmux.1,v 1.199 2009-11-04 22:46:25 tcunha Exp $
 | 
			
		||||
.\"
 | 
			
		||||
.\" Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
			
		||||
.\"
 | 
			
		||||
@@ -282,7 +282,7 @@ pattern.
 | 
			
		||||
If a single match is found, it is used as the target session; multiple matches
 | 
			
		||||
produce an error.
 | 
			
		||||
If a session is omitted, the current session is used if available; if no
 | 
			
		||||
current session is available, the most recently created is chosen.
 | 
			
		||||
current session is available, the most recently used is chosen.
 | 
			
		||||
.Pp
 | 
			
		||||
.Ar target-window
 | 
			
		||||
specifies a window in the form
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										3
									
								
								tmux.h
									
									
									
									
									
								
							
							
						
						
									
										3
									
								
								tmux.h
									
									
									
									
									
								
							@@ -1,4 +1,4 @@
 | 
			
		||||
/* $Id: tmux.h,v 1.495 2009-11-04 22:44:01 tcunha Exp $ */
 | 
			
		||||
/* $Id: tmux.h,v 1.496 2009-11-04 22:46:25 tcunha Exp $ */
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
			
		||||
@@ -1062,6 +1062,7 @@ struct client {
 | 
			
		||||
	struct imsgbuf	 ibuf;
 | 
			
		||||
 | 
			
		||||
	struct timeval	 creation_time;
 | 
			
		||||
	struct timeval	 activity_time;
 | 
			
		||||
 | 
			
		||||
	struct environ	 environ;
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user