/* * (c) copyright 1983 by the Vrije Universiteit, Amsterdam, The Netherlands. * * This product is part of the Amsterdam Compiler Kit. * * Permission to use, sell, duplicate or disclose this software must be * obtained in writing. Requests for such permissions may be sent to * * Dr. Andrew S. Tanenbaum * Wiskundig Seminarium * Vrije Universiteit * Postbox 7161 * 1007 MC Amsterdam * The Netherlands * */ /* This program can be used to test C-compilers */ int t, ect, tct; /**********************************************************************/ /* * Testing basic function calls * */ main() { tct = 0; ect = 0; test1(); test2(); test3(); test4(); test5(); test6(); printf("End of test program, %d tests completed, %d errors detected\n", tct,ect); return 0 ; } e(n) int n; { ect++; printf("Error %d in test%d \n",n,t); } one() { return(1); } two() { return(2); } three() { return(3); } four() { return(4); } five() { return(5); } plus() { return ( one() + two() + three() + four() + five() ); } multipl() { return( one() * two() * three() * four() * five() ); } subtr() { return( - one() - two() - three() - four() - five() ); } test1() { int i; int count; t = 1; tct++; if ( one() != 1 ) e(1); if ( two() != 2 ) e(2); if ( three() != 3 ) e(3); if ( four() != 4 ) e(4); if ( five() != 5 ) e(5); if ( (one() + two()) != 3 ) e(6); if ( ((((((one() + two())))))) != 3) e(7); if ( (one() * three()) != 3) e(8); if (( (four() + three()) * two()) != 14) e(9); if ( (four() + four()) != (two() * four()) ) e(10); if ( (four() - four()) / three() ) e(11); if (( four() + 3 * 12 - ( one() * two() * 2 ) ) != 36 ) e(12); if ( one() & two() & four() & three() ) e(13); if ( !( three() && two() ) ) e(14); for (i=0; i<8; i++) { count = one() + two() + three() + four(); count = count * one(); count = count * two() - one() - two() - three() - four(); } if (count != 10) e(15); if ( !one() ) e(16); if ( plus() != 15 ) e(17); if ( multipl() != 120 ) e(18); if ( subtr() != -15 ) e(19); if ( -subtr() != plus() ) e(18); if ( -subtr() != plus() ) e(21); } echo(a) int a; { return ( a ); } min(a,b) int a,b; { if ( a < b ) return(a); return(b); } max1(a,b) int a,b; { if ( a < b ) return(b); return(a); } max2(a,b) int a,b; { return ( ( a < b ? b : a ) ); } test2() { int i,j; int a,b; t = 2; tct++; if ( echo(1) != 1 ) e(1); if ( echo(3) != 3 ) e(2); if ( echo(0) ) e(3); if ( echo(2) + echo(3) != echo(5) ) e(4); if ( echo( 2 + 3 ) != 5 ) e(5); if ( echo ( 1 + 2 + 3 + 4 + 5 ) != 10 + echo(5) ) e(6); if (( echo( 2<<1 ) ) != 4 ) e(7); if ( echo( 2 >> 1 ) != 1 ) e(8); if ( echo( 1 << 4 ) != echo( 2 << 3 ) ) e(9); if ( echo( echo(4) ) != echo(4) ) e(10); if (( echo ( echo ( echo( echo ( echo ( 3 ) ) ) ) ) ) != 3 ) e(11); if ( echo( echo( echo(2+3-4+echo(4)*echo(2))) ) != 9 ) e(12); if ( min(1,2) != 1) e(13); if (min(0,45) != 0) e(14); if (min(45,0) != 0) e(15); if (min(-72,-100) != -100) e(16); if (min(-100,-72) != -100) e(17); if (min(1<<3,2<<3) != (1<<3) ) e(18); if ( min( echo(3), echo(3) ) != echo (echo(3)) ) e(19); if ( max1('a','b') != 'b' ) e(20); if ( max1('b','a') != 'b' ) e(21); if ( max1(-3,54+2) != ( -3 < 54+2 ? 54+2 : -3 ) ) e(22); if (max1('a'+'b'+34,'a'*2) != max2('a'*2,'a'+'b'+34)) e(23); if (max1(345/23,4) != max1( echo(345/23), 4) ) e(24); if ( max1( max1(2,3), max1(2,3) ) != max1(2,3) ) e(25); for (i=3; i<5; i++) if ((max1(i,-i)) != i) e(26); for (j=min('a',34); jmax1(min(34,'a'),max2(34,'a')) ) e(28); } a=b= -32768; if ( min(echo(a),a) != a) e(29); if ( max1(echo(b),max1(b,b)) != b) e(30); } sum(k) int k; { if (k<=0) return(0); return(k+sum(k-1)); } formula(k) int k; { if (k<=0) return(0); return ( ((((( (k*(k+1))/2 ))))) ); } test3() { int k; int count; t = 3; tct++; count=0; if ( sum(-4) != 0 ) e(1); if ( sum(0) != 0 ) e(2); if ( sum(2) != 3 ) e(3); if ( sum(10) != 55 ) e(4); if ( sum(34) != formula(34) ) e(5); if ( sum(101) != formula(101) ) e(6); if ( sum( sum(11) ) != formula( formula(11) ) ) e(7); if ( sum( sum(11) ) != formula( sum(11) ) ) e(8); if ( sum( sum( sum(4) )) != sum ( formula ( sum( 4) )) ) e(9); for (k = sum(-45); k