summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornicm <nicm>2019-06-24 10:04:29 +0000
committernicm <nicm>2019-06-24 10:04:29 +0000
commit20b938bcb18b8ae8b0535a1bcf8e7e1670a830bc (patch)
tree4c6d9b8b86ed0295b43a0c85ec39a2539356685f
parentbdab5950955539ea4ffab0816faf182607db4c2b (diff)
Expand arguments to C and s format modifiers (matches m which already expands).
-rw-r--r--format.c17
1 files changed, 11 insertions, 6 deletions
diff --git a/format.c b/format.c
index 6b07e67e..cb67405f 100644
--- a/format.c
+++ b/format.c
@@ -1644,13 +1644,15 @@ format_replace(struct format_tree *ft, const char *key, size_t keylen,
goto fail;
} else if (search != NULL) {
/* Search in pane. */
+ new = format_expand(ft, copy);
if (wp == NULL) {
- format_log(ft, "search '%s' but no pane", copy);
+ format_log(ft, "search '%s' but no pane", new);
value = xstrdup("0");
} else {
- format_log(ft, "search '%s' pane %%%u", copy, wp->id);
- value = format_search(fm, wp, copy);
+ format_log(ft, "search '%s' pane %%%u", new, wp->id);
+ value = format_search(fm, wp, new);
}
+ free(new);
} else if (cmp != NULL) {
/* Comparison of left and right. */
if (format_choose(ft, copy, &left, &right, 1) != 0) {
@@ -1780,11 +1782,14 @@ done:
/* Perform substitution if any. */
if (sub != NULL) {
- new = format_sub(sub, value, sub->argv[0], sub->argv[1]);
- format_log(ft, "substituted '%s' to '%s': %s", sub->argv[0],
- sub->argv[1], new);
+ left = format_expand(ft, sub->argv[0]);
+ right = format_expand(ft, sub->argv[1]);
+ new = format_sub(sub, value, left, right);
+ format_log(ft, "substitute '%s' to '%s': %s", left, right, new);
free(value);
value = new;
+ free(right);
+ free(left);
}
/* Truncate the value if needed. */