From ef15b0d921140a942200e931b61dc9ecac63cbf9 Mon Sep 17 00:00:00 2001 From: Nicholas Marriott Date: Thu, 5 Nov 2009 12:04:51 +0000 Subject: key_string_lookup_key uses a static buffer, so copy its output into the working buffer before calling the command print function which can also use it (eg send-keys). --- usr.bin/tmux/cmd-list-keys.c | 20 +++++++++++--------- 1 file changed, 11 insertions(+), 9 deletions(-) (limited to 'usr.bin') diff --git a/usr.bin/tmux/cmd-list-keys.c b/usr.bin/tmux/cmd-list-keys.c index f4b73e9017c..2d2baa88552 100644 --- a/usr.bin/tmux/cmd-list-keys.c +++ b/usr.bin/tmux/cmd-list-keys.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cmd-list-keys.c,v 1.7 2009/07/28 17:05:10 nicm Exp $ */ +/* $OpenBSD: cmd-list-keys.c,v 1.8 2009/11/05 12:04:50 nicm Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott @@ -47,7 +47,8 @@ cmd_list_keys_exec(struct cmd *self, struct cmd_ctx *ctx) struct cmd_target_data *data = self->data; struct key_binding *bd; const char *key; - char tmp[BUFSIZ], keytmp[64]; + char tmp[BUFSIZ]; + size_t used; int width, keywidth; if (data->target != NULL) @@ -70,14 +71,15 @@ cmd_list_keys_exec(struct cmd *self, struct cmd_ctx *ctx) key = key_string_lookup_key(bd->key & ~KEYC_PREFIX); if (key == NULL) continue; + if (!(bd->key & KEYC_PREFIX)) + used = xsnprintf(tmp, sizeof tmp, "[%s]: ", key); + else + used = xsnprintf(tmp, sizeof tmp, "%*s: ", width, key); + if (used >= sizeof tmp) + continue; - *tmp = '\0'; - cmd_list_print(bd->cmdlist, tmp, sizeof tmp); - if (!(bd->key & KEYC_PREFIX)) { - xsnprintf(keytmp, sizeof keytmp, "[%s]", key); - key = keytmp; - } - ctx->print(ctx, "%*s: %s", width, key, tmp); + cmd_list_print(bd->cmdlist, tmp + used, (sizeof tmp) - used); + ctx->print(ctx, "%s", tmp); } return (0); -- cgit v1.2.3