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


  • Subject: Re: Regarding retrieving source from modules
  • From: Jon.Paris@xxxxxxxxxx
  • Date: Sun, 13 Feb 2000 12:39:59 -0500




 > So, does the RPG compiler optimize the executable?  Or is that either not
 > possible, or an additional step I need to perform?

The default is for no (or as close to "no" as the AS/400 goes) optimization.  I
would suggest that you develop and test with this setting for reasons I'll cover
in a moment.  Once the program needs to move into production you can either
recompile and specify a higher level or (safer) simply use CHGPGM and change the
optimization level.

 > If the RPG compiler
 > doesn't optimize my code, then it is a non issue and I can go ahead and
 > compile with *ALL (since there is practically no size increase over *LIST).

This is probably a good time to point out that there is very little difference
in ability to step though a program regardless of what level of optimization you
use.  I've never tried it, but I guess in theory the dead code elimination
process could cause you to step from line 21 to line 23 (apparently) skipping
line 22 and things like this but it is not a practical consideration to my mind.
You'll know when this happens while setting debug points as when you point at
the source line and press F6 - if that line is not "debugable" then the system
just sets a break at  next line that is. Of more concern is the ability to
display and change variables.  at higher levels of optimization when  you
display a variable you may not be seeing the current value.  This is due to
"register" optimization which has caused the variables storage location to not
yet be updated.  I believe a similar process works in reverse when you change a
variable in debug.  If a copy is already in a "register" then your modified
value will not be used. In fact I think at some levels it will not even let you
change the variable.

 > And this CPROBJ (which I have never used before, nor heard of).  Does
 > that just remove the debugging information?  Or is that what actually does
 > the optimization?

Optimization is done by CHGPGM or CRTPGM.  CPROBJ can be used against most any
AS/400 object, look at the help for the command to what it does for each type of
object.  In the case of *PGM and *SRVPGM objects it compresses the observability
information (and I guess debug information in the case of ILE programs).  If you
were a software vendor and wanted to remove debug and/or observability - then
you can use CHGPGM to remove either or both. There is really no   point in
removing observability IMHO but some do it anyway (out of habit since in the
case of OPM programs debug and observability are the same thing ?).  In the case
of ILE programs they are separate and it is possible to remove one without
removing the other.

Let me stress again that debug and observability information are never a
performance consideration.  They do not affect program execution, only physical
DASD storage is involved here.


+---
| This is the Midrange System Mailing List!
| To submit a new message, send your mail to MIDRANGE-L@midrange.com.
| To subscribe to this list send email to MIDRANGE-L-SUB@midrange.com.
| To unsubscribe from this list send email to MIDRANGE-L-UNSUB@midrange.com.
| Questions should be directed to the list owner/operator: david@midrange.com
+---

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.