diff options
author | June McEnroe <june@causal.agency> | 2021-02-15 18:40:24 -0500 |
---|---|---|
committer | June McEnroe <june@causal.agency> | 2021-02-15 18:41:46 -0500 |
commit | a92f1260ea8fa662f0944a4941c8d87b37b15761 (patch) | |
tree | 824184759394468fbf19596cc1bfa9cff0d931a4 | |
parent | Add donation link to README (diff) | |
download | catgirl-a92f1260ea8fa662f0944a4941c8d87b37b15761.tar.gz catgirl-a92f1260ea8fa662f0944a4941c8d87b37b15761.zip |
Don't expand macro if it can't be converted to mbs
Otherwise expanding a macro could hit the assertion in editBuffer while converting to mbs for consumption by the rest of the program.
-rw-r--r-- | edit.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/edit.c b/edit.c index d9b7673..fc23c58 100644 --- a/edit.c +++ b/edit.c @@ -114,6 +114,7 @@ static void macroExpand(void) { if (macro == pos) return; for (size_t i = 0; i < ARRAY_LEN(Macros); ++i) { if (wcsncmp(Macros[i].name, &buf[macro], pos - macro)) continue; + if (wcstombs(NULL, Macros[i].string, 0) == (size_t)-1) continue; delete(false, macro, pos - macro); pos = macro; size_t expand = wcslen(Macros[i].string); |