/*PROGRAM ARP060 - HWCS ACCOUNTS RECEIVABLE CUSTOMER FILE LOAD PROGRAMMER ROBERT M. WHITE DATE WRITTEN APRIL 15, 1981 PURPOSE THIS ROUTINE LOADS THE CUSTOMER FILE FROM A PREVIOUSLY SAVED SEQUENTIAL FILE. THIS COM- PLEMENTS THE CUSTOMER FILE OFFLOAD PROGRAM. INPUT OUTPUT REMARKS */ ARP060: PROC; /* * * * A/R MASTER MENU PROGRAM * * * */ /* * * PROGRAM REPLACEMENTS * * */ %INCLUDE 'C:BTCCS.PLI'; /* BT-80 FUNCTIONS */ %INCLUDE 'C:BTERRCS.PLI'; /* BT-80 ERROR RETURN CODES */ %REPLACE FALSE BY '0'B; %REPLACE TRUE BY '1'B; /* * * PROGRAM AREAS * * */ DCL I BIN(7); /* INDEX VARIABLE */ DCL RP CHAR(2); /* CHAR RESPONSE */ DCL NRP BIN(15); /* NUMERIC RESPONSE */ DCL RTN_COD BIN(7); /* SUBROUTINE RETURN CODE */ DCL SYSPRINT FILE; /* CONSOLE OUTPUT FILE */ DCL PRINTFILE FILE; /* OUTPUT PRINT FILE */ DCL PF_TITLE CHAR(15); /* FILE NAME FOR PRINTFILE */ DCL SEL_TYPE(25) CHAR(2); /* PRINT SELECT TYPES */ DCL SEL_NUM BIN(7); DCL FIRST_TIME BIT(1) STATIC INITIAL('0'B); DCL EOF_MSTR BIT(1) STATIC INITIAL('0'B); DCL NUM_MSTR BIN(7); /* 1=A ONLY, 2=A & B */ DCL RCD_CNT BIN(15); /* RECORD COUNT */ /* * * COMMON DCL INCLUDES * * */ %INCLUDE 'C:SUBS1.DCL'; %INCLUDE 'ARCOMMON.DCL'; %INCLUDE 'ARCUSTM.DCL'; /* * * COMMON PROC INCLUDES * * */ DCL BTREE ENTRY(BIN(7),BIN(7),PTR,BIN(7)); DCL ARM060 ENTRY; /* EXTERNAL MAPS */ /* * * PRINT A RECORD. * * */ PUT_RECS: PROC; /* DELETE THE RECORD IF IT ALREADY EXISTS. */ CALL BTREE(BT_LOCATE,IDX1,IOCB1P,RTN_COD); IF RTN_COD=0 THEN CALL BTREE(BT_ERASE,IDX1,IOCB1P,RTN_COD); /* PUT THE RECORD. */ CALL BTREE(BT_WRITE,IDX1,IOCB1P,RTN_COD); IF RTN_COD=0 THEN PUT SKIP LIST(REC1.CSID,' HAS BEEN ADDED.'); ELSE PUT SKIP LIST('WRITE RETURN CODE FOR ',REC1.CSID,' IS',RTN_COD, '.'); /* RETURN TO CALLER. */ END PUT_RECS; /* * * PRINT A RECORD. * * */ GET_RECS: PROC; /* READ A RECORD. */ GET FILE(PRINTFILE) SKIP LIST(REC1.CSID, REC1.CSBILCON, REC1.CSBILCMP, REC1.CSBILAD1, REC1.CSBILAD2, REC1.CSBILAD3, REC1.CSBILZIP, REC1.CSBILTEL, REC1.CSBILEXT, REC1.CSTECCON, REC1.CSTECCMP, REC1.CSTECAD1, REC1.CSTECAD2, REC1.CSTECAD3, REC1.CSTECZIP, REC1.CSTECTEL, REC1.CSTECEXT, REC1.CSSTAT, REC1.CSTERM, REC1.CSBALTYP, REC1.CSPRCCOD, REC1.CSDISC, REC1.CSCURAMT, REC1.CS30DAMT, REC1.CS60DAMT, REC1.CSOVRAMT, REC1.CSLYRAMT, REC1.CSSPCL); /* RETURN TO CALLER. */ RETURN; END GET_RECS; /* * * START OF MAIN PROGRAM * * */ MAIN_MENU: BEGIN; CALL ARM060; /* PUT UP BACKGROUND. */ CALL GETB15(06,23,NRP,0,1,RTN_COD); /* GET THE FUNCTION. */ GOTO MAIN_FUNC(NRP); /* PERFORM THE FUNCTION. */ END; /* MAIN_MENU */ /* * * RETURN TO MAIN MENU * * */ MAIN_FUNC(00): BEGIN; CALL CLRSCRN; CALL PUTMSG(1,1,'RETURNING TO MASTER MENU...'); RETURN; END; /* * * PRINT THE REPORT * * */ MAIN_FUNC(01): BEGIN; /* DO INITIALIZATION. */ CALL CLRSCRN; PUT SKIP LIST(' * * * CUSTOMER FILE LOAD PROGRAM * * *'); PUT SKIP LIST(' ***PRINT THE REPORT***'); EOF_MSTR='0'B; /* OPEN THE PRINT FILE AND PRINT THE FIRST HEADING. */ CALL EOL(24,1); CALL PUTMSG(24,1,'ENTER INPUT FILE NAME:'); CALL GETSTR(24,26,LENGTH(PF_TITLE),ADDR(PF_TITLE),RTN_COD); OPEN FILE(PRINTFILE) STREAM INPUT PAGESIZE(0) LINESIZE(512) ENV(B(4096)) TITLE(PF_TITLE); ON ENDFILE(PRINTFILE) BEGIN; EOF_MSTR='1'B; END; /* PRINT THE DATA FROM THE FILE. */ RCD_CNT=0; CALL CLRSCRN; PUT SKIP(0); PUT SKIP LIST('LOADING THE FILE......'); PRINT_LOOP: DO WHILE(EOF_MSTR='0'B); CALL GET_RECS; IF EOF_MSTR='0'B THEN DO; CALL PUT_RECS; RCD_CNT=RCD_CNT+1; END; RP=CONINP(); IF RP=ASCII(27) THEN /* OPERATOR INTERVENTION VIA ESC */ DO; EOF_MSTR='1'B; END; END; /* RETURN TO CALLER. */ PRINT_END: CLOSE FILE(PRINTFILE); PUT SKIP; PUT SKIP LIST('RECORDS PRINTED:',RCD_CNT); PUT SKIP; CALL PUTMSG(24,1,'PRESS TO CONTINUE.'); CALL GETSTR(24,60,1,ADDR(RP),RTN_COD); GOTO MAIN_MENU; END; END ARP060;