|
|
1.1 root 1: /* The Plum Hall Validation Suite for C
2: * Unpublished copyright (c) 1986-1991, Chiron Systems Inc and Plum Hall Inc.
3: * VERSION: 4
4: * DATE: 1993-01-01
5: * The "ANSI" mode of the Suite corresponds to the official ANSI C, X3.159-1989.
6: * As per your license agreement, your distribution is not to be moved or copied outside the Designated Site
7: * without specific permission from Plum Hall Inc.
8: */
9:
10: /****************************************************************************
11: ** Self-checking C source code generated by EGEN component of **
12: ** The Plum Hall Validation Suite for C. **
13: ** (C) 1986-1988 Chiron Systems Inc and Plum Hall Inc **
14: ** EGEN Version 1.09.000 88/08/21 **
15: ** **
16: ** EGEN -P -R1 -V -A -N5 -Dreal.gen ( @ @ ) @ ( @ @ ) **
17: ****************************************************************************/
18: #include "defs.h"
19:
20:
21: int main()
22: {
23: extern char *Filename;
24: auto float f1;
25: auto float * pf1;
26: auto float f2;
27: auto float * pf2;
28: auto float f3;
29: auto float * pf3;
30: auto float f4;
31: auto float * pf4;
32: auto double d1;
33: auto double * pd1;
34: auto double d2;
35: auto double * pd2;
36: auto double d3;
37: auto double * pd3;
38: auto double d4;
39: auto double * pd4;
40: auto double d5;
41: auto double * pd5;
42: auto double d6;
43: auto double * pd6;
44:
45: f1 = fvalue(1.000000E+000);
46: pf1 = &f1;
47: f2 = fvalue(2.000000E+000);
48: pf2 = &f2;
49: f3 = fvalue(3.000000E+000);
50: pf3 = &f3;
51: f4 = fvalue(4.000000E+000);
52: pf4 = &f4;
53: d1 = dvalue(1.000000000000000E+000);
54: pd1 = &d1;
55: d2 = dvalue(2.000000000000000E+000);
56: pd2 = &d2;
57: d3 = dvalue(3.000000000000000E+000);
58: pd3 = &d3;
59: d4 = dvalue(4.000000000000000E+000);
60: pd4 = &d4;
61: d5 = dvalue(5.000000000000000E+000);
62: pd5 = &d5;
63: d6 = dvalue(6.000000000000000E+000);
64: pd6 = &d6;
65: Filename = "real1.c";
66:
67: /* 2.00000000000000E+000 != 1.00000000000000E+000 => 1 */
68: /* 4.00000E+000 >= 1.00000000000000E+000 => 1 */
69: /* 1.00000E+000 = 1 => 1.00000E+000 */
70: /* 1 == 1.00000E+000 => 1 */
71: iequals(__LINE__, (((d2 != *pd1) || *pd6) == (f1 = (*pf4 >= d1))), 1);
72: fequals(__LINE__, f1, 1.00000E+000);
73:
74: /* post-- 3.00000E+000 => 4.00000E+000 */
75: /* 2.00000E+000 += 4.00000E+000 => 6.00000E+000 */
76: /* 1 <= 6.00000E+000 => 1 */
77: iequals(__LINE__, ((*pd2 || ((f1)++ )) <= (*pf2 += ((*pd4)-- ))), 1);
78: fequals(__LINE__, d4, 3.00000E+000);
79: fequals(__LINE__, f2, 6.00000E+000);
80: fequals(__LINE__, f1, 1.00000E+000);
81:
82: /* 1.00000000000000E+000 / 6.00000000000000E+000 => 1.66666666666667E-001 */
83: /* 1.66666666666667E-001 == 3.00000E+000 => 0 */
84: /* 6.00000E+000 >= 6.00000000000000E+000 => 1 */
85: /* 1 != 3.00000000000000E+000 => 1 */
86: /* 0 <= 1 => 1 */
87: iequals(__LINE__, (((d1 / *pd6) == *pf3) <= ((f2 >= d6) != d4)), 1);
88:
89: /* 3.00000E+000 - 3.00000000000000E+000 => 0.00000000000000E+000 */
90: iequals(__LINE__, (((*pf3 - d4) && f1) && (((*pd2)-- ) || *pf3)), 0);
91: dequals(__LINE__, d2, 2.00000000000000E+000);
92:
93: /* 1.00000000000000E+000 *= 3.00000000000000E+000 => 3.00000000000000E+000 */
94: /* 3.00000E+000 /= 3.00000E+000 => 1.00000E+000 */
95: /* 2.00000E+000 / 1.00000E+000 => 2.00000E+000 */
96: /* 2.00000E+000 >= 6.00000E+000 => 0 */
97: /* 1.00000E+000 < 0 => 0 */
98: iequals(__LINE__, ((*pf3 /= (d1 *= d3)) < ((d2 / *pf1) >= *pd6)), 0);
99: fequals(__LINE__, d1, 3.00000E+000);
100: fequals(__LINE__, f3, 1.00000E+000);
101:
102: return report(Filename);
103: }
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.