| 101 |
|
sprintf(errmsg, "duplicate modifier '%s'", modn); |
| 102 |
|
error(USER, errmsg); |
| 103 |
|
} |
| 104 |
< |
if (nmods >= MAXMODLIST) |
| 105 |
< |
error(INTERNAL, "too many modifiers"); |
| 104 |
> |
if (nmods >= MAXMODLIST) { |
| 105 |
> |
sprintf(errmsg, "too many modifiers (%d limit)", MAXMODLIST); |
| 106 |
> |
error(INTERNAL, errmsg); |
| 107 |
> |
} |
| 108 |
> |
if (!strcmp(modn, VOIDID)) { |
| 109 |
> |
sprintf(errmsg, "cannot track '%s' modifier", VOIDID); |
| 110 |
> |
error(USER, errmsg); |
| 111 |
> |
} |
| 112 |
|
modname[nmods++] = modn; /* XXX assumes static string */ |
| 113 |
|
lep->key = modn; /* XXX assumes static string */ |
| 114 |
|
if (binv == NULL) |
| 152 |
|
char *mname[MAXMODLIST]; |
| 153 |
|
int i; |
| 154 |
|
/* find the file & store strings */ |
| 155 |
< |
if (wordfile(mname, getpath(fname, getrlibpath(), R_OK)) < 0) { |
| 155 |
> |
i = wordfile(mname, MAXMODLIST, getpath(fname, getrlibpath(), R_OK)); |
| 156 |
> |
if (i < 0) { |
| 157 |
|
sprintf(errmsg, "cannot find modifier file '%s'", fname); |
| 158 |
|
error(SYSTEM, errmsg); |
| 159 |
+ |
} |
| 160 |
+ |
if (i >= MAXMODLIST-1) { |
| 161 |
+ |
sprintf(errmsg, "too many modifiers (%d limit) in file '%s'", |
| 162 |
+ |
MAXMODLIST-1, fname); |
| 163 |
+ |
error(INTERNAL, errmsg); |
| 164 |
|
} |
| 165 |
|
for (i = 0; mname[i]; i++) /* add each one */ |
| 166 |
|
addmodifier(mname[i], outf, prms, binv, bincnt); |