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
*/