× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.



Hi Frank

Replacing the code in your program with /COPY won't reduce the number of
lines in the program.  When you compile the source member the compiler will
copy in the lines of code in the /COPY member and increase the number of
lines in your program accordingly.

The best way to get around this limit would be to split the program into
separate modules and bind them together into the program object as Tony
suggests.

All the best

Jonathan
www.astradyne-uk.com


-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx
[mailto:rpg400-l-bounces@xxxxxxxxxxxx]On Behalf Of
fkany@xxxxxxxxxxxxxxxxxx
Sent: 19 October 2004 16:45
To: RPG400-L@xxxxxxxxxxxx
Subject: Trivia: How many lines of code are allowed in an RPG Program?


If you guessed 32,764 lines, you are correct.  I found this out the hard
way.  I'm thinking about using /COPY to replace all of the long code.  Will
the progam still compile?

Thanks,

Frank


      *****************************************************************
      *
      *  PROGRAM      -  ZP47R00401
      *  Description  -  Range Canadian Zip Codes
      *  Date         -  October 14, 2004
      *  Programmer   -  Frank Kany
      *
      *****************************************************************
     FZP47P001  IF   E             DISK    PREFIX(X)
     FZP47P002  UF A E           K DISK
      *
     D COUNTER         S                   LIKE(XS19)
      *
     D STARTRANGE      S                   LIKE(XN14)
     D ENDRANGE        S                   LIKE(XP16)
      *
     D SV_CITY         S                   LIKE(XCITY)
     D SV_STATE        S                   LIKE(XSTATE)
     D SV_SZIP         S                   LIKE(XN14)
     D SV_SVCCTR       S                   LIKE(XSVCCTR)
     D SV_DIRECTION    S                   LIKE(XDIRECTION)
     D SV_ADDSVC       S                   LIKE(XADDSVCDAY)
      *
      * Start Main Processing
     C                   EXSR      MAINPRCS
      *
      * End Main Processing
     C                   EVAL      *INLR = *ON
     C                   RETURN
      *
      **********************************************************************
      * Main Processing Subroutine
      **********************************************************************
     C     MAINPRCS      BEGSR
      *
      * Reset Record Counter
     C                   EVAL      COUNTER = *ZEROS
      *
      * -----------------------------
      * Read all Records in ZP47P001:
      * -----------------------------
     C                   DOU       %EOF(ZP47P001)
     C                   READ      ZP47P001
      *
      * End of File(EOF); Leave this routine
     C                   IF        %EOF(ZP47P001)
     C                   LEAVE
     C                   ENDIF
      *
      * Another Record Found; Increase Record Counter
     C                   EVAL      COUNTER = COUNTER + 1
      *
      * (Only processes the first record in the file)
     C                   IF        COUNTER  = 1
     C                   EVAL      SV_CITY      = XCITY
     C                   EVAL      SV_STATE     = XSTATE
     C                   EVAL      SV_SZIP      = XN14
     C                   EVAL      STARTRANGE   = XN14
     C                   EVAL      SV_SVCCTR    = XSVCCTR
     C                   EVAL      SV_DIRECTION = XDIRECTION
     C                   EVAL      SV_ADDSVC    = XADDSVCDAY
     C                   ITER
     C                   ENDIF
      *
      /FREE


//======================================================================
               //First 5 pos. of Current_Zipcode match First 5 pos. of
Previous_Zipcode

//======================================================================
               IF %SUBST(XN14:1:5)=%SUBST(SV_SZIP:1:5);
                  //6 Pos. Current_Zipcode in Sequence with Previous_Zipcode
                  EXSR CHECK_6;
                  IF IN_SEQUENCE = 'Y'; //Yes
                  ENDRANGE = XN14;
                  ITER;
                  ENDIF;
                  IF IN_SEQUENCE = 'N'; //No
                  EXSR WRITE_RECORD;
                  EXSR SAVE_NEWINFO;
                  ITER;
                  ENDIF;
               ENDIF;


//======================================================================
               //First 4 pos. of Current_Zipcode match First 4 pos. of
Previous_Zipcode

//======================================================================
               IF %SUBST(XN14:1:4)=%SUBST(SV_SZIP:1:4);
                  //5,6 Pos. Current_Zipcode in Sequence with
Previous_Zipcode
                  EXSR CHECK_56;
                  IF IN_SEQUENCE = 'Y'; //Yes
                  ENDRANGE = XN14;
                  ITER;
                  ENDIF;
                  IF IN_SEQUENCE = 'N'; //No
                  EXSR WRITE_RECORD;
                  EXSR SAVE_NEWINFO;
                  ITER;
                  ENDIF;
               ENDIF;


//======================================================================
               //First 3 pos. of Current_Zipcode match First 3 pos. of
Previous_Zipcode

//======================================================================
               IF %SUBST(XN14:1:3)=%SUBST(SV_SZIP:1:3);
                  //4,5,6 Pos. Current_Zipcode in Sequence with
Previous_Zipcode
                  EXSR CHECK_456;
                  IF IN_SEQUENCE = 'Y'; //Yes
                  ENDRANGE = XN14;
                  ITER;
                  ENDIF;
                  IF IN_SEQUENCE = 'N'; //No
                  EXSR WRITE_RECORD;
                  EXSR SAVE_NEWINFO;
                  ITER;
                  ENDIF;
               ENDIF;


//======================================================================
               //First 2 pos. of Current_Zipcode match First 2 pos. of
Previous_Zipcode

//======================================================================
               IF %SUBST(XN14:1:2)=%SUBST(SV_SZIP:1:2);
                  //3,4,5,6 Pos. Current_Zipcode in Sequence with
Previous_Zipcode
                  EXSR CHECK_3456;
                  IF IN_SEQUENCE = 'Y'; //Yes
                  ENDRANGE = XN14;
                  ITER;
                  ENDIF;
                  IF IN_SEQUENCE = 'N'; //No
                  EXSR WRITE_RECORD;
                  EXSR SAVE_NEWINFO;
                  ITER;
                  ENDIF;
               ENDIF;


//======================================================================
               //First pos. of Current_Zipcode match First pos. of
Previous_Zipcode

//======================================================================
               IF %SUBST(XN14:1:1)=%SUBST(SV_SZIP:1:1);
                  //2,3,4,5,6 Pos. Current_Zipcode in Sequence with
Previous_Zipcode
                  EXSR CHECK_23456;
                  IF IN_SEQUENCE = 'Y'; //Yes
                  ENDRANGE = XN14;
                  ITER;
                  ENDIF;
                  IF IN_SEQUENCE = 'N'; //No
                  EXSR WRITE_RECORD;
                  EXSR SAVE_NEWINFO;
                  ITER;
                  ENDIF;
               ENDIF;

      /END-FREE
     C                   ENDDO
      *
     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 ...

Replies:

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.