Here's the fun stuff.  The program produces a file that resembles the
printed indented BOM.  I have put the file in Browser and it is highly
utilized in our facility to look at costing, determine spare parts lists,
produce manuals, look at availability, etc.  Hope you find it as enjoyable
as I did.

Also here's a challenge.  When I wrote this a couple of years ago, I was
forced to use native access (non-SQL) inside the sub procedure in order to
maintain the database pointer at each level.  SQL wanted to delete and
recreate the cursor.  If someone could tell me how this could be done in SQL
I would be very interested as this is the only thing I have not been able to
get SQL to do.
Lisa


First the file: EGR0111P
A                                      UNIQUE
 * 07/03/2003 LAT Indented Bill of Material
A          R R0111
A            SITE           3          TEXT('Site')
A            ITEM          15          TEXT('Item')
A            REV            6          TEXT('Revision')
A            SEQ            7S 0       TEXT('Sequence')
A            LEVEL         10          TEXT('Relative Level')
A            PINBR         15          TEXT('Parent Item')
A            PITR           6          TEXT('Parent Item Revision')
A            CINBR         15          TEXT('Component Item')
A            CITR           6          TEXT('Component Item Revision')
A            QTYPR         11S 3       TEXT('Quantity per') 
A            SPARECODE      5          TEXT('Spare Code') 
A            SPAREQTY       3S 0       TEXT('Spare Quantity')
A          K SITE
A          K PINBR
A          K PITR
A          K SEQ
A          K CINBR
A          K CITR                      


Program:        EGR0111R    
NOTE:  It can be compiled without the binding directory.  Just remove the
H-spec.

H BNDDIR('CMALIB/CMABNDDIR') DFTACTGRP(*NO) ACTGRP(*CALLER)

 * Program:    EGR0111R   - Indented Bill of Material
 * Programmer: Lisa Thomas          Date: 07/03/2003 
 *-------------------------------------------------------------------------*
 * Bill of Material Component File
FPSTDTLL0  IF   E           K DISK 

D EGR0111R        PR                  EXTPGM('EGR0111R')
D   Site                         3    CONST
D   Parent                      15    CONST
D   ParentRev                    6    CONST
D   AltID                       10    CONST
                                                                
D EGR0111R        PI
D   Site                         3    CONST
D   Parent                      15    CONST
D   ParentRev                    6    CONST
D   AltID                       10    CONST


D NextComponent   PR
D   LevelNumber                  3S 0 VALUE
D   Site                         3    VALUE
D   Item                        15    VALUE
D   Rev                          6    VALUE
D   AltId                       10    VALUE

D Seq             S              7S 0 



C/EXEC SQL
C+ DELETE from EGR0111P
C/END-EXEC 
 

C                   eval      Seq = 0   
C                   callp     NextComponent(1:Site:Parent:ParentRev:AltId) 

C                   eval      *inLR = *on 


                                                                 
 * Recursive NextComponent subprocedure.  Drills down through the Bill of

 * Materials populating the work file as it goes.
P NextComponent   B 
 
D                 PI
D   LevelNumber                  3S 0 VALUE
D   Site                         3    VALUE
D   Item                        15    VALUE
D   Rev                          6    VALUE

D   AltId                       10    VALUE


 * Local variables - visible only within this subprocedure.
D Level           S             10


D SaveUserSeq     S              4
D SaveItem        S             15
D SaveRev         S              6 

C     CompKey       KList
C                   KFld                    Site
C                   KFld                    Item
C                   KFld                    Rev
C                   KFld                    AltId


C     CompKey2      KList
C                   KFld                    Site
C                   KFld                    Item
C                   KFld                    Rev
C                   KFld                    AltId
C                   KFld                    SaveUserSeq
C                   KFld                    SaveItem
C                   KFld                    SaveRev


C     CompKey       setll     PstDtlL0
C     CompKey       ReadE     PstDtlL0


C                   dow       not %eof

 * Update the global Seq and write new record
C                   eval      Seq = Seq + 1
C                   exsr      WriteRec


 * Save the Component in the local variable and recursively call
 * NextComponent, updating the level number and passing the current
 * component as the parent.
C                   eval      SaveUserSeq = USR1CU
C                   eval      SaveItem = CITMCU
C                   eval      SaveRev = CITRCU
C                   callp     NextComponent(LevelNumber + 1:Site:
C                             CITMCU:CITRCU:AltId)

C     CompKey2      setgt     PstDtlL0
C     CompKey       ReadE     PstDtlL0
C                   enddo 


C     WriteRec      begsr


C                   select
C                   when      LevelNumber = 1
C                   eval      Level = '1         '
C                   when      LevelNumber = 2
C                   eval      Level = '.2        '
C                   when      LevelNumber = 3
C                   eval      Level = '..3       '
C                   when      LevelNumber = 4
C                   eval      Level = '...4      '
C                   when      LevelNumber = 5
C                   eval      Level = '....5     '
C                   when      LevelNumber = 6
C                   eval      Level = '.....6    '
C                   when      LevelNumber = 7
C                   eval      Level = '......7   '
C                   when      LevelNumber = 8
C                   eval      Level = '.......8  '
C                   when      LevelNumber = 9
C                   eval      Level = '........9 '
C                   when      LevelNumber = 10
C                   eval      Level = '........10'
C                   endsl


C/EXEC SQL
C+ INSERT INTO EGR0111P
C+       (SITE,
C+        ITEM,
C+        REV,
C+        SEQ,
C+        LEVEL,
C+        PINBR,
C+        PITR,
C+        CINBR,
C+        CITR,
C+        QTYPR,
C+        SPARECODE,
C+        SPAREQTY)
C+ VALUES(:Site,
C+        :Parent,
C+        :ParentRev,
C+        :Seq,
C+        :Level,
C+        :Item,
C+        :Rev,
C+        :CITMCU,
C+        :CITRCU,
C+        :QPERCU,
C+        :UUGACU,
C+        :UUT1CU)
C/END-EXEC 
 
C                   endsr 
 
P NextComponent   E          

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.