ref: 59eb8445113a831ac3edd6a42bc39438536db5da
parent: 83156e58cac626a74cbb47ae94300355a6b89813
author: Quentin Rameau <quinq@fifth.space>
date: Thu Feb 16 14:18:00 EST 2017
[cc1] Fix multiple void function parameter check
--- a/cc1/decl.c
+++ b/cc1/decl.c
@@ -166,11 +166,7 @@
switch (tp->op) {
case VOID:
- if (n != 0 || (funtp->prop & TK_R)) {
- errorp("incorrect void parameter");
- return NULL;
- }
- funtp->n.elem = -1;
+ funtp->n.elem = 1;
if (dcl->sclass)
errorp("void as unique parameter may not be qualified");
return NULL;
@@ -246,41 +242,30 @@
{
int npars = 0;
Symbol *sym;
- int toomany = 0, toovoid = 0;
+ int toomany = 0, voidparam = 0;
do {
- if (npars == -1 && !toovoid) {
- errorp("'void' must be the only parameter");
- toovoid = 1;
- }
+ ++npars;
if (accept(ELLIPSIS)) {
- if (npars == 0)
+ if (npars < 2)
errorp("a named argument is requiered before '...'");
- ++npars;
*syms = NULL;
*types++ = ellipsistype;
- break;
- }
- if ((sym = dodcl(NOREP, parameter, NS_IDEN, tp)) == NULL)
- continue;
- if (tp->n.elem == -1) {
- npars = -1;
- continue;
- }
- if (npars < NR_FUNPARAM) {
+ } else if ((sym = dodcl(NOREP, parameter, NS_IDEN, tp)) == NULL) {
+ if (tp->n.elem == 1)
+ voidparam = 1;
+ } else if (npars < NR_FUNPARAM) {
*syms++ = sym;
*types++ = sym->type;
- ++npars;
- continue;
- }
- if (!toomany) {
+ } else if (!toomany) {
errorp("too many parameters in function definition");
toomany = 1;
}
+ if (npars == 2 && voidparam)
+ errorp("'void' must be the only parameter");
} while (accept(','));
- *nsyms = npars;
- *ntypes = npars;
+ *nsyms = *ntypes = voidparam ? 0 : npars;
}
static void