1
0
mirror of https://github.com/cc65/cc65.git synced 2025-01-11 11:30:13 +00:00

Merge pull request #2224 from acqn/DeclCleanUp

[cc65] Made functions in src/cc65/declare.c less confusing
This commit is contained in:
Bob Andrews 2023-10-14 20:09:05 +02:00 committed by GitHub
commit 2726192aaf
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 95 additions and 99 deletions

View File

@ -72,7 +72,7 @@
static void ParseTypeSpec (DeclSpec* D, typespec_t TSFlags, int* SignednessSpecified); static void ParseTypeSpec (DeclSpec* Spec, typespec_t TSFlags, int* SignednessSpecified);
/* Parse a type specifier */ /* Parse a type specifier */
@ -125,7 +125,7 @@ static unsigned ParseOneStorageClass (void)
static int ParseStorageClass (DeclSpec* D) static int ParseStorageClass (DeclSpec* Spec)
/* Parse storage class specifiers. Return true if a specifier is read even if /* Parse storage class specifiers. Return true if a specifier is read even if
** it was duplicated or disallowed. */ ** it was duplicated or disallowed. */
{ {
@ -137,9 +137,9 @@ static int ParseStorageClass (DeclSpec* D)
} }
while (StorageClass != 0) { while (StorageClass != 0) {
if (D->StorageClass == 0) { if (Spec->StorageClass == 0) {
D->StorageClass = StorageClass; Spec->StorageClass = StorageClass;
} else if (D->StorageClass == StorageClass) { } else if (Spec->StorageClass == StorageClass) {
Warning ("Duplicate storage class specifier"); Warning ("Duplicate storage class specifier");
} else { } else {
Error ("Conflicting storage class specifier"); Error ("Conflicting storage class specifier");
@ -346,12 +346,12 @@ static void OptionalSigned (int* SignednessSpecified)
void InitDeclSpec (DeclSpec* D) static void InitDeclSpec (DeclSpec* Spec)
/* Initialize the DeclSpec struct for use */ /* Initialize the DeclSpec struct for use */
{ {
D->StorageClass = 0; Spec->StorageClass = 0;
D->Type[0].C = T_END; Spec->Type[0].C = T_END;
D->Flags = 0; Spec->Flags = 0;
} }
@ -1250,7 +1250,7 @@ NextMember: if (CurTok.Tok != TOK_COMMA) {
static void ParseTypeSpec (DeclSpec* D, typespec_t TSFlags, int* SignednessSpecified) static void ParseTypeSpec (DeclSpec* Spec, typespec_t TSFlags, int* SignednessSpecified)
/* Parse a type specifier. Store whether one of "signed" or "unsigned" was /* Parse a type specifier. Store whether one of "signed" or "unsigned" was
** specified, so bit-fields of unspecified signedness can be treated as ** specified, so bit-fields of unspecified signedness can be treated as
** unsigned; without special handling, it would be treated as signed. ** unsigned; without special handling, it would be treated as signed.
@ -1265,25 +1265,25 @@ static void ParseTypeSpec (DeclSpec* D, typespec_t TSFlags, int* SignednessSpeci
} }
/* Assume we have an explicit type */ /* Assume we have an explicit type */
D->Flags &= ~DS_DEF_TYPE; Spec->Flags &= ~DS_DEF_TYPE;
/* Read storage specifiers and/or type qualifiers if we have any */ /* Read storage specifiers and/or type qualifiers if we have any */
OptionalSpecifiers (D, &Qualifiers, TSFlags); OptionalSpecifiers (Spec, &Qualifiers, TSFlags);
/* Look at the data type */ /* Look at the data type */
switch (CurTok.Tok) { switch (CurTok.Tok) {
case TOK_VOID: case TOK_VOID:
NextToken (); NextToken ();
D->Type[0].C = T_VOID; Spec->Type[0].C = T_VOID;
D->Type[0].A.U = 0; Spec->Type[0].A.U = 0;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
break; break;
case TOK_CHAR: case TOK_CHAR:
NextToken (); NextToken ();
D->Type[0].C = T_CHAR; Spec->Type[0].C = T_CHAR;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
break; break;
case TOK_LONG: case TOK_LONG:
@ -1294,13 +1294,13 @@ static void ParseTypeSpec (DeclSpec* D, typespec_t TSFlags, int* SignednessSpeci
} }
NextToken (); NextToken ();
OptionalInt (); OptionalInt ();
D->Type[0].C = T_ULONG; Spec->Type[0].C = T_ULONG;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
} else { } else {
OptionalSigned (SignednessSpecified); OptionalSigned (SignednessSpecified);
OptionalInt (); OptionalInt ();
D->Type[0].C = T_LONG; Spec->Type[0].C = T_LONG;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
} }
break; break;
@ -1312,20 +1312,20 @@ static void ParseTypeSpec (DeclSpec* D, typespec_t TSFlags, int* SignednessSpeci
} }
NextToken (); NextToken ();
OptionalInt (); OptionalInt ();
D->Type[0].C = T_USHORT; Spec->Type[0].C = T_USHORT;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
} else { } else {
OptionalSigned (SignednessSpecified); OptionalSigned (SignednessSpecified);
OptionalInt (); OptionalInt ();
D->Type[0].C = T_SHORT; Spec->Type[0].C = T_SHORT;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
} }
break; break;
case TOK_INT: case TOK_INT:
NextToken (); NextToken ();
D->Type[0].C = T_INT; Spec->Type[0].C = T_INT;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
break; break;
case TOK_SIGNED: case TOK_SIGNED:
@ -1337,22 +1337,22 @@ static void ParseTypeSpec (DeclSpec* D, typespec_t TSFlags, int* SignednessSpeci
case TOK_CHAR: case TOK_CHAR:
NextToken (); NextToken ();
D->Type[0].C = T_SCHAR; Spec->Type[0].C = T_SCHAR;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
break; break;
case TOK_SHORT: case TOK_SHORT:
NextToken (); NextToken ();
OptionalInt (); OptionalInt ();
D->Type[0].C = T_SHORT; Spec->Type[0].C = T_SHORT;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
break; break;
case TOK_LONG: case TOK_LONG:
NextToken (); NextToken ();
OptionalInt (); OptionalInt ();
D->Type[0].C = T_LONG; Spec->Type[0].C = T_LONG;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
break; break;
case TOK_INT: case TOK_INT:
@ -1360,8 +1360,8 @@ static void ParseTypeSpec (DeclSpec* D, typespec_t TSFlags, int* SignednessSpeci
/* FALL THROUGH */ /* FALL THROUGH */
default: default:
D->Type[0].C = T_INT; Spec->Type[0].C = T_INT;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
break; break;
} }
break; break;
@ -1375,22 +1375,22 @@ static void ParseTypeSpec (DeclSpec* D, typespec_t TSFlags, int* SignednessSpeci
case TOK_CHAR: case TOK_CHAR:
NextToken (); NextToken ();
D->Type[0].C = T_UCHAR; Spec->Type[0].C = T_UCHAR;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
break; break;
case TOK_SHORT: case TOK_SHORT:
NextToken (); NextToken ();
OptionalInt (); OptionalInt ();
D->Type[0].C = T_USHORT; Spec->Type[0].C = T_USHORT;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
break; break;
case TOK_LONG: case TOK_LONG:
NextToken (); NextToken ();
OptionalInt (); OptionalInt ();
D->Type[0].C = T_ULONG; Spec->Type[0].C = T_ULONG;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
break; break;
case TOK_INT: case TOK_INT:
@ -1398,22 +1398,22 @@ static void ParseTypeSpec (DeclSpec* D, typespec_t TSFlags, int* SignednessSpeci
/* FALL THROUGH */ /* FALL THROUGH */
default: default:
D->Type[0].C = T_UINT; Spec->Type[0].C = T_UINT;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
break; break;
} }
break; break;
case TOK_FLOAT: case TOK_FLOAT:
NextToken (); NextToken ();
D->Type[0].C = T_FLOAT; Spec->Type[0].C = T_FLOAT;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
break; break;
case TOK_DOUBLE: case TOK_DOUBLE:
NextToken (); NextToken ();
D->Type[0].C = T_DOUBLE; Spec->Type[0].C = T_DOUBLE;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
break; break;
case TOK_UNION: case TOK_UNION:
@ -1426,13 +1426,13 @@ static void ParseTypeSpec (DeclSpec* D, typespec_t TSFlags, int* SignednessSpeci
AnonName (Ident, "union"); AnonName (Ident, "union");
} }
/* Remember we have an extra type decl */ /* Remember we have an extra type decl */
D->Flags |= DS_EXTRA_TYPE; Spec->Flags |= DS_EXTRA_TYPE;
/* Declare the union in the current scope */ /* Declare the union in the current scope */
TagEntry = ParseUnionSpec (Ident, &D->Flags); TagEntry = ParseUnionSpec (Ident, &Spec->Flags);
/* Encode the union entry into the type */ /* Encode the union entry into the type */
D->Type[0].C = T_UNION; Spec->Type[0].C = T_UNION;
SetESUTagSym (D->Type, TagEntry); SetESUTagSym (Spec->Type, TagEntry);
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
break; break;
case TOK_STRUCT: case TOK_STRUCT:
@ -1445,13 +1445,13 @@ static void ParseTypeSpec (DeclSpec* D, typespec_t TSFlags, int* SignednessSpeci
AnonName (Ident, "struct"); AnonName (Ident, "struct");
} }
/* Remember we have an extra type decl */ /* Remember we have an extra type decl */
D->Flags |= DS_EXTRA_TYPE; Spec->Flags |= DS_EXTRA_TYPE;
/* Declare the struct in the current scope */ /* Declare the struct in the current scope */
TagEntry = ParseStructSpec (Ident, &D->Flags); TagEntry = ParseStructSpec (Ident, &Spec->Flags);
/* Encode the struct entry into the type */ /* Encode the struct entry into the type */
D->Type[0].C = T_STRUCT; Spec->Type[0].C = T_STRUCT;
SetESUTagSym (D->Type, TagEntry); SetESUTagSym (Spec->Type, TagEntry);
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
break; break;
case TOK_ENUM: case TOK_ENUM:
@ -1467,13 +1467,13 @@ static void ParseTypeSpec (DeclSpec* D, typespec_t TSFlags, int* SignednessSpeci
AnonName (Ident, "enum"); AnonName (Ident, "enum");
} }
/* Remember we have an extra type decl */ /* Remember we have an extra type decl */
D->Flags |= DS_EXTRA_TYPE; Spec->Flags |= DS_EXTRA_TYPE;
/* Parse the enum decl */ /* Parse the enum decl */
TagEntry = ParseEnumSpec (Ident, &D->Flags); TagEntry = ParseEnumSpec (Ident, &Spec->Flags);
/* Encode the enum entry into the type */ /* Encode the enum entry into the type */
D->Type[0].C |= T_ENUM; Spec->Type[0].C |= T_ENUM;
SetESUTagSym (D->Type, TagEntry); SetESUTagSym (Spec->Type, TagEntry);
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
/* The signedness of enums is determined by the type, so say this is specified to avoid /* The signedness of enums is determined by the type, so say this is specified to avoid
** the int -> unsigned int handling for plain int bit-fields in AddBitField. ** the int -> unsigned int handling for plain int bit-fields in AddBitField.
*/ */
@ -1489,7 +1489,7 @@ static void ParseTypeSpec (DeclSpec* D, typespec_t TSFlags, int* SignednessSpeci
if (TagEntry && SymIsTypeDef (TagEntry)) { if (TagEntry && SymIsTypeDef (TagEntry)) {
/* It's a typedef */ /* It's a typedef */
NextToken (); NextToken ();
TypeCopy (D->Type, TagEntry->Type); TypeCopy (Spec->Type, TagEntry->Type);
/* If it's a typedef, we should actually use whether the signedness was /* If it's a typedef, we should actually use whether the signedness was
** specified on the typedef, but that information has been lost. Treat the ** specified on the typedef, but that information has been lost. Treat the
** signedness as being specified to work around the ICE in #1267. ** signedness as being specified to work around the ICE in #1267.
@ -1506,29 +1506,29 @@ static void ParseTypeSpec (DeclSpec* D, typespec_t TSFlags, int* SignednessSpeci
** in DeclareLocals. The type code used here doesn't matter as ** in DeclareLocals. The type code used here doesn't matter as
** long as it has no qualifiers. ** long as it has no qualifiers.
*/ */
D->Flags |= DS_DEF_TYPE; Spec->Flags |= DS_DEF_TYPE;
D->Type[0].C = T_INT; Spec->Type[0].C = T_INT;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
break; break;
} }
/* FALL THROUGH */ /* FALL THROUGH */
default: default:
if ((TSFlags & TS_MASK_DEFAULT_TYPE) == TS_DEFAULT_TYPE_NONE) { if ((TSFlags & TS_MASK_DEFAULT_TYPE) == TS_DEFAULT_TYPE_NONE) {
D->Flags |= DS_NO_TYPE; Spec->Flags |= DS_NO_TYPE;
D->Type[0].C = T_INT; Spec->Type[0].C = T_INT;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
} else { } else {
D->Flags |= DS_DEF_TYPE; Spec->Flags |= DS_DEF_TYPE;
D->Type[0].C = T_INT; Spec->Type[0].C = T_INT;
D->Type[1].C = T_END; Spec->Type[1].C = T_END;
} }
break; break;
} }
/* There may also be specifiers/qualifiers *after* the initial type */ /* There may also be specifiers/qualifiers *after* the initial type */
OptionalSpecifiers (D, &Qualifiers, TSFlags); OptionalSpecifiers (Spec, &Qualifiers, TSFlags);
D->Type[0].C |= Qualifiers; Spec->Type[0].C |= Qualifiers;
} }
@ -1646,7 +1646,7 @@ static void ParseOldStyleParamList (FuncDesc* F)
SymEntry* Param = FindLocalSym (Decl.Ident); SymEntry* Param = FindLocalSym (Decl.Ident);
if (Param) { if (Param) {
/* Check if we already changed the type for this /* Check if we already changed the type for this
** parameter ** parameter.
*/ */
if (Param->Flags & SC_DEFTYPE) { if (Param->Flags & SC_DEFTYPE) {
/* Found it, change the default type to the one given */ /* Found it, change the default type to the one given */
@ -1780,7 +1780,6 @@ static void ParseAnsiParamList (FuncDesc* F)
static FuncDesc* ParseFuncDecl (void) static FuncDesc* ParseFuncDecl (void)
/* Parse the argument list of a function with the enclosing parentheses */ /* Parse the argument list of a function with the enclosing parentheses */
{ {
SymEntry* Sym;
SymEntry* WrappedCall; SymEntry* WrappedCall;
unsigned int WrappedCallData; unsigned int WrappedCallData;
@ -1806,7 +1805,7 @@ static FuncDesc* ParseFuncDecl (void)
/* If the identifier is a typedef, we have a new-style parameter list; /* If the identifier is a typedef, we have a new-style parameter list;
** if it's some other identifier, it's an old-style parameter list. ** if it's some other identifier, it's an old-style parameter list.
*/ */
Sym = FindSym (CurTok.Ident); SymEntry* Sym = FindSym (CurTok.Ident);
if (Sym == 0 || !SymIsTypeDef (Sym)) { if (Sym == 0 || !SymIsTypeDef (Sym)) {
/* Old-style (K&R) function. */ /* Old-style (K&R) function. */
F->Flags |= FD_OLDSTYLE; F->Flags |= FD_OLDSTYLE;
@ -2012,7 +2011,7 @@ static void DirectDecl (const DeclSpec* Spec, Declarator* D, declmode_t Mode)
/*****************************************************************************/ /*****************************************************************************/
/* code */ /* Code */
/*****************************************************************************/ /*****************************************************************************/
@ -2150,34 +2149,34 @@ void ParseDecl (const DeclSpec* Spec, Declarator* D, declmode_t Mode)
void ParseDeclSpec (DeclSpec* D, typespec_t TSFlags, unsigned DefStorage) void ParseDeclSpec (DeclSpec* Spec, typespec_t TSFlags, unsigned DefStorage)
/* Parse a declaration specification */ /* Parse a declaration specification */
{ {
/* Initialize the DeclSpec struct */ /* Initialize the DeclSpec struct */
InitDeclSpec (D); InitDeclSpec (Spec);
/* Assume we're using an explicit storage class */ /* Assume we're using an explicit storage class */
D->Flags &= ~DS_DEF_STORAGE; Spec->Flags &= ~DS_DEF_STORAGE;
/* Parse the type specifiers */ /* Parse the type specifiers */
ParseTypeSpec (D, TSFlags | TS_STORAGE_CLASS_SPEC | TS_FUNCTION_SPEC, NULL); ParseTypeSpec (Spec, TSFlags | TS_STORAGE_CLASS_SPEC | TS_FUNCTION_SPEC, NULL);
/* If no explicit storage class is given, use the default */ /* If no explicit storage class is given, use the default */
if (D->StorageClass == 0) { if (Spec->StorageClass == 0) {
D->Flags |= DS_DEF_STORAGE; Spec->Flags |= DS_DEF_STORAGE;
D->StorageClass = DefStorage; Spec->StorageClass = DefStorage;
} }
} }
void CheckEmptyDecl (const DeclSpec* D) void CheckEmptyDecl (const DeclSpec* Spec)
/* Called after an empty type declaration (that is, a type declaration without /* Called after an empty type declaration (that is, a type declaration without
** a variable). Checks if the declaration does really make sense and issues a ** a variable). Checks if the declaration does really make sense and issues a
** warning if not. ** warning if not.
*/ */
{ {
if ((D->Flags & DS_EXTRA_TYPE) == 0) { if ((Spec->Flags & DS_EXTRA_TYPE) == 0) {
Warning ("Useless declaration"); Warning ("Useless declaration");
} }
} }

View File

@ -113,19 +113,16 @@ typedef enum {
void InitDeclSpec (DeclSpec* D);
/* Initialize the DeclSpec struct for use */
Type* ParseType (Type* Type); Type* ParseType (Type* Type);
/* Parse a complete type specification */ /* Parse a complete type specification */
void ParseDecl (const DeclSpec* Spec, Declarator* D, declmode_t Mode); void ParseDecl (const DeclSpec* Spec, Declarator* D, declmode_t Mode);
/* Parse a variable, type or function declarator */ /* Parse a variable, type or function declarator */
void ParseDeclSpec (DeclSpec* D, typespec_t TSFlags, unsigned DefStorage); void ParseDeclSpec (DeclSpec* Spec, typespec_t TSFlags, unsigned DefStorage);
/* Parse a declaration specification */ /* Parse a declaration specification */
void CheckEmptyDecl (const DeclSpec* D); void CheckEmptyDecl (const DeclSpec* Spec);
/* Called after an empty type declaration (that is, a type declaration without /* Called after an empty type declaration (that is, a type declaration without
** a variable). Checks if the declaration does really make sense and issues a ** a variable). Checks if the declaration does really make sense and issues a
** warning if not. ** warning if not.

View File

@ -1414,12 +1414,12 @@ static void Primary (ExprDesc* E)
} else { } else {
/* Let's see if this is a C99-style declaration */ /* Let's see if this is a C99-style declaration */
DeclSpec Spec; DeclSpec Spec;
InitDeclSpec (&Spec);
ParseDeclSpec (&Spec, TS_DEFAULT_TYPE_INT, SC_AUTO); ParseDeclSpec (&Spec, TS_DEFAULT_TYPE_INT, SC_AUTO);
if (Spec.Type->C != T_END) { if (Spec.Type->C != T_END) {
/* Recognized but not supported */
Error ("Mixed declarations and code are not supported in cc65"); Error ("Mixed declarations and code are not supported in cc65");
while (CurTok.Tok != TOK_SEMI) { while (CurTok.Tok != TOK_SEMI) {
Declarator Decl; Declarator Decl;