summaryrefslogtreecommitdiffstats
path: root/cmd-list-windows.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicholas.marriott@gmail.com>2008-09-25 20:08:57 +0000
committerNicholas Marriott <nicholas.marriott@gmail.com>2008-09-25 20:08:57 +0000
commitefe557313aef555b415fa2ea2c9a50c4404ed788 (patch)
tree4a197ade3d901f79bc8b0b990f9756d3da7f5f01 /cmd-list-windows.c
parent9edb4d4b85a8714162817f2ae428e654e6bf1f31 (diff)
Internal screen data rewrite for better 256 colour/UTF-8 support.
Diffstat (limited to 'cmd-list-windows.c')
-rw-r--r--cmd-list-windows.c23
1 files changed, 10 insertions, 13 deletions
diff --git a/cmd-list-windows.c b/cmd-list-windows.c
index d3cf24c0..d5ae16e2 100644
--- a/cmd-list-windows.c
+++ b/cmd-list-windows.c
@@ -1,4 +1,4 @@
-/* $Id: cmd-list-windows.c,v 1.23 2008-09-09 22:16:36 nicm Exp $ */
+/* $Id: cmd-list-windows.c,v 1.24 2008-09-25 20:08:52 nicm Exp $ */
/*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@@ -48,6 +48,7 @@ cmd_list_windows_exec(struct cmd *self, struct cmd_ctx *ctx)
struct session *s;
struct winlink *wl;
struct window *w;
+ struct grid_data *gd;
u_int i;
unsigned long long size;
const char *name;
@@ -57,27 +58,23 @@ cmd_list_windows_exec(struct cmd *self, struct cmd_ctx *ctx)
RB_FOREACH(wl, winlinks, &s->windows) {
w = wl->window;
+ gd = w->base.grid;
size = 0;
- for (i = 0; i < w->base.hsize; i++)
- size += w->base.grid_size[i] * 3;
- size += w->base.hsize * (sizeof *w->base.grid_data);
- size += w->base.hsize * (sizeof *w->base.grid_attr);
- size += w->base.hsize * (sizeof *w->base.grid_fg);
- size += w->base.hsize * (sizeof *w->base.grid_bg);
- size += w->base.hsize * (sizeof *w->base.grid_size);
-
+ for (i = 0; i < gd->hsize; i++)
+ size += gd->size[i] * sizeof **gd->data;
+ size += gd->hsize * (sizeof *gd->data);
+ size += gd->hsize * (sizeof *gd->size);
+
if (w->fd != -1)
name = ttyname(w->fd);
else
name = "";
ctx->print(ctx,
- "%d: %s \"%s\" (%s) [%ux%u] [history %u/%u, %llu bytes] "
- "[UTF8 table %u/%u]",
+ "%d: %s \"%s\" (%s) [%ux%u] [history %u/%u, %llu bytes]",
wl->idx, w->name, w->base.title, name,
screen_size_x(&w->base), screen_size_y(&w->base),
- w->base.hsize, w->base.hlimit, size,
- ARRAY_LENGTH(&w->base.utf8_table.array), UTF8_LIMIT);
+ gd->hsize, gd->hlimit, size);
}
if (ctx->cmdclient != NULL)