1
0
mirror of https://github.com/cc65/cc65.git synced 2025-01-06 22:31:52 +00:00

Merge pull request from kugelfuhr/kugelfuhr/fix-2523

Fix some issues with preprocessor expressions
This commit is contained in:
Bob Andrews 2024-10-05 14:14:29 +02:00 committed by GitHub
commit 270aa4417b
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 39 additions and 24 deletions
src/cc65
test

View File

@ -55,7 +55,6 @@ static int PPEvaluationFailed = 0;
static void PPhie0 (PPExpr* Expr);
static void PPhie1 (PPExpr* Expr);
@ -138,7 +137,7 @@ static void PPhiePrimary (PPExpr* Expr)
** recursively.
*/
NextToken ();
PPhie0 (Expr);
PPhie1 (Expr);
ConsumeRParen ();
break;
@ -263,6 +262,7 @@ void PPhie10 (PPExpr* Expr)
NextToken ();
PPhie10 (Expr);
Expr->IVal = !Expr->IVal;
Expr->Flags &= ~PPEXPR_UNSIGNED; /* Result is signed */
break;
case TOK_CEOF:
@ -424,10 +424,10 @@ static void PPhie_compare (const token_t* Ops, /* List of generators */
}
}
}
}
/* The result is signed */
Expr->Flags &= ~PPEXPR_UNSIGNED;
/* The result is signed */
Expr->Flags &= ~PPEXPR_UNSIGNED;
}
}
@ -711,7 +711,7 @@ static void PPhieQuest (PPExpr* Expr)
/* Parse second expression */
PPExprInit (&Expr2);
PPhie0 (&Expr2);
PPhie1 (&Expr2);
/* Skip the colon */
ConsumeColon ();
@ -809,23 +809,6 @@ static void PPhie1 (PPExpr* Expr)
static void PPhie0 (PPExpr* Expr)
/* Handle the comma "," operator */
{
PPhie1 (Expr);
while (CurTok.Tok == TOK_COMMA) {
/* Skip the comma */
NextToken ();
/* Reset the expression */
PPExprInit (Expr);
/* Use the next operand as the value instead */
PPhie1 (Expr);
}
}
void ParsePPExprInLine (PPExpr* Expr)
/* Parse a line for PP expression */
{
@ -836,7 +819,7 @@ void ParsePPExprInLine (PPExpr* Expr)
/* Parse */
PPExprInit (Expr);
PPhie0 (Expr);
PPhie1 (Expr);
/* If the evaluation fails, the result is always zero */
if (PPEvaluationFailed) {

3
test/err/bug2523.c Normal file
View File

@ -0,0 +1,3 @@
#if (1, 0) < 0
#error
#endif

29
test/val/bug2523.c Normal file
View File

@ -0,0 +1,29 @@
#if (0u - 1) < 0
#error
#endif
#if !1u - 1 > 0
#error
#endif
#if (1 & 1u) - 2 < 0
#error
#endif
#if (1 | 1u) - 2 < 0
#error
#endif
#if (1 ^ 1u) - 2 < 0
#error
#endif
#if (1u >> 1) - 2 < 0
#error
#endif
#if (0u << 1) - 1 < 0
#error
#endif
int main() { return 0; }