From d9967c2638052730c6eeb1624586d633d6482003 Mon Sep 17 00:00:00 2001 From: Taylor R Campbell Date: Sat, 27 Apr 2024 19:54:23 +0000 Subject: Avoid ctype abuse. fix https://github.com/ledger/ledger/issues/2338 fix https://github.com/ledger/ledger/issues/2340 --- src/textual.cc | 36 ++++++++++++++++++++++-------------- 1 file changed, 22 insertions(+), 14 deletions(-) (limited to 'src/textual.cc') diff --git a/src/textual.cc b/src/textual.cc index 5488c6a3..4105a42d 100644 --- a/src/textual.cc +++ b/src/textual.cc @@ -349,7 +349,8 @@ std::streamsize instance_t::read_line(char *& line) --len; } - while (len > 0 && std::isspace(line[len - 1])) // strip trailing whitespace + // strip trailing whitespace + while (len > 0 && std::isspace(static_cast(line[len - 1]))) line[--len] = '\0'; return len; @@ -364,7 +365,7 @@ xact_t * instance_t::read_next_directive(bool& error_flag, xact_t * previous_xac if (len == 0 || line == NULL) return NULL; - if (! std::isspace(line[0])) + if (! std::isspace(static_cast(line[0]))) error_flag = false; switch (line[0]) { @@ -625,12 +626,16 @@ void instance_t::automated_xact_directive(char * line) item->pos->end_line++; } else if ((remlen > 7 && *p == 'a' && - std::strncmp(p, "assert", 6) == 0 && std::isspace(p[6])) || + std::strncmp(p, "assert", 6) == 0 && + std::isspace(static_cast(p[6]))) || (remlen > 6 && *p == 'c' && - std::strncmp(p, "check", 5) == 0 && std::isspace(p[5])) || + std::strncmp(p, "check", 5) == 0 && + std::isspace(static_cast(p[5]))) || (remlen > 5 && *p == 'e' && - ((std::strncmp(p, "expr", 4) == 0 && std::isspace(p[4])) || - (std::strncmp(p, "eval", 4) == 0 && std::isspace(p[4]))))) { + ((std::strncmp(p, "expr", 4) == 0 && + std::isspace(static_cast(p[4]))) || + (std::strncmp(p, "eval", 4) == 0 && + std::isspace(static_cast(p[4])))))) { const char c = *p; p = skip_ws(&p[*p == 'a' ? 6 : (*p == 'c' ? 5 : 4)]); if (! ae->check_exprs) @@ -1028,7 +1033,7 @@ void instance_t::alias_directive(char * line) { if (char * e = std::strchr(line, '=')) { char * z = e - 1; - while (std::isspace(*z)) + while (std::isspace(static_cast(*z))) *z-- = '\0'; *e++ = '\0'; e = skip_ws(e); @@ -1247,7 +1252,7 @@ void instance_t::python_directive(char * line) if (read_line(line) > 0) { if (! indent) { const char * p = line; - while (*p && std::isspace(*p)) { + while (*p && std::isspace(static_cast(*p))) { ++indent; ++p; } @@ -1255,7 +1260,7 @@ void instance_t::python_directive(char * line) const char * p = line; for (std::size_t i = 0; i < indent; i++) { - if (std::isspace(*p)) + if (std::isspace(static_cast(*p))) ++p; else break; @@ -1486,7 +1491,7 @@ post_t * instance_t::parse_post(char * line, char * next = next_element(p, true); char * e = p + std::strlen(p); - while (e > p && std::isspace(*(e - 1))) + while (e > p && std::isspace(static_cast(*(e - 1)))) e--; if ((*p == '[' && *(e - 1) == ']') || (*p == '(' && *(e - 1) == ')')) { @@ -1898,7 +1903,7 @@ xact_t * instance_t::parse_xact(char * line, } else if (*p == ';' && (tabs > 0 || spaces > 1)) { char *q = p - 1; - while (q > next && std::isspace(*q)) + while (q > next && std::isspace(static_cast(*q))) --q; if (q >= next) *(q + 1) = '\0'; @@ -1951,11 +1956,14 @@ xact_t * instance_t::parse_xact(char * line, item->pos->end_line++; } else if ((remlen > 7 && *p == 'a' && - std::strncmp(p, "assert", 6) == 0 && std::isspace(p[6])) || + std::strncmp(p, "assert", 6) == 0 && + std::isspace(static_cast(p[6]))) || (remlen > 6 && *p == 'c' && - std::strncmp(p, "check", 5) == 0 && std::isspace(p[5])) || + std::strncmp(p, "check", 5) == 0 && + std::isspace(static_cast(p[5]))) || (remlen > 5 && *p == 'e' && - std::strncmp(p, "expr", 4) == 0 && std::isspace(p[4]))) { + std::strncmp(p, "expr", 4) == 0 && + std::isspace(static_cast(p[4])))) { const char c = *p; p = skip_ws(&p[*p == 'a' ? 6 : (*p == 'c' ? 5 : 4)]); expr_t expr(p); -- cgit v1.2.3