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



Mike,

>No I don't avoid it because of fear of the unknown, but because I can write
>the same code myself which will immediately be understandable to any other
>competent RPG programmer.

Any "competent RPG programmer" *will* immediately understand a cycle program, or
he/she is not "competent" IMHO.

Used correctly, the cycle is *very* easy to understand and maintain.  A program
using multiple level breaks should be *immediately* grasped by the maintenance
coder.   You can see at a literal glance exactly what is happening, and rest
assured it acts exactly as designed.

On the other hand, manually coded level breaks can *not* be verified with a
literal glance at the code.  It of course helps if there is a strict shop
standard and everybody codes it the same way.  But if you do that, what is wrong
with a shop standard which uses level breaks to accomplish the same thing?

Level breaks are *not* hard to understand -- or maintain.  They are *faster* to
code initially, *faster* to comprehend when perusing the code, *faster* to
modify when additional level breaks are needed, and have *faster* execution
performance.  What is wrong with that picture??

Manually coded level breaks -- particularly if not coded in a uniform shop
standard method -- must be examined to ensure that level breaks propagate to all
lower levels correctly.  And it also means your field contents have already been
destroyed by the next record so you can't use them for "total time" processing
unless you are performing an inner loop via READE (which only is possible in
some scenarios).

I have never understood the disdain some folks have for the cycle.  Sure there
is some ugly code where people did things they should not have, and tried to
make the cycle do things it shouldn't.  (When I started in RPG II, a program
*had* to have a primary file or it wouldn't compile!  It was *not* optional.)

But mis-guided, ugly cycle code is no reason to throw the baby out with the bath
water.  You can write ugly code without the cycle too -- I'm sure we've all seen
our share.

Here is an example using (gasp!) left-hand indicators -- another "cardinal sin"
which in this case *promotes* readability.   Now lets's say you have a new hire
who has never seen the cycle used, and comes across this code:

     FMaster    IP   E           K Disk

     IMasterRec
     I                                          Division      L4
     I                                          Zone          L3
     I                                          Territory     L2
     I                                          Salesman      L1

     C   L4               Exsr     NewDivision
     C   L3               Exsr     NewZone
     C   L2               Exsr     NewTerritory
     C   L1               Exsr     NewSalesman

     C                    Exsr     Detail

     CL1                  Exsr     EndSalesman
     CL2                  Exsr     EndTerritory
     CL3                  Exsr     EndZone
     CL4                  Exsr     EndDivision
     CLR                  Exsr     EndProgram

If the person *can't* be trained what that means -- in very short order -- then
what are they going to do with pointers, user spaces and indexes, various APIs,
knowing when to use CONST vs VALUE vs not, *NoPass vs *Omit vs not, service
program signatures and bindery language, yada, yada, yada.

I defy you to take the above code and show me how it is more readable in your
Do-It-Yourself level breaks.  Oh, and by the way, the "End..." subroutines must
have the original field values (the group just ending) available for printing
and other calculations.

Go ahead -- show me how you would code the same thing as above.

For those of you who have never seen a cycle program: now you have.  Even if you
have never seen Lx level break indicators, can you really tell me you have *no
idea* what the above code is doing?

The above is *exactly* how I code the mainline of cycle programs.  Everything
else is in subroutines.  It is *trivial* to add level breaks or make other
changes, and I can see *at a glance* exactly what the intent is and feel 100%
confidence in how it does it.

Somebody prove me wrong and show me an equivalent mainline which is *faster* to
code, *faster* to comprehend, *faster* to change when the need arises, and
executes *faster*.

Doug


As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:
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.