Store time lines are scrolled into history and display in copy mode.

This commit is contained in:
nicm 2022-06-21 09:30:01 +00:00
parent a888ce9963
commit 9c89f7c2af
5 changed files with 37 additions and 18 deletions

View File

@ -3387,12 +3387,12 @@ format_quote_style(const char *s)
} }
/* Make a prettier time. */ /* Make a prettier time. */
static char * char *
format_pretty_time(time_t t) format_pretty_time(time_t t, int seconds)
{ {
struct tm now_tm, tm; struct tm now_tm, tm;
time_t now, age; time_t now, age;
char s[6]; char s[9];
time(&now); time(&now);
if (now < t) if (now < t)
@ -3404,6 +3404,9 @@ format_pretty_time(time_t t)
/* Last 24 hours. */ /* Last 24 hours. */
if (age < 24 * 3600) { if (age < 24 * 3600) {
if (seconds)
strftime(s, sizeof s, "%H:%M:%S", &tm);
else
strftime(s, sizeof s, "%H:%M", &tm); strftime(s, sizeof s, "%H:%M", &tm);
return (xstrdup(s)); return (xstrdup(s));
} }
@ -3509,7 +3512,7 @@ found:
if (t == 0) if (t == 0)
return (NULL); return (NULL);
if (modifiers & FORMAT_PRETTY) if (modifiers & FORMAT_PRETTY)
found = format_pretty_time(t); found = format_pretty_time(t, 0);
else { else {
if (time_format != NULL) { if (time_format != NULL) {
localtime_r(&t, &tm); localtime_r(&t, &tm);

2
grid.c
View File

@ -399,6 +399,7 @@ grid_scroll_history(struct grid *gd, u_int bg)
gd->hscrolled++; gd->hscrolled++;
grid_compact_line(&gd->linedata[gd->hsize]); grid_compact_line(&gd->linedata[gd->hsize]);
gd->linedata[gd->hsize].time = current_time;
gd->hsize++; gd->hsize++;
} }
@ -438,6 +439,7 @@ grid_scroll_history_region(struct grid *gd, u_int upper, u_int lower, u_int bg)
/* Move the line into the history. */ /* Move the line into the history. */
memcpy(gl_history, gl_upper, sizeof *gl_history); memcpy(gl_history, gl_upper, sizeof *gl_history);
gl_history->time = current_time;
/* Then move the region up and clear the bottom line. */ /* Then move the region up and clear the bottom line. */
memmove(gl_upper, gl_upper + 1, (lower - upper) * sizeof *gl_upper); memmove(gl_upper, gl_upper + 1, (lower - upper) * sizeof *gl_upper);

View File

@ -55,6 +55,8 @@ struct cmd_find_state marked_pane;
static u_int message_next; static u_int message_next;
struct message_list message_log; struct message_list message_log;
time_t current_time;
static int server_loop(void); static int server_loop(void);
static void server_send_exit(void); static void server_send_exit(void);
static void server_accept(int, short, void *); static void server_accept(int, short, void *);
@ -257,6 +259,8 @@ server_loop(void)
struct client *c; struct client *c;
u_int items; u_int items;
current_time = time (NULL);
do { do {
items = cmdq_next(NULL); items = cmdq_next(NULL);
TAILQ_FOREACH(c, &clients, entry) { TAILQ_FOREACH(c, &clients, entry) {

3
tmux.h
View File

@ -725,6 +725,7 @@ struct grid_line {
u_int extdsize; u_int extdsize;
int flags; int flags;
time_t time;
}; };
/* Entire grid of cells. */ /* Entire grid of cells. */
@ -2095,6 +2096,7 @@ void format_add_cb(struct format_tree *, const char *, format_cb);
void format_log_debug(struct format_tree *, const char *); void format_log_debug(struct format_tree *, const char *);
void format_each(struct format_tree *, void (*)(const char *, void format_each(struct format_tree *, void (*)(const char *,
const char *, void *), void *); const char *, void *), void *);
char *format_pretty_time(time_t, int);
char *format_expand_time(struct format_tree *, const char *); char *format_expand_time(struct format_tree *, const char *);
char *format_expand(struct format_tree *, const char *); char *format_expand(struct format_tree *, const char *);
char *format_single(struct cmdq_item *, const char *, char *format_single(struct cmdq_item *, const char *,
@ -2587,6 +2589,7 @@ extern struct tmuxproc *server_proc;
extern struct clients clients; extern struct clients clients;
extern struct cmd_find_state marked_pane; extern struct cmd_find_state marked_pane;
extern struct message_list message_log; extern struct message_list message_log;
extern time_t current_time;
void server_set_marked(struct session *, struct winlink *, void server_set_marked(struct session *, struct winlink *,
struct window_pane *); struct window_pane *);
void server_clear_marked(void); void server_clear_marked(void);

View File

@ -4092,8 +4092,9 @@ window_copy_write_line(struct window_mode_entry *wme,
struct window_copy_mode_data *data = wme->data; struct window_copy_mode_data *data = wme->data;
struct screen *s = &data->screen; struct screen *s = &data->screen;
struct options *oo = wp->window->options; struct options *oo = wp->window->options;
struct grid_line *gl;
struct grid_cell gc, mgc, cgc, mkgc; struct grid_cell gc, mgc, cgc, mkgc;
char hdr[512]; char hdr[512], tmp[256], *t;
size_t size = 0; size_t size = 0;
u_int hsize = screen_hsize(data->backing); u_int hsize = screen_hsize(data->backing);
@ -4107,23 +4108,29 @@ window_copy_write_line(struct window_mode_entry *wme,
mkgc.flags |= GRID_FLAG_NOPALETTE; mkgc.flags |= GRID_FLAG_NOPALETTE;
if (py == 0 && s->rupper < s->rlower && !data->hide_position) { if (py == 0 && s->rupper < s->rlower && !data->hide_position) {
gl = grid_get_line(data->backing->grid, hsize - data->oy);
if (gl->time == 0)
xsnprintf(tmp, sizeof tmp, "[%u/%u]", data->oy, hsize);
else {
t = format_pretty_time(gl->time, 1);
xsnprintf(tmp, sizeof tmp, "%s [%u/%u]", t, data->oy,
hsize);
free(t);
}
if (data->searchmark == NULL) { if (data->searchmark == NULL) {
if (data->timeout) { if (data->timeout) {
size = xsnprintf(hdr, sizeof hdr, size = xsnprintf(hdr, sizeof hdr,
"(timed out) [%u/%u]", data->oy, hsize); "(timed out) %s", tmp);
} else
size = xsnprintf(hdr, sizeof hdr, "%s", tmp);
} else { } else {
if (data->searchcount == -1)
size = xsnprintf(hdr, sizeof hdr, "%s", tmp);
else {
size = xsnprintf(hdr, sizeof hdr, size = xsnprintf(hdr, sizeof hdr,
"[%u/%u]", data->oy, hsize); "(%d%s results) %s", data->searchcount,
} data->searchmore ? "+" : "", tmp);
} else {
if (data->searchcount == -1) {
size = xsnprintf(hdr, sizeof hdr,
"[%u/%u]", data->oy, hsize);
} else {
size = xsnprintf(hdr, sizeof hdr,
"(%d%s results) [%u/%u]", data->searchcount,
data->searchmore ? "+" : "", data->oy,
hsize);
} }
} }
if (size > screen_size_x(s)) if (size > screen_size_x(s))