C*********************************************************************** C***** FORTRAN 77 C***** FM404 AFMTS - (022) C***** C*********************************************************************** C***** GENERAL PURPOSE SUBSET REFS C***** TO TEST SIMPLE FORMAT AND FORMATTED DATA 12.9.5.2 C***** TRANSFER STATEMENTS IN EXTERNAL SEQUENTIAL I/O SO 13.1.1 C***** THAT THESE FEATURES MAY BE USED IN OTHER TEST 12.8.1 C***** PROGRAM SEGMENTS FOR CHARACTER DATA TYPES. 4.8 C***** C***** RESTRICTIONS OBSERVED C***** * ALL FORMAT STATEMENTS ARE LABELED 12.8.2 C***** * H AND X DESCRIPTORS ARE NEVER REPEATED 13.1.1 C***** * FIELD WIDTH IS NEVER ZERO 13.5.11 C***** * IF AN I/O LIST SPECIFIES AT LEAST ONE LIST ITEM 13.3 C***** AT LEAST ONE REPEATABLE EDIT DESCRIPTOR MUST EXIST C***** IN THE FORMAT SPECIFICATION. C***** * ITEMS IN I/O LIST CORRESPOND TO FORMAT DESCRIPTORS 13.3 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 INPUT DATA TO THIS SEG. CONSISTS OF 6 DATA CARD IMAGES IN COLS. 1 - 55 COL. 1--------------------------------------------47 CARD 1 QRSTMNOPIJKLYZ127890ABCD3456EFGHUVWX/(),.' =+-* CARD 2 AABABCABCDABCDEABCDEFWXYZWXYZWXYZWXYZWXYZWXYZ CARD 3 112123123412345123456 CARD 4 GGGGHHHHIIIIJJJJ CARD 5 ----LLLL CARD 6 ....NNNN C***** C***** S P E C I F I C A T I O N S SEGMENT 022 C***** CHARACTER*1 A1VK CHARACTER*2 A2VK CHARACTER*3 A3VK CHARACTER*4 A4VK, A41K(6), A43K(2,2,3) CHARACTER*5 A5VK CHARACTER*6 A6VK 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 ********************************** IRVI = I01 NUVI = I02 IVTOTL = 5 ZPROG = 'FM404' 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 ********************************** C***** C***** HEADER FOR SEGMENT 22 WRITE (NUVI,02200) 02200 FORMAT(1H , /1X,38H AFMTS - (022) FORMATTED DATA TRANSFER// 1 1X,19H USING A-CONVERSION//1X, 2 38H SUBSET REFS - 12.9.5.2 13.3 13.5.11) 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***** C***** TESTS THAT ALL FORTRAN (SUBSET) CHARACTERS MAY BE READ. 3.1 C***** C***** INPUT CARD 1 READ(IRVI, 02201) A43K(1,1,1), A43K(1,1,2), A43K(1,1,3), 1 A43K(1,2,1), A43K(1,2,2), A43K(1,2,3), A43K(2,1,1), 2 A43K(2,1,2), A43K(2,1,3), A6VK, A5VK 02201 FORMAT(9A4, A6, A5) CT001* TEST 1 IVTNUM = 1 REMRKS = '2 COMPUTED LINES EXPECTED' WRITE (NUVI, 80004) IVTNUM, REMRKS WRITE (NUVI, 80020) WRITE(NUVI, 70010) A43K(1,2,3), A43K(2,1,2), A43K(1,1,3), 1 A43K(1,1,2), A43K(1,1,1), A43K(2,1,3), A43K(1,2,1), 2 A43K(2,1,1), A43K(1,2,2), A5VK, A6VK 70010 FORMAT(26X,9A4/25X,A5,A6) IVINSP = IVINSP + 1 WRITE (NUVI, 70011) 70011 FORMAT(1H ,16X,10HCORRECT: ,22X,32HCORRESPONDING LINE(S) MUST M 1ATCH) WRITE (NUVI, 70012) 70012 FORMAT(26X, 36HABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890/ 1 26X,10H=+-*/(),.') C***** C***** AW CONVERSION IS USED IN THE FORMAT STATEMENTS. 3.5.11 C***** SOME FORMAT DESCRIPTORS ARE REPEATED. C***** THE FOLLOWING THREE CASES ARE USED FOR BOTH INPUT AND OUTPUT. C***** INPUT FIELD WIDTH = CHARACTER VARIABLE LENGTH C***** INPUT FIELD WIDTH < CHARACTER VARIABLE LENGTH C***** INPUT FIELD WIDTH > CHARACTER VARIABLE LENGTH C***** C***** INPUT CARD 2 READ(IRVI, 02203) A41K(1), A41K(2), A41K(3), A41K(4), A41K(5), 1 A41K(6), A1VK, A2VK, A3VK, A4VK, A5VK, A6VK 02203 FORMAT(A1, A2, 1A3, A4, A5, 1(A6), A4, 2A4, 3(A4)) CT002* TEST 2 IVTNUM = 2 REMRKS = '2 COMPUTED LINES EXPECTED' WRITE (NUVI, 80004) IVTNUM, REMRKS WRITE (NUVI, 80020) WRITE(NUVI, 70020) A41K(1), A41K(2), A41K(3), A41K(4), A41K(5), 1 A41K(6), A6VK, A5VK, A4VK, A3VK, A2VK, A1VK 70020 FORMAT(26X,A4,A4,4A4/26X,A6,A5,A4,A3,A2,A1) IVINSP = IVINSP + 1 WRITE (NUVI, 70011) WRITE (NUVI, 70022) 70022 FORMAT(26X,24HA AB ABC ABCDBCDECDEF/ 1 26X,21HWXYZ WXYZ WXYZXYZYZZ) C***** CT003* TEST 3 IVTNUM = 3 REMRKS = '2 COMPUTED LINES EXPECTED' WRITE (NUVI, 80004) IVTNUM, REMRKS WRITE (NUVI, 80020) WRITE(NUVI, 70030) A41K(1), A41K(2), A41K(3), A41K(4), A41K(5), 1 A41K(6), A1VK, A2VK, A3VK, A4VK, A5VK, A6VK 70030 FORMAT(26X,A1,A2,A3,A4,A5,A6/23X,4(A4),A4,A4) IVINSP = IVINSP + 1 WRITE (NUVI, 70011) WRITE (NUVI, 70032) 70032 FORMAT(26X,21HAABABCABCD BCDE CDEF/ 1 26X,21HZ YZ XYZWXYZWXYZWXYZ) C***** C***** A CONVERSION IS USED IN THE FORMAT STATEMENTS. 3.5.11 C***** SOME FORMAT DESCRIPTORS ARE REPEATED. C***** READ WITH A-EDIT DESCRIPTOR, A STRING, FOLLOWED BY ANOTHER C***** FIELD TO SHOW THAT THE POINTER PICKS UP THE NEXT FIELD C***** FOLLOWING THE COUNT OF THE LENGTH OF THE DECLARED VARIABLE. C***** C***** INPUT CARD 3 READ(IRVI, 02206) A1VK, A2VK, A3VK, A4VK, A5VK, A6VK 02206 FORMAT(A, 2A, 3(A)) CT004* TEST 4 IVTNUM = 4 WRITE (NUVI, 80004) IVTNUM WRITE (NUVI, 80020) WRITE(NUVI, 70040) A1VK, A2VK, A3VK, A4VK, A5VK, A6VK 70040 FORMAT(26X,6A) IVINSP = IVINSP + 1 WRITE (NUVI, 80022) WRITE (NUVI, 70042) 70042 FORMAT(26X,21H112123123412345123456) C***** C***** TEST THAT A SLASH ON INPUT CAUSES THE UNPROCESSED CHARACTERS C***** TO BE SKIPPED. 13.5.4 C***** ALSO TEST THAT AN APOSTROPHE MAY BE USED INSTEAD OF AN 13.5.1 C***** H-EDIT DESCRIPTOR. 13.5.2 C***** C***** INPUT CARD 4 READ(IRVI, 02208) A41K(2), A41K(1), A41K(4), A41K(3) 02208 FORMAT(4A4) C***** INPUT CARDS 5-6 READ(IRVI, 02209) A41K(2), A41K(4), A41K(3) 02209 FORMAT(A4 / 2A4) CT005* TEST 5 IVTNUM = 5 REMRKS = '2 IDENTICAL COMPUTED LINES ' WRITE (NUVI, 80004) IVTNUM, REMRKS REMRKS = 'EXPECTED ' WRITE (NUVI, 80050) REMRKS WRITE (NUVI, 80020) WRITE(NUVI, 70050) A41K(2), A41K(1), A41K(4), A41K(3) 70050 FORMAT(26X,'----HHHH....NNNN'/26X,3(A4),A4) IVINSP = IVINSP + 1 WRITE (NUVI, 70011) WRITE (NUVI, 70052) 70052 FORMAT (26X,16H----HHHH....NNNN) 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** ********************** 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***** C***** END OF TEST SEGMENT 022 STOP END