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



> From: Simon Coulter
>
> If I have a standard RPG III display file processing loop like:
> <SNIP CODE>
> What will that look like after it has been run through your conversion
> process?  That is, what happens to the WRITE and EXFMT statements?

The mainline is very simple:

      * Display the screen until user requests exit
B1   C           EXIT      DOUEQ$YES
      *   Display the static parts of the screen
RV01dC**                   WRITEOBJHDR
RV01aC                     EXSR PSCI01
RV01dC**                   WRITEOBJOPT
RV01aC                     EXSR PSCI02
RV01dC**                   WRITEOBJFKEY
RV01aC                     EXSR PSCI03
      *   Display program messages - OS/400 does the hard work
RV01dC**                   WRITEERRCTL
RV01aC                     EXSR PSCI04
      *   If we have object list entries to display
B2   C           LSTCNT    IFGT *ZERO
      *     Display the filled SFL and wait for user action
     C                     SETON                     9192   SFLDSP
SFLDSPCTL
     C                     EXFMTOBJCTL1                     First SFL
     C                     SETOF                     9192   SFLDSP
SFLDSPCTL
      *   . . . otherwise . . .
X2   C                     ELSE
      *     Display 'no objects' message
     C                     SETON                       92   SFLDSPCTL
RV01dC**                   WRITEOBJCTL1                     First SFL
RV01aC                     EXSR PSCI05
RV01dC**                   EXFMTOBJNUN                      No objects
RV01aC                     EXSR PSCI06
     C                     SETOF                       92   SFLDSPCTL
E2   C                     END                              LSTCNT > *ZERO
      *
E1   C                     END                              EXIT U= $YES

As you can see, each I/O opcode is replaced with a subroutine.  This way,
your mainline stays pretty much intact.  I think the above code is pretty
readable, especially since the original I/O statements are left in place as
comments.  The subroutine looks something like this:

PSC aC           PSCI01    BEGSR
PSC aC           PSCTYP    IFEQ '1'
PSC aC                     WRITEOBJHDR
PSC aC                     ELSE
PSC aC                     EXSR PSCW01
PSC aC                     CALL 'PSCBAPI2'
PSC aC                     PARM PSCN01    PSCRCD 10
PSC aC                     PARM 'WRITE'   PSCOPC  5
PSC aC           *IN       PARM *IN       PSCIND
PSC aC                     PARM           PSCD01
PSC aC                     ENDIF
PSC aC                     ENDSR

If we're in interactive mode, the PSCTYP field is a '1', and the original
statement is executed.  Otherwise, a call is made to the PSC400 API program,
passing the appropriate parameters.  (Note that if the same I/O opcode
appears more than once, it's replaced by a call to the same subroutine.)

You might start wondering about a few things like "What is PSCW01"?  PSCW01
is a subroutine that moves data from screen fields into the PSCD01 data
structure.  Or "What is PSCN01"?  It's a constant containing the ID for the
OBJHDR record format.  Or "How do the command keys and the INFDS get set"?
That depends on the I/O opcode.  EXFMT will set the command keys, as will a
READ.  The INFDS is only set if there is one defined in the program.  And so
on.  Once you start getting to that level of detail, you really need to see
an assessment of the product working with your code.  I hope that this is
enough to give you a general idea of how the tool works.

Joe



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.