aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas Adam <thomas@xteddy.org>2019-12-12 15:38:33 +0000
committerThomas Adam <thomas@xteddy.org>2019-12-12 15:38:33 +0000
commit58908b045b48b224063ce04d3db63741d32d0898 (patch)
tree7f6a79252f87a0f01c6f57b6d7795e6f30025cfd
parent7922f4ee7bd4c18509c6774971fd007a4c5a10e3 (diff)
parentdcf41ec9275a2a1a87a5943d9ba189d83de67a89 (diff)
downloadrtmux-58908b045b48b224063ce04d3db63741d32d0898.tar.gz
rtmux-58908b045b48b224063ce04d3db63741d32d0898.tar.bz2
rtmux-58908b045b48b224063ce04d3db63741d32d0898.zip
Merge branch 'obsd-master'
-rw-r--r--cmd-parse.y10
-rw-r--r--mode-tree.c6
2 files changed, 12 insertions, 4 deletions
diff --git a/cmd-parse.y b/cmd-parse.y
index 2c924010..97b50f57 100644
--- a/cmd-parse.y
+++ b/cmd-parse.y
@@ -746,6 +746,12 @@ cmd_parse_from_file(FILE *f, struct cmd_parse_input *pi)
struct cmd_parse_result *
cmd_parse_from_string(const char *s, struct cmd_parse_input *pi)
{
+ return (cmd_parse_from_buffer(s, strlen(s), pi));
+}
+
+struct cmd_parse_result *
+cmd_parse_from_buffer(const void *buf, size_t len, struct cmd_parse_input *pi)
+{
static struct cmd_parse_result pr;
struct cmd_parse_input input;
struct cmd_parse_commands *cmds;
@@ -757,14 +763,14 @@ cmd_parse_from_string(const char *s, struct cmd_parse_input *pi)
}
memset(&pr, 0, sizeof pr);
- if (*s == '\0') {
+ if (len == 0) {
pr.status = CMD_PARSE_EMPTY;
pr.cmdlist = NULL;
pr.error = NULL;
return (&pr);
}
- cmds = cmd_parse_do_buffer(s, strlen(s), pi, &cause);
+ cmds = cmd_parse_do_buffer(buf, len, pi, &cause);
if (cmds == NULL) {
pr.status = CMD_PARSE_ERROR;
pr.error = cause;
diff --git a/mode-tree.c b/mode-tree.c
index 054989fb..b9fa5f65 100644
--- a/mode-tree.c
+++ b/mode-tree.c
@@ -598,6 +598,8 @@ mode_tree_draw(struct mode_tree_data *mtd)
xasprintf(&text, "%-*s%s%s%s: ", keylen, key, start, mti->name,
tag);
width = utf8_cstrwidth(text);
+ if (width > w)
+ width = w;
free(start);
if (mti->tagged) {
@@ -607,11 +609,11 @@ mode_tree_draw(struct mode_tree_data *mtd)
if (i != mtd->current) {
screen_write_clearendofline(&ctx, 8);
- screen_write_puts(&ctx, &gc0, "%s", text);
+ screen_write_nputs(&ctx, w, &gc0, "%s", text);
format_draw(&ctx, &gc0, w - width, mti->text, NULL);
} else {
screen_write_clearendofline(&ctx, gc.bg);
- screen_write_puts(&ctx, &gc, "%s", text);
+ screen_write_nputs(&ctx, w, &gc, "%s", text);
format_draw(&ctx, &gc, w - width, mti->text, NULL);
}
free(text);