mirror of
https://github.com/byteworksinc/ORCA-C.git
synced 2025-01-21 06:30:41 +00:00
91d33b586d
The main changes made to most tests are: *Declarations always include explicit types, not relying on implicit int. The declaration of main in most test programs is changed to be "int main (void) {...}", adding an explicit return type and a prototype. (There are still some non-prototyped functions, though.) *Functions are always declared before use, either by including a header or by providing a declaration for the specific function. The latter approach is usually used for printf, to avoid requiring ORCA/C to process stdio.h when compiling every test case (which might make test runs noticeably slower). *Make all return statements in non-void functions (e.g. main) return a value. *Avoid some instances of undefined behavior and type errors in printf and scanf calls. Several miscellaneous bugs are also fixed. There are still a couple test cases that intentionally rely on the C89 behavior, to ensure it still works.
107 lines
2.8 KiB
C++
107 lines
2.8 KiB
C++
/* Conformance Test 24.0.1: Verification of floating-point expressions for */
|
|
/* 68881 card */
|
|
|
|
#define SLOT 3
|
|
#define __FPE__ SLOT
|
|
#pragma float 1 SLOT
|
|
|
|
#include <stdio.h>
|
|
#include <math.h>
|
|
|
|
float f = 3.5;
|
|
double d = 87.65;
|
|
extended e = 92.33;
|
|
|
|
int i, j, k, m;
|
|
|
|
int sub1(void)
|
|
|
|
{
|
|
f++; d++; e++; /* test postincrement */
|
|
if ((fabs(f - 4.5) > 0.00001) || (fabs(d - 88.65) > 0.00001) ||
|
|
(fabs(e - 93.33) > 0.00001))
|
|
goto Fail;
|
|
|
|
f--; d--; e--; /* test postdecrement */
|
|
if ((fabs(f - 3.5) > 0.00001) || (fabs(d - 87.65) > 0.00001) ||
|
|
(fabs(e - 92.33) > 0.00001))
|
|
goto Fail;
|
|
|
|
f = f * 2.4; d = d * (-7.2); e = e * 9.22; /* multiplication */
|
|
if ((fabs(f - 8.4) > 0.00001) || (fabs(d - (-631.08)) > 0.00001) ||
|
|
(fabs(e - 851.2826) > 0.00001))
|
|
goto Fail;
|
|
|
|
f = f / 2.0; d = d / -3.0; e = e / 0.2; /* division */
|
|
if ((fabs(f - 4.2) > 0.00001) || (fabs(d - 210.36) > 0.00001) ||
|
|
(fabs(e - 4256.413) > 0.00001))
|
|
goto Fail;
|
|
|
|
i = f < d; j = d <= e; k = e > f; m = e >= e; /* relational operators */
|
|
if ((i != 1) || (j != 1) || (k != 1) || (m != 1))
|
|
goto Fail;
|
|
|
|
return 0;
|
|
|
|
Fail:
|
|
return 1;
|
|
}
|
|
|
|
int sub2(void)
|
|
|
|
{
|
|
i = 0 && e--; j = f && 0; k = d++ && --f; /* logical AND operator */
|
|
if ((i != 0) || (j != 0) || (k != 1) || (fabs(e - 4256.413) > 0.00001) ||
|
|
(fabs(d - 211.36) > 0.00001) || (fabs(f - 3.2) > 0.00001))
|
|
goto Fail;
|
|
|
|
i = 0 || e--; j = f || 0; k = d++ || --f; /* logical OR operator */
|
|
if ((i != 1) || (j != 1) || (k != 1) || (fabs(e - 4255.413) > 0.00001) ||
|
|
(fabs(d - 212.36) > 0.00001) || (fabs(f - 3.2) > 0.00001))
|
|
goto Fail;
|
|
|
|
f = e ? 8 >> 1: d--; /* conditional expression */
|
|
if ((fabs(f - 4.0) > 0.00001) || (fabs(d - 212.36) > 0.00001))
|
|
goto Fail;
|
|
|
|
return 0;
|
|
|
|
Fail:
|
|
return 1;
|
|
}
|
|
|
|
int sub3(void)
|
|
|
|
{
|
|
d += 5; e -= 8.9; f *= 3.0; /* compound assignment */
|
|
if ((fabs(f - 12.0) > 0.00001) || (fabs(d - 217.36) > 0.00001) ||
|
|
(fabs(e - 4246.513) > 0.00001))
|
|
goto Fail;
|
|
f /= -0.4;
|
|
if (fabs(f - (-30.0)) > 0.00001)
|
|
goto Fail;
|
|
|
|
f = (e = ((extended) (long) (e * 2.0)), d--, d--); /* comma operator */
|
|
if ((fabs(f - 216.36) > 0.00001) || (fabs(d - 215.36) > 0.00001) ||
|
|
(fabs(e - 8493.0) > 0.00001))
|
|
goto Fail;
|
|
|
|
return 0;
|
|
|
|
Fail:
|
|
return 1;
|
|
}
|
|
|
|
int main (void)
|
|
{
|
|
if (sub1()) goto Fail;
|
|
if (sub2()) goto Fail;
|
|
if (sub3()) goto Fail;
|
|
|
|
printf ("Passed Conformance Test 24.0.1\n");
|
|
return 0;
|
|
|
|
Fail:
|
|
printf ("Failed Conformance Test 24.0.1\n");
|
|
}
|