about summary refs log tree commit diff
diff options
context:
space:
mode:
-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);
/tr> These don't really go together, but... 2021-01-19Match tab following escaped newline in make assignmentsJune McEnroe Otherwise it ends up going into Shell state. 2021-01-18Allow matching lexers using first input lineJune McEnroe