1
0
mirror of https://github.com/cc65/cc65.git synced 2025-01-13 09:31:53 +00:00

New syntax for symbols

git-svn-id: svn://svn.cc65.org/cc65/trunk@3546 b7a2c559-68d2-44c3-8de9-860c34a00d81
This commit is contained in:
cuz 2005-07-24 21:09:23 +00:00
parent 7101c646e3
commit a45649752f
2 changed files with 102 additions and 12 deletions

View File

@ -1351,14 +1351,28 @@ static void ParseFeatures (void)
static void ParseSymbols (void) static void ParseSymbols (void)
/* Parse a symbols section */ /* Parse a symbols section */
{ {
static const IdentTok Attributes[] = {
{ "VALUE", CFGTOK_VALUE },
{ "WEAK", CFGTOK_WEAK },
};
while (CfgTok == CFGTOK_IDENT) { while (CfgTok == CFGTOK_IDENT) {
long Val; long Val = 0L;
int Weak;
/* Remember the name */ /* Remember the name */
unsigned Name = GetStringId (CfgSVal); unsigned Name = GetStringId (CfgSVal);
CfgNextTok (); CfgNextTok ();
/* Support both, old and new syntax here. New syntax is a colon
* followed by an attribute list, old syntax is an optional equal
* sign plus a value.
*/
if (CfgTok != CFGTOK_COLON) {
/* Old syntax */
/* Allow an optional assignment */ /* Allow an optional assignment */
CfgOptionalAssign (); CfgOptionalAssign ();
@ -1370,6 +1384,79 @@ static void ParseSymbols (void)
/* Generate an export with the given value */ /* Generate an export with the given value */
CreateConstExport (Name, Val); CreateConstExport (Name, Val);
} else {
/* Bitmask to remember the attributes we got already */
enum {
atNone = 0x0000,
atValue = 0x0001,
atWeak = 0x0002
};
unsigned AttrFlags = atNone;
/* New syntax - skip the colon */
CfgNextTok ();
/* Parse the attributes */
while (1) {
/* Map the identifier to a token */
cfgtok_t AttrTok;
CfgSpecialToken (Attributes, ENTRY_COUNT (Attributes), "Attribute");
AttrTok = CfgTok;
/* An optional assignment follows */
CfgNextTok ();
CfgOptionalAssign ();
/* Check which attribute was given */
switch (AttrTok) {
case CFGTOK_VALUE:
/* Don't allow this twice */
FlagAttr (&AttrFlags, atValue, "VALUE");
/* We expect a number */
CfgAssureInt ();
/* Remember the value for later */
Val = CfgIVal;
break;
case CFGTOK_WEAK:
/* Don't allow this twice */
FlagAttr (&AttrFlags, atWeak, "WEAK");
CfgBoolToken ();
Weak = (CfgTok == CFGTOK_TRUE);
break;
default:
FAIL ("Unexpected attribute token");
}
/* Skip the attribute value */
CfgNextTok ();
/* Semicolon ends the decl, otherwise accept an optional comma */
if (CfgTok == CFGTOK_SEMI) {
break;
} else if (CfgTok == CFGTOK_COMMA) {
CfgNextTok ();
}
}
/* Check if we have all mandatory attributes */
AttrCheck (AttrFlags, atValue, "VALUE");
/* Weak is optional, the default are non weak symbols */
if ((AttrFlags & atWeak) == 0) {
Weak = 0;
}
/* Generate an export with the given value */
CreateConstExport (Name, Val);
}
/* Skip the semicolon */ /* Skip the semicolon */
CfgConsumeSemi (); CfgConsumeSemi ();
} }

View File

@ -110,6 +110,9 @@ typedef enum {
CFGTOK_CONDES, CFGTOK_CONDES,
CFGTOK_STARTADDRESS, CFGTOK_STARTADDRESS,
CFGTOK_VALUE,
CFGTOK_WEAK,
CFGTOK_SEGMENT, CFGTOK_SEGMENT,
CFGTOK_LABEL, CFGTOK_LABEL,
CFGTOK_COUNT, CFGTOK_COUNT,