summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorC. McEnroe2020-04-23 20:22:15 -0400
committerC. McEnroe2020-04-23 20:22:15 -0400
commit88263cc1d7610233606ddd30bee5202e330e57e5 (patch)
tree99c248ced876b0193d52e91ba3d295c8ee50a99c
parenta632ee741b1baa0eeb336cb56c698cf5c7e5e22d (diff)
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.c8
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);