Merge pull request #291 from VoiDeD/spcomp-error25-improvements
Improve the diagnostic given when a function prototype doesn't match an existing definition
This commit is contained in:
commit
782eee3c58
@ -981,7 +981,7 @@ typedef struct array_info_s
|
|||||||
} array_info_t;
|
} array_info_t;
|
||||||
|
|
||||||
enum FatalError {
|
enum FatalError {
|
||||||
FIRST_FATAL_ERROR = 180,
|
FIRST_FATAL_ERROR = 182,
|
||||||
|
|
||||||
FATAL_ERROR_READ = FIRST_FATAL_ERROR,
|
FATAL_ERROR_READ = FIRST_FATAL_ERROR,
|
||||||
FATAL_ERROR_WRITE,
|
FATAL_ERROR_WRITE,
|
||||||
|
@ -5535,7 +5535,7 @@ static int newfunc(declinfo_t *decl, const int *thistag, int fpublic, int fstati
|
|||||||
if ((sym->usage & uPROTOTYPED) && !compare_tag(sym->tag, decl->type.tag)) {
|
if ((sym->usage & uPROTOTYPED) && !compare_tag(sym->tag, decl->type.tag)) {
|
||||||
int old_fline = fline;
|
int old_fline = fline;
|
||||||
fline = funcline;
|
fline = funcline;
|
||||||
error(25);
|
error(180, type_to_name(sym->tag), type_to_name(decl->type.tag));
|
||||||
fline = old_fline;
|
fline = old_fline;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -5745,7 +5745,7 @@ static int declargs(symbol *sym, int chkshadow, const int *thistag)
|
|||||||
} else {
|
} else {
|
||||||
/* check the argument with the earlier definition */
|
/* check the argument with the earlier definition */
|
||||||
if (argcnt>oldargcnt || !argcompare(&sym->dim.arglist[argcnt],&arg))
|
if (argcnt>oldargcnt || !argcompare(&sym->dim.arglist[argcnt],&arg))
|
||||||
error(25); /* function definition does not match prototype */
|
error(181, arg.name); /* function argument does not match prototype */
|
||||||
/* may need to free default array argument and the tag list */
|
/* may need to free default array argument and the tag list */
|
||||||
if (arg.ident==iREFARRAY && arg.hasdefault)
|
if (arg.ident==iREFARRAY && arg.hasdefault)
|
||||||
free(arg.defvalue.array.data);
|
free(arg.defvalue.array.data);
|
||||||
|
@ -222,7 +222,9 @@ static const char *errmsg[] = {
|
|||||||
/*176*/ "non-static method or property '%s' must be called with a value of type '%s'\n",
|
/*176*/ "non-static method or property '%s' must be called with a value of type '%s'\n",
|
||||||
/*177*/ "static method '%s' must be invoked via its type (try '%s.%s')\n",
|
/*177*/ "static method '%s' must be invoked via its type (try '%s.%s')\n",
|
||||||
/*178*/ "cannot coerce %s[] to %s[]; storage classes differ\n",
|
/*178*/ "cannot coerce %s[] to %s[]; storage classes differ\n",
|
||||||
/*179*/ "cannot assign %s[] to %s[], storage classes differ\n",
|
/*179*/ "cannot assign %s[] to %s[], storage classes differ\n",
|
||||||
|
/*180*/ "function return type differs from prototype. expected '%s', but got '%s'\n",
|
||||||
|
/*181*/ "function argument named '%s' differs from prototype\n",
|
||||||
#else
|
#else
|
||||||
"\315e\306\227\266k\217:\235\277bu\201fo\220\204\223\012",
|
"\315e\306\227\266k\217:\235\277bu\201fo\220\204\223\012",
|
||||||
"\202l\224\250s\205g\346\356e\233\201(\243\315\214\267\202) \253 f\255low ea\305 \042c\353e\042\012",
|
"\202l\224\250s\205g\346\356e\233\201(\243\315\214\267\202) \253 f\255low ea\305 \042c\353e\042\012",
|
||||||
@ -386,24 +388,24 @@ static const char *errmsg[] = {
|
|||||||
|
|
||||||
static const char *fatalmsg[] = {
|
static const char *fatalmsg[] = {
|
||||||
#ifdef SCPACK
|
#ifdef SCPACK
|
||||||
/*180*/ "cannot read from file: \"%s\"\n",
|
/*182*/ "cannot read from file: \"%s\"\n",
|
||||||
/*181*/ "cannot write to file: \"%s\"\n",
|
/*183*/ "cannot write to file: \"%s\"\n",
|
||||||
/*182*/ "table overflow: \"%s\"\n",
|
/*184*/ "table overflow: \"%s\"\n",
|
||||||
/* table can be: loop table
|
/* table can be: loop table
|
||||||
* literal table
|
* literal table
|
||||||
* staging buffer
|
* staging buffer
|
||||||
* option table (response file)
|
* option table (response file)
|
||||||
* peephole optimizer table
|
* peephole optimizer table
|
||||||
*/
|
*/
|
||||||
/*183*/ "insufficient memory\n",
|
/*185*/ "insufficient memory\n",
|
||||||
/*184*/ "invalid assembler instruction \"%s\"\n",
|
/*186*/ "invalid assembler instruction \"%s\"\n",
|
||||||
/*185*/ "numeric overflow, exceeding capacity\n",
|
/*187*/ "numeric overflow, exceeding capacity\n",
|
||||||
/*186*/ "compiled script exceeds the maximum memory size (%ld bytes)\n",
|
/*188*/ "compiled script exceeds the maximum memory size (%ld bytes)\n",
|
||||||
/*187*/ "too many error messages on one line\n",
|
/*189*/ "too many error messages on one line\n",
|
||||||
/*188*/ "codepage mapping file not found\n",
|
/*190*/ "codepage mapping file not found\n",
|
||||||
/*189*/ "invalid path: \"%s\"\n",
|
/*191*/ "invalid path: \"%s\"\n",
|
||||||
/*190*/ "assertion failed: %s\n",
|
/*192*/ "assertion failed: %s\n",
|
||||||
/*191*/ "user error: %s\n",
|
/*193*/ "user error: %s\n",
|
||||||
#else
|
#else
|
||||||
"\256\214a\204from \344le:\354",
|
"\256\214a\204from \344le:\354",
|
||||||
"\256writ\200\266 \344le:\354",
|
"\256writ\200\266 \344le:\354",
|
||||||
|
Loading…
Reference in New Issue
Block a user