diff --git a/src/ca65/pseudo.c b/src/ca65/pseudo.c index 6ac295017..2522e54c8 100644 --- a/src/ca65/pseudo.c +++ b/src/ca65/pseudo.c @@ -384,8 +384,8 @@ static void DoAssert (void) "ERROR" }; - int Action; - + int Action; + long Val; /* First we have the expression that has to evaluated */ ExprNode* Expr = Expression (); @@ -419,10 +419,35 @@ static void DoAssert (void) /* Read the message */ if (Tok != TOK_STRCON) { ErrorSkip ("String constant expected"); - } else { - AddAssertion (Expr, Action, GetStringId (SVal)); - NextTok (); + return; } + + /* If we can evaluate the assertion now, there's no need to pass it to the + * linker. + */ + if (IsConstExpr (Expr, &Val)) { + /* We can evaluate the expression, so handle it in the assembler */ + switch (Action) { + + case ASSERT_ACT_WARN: + Warning (0, "%s", SVal); + break; + + case ASSERT_ACT_ERROR: + Error ("%s", SVal); + break; + + default: + Internal ("Illegal assert action specifier"); + break; + } + } else { + /* Cannot evaluate, add it to the object file */ + AddAssertion (Expr, Action, GetStringId (SVal)); + } + + /* Skip the message */ + NextTok (); }