diff options
author | June McEnroe <june@causal.agency> | 2020-04-23 20:22:15 -0400 |
---|---|---|
committer | June McEnroe <june@causal.agency> | 2020-04-23 20:22:15 -0400 |
commit | 88263cc1d7610233606ddd30bee5202e330e57e5 (patch) | |
tree | 99c248ced876b0193d52e91ba3d295c8ee50a99c | |
parent | Don't clobber windows.swap in else of showAuto (diff) | |
download | catgirl-88263cc1d7610233606ddd30bee5202e330e57e5.tar.gz catgirl-88263cc1d7610233606ddd30bee5202e330e57e5.zip |
Separate completeID state from complete state
I think this is what causes QUITs to sometimes not appear, because wherever the complete match is skips over some IDs.
-rw-r--r-- | complete.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/complete.c b/complete.c index d23932c..86846f4 100644 --- a/complete.c +++ b/complete.c @@ -117,9 +117,11 @@ void completeReject(void) { match = NULL; } +static struct Node *iter; + uint completeID(const char *str) { - for (match = (match ? match->next : head); match; match = match->next) { - if (match->id && !strcmp(match->str, str)) return match->id; + for (iter = (iter ? iter->next : head); iter; iter = iter->next) { + if (iter->id && !strcmp(iter->str, str)) return iter->id; } return None; } @@ -144,6 +146,7 @@ void completeRemove(uint id, const char *str) { if (id && node->id != id) continue; if (strcmp(node->str, str)) continue; if (match == node) match = NULL; + if (iter == node) iter = NULL; detach(node); free(node->str); free(node); @@ -156,6 +159,7 @@ void completeClear(uint id) { next = node->next; if (node->id != id) continue; if (match == node) match = NULL; + if (iter == node) iter = NULL; detach(node); free(node->str); free(node); |