aboutsummaryrefslogtreecommitdiff
path: root/arguments.c
diff options
context:
space:
mode:
authornicm <nicm>2020-04-22 06:57:13 +0000
committernicm <nicm>2020-04-22 06:57:13 +0000
commitde5163a634374d64f98a79afafe0c2a526c21a04 (patch)
tree8f1309185c61856da00810fa50c937d9ed01d18b /arguments.c
parent445dfa8512b3b5552a444dd03958cdec3f968f83 (diff)
downloadrtmux-de5163a634374d64f98a79afafe0c2a526c21a04.tar.gz
rtmux-de5163a634374d64f98a79afafe0c2a526c21a04.tar.bz2
rtmux-de5163a634374d64f98a79afafe0c2a526c21a04.zip
Change so main-pane-width and height can be given as a percentage.
Diffstat (limited to 'arguments.c')
-rw-r--r--arguments.c27
1 files changed, 17 insertions, 10 deletions
diff --git a/arguments.c b/arguments.c
index 5b882ea1..547cec00 100644
--- a/arguments.c
+++ b/arguments.c
@@ -352,22 +352,29 @@ long long
args_percentage(struct args *args, u_char ch, long long minval,
long long maxval, long long curval, char **cause)
{
- const char *errstr;
- long long ll;
+ const char *value;
struct args_entry *entry;
- struct args_value *value;
- size_t valuelen;
- char *copy;
if ((entry = args_find(args, ch)) == NULL) {
*cause = xstrdup("missing");
return (0);
}
- value = TAILQ_LAST(&entry->values, args_values);
- valuelen = strlen(value->value);
+ value = TAILQ_LAST(&entry->values, args_values)->value;
+ return (args_string_percentage(value, minval, maxval, curval, cause));
+}
+
+/* Convert a string to a number which may be a percentage. */
+long long
+args_string_percentage(const char *value, long long minval, long long maxval,
+ long long curval, char **cause)
+{
+ const char *errstr;
+ long long ll;
+ size_t valuelen = strlen(value);
+ char *copy;
- if (value->value[valuelen - 1] == '%') {
- copy = xstrdup(value->value);
+ if (value[valuelen - 1] == '%') {
+ copy = xstrdup(value);
copy[valuelen - 1] = '\0';
ll = strtonum(copy, 0, 100, &errstr);
@@ -386,7 +393,7 @@ args_percentage(struct args *args, u_char ch, long long minval,
return (0);
}
} else {
- ll = strtonum(value->value, minval, maxval, &errstr);
+ ll = strtonum(value, minval, maxval, &errstr);
if (errstr != NULL) {
*cause = xstrdup(errstr);
return (0);