1
0
mirror of https://github.com/cc65/cc65.git synced 2025-01-10 19:29:45 +00:00

Fixed the handling of "while (0) {}".

It's a corner case; but, conditional macroes might create it -- better safe than sorry.
This commit is contained in:
Greg King 2017-04-07 09:26:58 -04:00
parent e43dbe1c24
commit 1aab287189
2 changed files with 88 additions and 34 deletions

View File

@ -273,9 +273,6 @@ static void WhileStatement (void)
/* Remember the current position */ /* Remember the current position */
GetCodePos (&CondCodeStart); GetCodePos (&CondCodeStart);
/* Emit the code position label */
g_defcodelabel (CondLabel);
/* Test the loop condition */ /* Test the loop condition */
TestInParens (LoopLabel, 1); TestInParens (LoopLabel, 1);
@ -288,6 +285,9 @@ static void WhileStatement (void)
/* Loop body */ /* Loop body */
Statement (&PendingToken); Statement (&PendingToken);
/* Emit the while condition label */
g_defcodelabel (CondLabel);
/* Move the test code here */ /* Move the test code here */
GetCodePos (&Here); GetCodePos (&Here);
MoveCode (&CondCodeStart, &CondCodeEnd, &Here); MoveCode (&CondCodeStart, &CondCodeEnd, &Here);

View File

@ -1,53 +1,107 @@
/* /*
!!DESCRIPTION!! !!DESCRIPTION!! while-condition tests
!!ORIGIN!! SDCC regression tests !!ORIGIN!! SDCC regression tests
!!LICENCE!! GPL, read COPYING.GPL !!LICENCE!! GPL, read COPYING.GPL
*/ */
#include <stdio.h> #include <stdio.h>
#include <limits.h>
unsigned char success = 0; static unsigned char failures = 0x00;
unsigned char failures = 0; static unsigned char achar0 = 0;
unsigned char dummy = 0;
#ifdef SUPPORT_BIT_TYPES static void
bit bit0 = 0;
#endif
unsigned int aint0 = 0;
unsigned int aint1 = 0;
unsigned char achar0 = 0;
unsigned char achar1 = 0;
void
done ()
{
dummy++;
}
void
while1 (void) while1 (void)
{ {
unsigned char i = 10; unsigned char i = 10;
do do {
{ ++achar0;
achar0++; } while (--i);
}
while (--i);
if (achar0 != 10) if (achar0 != 10) {
failures++; failures |= 0x01;
}
}
static void
while2 (void)
{
unsigned char i = 10;
achar0 = 0;
while (--i) {
++achar0;
}
if (achar0 != 10 - 1) {
failures |= 0x02;
}
}
static void
while3 (void)
{
achar0 = 0;
do {
if (++achar0 == (unsigned char)0) {
return;
}
} while (1);
failures |= 0x04;
}
static void
while4 (void)
{
achar0 = 0;
while (1) {
if (++achar0 == (unsigned char)0) {
return;
}
}
failures |= 0x08;
}
static void
while5 (void)
{
achar0 = 0;
do {
++achar0;
} while (0);
if (achar0 != 1) {
failures |= 0x10;
}
}
static void
while6 (void)
{
achar0 = 0;
while (0) {
++achar0;
}
if (achar0 != 1 - 1) {
failures |= 0x20;
}
} }
int int
main (void) main (void)
{ {
while1 (); while1 ();
while2 ();
while3 ();
while4 ();
while5 ();
while6 ();
success = failures; if (failures) {
done (); printf("failures: 0x%02X\n", failures);
printf("failures: %d\n",failures); }
return failures; return failures;
} }