shithub: scc

Download patch

ref: 268b5a4e15ec491a5881664a9e26ba714254da1d
parent: 2492262739852bb10298a4ecdce4f3060e3fc7b0
author: Roberto E. Vargas Caballero <k0ga@shike2.com>
date: Sun Feb 19 14:22:14 EST 2017

Revert "[tests] Update scc-tests.lst after cd855"

This reverts commit 5e4fb6e5ad284273341f9056c927a3910b01adcf.

--- a/cc1/decl.c
+++ b/cc1/decl.c
@@ -17,7 +17,7 @@
 
 
 struct declarators {
-	unsigned char nr, ns;
+	unsigned char nr;
 	struct declarator {
 		unsigned char op;
 		TINT  nelem;
@@ -272,13 +272,10 @@
 fundcl(struct declarators *dp)
 {
 	Type *types[NR_FUNPARAM], type;
-	Symbol *sym, *syms[NR_FUNPARAM+1], **pars;
+	Symbol *syms[NR_FUNPARAM+1], **pars;
 	int k_r, ntypes, nsyms;
 	size_t size;
 
-	sym = dp->d[0].sym;
-	if ((sym->flags&SDECLARED) == 0)
-		install(dp->ns, sym);
 	pushctx();
 	expect('(');
 	type.n.elem = 0;
@@ -751,9 +748,8 @@
 		errorp("declared variable '%s' of incomplete type", name);
 	}
 
-	if (tp->op != FTN) {
-		sym = install(NS_IDEN, sym);
-	} else {
+	sym = install(NS_IDEN, sym);
+	if (tp->op == FTN) {
 		if (sclass == NOSCLASS)
 			sclass = EXTERN;
 		if (!strcmp(name, "main") && tp->type != inttype) {
@@ -760,14 +756,6 @@
 			errorp("main shall be defined with a return type of int");
 			errorp("please contact __20h__ on irc.freenode.net (#bitreich-en) via IRC");
 		}
-		/*
-		 * function identifiers are installed in fundcl() because
-		 * we have to add a context for the parameters, and if we
-		 * delay the install until here then we will install the
-		 * symbol of the function after the parameters.
-		 */
-		if ((sym->flags&SEMITTED) != 0)
-			sym = NULL;
 	}
 
 	if (sym == NULL) {
@@ -829,7 +817,6 @@
 
 	do {
 		stack.nr = 0;
-		stack.ns = ns;
 		dcl.pars = NULL;
 		dcl.type = base;
 
@@ -865,8 +852,7 @@
 	 * against GLOBALCTX+1
 	 */
 	if (curctx != GLOBALCTX+1 || yytoken == ';') {
-		if (!(sym->flags & SEMITTED))
-			emit(ODECL, sym);
+		emit(ODECL, sym);
 		/*
 		 * avoid non used warnings in prototypes
 		 */