mirror of
https://github.com/cc65/cc65.git
synced 2025-01-25 11:30:06 +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:
parent
e43dbe1c24
commit
1aab287189
@ -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);
|
||||||
|
116
test/val/while.c
116
test/val/while.c
@ -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;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user