<    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 thread ...


Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

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.