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



Hello Gary,

You wrote:
>I don't agree with your assessment.

That's OK.  I don't care, but I did bother to refute your statements
below ...

>While unused prototypes don't occupy program object space, they do
>occupy space.

Only in the source (unless you like DBGVIEW(*LIST))

>Here's what I consider the advantages...

>1) By Defining the prototypes you want to use, you make clear the
>intent.

Rubbish.  Grouping the prototypes into separate members by classification
(i.e., string stuff, maths stuff, date stuff, etc.) is far more obvious
in intent.  If I code:
        /copy rpgleinc,fbnstring
it is obvious that I am intending to use string functions.  No one should
care that I'm using toUnicode(), getSoundex(), and getDifference() but
not using any of the sixty other functions in FBNSTRING. (Well, a
maintenance programmer might care which ones I'm using but they can see
that from the function calls.)  Why complicate the source with a plethora
of /define statements?

Also, if I use one string fuction then I am quite likely to use more than
one and I'd rather simply include the STRING copy member and have all the
procedures available to me than have to /define some magic incantation in
order to use a given procedure.

>2) Copying 1000 prototypes when you only need 2, in my opinion,
>increases the complexity with respect to debug. There's a lot of unused
>CRAP there when you copy all the unnecessary prototypes.

Rubbish.  Prototypes are completely unnecessary in debug since the
compiler has already determined if they match.  The PI is important in
debug.  In the source view you only see the /copy line, not the contents
so they don't get in the way there.  Switching to the *COPY view as
needed and then back to *SOURCE view solves any problem with respect to
"unused CRAP".

Except, if I recall correctly, you promote putting PR and PI in the same
source member and using conditional compiler statements to control
whether only the PR is included (for the user) or whether both PR and PI
are included (for the implementor).  I've seen articles by someone in
News/400 (I think it's you) promoting that approach which I've always
thought to be inane for a number of reasons.

If that is indeed what you do, then I can understand why you would find
lots of clutter in your debug view without conditional compile
statements.  But you would only get that 'benefit' in *LIST view, using
*SOURCE or *COPY views would still expose the clutter.

>I could probably name some more, but I've got to head out to the office
>about now!

The only advantage I can see to your preference is that compiles might
run marginally faster since conditional directives can cause the compiler
to skip source therefore there is less source to parse.  Big deal,
compiles on RISC boxes are so fast it doesn't matter (and since I didn't
see any /EOF in the original example the compiler will parse all the
source lines anyway -- looking for the closing /endif).

Regards,
Simon Coulter.

--------------------------------------------------------------------
   FlyByNight Software         AS/400 Technical Specialists
   http://www.flybynight.com.au/

   Phone: +61 3 9419 0175   Mobile: +61 0411 091 400        /"\
   Fax:   +61 3 9419 0175   mailto: shc@flybynight.com.au   \ /
                                                             X
                 ASCII Ribbon campaign against HTML E-Mail  / \
--------------------------------------------------------------------



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.