mirror of
https://github.com/tmux/tmux.git
synced 2025-01-14 20:58:53 +00:00
Having three *clock* files is ridiculous, remove clock.c.
This commit is contained in:
parent
18cb135218
commit
175f215187
1
Makefile
1
Makefile
@ -5,7 +5,6 @@ SRCS= arguments.c \
|
|||||||
attributes.c \
|
attributes.c \
|
||||||
cfg.c \
|
cfg.c \
|
||||||
client.c \
|
client.c \
|
||||||
clock.c \
|
|
||||||
cmd-attach-session.c \
|
cmd-attach-session.c \
|
||||||
cmd-bind-key.c \
|
cmd-bind-key.c \
|
||||||
cmd-break-pane.c \
|
cmd-break-pane.c \
|
||||||
|
166
clock.c
166
clock.c
@ -1,166 +0,0 @@
|
|||||||
/* $OpenBSD$ */
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Copyright (c) 2009 Nicholas Marriott <nicm@users.sourceforge.net>
|
|
||||||
*
|
|
||||||
* Permission to use, copy, modify, and distribute this software for any
|
|
||||||
* purpose with or without fee is hereby granted, provided that the above
|
|
||||||
* copyright notice and this permission notice appear in all copies.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
||||||
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
||||||
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
||||||
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
||||||
* WHATSOEVER RESULTING FROM LOSS OF MIND, USE, DATA OR PROFITS, WHETHER
|
|
||||||
* IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
|
|
||||||
* OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <sys/types.h>
|
|
||||||
|
|
||||||
#include <string.h>
|
|
||||||
#include <time.h>
|
|
||||||
|
|
||||||
#include "tmux.h"
|
|
||||||
|
|
||||||
const char clock_table[14][5][5] = {
|
|
||||||
{ { 1,1,1,1,1 }, /* 0 */
|
|
||||||
{ 1,0,0,0,1 },
|
|
||||||
{ 1,0,0,0,1 },
|
|
||||||
{ 1,0,0,0,1 },
|
|
||||||
{ 1,1,1,1,1 } },
|
|
||||||
{ { 0,0,0,0,1 }, /* 1 */
|
|
||||||
{ 0,0,0,0,1 },
|
|
||||||
{ 0,0,0,0,1 },
|
|
||||||
{ 0,0,0,0,1 },
|
|
||||||
{ 0,0,0,0,1 } },
|
|
||||||
{ { 1,1,1,1,1 }, /* 2 */
|
|
||||||
{ 0,0,0,0,1 },
|
|
||||||
{ 1,1,1,1,1 },
|
|
||||||
{ 1,0,0,0,0 },
|
|
||||||
{ 1,1,1,1,1 } },
|
|
||||||
{ { 1,1,1,1,1 }, /* 3 */
|
|
||||||
{ 0,0,0,0,1 },
|
|
||||||
{ 1,1,1,1,1 },
|
|
||||||
{ 0,0,0,0,1 },
|
|
||||||
{ 1,1,1,1,1 } },
|
|
||||||
{ { 1,0,0,0,1 }, /* 4 */
|
|
||||||
{ 1,0,0,0,1 },
|
|
||||||
{ 1,1,1,1,1 },
|
|
||||||
{ 0,0,0,0,1 },
|
|
||||||
{ 0,0,0,0,1 } },
|
|
||||||
{ { 1,1,1,1,1 }, /* 5 */
|
|
||||||
{ 1,0,0,0,0 },
|
|
||||||
{ 1,1,1,1,1 },
|
|
||||||
{ 0,0,0,0,1 },
|
|
||||||
{ 1,1,1,1,1 } },
|
|
||||||
{ { 1,1,1,1,1 }, /* 6 */
|
|
||||||
{ 1,0,0,0,0 },
|
|
||||||
{ 1,1,1,1,1 },
|
|
||||||
{ 1,0,0,0,1 },
|
|
||||||
{ 1,1,1,1,1 } },
|
|
||||||
{ { 1,1,1,1,1 }, /* 7 */
|
|
||||||
{ 0,0,0,0,1 },
|
|
||||||
{ 0,0,0,0,1 },
|
|
||||||
{ 0,0,0,0,1 },
|
|
||||||
{ 0,0,0,0,1 } },
|
|
||||||
{ { 1,1,1,1,1 }, /* 8 */
|
|
||||||
{ 1,0,0,0,1 },
|
|
||||||
{ 1,1,1,1,1 },
|
|
||||||
{ 1,0,0,0,1 },
|
|
||||||
{ 1,1,1,1,1 } },
|
|
||||||
{ { 1,1,1,1,1 }, /* 9 */
|
|
||||||
{ 1,0,0,0,1 },
|
|
||||||
{ 1,1,1,1,1 },
|
|
||||||
{ 0,0,0,0,1 },
|
|
||||||
{ 1,1,1,1,1 } },
|
|
||||||
{ { 0,0,0,0,0 }, /* : */
|
|
||||||
{ 0,0,1,0,0 },
|
|
||||||
{ 0,0,0,0,0 },
|
|
||||||
{ 0,0,1,0,0 },
|
|
||||||
{ 0,0,0,0,0 } },
|
|
||||||
{ { 1,1,1,1,1 }, /* A */
|
|
||||||
{ 1,0,0,0,1 },
|
|
||||||
{ 1,1,1,1,1 },
|
|
||||||
{ 1,0,0,0,1 },
|
|
||||||
{ 1,0,0,0,1 } },
|
|
||||||
{ { 1,1,1,1,1 }, /* P */
|
|
||||||
{ 1,0,0,0,1 },
|
|
||||||
{ 1,1,1,1,1 },
|
|
||||||
{ 1,0,0,0,0 },
|
|
||||||
{ 1,0,0,0,0 } },
|
|
||||||
{ { 1,0,0,0,1 }, /* M */
|
|
||||||
{ 1,1,0,1,1 },
|
|
||||||
{ 1,0,1,0,1 },
|
|
||||||
{ 1,0,0,0,1 },
|
|
||||||
{ 1,0,0,0,1 } },
|
|
||||||
};
|
|
||||||
|
|
||||||
void
|
|
||||||
clock_draw(struct screen_write_ctx *ctx, int colour, int style)
|
|
||||||
{
|
|
||||||
struct screen *s = ctx->s;
|
|
||||||
struct grid_cell gc;
|
|
||||||
char tim[64], *ptr;
|
|
||||||
time_t t;
|
|
||||||
struct tm *tm;
|
|
||||||
u_int i, j, x, y, idx;
|
|
||||||
|
|
||||||
t = time(NULL);
|
|
||||||
tm = localtime(&t);
|
|
||||||
if (style == 0) {
|
|
||||||
strftime(tim, sizeof tim, "%l:%M ", localtime(&t));
|
|
||||||
if (tm->tm_hour >= 12)
|
|
||||||
strlcat(tim, "PM", sizeof tim);
|
|
||||||
else
|
|
||||||
strlcat(tim, "AM", sizeof tim);
|
|
||||||
} else
|
|
||||||
strftime(tim, sizeof tim, "%H:%M", tm);
|
|
||||||
|
|
||||||
|
|
||||||
screen_write_clearscreen(ctx);
|
|
||||||
|
|
||||||
if (screen_size_x(s) < 6 * strlen(tim) || screen_size_y(s) < 6) {
|
|
||||||
if (screen_size_x(s) >= strlen(tim) && screen_size_y(s) != 0) {
|
|
||||||
x = (screen_size_x(s) / 2) - (strlen(tim) / 2);
|
|
||||||
y = screen_size_y(s) / 2;
|
|
||||||
screen_write_cursormove(ctx, x, y);
|
|
||||||
|
|
||||||
memcpy(&gc, &grid_default_cell, sizeof gc);
|
|
||||||
colour_set_fg(&gc, colour);
|
|
||||||
screen_write_puts(ctx, &gc, "%s", tim);
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
x = (screen_size_x(s) / 2) - 3 * strlen(tim);
|
|
||||||
y = (screen_size_y(s) / 2) - 3;
|
|
||||||
|
|
||||||
memcpy(&gc, &grid_default_cell, sizeof gc);
|
|
||||||
colour_set_bg(&gc, colour);
|
|
||||||
for (ptr = tim; *ptr != '\0'; ptr++) {
|
|
||||||
if (*ptr >= '0' && *ptr <= '9')
|
|
||||||
idx = *ptr - '0';
|
|
||||||
else if (*ptr == ':')
|
|
||||||
idx = 10;
|
|
||||||
else if (*ptr == 'A')
|
|
||||||
idx = 11;
|
|
||||||
else if (*ptr == 'P')
|
|
||||||
idx = 12;
|
|
||||||
else if (*ptr == 'M')
|
|
||||||
idx = 13;
|
|
||||||
else {
|
|
||||||
x += 6;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (j = 0; j < 5; j++) {
|
|
||||||
for (i = 0; i < 5; i++) {
|
|
||||||
screen_write_cursormove(ctx, x + i, y + j);
|
|
||||||
if (clock_table[idx][j][i])
|
|
||||||
screen_write_putc(ctx, &gc, ' ');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
x += 6;
|
|
||||||
}
|
|
||||||
}
|
|
@ -381,7 +381,7 @@ screen_redraw_draw_number(struct client *c, struct window_pane *wp)
|
|||||||
for (j = 0; j < 5; j++) {
|
for (j = 0; j < 5; j++) {
|
||||||
for (i = px; i < px + 5; i++) {
|
for (i = px; i < px + 5; i++) {
|
||||||
tty_cursor(tty, xoff + i, yoff + py + j);
|
tty_cursor(tty, xoff + i, yoff + py + j);
|
||||||
if (clock_table[idx][j][i - px])
|
if (window_clock_table[idx][j][i - px])
|
||||||
tty_putc(tty, ' ');
|
tty_putc(tty, ' ');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
5
tmux.h
5
tmux.h
@ -1713,10 +1713,6 @@ char *paste_print(struct paste_buffer *, size_t);
|
|||||||
void paste_send_pane(struct paste_buffer *, struct window_pane *,
|
void paste_send_pane(struct paste_buffer *, struct window_pane *,
|
||||||
const char *, int);
|
const char *, int);
|
||||||
|
|
||||||
/* clock.c */
|
|
||||||
extern const char clock_table[14][5][5];
|
|
||||||
void clock_draw(struct screen_write_ctx *, int, int);
|
|
||||||
|
|
||||||
/* arguments.c */
|
/* arguments.c */
|
||||||
int args_cmp(struct args_entry *, struct args_entry *);
|
int args_cmp(struct args_entry *, struct args_entry *);
|
||||||
RB_PROTOTYPE(args_tree, args_entry, entry, args_cmp);
|
RB_PROTOTYPE(args_tree, args_entry, entry, args_cmp);
|
||||||
@ -2222,6 +2218,7 @@ void layout_set_active_changed(struct window *);
|
|||||||
|
|
||||||
/* window-clock.c */
|
/* window-clock.c */
|
||||||
extern const struct window_mode window_clock_mode;
|
extern const struct window_mode window_clock_mode;
|
||||||
|
extern const char window_clock_table[14][5][5];
|
||||||
|
|
||||||
/* window-copy.c */
|
/* window-copy.c */
|
||||||
extern const struct window_mode window_copy_mode;
|
extern const struct window_mode window_copy_mode;
|
||||||
|
143
window-clock.c
143
window-clock.c
@ -46,6 +46,79 @@ struct window_clock_mode_data {
|
|||||||
time_t tim;
|
time_t tim;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const char window_clock_table[14][5][5] = {
|
||||||
|
{ { 1,1,1,1,1 }, /* 0 */
|
||||||
|
{ 1,0,0,0,1 },
|
||||||
|
{ 1,0,0,0,1 },
|
||||||
|
{ 1,0,0,0,1 },
|
||||||
|
{ 1,1,1,1,1 } },
|
||||||
|
{ { 0,0,0,0,1 }, /* 1 */
|
||||||
|
{ 0,0,0,0,1 },
|
||||||
|
{ 0,0,0,0,1 },
|
||||||
|
{ 0,0,0,0,1 },
|
||||||
|
{ 0,0,0,0,1 } },
|
||||||
|
{ { 1,1,1,1,1 }, /* 2 */
|
||||||
|
{ 0,0,0,0,1 },
|
||||||
|
{ 1,1,1,1,1 },
|
||||||
|
{ 1,0,0,0,0 },
|
||||||
|
{ 1,1,1,1,1 } },
|
||||||
|
{ { 1,1,1,1,1 }, /* 3 */
|
||||||
|
{ 0,0,0,0,1 },
|
||||||
|
{ 1,1,1,1,1 },
|
||||||
|
{ 0,0,0,0,1 },
|
||||||
|
{ 1,1,1,1,1 } },
|
||||||
|
{ { 1,0,0,0,1 }, /* 4 */
|
||||||
|
{ 1,0,0,0,1 },
|
||||||
|
{ 1,1,1,1,1 },
|
||||||
|
{ 0,0,0,0,1 },
|
||||||
|
{ 0,0,0,0,1 } },
|
||||||
|
{ { 1,1,1,1,1 }, /* 5 */
|
||||||
|
{ 1,0,0,0,0 },
|
||||||
|
{ 1,1,1,1,1 },
|
||||||
|
{ 0,0,0,0,1 },
|
||||||
|
{ 1,1,1,1,1 } },
|
||||||
|
{ { 1,1,1,1,1 }, /* 6 */
|
||||||
|
{ 1,0,0,0,0 },
|
||||||
|
{ 1,1,1,1,1 },
|
||||||
|
{ 1,0,0,0,1 },
|
||||||
|
{ 1,1,1,1,1 } },
|
||||||
|
{ { 1,1,1,1,1 }, /* 7 */
|
||||||
|
{ 0,0,0,0,1 },
|
||||||
|
{ 0,0,0,0,1 },
|
||||||
|
{ 0,0,0,0,1 },
|
||||||
|
{ 0,0,0,0,1 } },
|
||||||
|
{ { 1,1,1,1,1 }, /* 8 */
|
||||||
|
{ 1,0,0,0,1 },
|
||||||
|
{ 1,1,1,1,1 },
|
||||||
|
{ 1,0,0,0,1 },
|
||||||
|
{ 1,1,1,1,1 } },
|
||||||
|
{ { 1,1,1,1,1 }, /* 9 */
|
||||||
|
{ 1,0,0,0,1 },
|
||||||
|
{ 1,1,1,1,1 },
|
||||||
|
{ 0,0,0,0,1 },
|
||||||
|
{ 1,1,1,1,1 } },
|
||||||
|
{ { 0,0,0,0,0 }, /* : */
|
||||||
|
{ 0,0,1,0,0 },
|
||||||
|
{ 0,0,0,0,0 },
|
||||||
|
{ 0,0,1,0,0 },
|
||||||
|
{ 0,0,0,0,0 } },
|
||||||
|
{ { 1,1,1,1,1 }, /* A */
|
||||||
|
{ 1,0,0,0,1 },
|
||||||
|
{ 1,1,1,1,1 },
|
||||||
|
{ 1,0,0,0,1 },
|
||||||
|
{ 1,0,0,0,1 } },
|
||||||
|
{ { 1,1,1,1,1 }, /* P */
|
||||||
|
{ 1,0,0,0,1 },
|
||||||
|
{ 1,1,1,1,1 },
|
||||||
|
{ 1,0,0,0,0 },
|
||||||
|
{ 1,0,0,0,0 } },
|
||||||
|
{ { 1,0,0,0,1 }, /* M */
|
||||||
|
{ 1,1,0,1,1 },
|
||||||
|
{ 1,0,1,0,1 },
|
||||||
|
{ 1,0,0,0,1 },
|
||||||
|
{ 1,0,0,0,1 } },
|
||||||
|
};
|
||||||
|
|
||||||
struct screen *
|
struct screen *
|
||||||
window_clock_init(struct window_pane *wp)
|
window_clock_init(struct window_pane *wp)
|
||||||
{
|
{
|
||||||
@ -114,11 +187,77 @@ window_clock_draw_screen(struct window_pane *wp)
|
|||||||
struct window_clock_mode_data *data = wp->modedata;
|
struct window_clock_mode_data *data = wp->modedata;
|
||||||
struct screen_write_ctx ctx;
|
struct screen_write_ctx ctx;
|
||||||
int colour, style;
|
int colour, style;
|
||||||
|
struct screen *s = &data->screen;
|
||||||
|
struct grid_cell gc;
|
||||||
|
char tim[64], *ptr;
|
||||||
|
time_t t;
|
||||||
|
struct tm *tm;
|
||||||
|
u_int i, j, x, y, idx;
|
||||||
|
|
||||||
colour = options_get_number(&wp->window->options, "clock-mode-colour");
|
colour = options_get_number(&wp->window->options, "clock-mode-colour");
|
||||||
style = options_get_number(&wp->window->options, "clock-mode-style");
|
style = options_get_number(&wp->window->options, "clock-mode-style");
|
||||||
|
|
||||||
screen_write_start(&ctx, NULL, &data->screen);
|
screen_write_start(&ctx, NULL, s);
|
||||||
clock_draw(&ctx, colour, style);
|
|
||||||
|
t = time(NULL);
|
||||||
|
tm = localtime(&t);
|
||||||
|
if (style == 0) {
|
||||||
|
strftime(tim, sizeof tim, "%l:%M ", localtime(&t));
|
||||||
|
if (tm->tm_hour >= 12)
|
||||||
|
strlcat(tim, "PM", sizeof tim);
|
||||||
|
else
|
||||||
|
strlcat(tim, "AM", sizeof tim);
|
||||||
|
} else
|
||||||
|
strftime(tim, sizeof tim, "%H:%M", tm);
|
||||||
|
|
||||||
|
screen_write_clearscreen(&ctx);
|
||||||
|
|
||||||
|
if (screen_size_x(s) < 6 * strlen(tim) || screen_size_y(s) < 6) {
|
||||||
|
if (screen_size_x(s) >= strlen(tim) && screen_size_y(s) != 0) {
|
||||||
|
x = (screen_size_x(s) / 2) - (strlen(tim) / 2);
|
||||||
|
y = screen_size_y(s) / 2;
|
||||||
|
screen_write_cursormove(&ctx, x, y);
|
||||||
|
|
||||||
|
memcpy(&gc, &grid_default_cell, sizeof gc);
|
||||||
|
colour_set_fg(&gc, colour);
|
||||||
|
screen_write_puts(&ctx, &gc, "%s", tim);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
screen_write_stop(&ctx);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
x = (screen_size_x(s) / 2) - 3 * strlen(tim);
|
||||||
|
y = (screen_size_y(s) / 2) - 3;
|
||||||
|
|
||||||
|
memcpy(&gc, &grid_default_cell, sizeof gc);
|
||||||
|
colour_set_bg(&gc, colour);
|
||||||
|
for (ptr = tim; *ptr != '\0'; ptr++) {
|
||||||
|
if (*ptr >= '0' && *ptr <= '9')
|
||||||
|
idx = *ptr - '0';
|
||||||
|
else if (*ptr == ':')
|
||||||
|
idx = 10;
|
||||||
|
else if (*ptr == 'A')
|
||||||
|
idx = 11;
|
||||||
|
else if (*ptr == 'P')
|
||||||
|
idx = 12;
|
||||||
|
else if (*ptr == 'M')
|
||||||
|
idx = 13;
|
||||||
|
else {
|
||||||
|
x += 6;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (j = 0; j < 5; j++) {
|
||||||
|
for (i = 0; i < 5; i++) {
|
||||||
|
screen_write_cursormove(&ctx, x + i, y + j);
|
||||||
|
if (window_clock_table[idx][j][i])
|
||||||
|
screen_write_putc(&ctx, &gc, ' ');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
x += 6;
|
||||||
|
}
|
||||||
|
|
||||||
screen_write_stop(&ctx);
|
screen_write_stop(&ctx);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user