shithub: scc

Download patch

ref: d092be22d3220430733d7fb532d72d6a2348e9d1
parent: f6df05343dbc81b5f3f8f1fa129007b3dd4a47fc
author: Roberto E. Vargas Caballero <k0ga@shike2.com>
date: Tue Aug 11 07:53:31 EDT 2015

Keep hash order in lookup() too

The order was not preserved in lookup(), which was
inserting always in the head.

--- a/cc1/symbol.c
+++ b/cc1/symbol.c
@@ -53,6 +53,44 @@
 	return h & NR_SYM_HASH-1;
 }
 
+static Symbol *
+linkhash(Symbol *sym, char *name)
+{
+	Symbol **h, *p, *prev;
+
+	sym->name = xstrdup(name);
+	h = &htab[hash(name)];
+
+	for (prev = p = *h; p; prev = p, p = p->hash) {
+		if (p->ctx <= sym->ctx)
+			break;
+	}
+	if (p == prev) {
+		sym->hash = *h;
+		*h = sym;
+	} else {
+		p = prev->hash;
+		prev->hash = sym;
+		sym->hash = p;
+	}
+
+	return sym;
+}
+
+static void
+unlinkhash(Symbol *sym)
+{
+	Symbol **h, *p, *prev;
+
+	h = &htab[hash(sym->name)];
+	for (prev = p = *h; p != sym; prev = p, p = p->hash)
+		/* nothing */;
+	if (prev == p)
+		*h = sym->hash;
+	else
+		prev->hash = sym->hash;
+}
+
 void
 pushctx(void)
 {
@@ -94,7 +132,7 @@
 		}
 		if (sym->name) {
 			short f = sym->flags;
-			htab[hash(sym->name)] = sym->hash;
+			unlinkhash(sym);
 			if ((f & (ISUSED|ISGLOBAL|ISDECLARED)) == ISDECLARED)
 				warn("'%s' defined but not used", sym->name);
 		}
@@ -119,7 +157,7 @@
 Symbol *
 newsym(unsigned ns)
 {
-	Symbol *sym;
+	Symbol *sym, *p, *prev;
 
 	sym = malloc(sizeof(*sym));
 	sym->id = 0;
@@ -129,22 +167,24 @@
 	sym->flags = ISDECLARED;
 	sym->name = NULL;
 	sym->type = NULL;
-	sym->hash = NULL;
+	sym->next = sym->hash = NULL;
 
-	if (!head || head->ctx <= curctx) {
+	if (ns == NS_CPP)
+		return sym;
+
+	for (prev = p = head; p; prev = p, p = p->next) {
+		if (p->ctx <= sym->ctx)
+			break;
+	}
+	if (p == prev) {
 		sym->next = head;
 		head = sym;
 	} else {
-		Symbol *p, *prev;
-
-		for (prev = p = head; p; prev = p, p = p->next) {
-			if (p->ctx <= sym->ctx)
-				break;
-		}
 		p = prev->next;
 		prev->next = sym;
 		sym->next = p;
 	}
+
 	return sym;
 }
 
@@ -168,12 +208,9 @@
 			continue;
 		return sym;
 	}
-
-	sym = newsym(ns);
-	sym->name = xstrdup(yytext);
+	sym = linkhash(newsym(ns), yytext);
 	sym->flags &= ~ISDECLARED;
-	sym->hash = *h;
-	*h = sym;
+
 	return sym;
 }
 
@@ -213,27 +250,7 @@
 			return NULL;
 		sym->flags |= ISDECLARED;
 	} else {
-		char *name = sym->name;
-		Symbol **h;
-
-		sym = newsym(ns);
-		sym->name = xstrdup(name);
-		h = &htab[hash(name)];
-
-		if (!*h || (*h)->ctx <= curctx) {
-			sym->hash = *h;
-			*h = sym;
-		} else {
-			Symbol *p, *prev;
-
-			for (prev = p = *h; p; prev = p, p = p->hash) {
-				if (p->ctx <= sym->ctx)
-					break;
-			}
-			p = prev->hash;
-			prev->hash = sym;
-			sym->hash = p;
-		}
+		sym = linkhash(newsym(ns), sym->name);
 	}
 
 	if (sym->ns != NS_CPP)