File:  [Research Unix] / researchv10no / cmd / lcc / ph / mix5.c
Revision 1.1.1.1 (vendor branch): download - view: text, annotated - select for diffs
Tue Apr 24 17:21:35 2018 UTC (8 years, 1 month ago) by root
Branches: belllabs, MAIN
CVS tags: researchv10, HEAD
researchv10 Norman

/* The Plum Hall Validation Suite for C
 * Unpublished copyright (c) 1986-1991, Chiron Systems Inc and Plum Hall Inc.
 * VERSION: 4
 * DATE: 1993-01-01
 * The "ANSI" mode of the Suite corresponds to the official ANSI C, X3.159-1989.
 * As per your license agreement, your distribution is not to be moved or copied outside the Designated Site
 * without specific permission from Plum Hall Inc.
 */

/****************************************************************************
 ** Self-checking C source code generated by EGEN component of             **
 **    The Plum Hall Validation Suite for C.                               **
 **    (C) 1986-1988 Chiron Systems Inc and Plum Hall Inc                  **
 **    EGEN Version 1.09.000  88/08/21                                     **
 **                                                                        **
 **    EGEN -P -R5 -V -A -N5 -Dmixed.gen ( @ @ ) @ ( @ @ )                 **
 ****************************************************************************/
#include "defs.h"


int main()
	{
	extern char *Filename;
	static float f1;
	auto float * pf1;
	static long stlong1;
	static float f2;
	auto float * pf2;
	static long stlong2;
	static float f3;
	static float * pf3;
	auto long stlong3;
	static float f4;
	static float * pf4;
	static long stlong4;
	static double d1;
	auto double * pd1;
	static long stlong5;
	static double d2;
	static double * pd2;
	static long stlong6;
	auto double d3;
	static double * pd3;
	static long stlong7;
	static double d4;
	static double * pd4;
	auto long stlong8;

	f1 = fvalue(1.100000E+000);
	pf1 = &f1;
	stlong1 = lvalue(1L);
	f2 = fvalue(2.200000E+000);
	pf2 = &f2;
	stlong2 = lvalue(2L);
	f3 = fvalue(3.300000E+000);
	pf3 = &f3;
	stlong3 = lvalue(3L);
	f4 = fvalue(4.400000E+000);
	pf4 = &f4;
	stlong4 = lvalue(4L);
	d1 = dvalue(1.100000000000000E+000);
	pd1 = &d1;
	stlong5 = lvalue(5L);
	d2 = dvalue(2.200000000000000E+000);
	pd2 = &d2;
	stlong6 = lvalue(6L);
	d3 = dvalue(3.300000000000000E+000);
	pd3 = &d3;
	stlong7 = lvalue(7L);
	d4 = dvalue(4.400000000000000E+000);
	pd4 = &d4;
	stlong8 = lvalue(8L);
	Filename = "mix5.c";

	/* 7L - 2L => 5L */
	/* 4.40000000000000E+000 += 5L => 9.40000000000000E+000 */
	iequals(__LINE__, ((d4 += (stlong7 - stlong2)) || ((stlong2 << stlong4) || stlong6)), 1);
	dequals(__LINE__, d4, 9.40000000000000E+000);

	/* 7L * 2L => 14L */
	/* 14L | 5L => 15L */
	/* 15L > 1 => 1 */
	iequals(__LINE__, (((stlong7 * stlong2) | stlong5) > (f1 || (f3 <= stlong5))), 1);

	/* 1.10000000000000E+000 <= 2.20000000000000E+000 => 1 */
	/* 5L -= 1 => 4L */
	/* pre++ 1.10000E+000 => 2.10000E+000 */
	/* 6L == 2.10000E+000 => 0 */
	/* 4L - 0 => 4L */
	lequals(__LINE__, ((stlong5 -= (*pd1 <= d2)) - (stlong6 == ( ++ f1))), 4L);
	fequals(__LINE__, f1, 2.10000E+000);
	lequals(__LINE__, stlong5, 4L);

	/* 8L <<= 1L => 16L */
	/* 7L = 16L => 16L */
	/* neg 2.20000E+000 => -2.20000E+000 */
	/* -2.20000E+000 / 3.30000E+000 => -6.66667E-001 */
	/* 16L * -6.66667E-001 => -1.06667E+001 */
	fequals(__LINE__, ((stlong7 = (stlong8 <<= stlong1)) * (( - f2) / f3)), -1.0666666666666666666666667E+001);
	lequals(__LINE__, stlong8, 16L);
	lequals(__LINE__, stlong7, 16L);

	/* 1.10000000000000E+000 + 2.10000E+000 => 3.2000000E+000 */
	/* 16L == 3.2000000E+000 => 0 */
	/* 1L - 16L => -15L */
	/* 6L |= -15L => -9L */
	/* 0 - -9L => 9L */
/* 	lequals(__LINE__, ((stlong8 == (*pd1 + *pf1)) - (stlong6 |= (stlong1 - stlong7))), 9L);  /* non-portable */
/* 	lequals(__LINE__, stlong6, -9L);  /* non-portable */

	return 	report(Filename);
	}

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.