Commit c17ce9f9 authored by Ken Thompson's avatar Ken Thompson

prevent multiple similar errors

in complex literals. side effect is
fix of error in initializerr.go

R=r
OCL=29667
CL=29667
parent ead9f8be
...@@ -464,9 +464,6 @@ initfix(Node* n) ...@@ -464,9 +464,6 @@ initfix(Node* n)
if(0) if(0)
return xxx.list; return xxx.list;
if(debug['A'])
dump("preinitfix", xxx.list);
// look for the copy-out reference // look for the copy-out reference
r = listfirst(&iter, &xxx.list); r = listfirst(&iter, &xxx.list);
while(r != N) { while(r != N) {
...@@ -476,7 +473,5 @@ dump("preinitfix", xxx.list); ...@@ -476,7 +473,5 @@ dump("preinitfix", xxx.list);
} }
r = listnext(&iter); r = listnext(&iter);
} }
if(debug['A'])
dump("postinitfix", xxx.list);
return xxx.list; return xxx.list;
} }
...@@ -4084,9 +4084,10 @@ structlit(Node *n, Node *var) ...@@ -4084,9 +4084,10 @@ structlit(Node *n, Node *var)
Iter savel, saver; Iter savel, saver;
Type *l, *t; Type *l, *t;
Node *r, *a; Node *r, *a;
int mixflag;
Node* hash[101]; Node* hash[101];
int nerr;
nerr = nerrors;
t = n->type; t = n->type;
if(t->etype != TSTRUCT) if(t->etype != TSTRUCT)
fatal("structlit: not struct"); fatal("structlit: not struct");
...@@ -4102,7 +4103,6 @@ structlit(Node *n, Node *var) ...@@ -4102,7 +4103,6 @@ structlit(Node *n, Node *var)
if(r == N) if(r == N)
return var; return var;
mixflag = 0;
if(r->op == OKEY) if(r->op == OKEY)
goto keyval; goto keyval;
l = structfirst(&savel, &n->type); l = structfirst(&savel, &n->type);
...@@ -4112,16 +4112,16 @@ structlit(Node *n, Node *var) ...@@ -4112,16 +4112,16 @@ structlit(Node *n, Node *var)
if(l == T) if(l == T)
break; break;
if(r->op == OKEY) { if(r->op == OKEY) {
mixflag = 1; // defer diagnostic yyerror("mixture of value and field:value initializers");
l = structnext(&savel); return var;
r = listnext(&saver);
continue;
} }
// build list of var.field = expr // build list of var.field = expr
a = nod(ODOT, var, newname(l->sym)); a = nod(ODOT, var, newname(l->sym));
a = nod(OAS, a, r); a = nod(OAS, a, r);
walktype(a, Etop); walktype(a, Etop);
if(nerr != nerrors)
return var;
addtop = list(addtop, a); addtop = list(addtop, a);
l = structnext(&savel); l = structnext(&savel);
...@@ -4131,8 +4131,6 @@ structlit(Node *n, Node *var) ...@@ -4131,8 +4131,6 @@ structlit(Node *n, Node *var)
yyerror("struct literal expect expr of type %T", l); yyerror("struct literal expect expr of type %T", l);
if(r != N) if(r != N)
yyerror("struct literal too many expressions"); yyerror("struct literal too many expressions");
if(mixflag)
yyerror("mixture of field:value initializers");
return var; return var;
keyval: keyval:
...@@ -4143,22 +4141,25 @@ keyval: ...@@ -4143,22 +4141,25 @@ keyval:
while(r != N) { while(r != N) {
// assignment to field:value elements // assignment to field:value elements
if(r->op != OKEY) { if(r->op != OKEY) {
mixflag = 1; yyerror("mixture of field:value and value initializers");
r = listnext(&saver); break;
continue;
} }
// build list of var.field = expr // build list of var.field = expr
a = nod(ODOT, var, newname(r->left->sym)); a = nod(ODOT, var, newname(r->left->sym));
fielddup(a->right, hash, nelem(hash)); fielddup(a->right, hash, nelem(hash));
if(nerr != nerrors)
break;
a = nod(OAS, a, r->right); a = nod(OAS, a, r->right);
walktype(a, Etop); walktype(a, Etop);
if(nerr != nerrors)
break;
addtop = list(addtop, a); addtop = list(addtop, a);
r = listnext(&saver); r = listnext(&saver);
} }
if(mixflag)
yyerror("mixture of field:value initializers");
return var; return var;
} }
...@@ -4193,7 +4194,9 @@ arraylit(Node *n, Node *var) ...@@ -4193,7 +4194,9 @@ arraylit(Node *n, Node *var)
Node *r, *a; Node *r, *a;
long ninit, b; long ninit, b;
Node* hash[101]; Node* hash[101];
int nerr;
nerr = nerrors;
t = n->type; t = n->type;
if(t->etype != TARRAY) if(t->etype != TARRAY)
fatal("arraylit: not array"); fatal("arraylit: not array");
...@@ -4263,12 +4266,23 @@ arraylit(Node *n, Node *var) ...@@ -4263,12 +4266,23 @@ arraylit(Node *n, Node *var)
} }
r = r->right; r = r->right;
} }
if(t->bound >= 0 && b > t->bound) {
yyerror("array index out of bounds");
break;
}
a = nodintconst(b); a = nodintconst(b);
indexdup(a, hash, nelem(hash)); indexdup(a, hash, nelem(hash));
if(nerr != nerrors)
break;
a = nod(OINDEX, var, a); a = nod(OINDEX, var, a);
a = nod(OAS, a, r); a = nod(OAS, a, r);
walktype(a, Etop); // add any assignments in r to addtop walktype(a, Etop); // add any assignments in r to addtop
if(nerr != nerrors)
break;
addtop = list(addtop, a); addtop = list(addtop, a);
b++; b++;
...@@ -4339,7 +4353,9 @@ maplit(Node *n, Node *var) ...@@ -4339,7 +4353,9 @@ maplit(Node *n, Node *var)
Type *t; Type *t;
Node *r, *a; Node *r, *a;
Node* hash[101]; Node* hash[101];
int nerr;
nerr = nerrors;
t = n->type; t = n->type;
if(t->etype != TMAP) if(t->etype != TMAP)
fatal("maplit: not map"); fatal("maplit: not map");
...@@ -4370,10 +4386,15 @@ maplit(Node *n, Node *var) ...@@ -4370,10 +4386,15 @@ maplit(Node *n, Node *var)
// build list of var[c] = expr // build list of var[c] = expr
keydup(r->left, hash, nelem(hash)); keydup(r->left, hash, nelem(hash));
if(nerr != nerrors)
break;
a = nod(OINDEX, var, r->left); a = nod(OINDEX, var, r->left);
a = nod(OAS, a, r->right); a = nod(OAS, a, r->right);
walktype(a, Etop); walktype(a, Etop);
if(nerr != nerrors)
break;
addtop = list(addtop, a); addtop = list(addtop, a);
r = listnext(&saver); r = listnext(&saver);
......
...@@ -26,9 +26,6 @@ panic PC=xxx ...@@ -26,9 +26,6 @@ panic PC=xxx
=========== ./helloworld.go =========== ./helloworld.go
hello, world hello, world
=========== ./initializerr.go
BUG: errchk: ./initializerr.go:17: missing expected error: 'index|too many'
=========== ./peano.go =========== ./peano.go
0! = 1 0! = 1
1! = 1 1! = 1
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment