C*********************************************************************** C***** FORTRAN 77 C***** FM503 C***** BLKD2 - (261) C***** THIS PROGRAM USES FM504 (UNNAMED BLOCK DATA SUBPROGRAM C***** AND SUBROUTINE SN505 C*********************************************************************** C***** TESTING OF BLOCK DATA SUBPROGRAMS ANS REF C***** DATA INTERNAL FORMS 16 C***** THIS SEGMENT USES SEGMENTS 702 AND 703, BLOCK DATA PROGRAM C***** FM504 AND SUBROUTINE SN505 C***** CBB** ********************** BBCCOMNT ********************************** C**** C**** 1978 FORTRAN COMPILER VALIDATION SYSTEM C**** VERSION 2.0 C**** C**** C**** SUGGESTIONS AND COMMENTS SHOULD BE FORWARDED TO C**** GENERAL SERVICES ADMINISTRATION C**** FEDERAL SOFTWARE TESTING CENTER C**** 5203 LEESBURG PIKE, SUITE 1100 C**** FALLS CHURCH, VA. 22041 C**** C**** (703) 756-6153 C**** CBE** ********************** BBCCOMNT ********************************** C***** C***** S P E C I F I C A T I O N S SEGMENT 261 C***** C***** DECLARATION OF VARIABLES IN COMMON BLOCKS C***** DOUBLE PRECISION AXVD, DVCORR C***** COMPLEX AXVC, ZVCORR C***** LOGICAL AXVB C***** CHARACTER*6 A6XVK, B6XVK, CVCORR C***** C***** COMMON /BLK9/ AXVS, BXVS, IXVI, AXVD, AXVC, AXVB C***** COMMON /BLK7/ A6XVK, B6XVK C***** C***** CALL SN505 STOP C***** C***** END OF TEST SEGMENT 261 END C*********************************************************************** C***** FORTRAN 77 C***** FM504 BDS2 (UNNAMED) - (702) C***** THIS BLOCK DATA SUBPROGRAM IS USED BY FM503 C*********************************************************************** C***** C***** GENERAL PURPOSE C***** THIS SEGMENT CONTAINS A BLOCK DATA SUBPROGRAM THAT IS C***** TO BE RUN WITH TEST SEGMENT 261 C***** THIS SEGMENT WILL TEST INTERNAL DATA FORMS, AS WELL C***** AS THE USE OF UNNAMED BLOCK DATA PROGRAM C***** BLOCK DATA C***** C***** DECLARATION OF VARIABLES IN COMMON BLOCKS DOUBLE PRECISION AXVD COMPLEX AXVC LOGICAL AXVB CHARACTER*6 A6XVK, B6XVK C***** COMMON /BLK9/ AXVS, BXVS, IXVI, AXVD, AXVC, AXVB COMMON /BLK7/ A6XVK, B6XVK DATA AXVS, BXVS, IXVI, AXVD, AXVC, AXVB /34.25E-1, 43.23, 21, 1 1.23456, (234.23, 34.9), .TRUE./ DATA A6XVK, B6XVK /'ABCDE', 'FGHIJK'/ C***** END C*********************************************************************** C***** FORTRAN 77 C***** FM505 BLKD2Q - (703) C***** THIS SUBROUTINE IS CALLED BY FM503 C*********************************************************************** C***** C***** GENERAL PURPOSE C***** THIS SEGMENT IS TO BE RUN WITH TEST SEGMENT 261 C***** THIS SEGMENT CONTAINS A SUBROUTINE THAT CHECKS TO SEE IF C***** IF THE BLOCK DATA PROGRAM CORRECTLY INITIALIZED THE MANY C***** VARIABLES C***** SUBROUTINE SN505 C***** C***** C***** DECLARATION OF VARIABLES IN COMMON BLOCKS DOUBLE PRECISION AXVD, DVCORR COMPLEX AXVC, ZVCORR LOGICAL AXVB CHARACTER*6 A6XVK, B6XVK, CVCORR C***** COMMON /BLK9/ AXVS, BXVS, IXVI, AXVD, AXVC, AXVB COMMON /BLK7/ A6XVK, B6XVK C***** LOCAL DECLARATION DOUBLE PRECISION AVD COMPLEX AVC REAL R2E(2) EQUIVALENCE (AVC, R2E) C***** CBB** ********************** BBCINITA ********************************** C**** SPECIFICATION STATEMENTS C**** CHARACTER ZVERS*13, ZVERSD*17, ZDATE*17, ZPROG*5, ZCOMPL*20, 1 ZNAME*20, ZTAPE*10, ZPROJ*13, REMRKS*31, ZTAPED*13 CBE** ********************** BBCINITA ********************************** CBB** ********************** BBCINITB ********************************** C**** INITIALIZE SECTION DATA ZVERS, ZVERSD, ZDATE 1 /'VERSION 2.0 ', '82/08/02*18.33.46', '*NO DATE*TIME'/ DATA ZCOMPL, ZNAME, ZTAPE 1 /'*NONE SPECIFIED*', '*NO COMPANY NAME*', '*NO TAPE*'/ DATA ZPROJ, ZTAPED, ZPROG 1 /'*NO PROJECT*', '*NO TAPE DATE', 'XXXXX'/ DATA REMRKS /' '/ C**** THE FOLLOWING 9 COMMENT LINES (CZ01, CZ02, ...) CAN BE REPLACED C**** FOR IDENTIFYING THE TEST ENVIRONMENT C**** CZ01 ZVERS = 'VERSION OF THE COMPILER VALIDATION SYSTEM' CZ02 ZVERSD = 'CREATION DATE/TIME OF THE COMPILER VALIDATION SYSTEM' CZ03 ZPROG = 'PROGRAM NAME' ZDATE = ' DEC. 1983 ' ZCOMPL = ' ICL VME FORTRAN77 ' ZPROJ = ' LANG. CENTRE' ZNAME = 'ICL ' ZTAPE = 'M999 ' ZTAPED = '831005 ' C IVPASS = 0 IVFAIL = 0 IVDELE = 0 IVINSP = 0 IVTOTL = 0 IVTOTN = 0 ICZERO = 0 C C I01 CONTAINS THE LOGICAL UNIT NUMBER FOR THE CARD READER. I01 = 05 C I02 CONTAINS THE LOGICAL UNIT NUMBER FOR THE PRINTER. I02 = 06 C CX010 REPLACED BY FEXEC X-010 CONTROL CARD (CARD-READER UNIT NUMBER). C THE CX010 CARD IS FOR OVERRIDING THE PROGRAM DEFAULT I01 = 5 CX011 REPLACED BY FEXEC X-011 CONTROL CARD. CX011 IS FOR SYSTEMS C REQUIRING ADDITIONAL STATEMENTS FOR FILES ASSOCIATED WITH CX010. C CX020 REPLACED BY FEXEC X-020 CONTROL CARD (PRINTER UNIT NUMBER). C THE CX020 CARD IS FOR OVERRIDING THE PROGRAM DEFAULT I02= 6 CX021 REPLACED BY FEXEC X-021 CONTROL CARD. CX021 IS FOR SYSTEMS C REQUIRING ADDITIONAL STATEMENTS FOR FILES ASSOCIATED WITH CX020. C CBE** ********************** BBCINITB ********************************** NUVI = I02 IVTOTL = 8 ZPROG = 'FM503' CBB** ********************** BBCHED0A ********************************** C**** C**** WRITE REPORT TITLE C**** WRITE (I02, 90002) WRITE (I02, 90006) WRITE (I02, 90007) WRITE (I02, 90008) ZVERS, ZVERSD WRITE (I02, 90009) ZPROG, ZPROG WRITE (I02, 90010) ZDATE, ZCOMPL CBE** ********************** BBCHED0A ********************************** WRITE(NUVI,26100) 26100 FORMAT( 1H , / 39H BLKD2 - (261) BLOCK DATA SUBPROGRAM --// 1 21H DATA INTERNAL FORMS// 2 15H ANS REF. - 16) CBB** ********************** BBCHED0B ********************************** C**** WRITE DETAIL REPORT HEADERS C**** WRITE (I02,90004) WRITE (I02,90004) WRITE (I02,90013) WRITE (I02,90014) WRITE (I02,90015) IVTOTL CBE** ********************** BBCHED0B ********************************** C***** CT001* TEST 1 REAL VARIABLE - EXPONENT FORM IVTNUM = 1 AVS = AXVS IF (AVS - 0.34248E+01) 20010, 10010, 40010 40010 IF (AVS - 0.34252E+01) 10010, 10010, 20010 10010 IVPASS = IVPASS + 1 WRITE (NUVI, 80002) IVTNUM GO TO 0011 20010 IVFAIL = IVFAIL + 1 RVCORR = 34.25E-1 WRITE (NUVI, 80012) IVTNUM, AVS, RVCORR 0011 CONTINUE CT002* TEST 2 REAL VARIABLE - NON EXPONENT FORM IVTNUM = 2 AVS = BXVS IF (AVS - 0.43227E+02) 20020, 10020, 40020 40020 IF (AVS - 0.43233E+02) 10020, 10020, 20020 10020 IVPASS = IVPASS + 1 WRITE (NUVI, 80002) IVTNUM GO TO 0021 20020 IVFAIL = IVFAIL + 1 RVCORR = 43.23 WRITE (NUVI, 80012) IVTNUM, AVS, RVCORR 0021 CONTINUE CT003* TEST 3 INTEGER VARIABLE IVTNUM = 3 IVI = IXVI IF (IVI - 21) 20030, 10030, 20030 10030 IVPASS = IVPASS + 1 WRITE (NUVI, 80002) IVTNUM GO TO 0031 20030 IVFAIL = IVFAIL + 1 IVCORR = 21 WRITE (NUVI, 80010) IVTNUM, IVI, IVCORR 0031 CONTINUE CT004* TEST 4 DOUBLE PRECISION VARIABLE IVTNUM = 4 AVD = AXVD IF (AVD - 0.12345D+01) 20040, 10040, 40040 40040 IF (AVD - 0.12347D+01) 10040, 10040, 20040 10040 IVPASS = IVPASS + 1 WRITE (NUVI, 80002) IVTNUM GO TO 0041 20040 IVFAIL = IVFAIL + 1 DVCORR = 1.23456D+0 WRITE (NUVI, 80031) IVTNUM, AVD, DVCORR 0041 CONTINUE CT005* TEST 5 COMPLEX VARIABLE IVTNUM = 5 AVC = AXVC IF (R2E(1) - 0.23421E+03) 20050, 40052, 40051 40051 IF (R2E(1) - 0.23425E+03) 40052, 40052, 20050 40052 IF (R2E(2) - 0.34898E+02) 20050, 10050, 40050 40050 IF (R2E(2) - 0.34902E+02) 10050, 10050, 20050 10050 IVPASS = IVPASS + 1 WRITE (NUVI, 80002) IVTNUM GO TO 0051 20050 IVFAIL = IVFAIL + 1 ZVCORR = (234.23, 34.9) WRITE (NUVI, 80045) IVTNUM, AVC, ZVCORR 0051 CONTINUE CT006* TEST 6 LOGICAL VARIABLE IVTNUM = 6 IVI = 0 IF (AXVB) IVI = 1 IF (IVI - 1) 20060, 10060, 20060 10060 IVPASS = IVPASS + 1 WRITE (NUVI, 80002) IVTNUM GO TO 0061 20060 IVFAIL = IVFAIL + 1 LVCORR = 1 REMRKS = '1 = TRUE ; 0 = FALSE' WRITE (NUVI, 80008) IVTNUM, REMRKS WRITE (NUVI, 80024) IVI WRITE (NUVI, 80026) LVCORR 0061 CONTINUE CT007* TEST 7 6 CHARACTER VARIABLE - INIT WITH 5 CHARACTERS IVTNUM = 7 IVI = 0 IF (A6XVK.EQ.'ABCDE ') IVI = 1 IF (IVI - 1) 20070, 10070, 20070 10070 IVPASS = IVPASS + 1 WRITE (NUVI, 80002) IVTNUM GO TO 0071 20070 IVFAIL = IVFAIL + 1 CVCORR = 'ABCDE ' WRITE (NUVI, 80018) IVTNUM, A6XVK, CVCORR 0071 CONTINUE CT008* TEST 8 6 CHARACTER VARIABLE - INIT WITH 6 CHARACTERS IVTNUM = 8 IVI = 0 IF (B6XVK.EQ.'FGHIJK') IVI = 1 IF (IVI - 1) 20080, 10080, 20080 10080 IVPASS = IVPASS + 1 WRITE (NUVI, 80002) IVTNUM GO TO 0081 20080 IVFAIL = IVFAIL + 1 CVCORR = 'FGHIJK' WRITE (NUVI, 80018) IVTNUM, B6XVK, CVCORR 0081 CONTINUE C***** CBB** ********************** BBCSUM0 ********************************** C**** WRITE OUT TEST SUMMARY C**** IVTOTN = IVPASS + IVFAIL + IVDELE + IVINSP WRITE (I02, 90004) WRITE (I02, 90014) WRITE (I02, 90004) WRITE (I02, 90020) IVPASS WRITE (I02, 90022) IVFAIL WRITE (I02, 90024) IVDELE WRITE (I02, 90026) IVINSP WRITE (I02, 90028) IVTOTN, IVTOTL CBE** ********************** BBCSUM0 ********************************** CBB** ********************** BBCFOOT0 ********************************** C**** WRITE OUT REPORT FOOTINGS C**** WRITE (I02,90016) ZPROG, ZPROG WRITE (I02,90018) ZPROJ, ZNAME, ZTAPE, ZTAPED WRITE (I02,90019) CBE** ********************** BBCFOOT0 ********************************** CBB** ********************** BBCFMT0A ********************************** C**** FORMATS FOR TEST DETAIL LINES C**** 80000 FORMAT (1H ,2X,I3,4X,7HDELETED,32X,A31) 80002 FORMAT (1H ,2X,I3,4X,7H PASS ,32X,A31) 80004 FORMAT (1H ,2X,I3,4X,7HINSPECT,32X,A31) 80008 FORMAT (1H ,2X,I3,4X,7H FAIL ,32X,A31) 80010 FORMAT (1H ,2X,I3,4X,7H FAIL ,/,1H ,15X,10HCOMPUTED= , 1I6,/,1H ,15X,10HCORRECT= ,I6) 80012 FORMAT (1H ,2X,I3,4X,7H FAIL ,/,1H ,16X,10HCOMPUTED= , 1E12.5,/,1H ,16X,10HCORRECT= ,E12.5) 80018 FORMAT (1H ,2X,I3,4X,7H FAIL ,/,1H ,16X,10HCOMPUTED= , 1A21,/,1H ,16X,10HCORRECT= ,A21) 80020 FORMAT (1H ,16X,10HCOMPUTED= ,A21,1X,A31) 80022 FORMAT (1H ,16X,10HCORRECT= ,A21,1X,A31) 80024 FORMAT (1H ,16X,10HCOMPUTED= ,I6,16X,A31) 80026 FORMAT (1H ,16X,10HCORRECT= ,I6,16X,A31) 80028 FORMAT (1H ,16X,10HCOMPUTED= ,E12.5,10X,A31) 80030 FORMAT (1H ,16X,10HCORRECT= ,E12.5,10X,A31) 80050 FORMAT (1H ,48X,A31) CBE** ********************** BBCFMT0A ********************************** CBB** ********************** BBCFMAT1 ********************************** C**** FORMATS FOR TEST DETAIL LINES - FULL LANGUAGE C**** 80031 FORMAT (1H ,2X,I3,4X,7H FAIL ,/,1H ,16X,10HCOMPUTED= , 1D17.10,/,1H ,16X,10HCORRECT= ,D17.10) 80033 FORMAT (1H ,16X,10HCOMPUTED= ,D17.10,10X,A31) 80035 FORMAT (1H ,16X,10HCORRECT= ,D17.10,10X,A31) 80037 FORMAT (1H ,16X,10HCOMPUTED= ,1H(,E12.5,2H, ,E12.5,1H),6X,A31) 80039 FORMAT (1H ,16X,10HCORRECT= ,1H(,E12.5,2H, ,E12.5,1H),6X,A31) 80041 FORMAT (1H ,16X,10HCOMPUTED= ,1H(,F12.5,2H, ,F12.5,1H),6X,A31) 80043 FORMAT (1H ,16X,10HCORRECT= ,1H(,F12.5,2H, ,F12.5,1H),6X,A31) 80045 FORMAT (1H ,2X,I3,4X,7H FAIL ,/,1H ,16X,10HCOMPUTED= , 11H(,F12.5,2H, ,F12.5,1H)/,1H ,16X,10HCORRECT= , 21H(,F12.5,2H, ,F12.5,1H)) CBE** ********************** BBCFMAT1 ********************************** CBB** ********************** BBCFMT0B ********************************** C**** FORMAT STATEMENTS FOR PAGE HEADERS C**** 90002 FORMAT (1H1) 90004 FORMAT (1H ) 90006 FORMAT (1H ,20X,31HFEDERAL SOFTWARE TESTING CENTER) 90007 FORMAT (1H ,19X,34HFORTRAN COMPILER VALIDATION SYSTEM) 90008 FORMAT (1H ,21X,A13,A17) 90009 FORMAT (1H ,/,2H *,A5,6HBEGIN*,12X,15HTEST RESULTS - ,A5,/) 90010 FORMAT (1H ,8X,16HTEST DATE*TIME= ,A17,15H - COMPILER= ,A20) 90013 FORMAT (1H ,8H TEST ,10HPASS/FAIL ,6X,17HDISPLAYED RESULTS, 1 7X,7HREMARKS,24X) 90014 FORMAT (1H ,46H----------------------------------------------, 1 33H---------------------------------) 90015 FORMAT (1H ,48X,17HTHIS PROGRAM HAS ,I3,6H TESTS,/) C**** C**** FORMAT STATEMENTS FOR REPORT FOOTINGS C**** 90016 FORMAT (1H ,/,2H *,A5,4HEND*,14X,14HEND OF TEST - ,A5,/) 90018 FORMAT (1H ,A13,13X,A20,7H * ,A10,1H/, 1 A13) 90019 FORMAT (1H ,26HFOR OFFICIAL USE ONLY ,35X,15HCOPYRIGHT 1982) C**** C**** FORMAT STATEMENTS FOR RUN SUMMARY C**** 90020 FORMAT (1H ,21X,I5,13H TESTS PASSED) 90022 FORMAT (1H ,21X,I5,13H TESTS FAILED) 90024 FORMAT (1H ,21X,I5,14H TESTS DELETED) 90026 FORMAT (1H ,21X,I5,25H TESTS REQUIRE INSPECTION) 90028 FORMAT (1H ,21X,I5,4H OF ,I3,15H TESTS EXECUTED) CBE** ********************** BBCFMT0B ********************************** C***** END