Commit bd77eeda authored by Russ Cox's avatar Russ Cox

gc: fix use of typekind array in error messages

Fixes #1697.

R=ken2
CC=golang-dev
https://golang.org/cl/4395045
parent dd93df35
......@@ -56,7 +56,7 @@ typechecklist(NodeList *l, int top)
typecheck(&l->n, top);
}
static char* typekind[] = {
static char* _typekind[] = {
[TINT] = "int",
[TUINT] = "uint",
[TINT8] = "int8",
......@@ -82,8 +82,22 @@ static char* typekind[] = {
[TMAP] = "map",
[TARRAY] = "array",
[TFUNC] = "func",
[TNIL] = "nil",
[TIDEAL] = "ideal number",
};
static char*
typekind(int et)
{
static char buf[50];
char *s;
if(0 <= et && et < nelem(_typekind) && (s=_typekind[et]) != nil)
return s;
snprint(buf, sizeof buf, "etype=%d", et);
return buf;
}
/*
* type check node *np.
* replaces *np with a new pointer in some cases.
......@@ -406,7 +420,7 @@ reswitch:
}
if(!okfor[op][et]) {
notokfor:
yyerror("invalid operation: %#N (operator %#O not defined on %s)", n, op, typekind[et]);
yyerror("invalid operation: %#N (operator %#O not defined on %s)", n, op, typekind(et));
goto error;
}
// okfor allows any array == array;
......
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