diff options
author | nicm <nicm> | 2019-05-31 11:34:09 +0000 |
---|---|---|
committer | nicm <nicm> | 2019-05-31 11:34:09 +0000 |
commit | 82e47403c6a8d6fff90f77e9262840050b8e6b2e (patch) | |
tree | 38285e4e7654ad6d7e59facaba4b500fbf10ad92 | |
parent | b26523c26dc7cf0a24a1adb787aa1816deb40693 (diff) | |
download | rtmux-82e47403c6a8d6fff90f77e9262840050b8e6b2e.tar.gz rtmux-82e47403c6a8d6fff90f77e9262840050b8e6b2e.tar.bz2 rtmux-82e47403c6a8d6fff90f77e9262840050b8e6b2e.zip |
Allow % strings that are all numbers or %s, and fix a double free. Both
reported by George Nachman, GitHub issues 1765 and 1766.
-rw-r--r-- | cmd-parse.y | 10 | ||||
-rw-r--r-- | control.c | 1 |
2 files changed, 7 insertions, 4 deletions
diff --git a/cmd-parse.y b/cmd-parse.y index d5d12d95..0a627268 100644 --- a/cmd-parse.y +++ b/cmd-parse.y @@ -998,11 +998,15 @@ yylex(void) if (ch == '%') { /* - * % is a condition unless it is alone, then it is a - * token. + * % is a condition unless it is all % or all numbers, + * then it is a token. */ yylval.token = yylex_get_word('%'); - if (strcmp(yylval.token, "%") == 0) + for (cp = yylval.token; *cp != '\0'; cp++) { + if (*cp != '%' && !isdigit((u_char)*cp)) + break; + } + if (*cp == '\0') return (TOKEN); if (strcmp(yylval.token, "%if") == 0) { free(yylval.token); @@ -91,7 +91,6 @@ control_callback(struct client *c, int closed, __unused void *data) case CMD_PARSE_ERROR: item = cmdq_get_callback(control_error, pr->error); cmdq_append(c, item); - free(pr->error); break; case CMD_PARSE_SUCCESS: item = cmdq_get_command(pr->cmdlist, NULL, NULL, 0); |