From 175fed4628acb9c46b073401c349a18154194ed7 Mon Sep 17 00:00:00 2001 From: "C. McEnroe" Date: Mon, 17 May 2021 18:03:38 -0400 Subject: Avoid VLAs People don't like them. I'm still not sold on their dangers or whatever, but they're easy enough to avoid anyway. --- unscoop.c | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) (limited to 'unscoop.c') diff --git a/unscoop.c b/unscoop.c index 0ae16d9..72bf65f 100644 --- a/unscoop.c +++ b/unscoop.c @@ -352,7 +352,8 @@ int main(int argc, char *argv[]) { } regex_t pathRegex = compile(format->pattern); - regex_t regex[format->len]; + regex_t *regex = calloc(format->len, sizeof(*regex)); + if (!regex) err(EX_OSERR, "calloc"); for (size_t i = 0; i < format->len; ++i) { regex[i] = compile(format->matchers[i].pattern); } @@ -388,10 +389,12 @@ int main(int argc, char *argv[]) { size_t sizeTotal = 0; size_t sizeRead = 0; size_t sizePercent = -1; - regmatch_t match[argc][ParamCap]; + struct { + regmatch_t match[ParamCap]; + } *paths = calloc(argc, sizeof(*paths)); for (int i = optind; i < argc; ++i) { - int error = regexec(&pathRegex, argv[i], ParamCap, match[i], 0); + int error = regexec(&pathRegex, argv[i], ParamCap, paths[i].match, 0); if (error && (!network || !context)) { warnx("skipping %s", argv[i]); argv[i] = NULL; @@ -413,8 +416,8 @@ int main(int argc, char *argv[]) { if (!file) err(EX_NOINPUT, "%s", argv[i]); dbExec(SQL(BEGIN TRANSACTION;)); - regmatch_t pathNetwork = match[i][format->network]; - regmatch_t pathContext = match[i][format->context]; + regmatch_t pathNetwork = paths[i].match[format->network]; + regmatch_t pathContext = paths[i].match[format->context]; if (!network) { bindMatch(insertContext, ":network", argv[i], pathNetwork); bindMatch(insertEvent, ":network", argv[i], pathNetwork); -- cgit 1.4.1