mirror of
https://github.com/byteworksinc/ORCA-C.git
synced 2025-01-21 21:32:00 +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.
74 lines
1.5 KiB
C++
74 lines
1.5 KiB
C++
/* Conformance Test 2.7.2.1: Test single-precision floating-point constants */
|
|
|
|
#include <math.h>
|
|
|
|
int printf(const char *, ...);
|
|
|
|
int main (void)
|
|
{
|
|
float a;
|
|
|
|
/* Test maximum and minimum single-precision floating-point values, using */
|
|
/* all valid syntactic constructs. */
|
|
a = 1e+38;
|
|
if (fabs(a - 1.E38) > 1e32)
|
|
goto Fail;
|
|
|
|
a = .1e-37;
|
|
if (fabs(a - 0.1e-37) > 1e-42)
|
|
goto Fail;
|
|
|
|
/* Test other miscellaneous values. */
|
|
a = 32767.F;
|
|
if (fabs(a - 32767.000E+00000) > 0.01)
|
|
goto Fail;
|
|
|
|
a = 123.4567;
|
|
if (fabs(a - 1.234567E+02) > 0.001)
|
|
goto Fail;
|
|
|
|
a = 00000000;
|
|
if (a != 0)
|
|
goto Fail;
|
|
|
|
a = .456789;
|
|
if (fabs(a - 456789E-6) > 0.00001)
|
|
goto Fail;
|
|
|
|
/* Test negative values. */
|
|
a = -1e+38;
|
|
if (fabs(a - (-1.E38)) > 1e33)
|
|
goto Fail;
|
|
|
|
a = -.1e-37;
|
|
if (fabs(a - (-1.0e-38)) > 1e-42)
|
|
goto Fail;
|
|
|
|
/* Test other miscellaneous values. */
|
|
a = -32768.f;
|
|
if (fabs(a - (-32768.000E+00000)) > 0.01)
|
|
goto Fail;
|
|
|
|
a = -123.4567;
|
|
if (fabs(a - (-1.234567E+02)) > 0.001)
|
|
goto Fail;
|
|
|
|
a = -.456789;
|
|
if (fabs(a - (-456789E-6)) > 0.00001)
|
|
goto Fail;
|
|
|
|
/* Test floating-point constant with many characters in a digit string */
|
|
a = \
|
|
000000000000000000000000000000000000000000000000000000000000000000000000000007.0
|
|
;
|
|
|
|
if (fabs(a - 7.0) > 0.00001)
|
|
goto Fail;
|
|
|
|
printf ("Passed Conformance Test 2.7.2.1\n");
|
|
return 0;
|
|
|
|
Fail:
|
|
printf("Failed Conformance Test 2.7.2.1\n");
|
|
}
|