|
< C EVAL DSTOCKNO = ILNSTK add this line C exsr prtheading < C DOW NOT %EOF(BRCHMARGIN) <... <... < C EXSR PRTDETAIL delete this line C* EVAL *IN99 = *ON < C ENDIF Ed -----Original Message----- From: rpg400-l-bounces@xxxxxxxxxxxx [mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of Douglas W. Palme Sent: Thursday, May 12, 2005 3:56 PM To: rpg400-l@xxxxxxxxxxxx Subject: Need some help with a report I have been moving along in my feeble attempt to gain as much rpg knowledge as I can get, however I have a report that I need to produce that has been giving me fits for four days and if anyone can provide any assistance I would appreciate it. I will post the source below. I have a logical file which contains branch (location) id, customer number, stock numbers, and each record is equivalent to one line item from our sales. It is keyed by ilninv#a (location id), ilnsoldto (customer number) and ilnstk (stock number), it also has a range restriction on it for line items related to this fiscal year. I am attempting to print out one detail line with the sum of sales and costs for each stock number and customer number, with a page break when the location id changes. So far, every time I run the report it spits out over a 1,000 pages and has produced as many as 89,000 pages....it appears to keep printing the same header file over and over again..... Any help, pointers or suggestions would be appreciated. Douglas '*********************************************************************** *** '* ORIGINAL DATE: 05/11/2005 '* APPLICATION NAME: BRANCH MARGIN REPORT '* PROGRAM NAME: BRCHMARRPT '* DESCRIPTION: 1. READ FIRST REC 2. CREATE HEADING '* 3. READ RECORDS INTO TOTALS '* 4. BREAK ON STK NO, CUST NO AND THE '* BRANCH LOCATION '*********************************************************************** *** '* LOG OF MODIFICATIONS '* '* DATE PGMR DESCRIPTION '*---------------------------------------------------------------------- --- '* / / '*********************************************************************** *** '* FUNCTION OF INDICATORS '* '* IND FUNCTION '*---------------------------------------------------------------------- --- '* 99 OFLIND INDICATOR '* INLR LAST RECORD INDICATOR '*********************************************************************** *** '* SUBROUTINE INDEX '*********************************************************************** *** '* PRTHEADING - PRINT HEADING SUB ROUTINE '* BRCHLOOKUP - BRANCH LOOKUP SUB ROUTINE '*********************************************************************** *** '* FILES '*********************************************************************** *** FCUSTMLF IF E K DISK FBRCHMARGINIF E K DISK FBRCHMARLSTO E PRINTER OFLIND(*IN99) '*********************************************************************** *** '* STANDALONE VARIABLES '*********************************************************************** *** DDBRANCH S 20A DDBRANCHID S 2A DDSTOCKNO S 20A DDDESC S 24A DDCUSTNO S 9S 0 DDTSALES S 12S 2 DDTCOST S 12S 2 DDMARGIN S 12S 2 DDPCT S 4S 3 '*********************************************************************** *** '* MAINLINE '*********************************************************************** *** '* READ THE FIRST RECORD IN THE FILE AND WRITE DATA TO VARIABLES '*********************************************************************** *** C READ BRANCH * COPY DATA TO HOLDING AREA C EVAL DBRANCHID = ILNINV#A C EVAL DCUSTNO = ILNSOLDTO C EVAL DSTOCKNO = ILNSTK C DOW NOT %EOF(BRCHMARGIN) C IF ILNINV#A = DBRANCHID C IF ILNSOLDTO = DCUSTNO C IF ILNSTK = DSTOCKNO C EVAL DTSALES = DTSALES + ILNEPRICE C EVAL DTCOST = DTCOST + ILNEUAVCST C ELSE C EXSR PRTDETAIL C ENDIF C ELSE C EXSR PRTDETAIL C ENDIF C ELSE C EXSR PRTDETAIL C EVAL *IN99 = *ON C ENDIF C READ BRANCH C ENDDO C EVAL *INLR = *ON C RETURN ************************************************************************ ** '* PRINT HEADINGS SUB-ROUTINE '*********************************************************************** *** C PRTHEADING BEGSR C EXSR BRCHLOOKUP C EVAL PRTBRANCH = DBRANCH C WRITE HEADINGS C EVAL *IN99 = *OFF C ENDSR '*********************************************************************** *** '* BRANCH LOOKUP SUB-ROUTINE '*********************************************************************** *** C BRCHLOOKUP BEGSR C SELECT C WHEN DBRANCHID = 'D ' C EVAL DBRANCH = 'DECATUR' C WHEN DBRANCHID = 'A ' C EVAL DBRANCH = 'ALL COMPANY' C WHEN DBRANCHID = 'J ' C EVAL DBRANCH = 'JACKSONVILLE' C WHEN DBRANCHID = 'Q ' C EVAL DBRANCH = 'QUINCY' C WHEN DBRANCHID = 'B ' C EVAL DBRANCH = 'RIVER BEND' C WHEN DBRANCHID = 'S ' C EVAL DBRANCH = 'SPRINGFIELD' C WHEN DBRANCHID = 'M ' C EVAL DBRANCH = 'MATTOON' C WHEN DBRANCHID = 'V ' C EVAL DBRANCH = 'MOUNT VERNON' C WHEN DBRANCHID = 'N ' C EVAL DBRANCH = 'PONTIAC' C WHEN DBRANCHID = 'L ' C EVAL DBRANCH = 'LITCHFIELD' C ENDSL C ENDSR '*********************************************************************** *** '* PRINT DETAIL SUB-ROUTINE '*********************************************************************** *** C PRTDETAIL BEGSR '* WRITE DATA TO VARIABLES AND MAKE NECESSARY CALCULATIONS C IF DTSALES = 0 C ELSE C EVAL DMARGIN = DTSALES - DTCOST C EVAL DPCT = DMARGIN / DTSALES C EVAL PRTCUSTNO = DCUSTNO C EVAL PRTBRANCH = DBRANCH C EVAL PRTSTKNO = DSTOCKNO C EVAL PRTDESC = DDESC C EVAL PRTSALES = DTSALES C EVAL PRTCOST = DTCOST C EVAL PRTMARGIN = DMARGIN C EVAL PRTPCT = DPCT C WRITE DETAIL C EVAL DTSALES = ILNEPRICE C EVAL DTCOST = ILNEUAVCST C EVAL DBRANCHID = ILNINV#A C EVAL DCUSTNO = ILNSOLDTO C EVAL DSTOCKNO = ILNSTK C EVAL DMARGIN = 0 C EVAL DPCT = 0 C ENDIF C IF *IN99 = *ON C EXSR PRTHEADING C EVAL *IN99 = *OFF C ENDIF C ENDSR '*********************************************************************** *** -- This is the RPG programming on the AS400 / iSeries (RPG400-L) mailing list To post a message email: RPG400-L@xxxxxxxxxxxx To subscribe, unsubscribe, or change list options, visit: http://lists.midrange.com/mailman/listinfo/rpg400-l or email: RPG400-L-request@xxxxxxxxxxxx Before posting, please take a moment to review the archives at http://archive.midrange.com/rpg400-l.
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.