SUBROUTINE UFBMMS(IMSG,ISUB,SUBSET,JDATE) C$$$ SUBPROGRAM DOCUMENTATION BLOCK C C SUBPROGRAM: UFBMMS C PRGMMR: WOOLLEN ORG: NP20 DATE: 1994-01-06 C C ABSTRACT: THIS SUBROUTINE READS A PARTICULAR SUBSET INTO INTERNAL C SUBSET ARRAYS FROM A PARTICULAR BUFR MESSAGE IN INTERNAL MEMORY C BASED ON THE SUBSET NUMBER IN THE MESSAGE AND THE MESSAGE NUMBER IN C INTERNAL MEMORY. THIS SUBROUTINE IS ACTUALLY A COMBINATION OF C BUFR ARCHIVE LIBRARY SUBROUTINES RDMEMM AND RDMEMS. C C PROGRAM HISTORY LOG: C 1994-01-06 J. WOOLLEN -- ORIGINAL AUTHOR C 1998-07-08 J. WOOLLEN -- REPLACED CALL TO CRAY LIBRARY ROUTINE C "ABORT" WITH CALL TO NEW INTERNAL BUFRLIB C ROUTINE "BORT" C 1999-11-18 J. WOOLLEN -- THE MAXIMUM NUMBER OF BYTES REQUIRED TO C STORE ALL MESSAGES INTERNALLY WAS INCREASED C FROM 4 MBYTES TO 8 MBYTES C 2001-08-15 D. KEYSER -- PARAMETER MAXMEM (THE MAXIMUM NUMBER OF C BYTES REQUIRED TO STORE ALL MESSAGES C INTERNALLY) WAS INCREASED FROM 8 MBYTES TO C 16 MBYTES C 2003-11-04 S. BENDER -- ADDED REMARKS/BUFRLIB ROUTINE C INTERDEPENDENCIES C 2003-11-04 D. KEYSER -- PARAMETER MAXMSG (THE MAXIMUM NUMBER OF C BUFR MESSAGES WHICH CAN BE STORED C INTERNALLY) INCREASED FROM 50000 TO 200000; C UNIFIED/PORTABLE FOR WRF; ADDED C DOCUMENTATION (INCLUDING HISTORY); OUTPUTS C MORE COMPLETE DIAGNOSTIC INFO WHEN ROUTINE C TERMINATES ABNORMALLY C 2004-11-15 D. KEYSER -- PARAMETER MAXMEM (THE MAXIMUM NUMBER OF C BYTES REQUIRED TO STORE ALL MESSAGES C INTERNALLY) WAS INCREASED FROM 16 MBYTES TO C 50 MBYTES C C USAGE: CALL UFBMMS (IMSG, ISUB, SUBSET, JDATE) C INPUT ARGUMENT LIST: C IMSG - INTEGER: POINTER TO BUFR MESSAGE NUMBER (RECORD) IN C STORAGE C ISUB - INTEGER: POINTER TO SUBSET NUMBER TO READ IN BUFR C MESSAGE C C OUTPUT ARGUMENT LIST: C SUBSET - CHARACTER*8: TABLE A MNEMONIC FOR BUFR MESSAGE C CONTAINING SUBSET C JDATE - INTEGER: DATE-TIME FROM SECTION 1 OF BUFR MESSAGE C CONTAINING SUBSET, IN FORMAT OF EITHER YYMMDDHH OR C YYYYMMDDHH, DEPENDING ON DATELEN() VALUE C C REMARKS: C NOTE THAT UFBMEM IS CALLED PRIOR TO THIS TO STORE THE BUFR C MESSAGES INTO INTERNAL MEMORY. C C THIS ROUTINE CALLS: BORT RDMEMM RDMEMS STATUS C THIS ROUTINE IS CALLED BY: None C Normally called only by application C programs. C C ATTRIBUTES: C LANGUAGE: FORTRAN 77 C MACHINE: PORTABLE TO ALL PLATFORMS C C$$$ INCLUDE 'bufrlib.prm' COMMON /MSGMEM/ MUNIT,MLAST,MSGP(0:MAXMSG),MSGS(MAXMEM), . MDX(MXDXW),IPDXM(MXDXM),LDXM,NDXM,LDXTS,NDXTS, . IFDXTS(MXDXTS),ICDXTS(MXDXTS),IPMSGS(MXDXTS) COMMON /MSGCWD/ NMSG(NFILES),NSUB(NFILES),MSUB(NFILES), . INODE(NFILES),IDATE(NFILES) CHARACTER*128 BORT_STR CHARACTER*8 SUBSET C----------------------------------------------------------------------- C----------------------------------------------------------------------- C READ SUBSET #ISUB FROM MEMORY MESSAGE #IMSG C ------------------------------------------- CALL RDMEMM(IMSG,SUBSET,JDATE,IRET) IF(IRET.LT.0) GOTO 900 CALL RDMEMS(ISUB,IRET) IF(IRET.NE.0) GOTO 901 C EXITS C ----- RETURN 900 IF(IMSG.GT.0) THEN WRITE(BORT_STR,'("BUFRLIB: UFBMMS - REQUESTED MEMORY MESSAGE '// . 'NUMBER TO READ IN (",I5,") EXCEEDS THE NUMBER OF MESSAGES IN '// . 'MEMORY (",I5,")")') IMSG,MSGP(0) ELSE WRITE(BORT_STR,'("BUFRLIB: UFBMMS - REQUESTED MEMORY MESSAGE '// . 'NUMBER TO READ IN IS ZERO - THIS IS NOT VALID")') ENDIF CALL BORT(BORT_STR) 901 CALL STATUS(MUNIT,LUN,IL,IM) WRITE(BORT_STR,'("BUFRLIB: UFBMMS - REQ. SUBSET NUMBER TO READ '// . 'IN (",I3,") EXCEEDS THE NUMBER OF SUBSETS (",I3,") IN THE '// . 'REG. MEMORY MESSAGE (",I5,")")') ISUB,MSUB(LUN),IMSG CALL BORT(BORT_STR) END