At 12:50 09/11/1999 , Booth Martin wrote:
>I am getting unexpected behavior and can't figure out why.  I have a
>program with a main screen with header information about the application
>and as the user makes various choices on the screen various windows are
>displayed to respond to his requests.  What is disconcerting is that when
>the window is displayed the screen in the background is the first screen
>used that day. It seems to never have the currnet background.

Here's an oldie from the archives that explains how to get around this 
problem. I can't take any credit for it, other than to say that I have done 
it, and it works.


To keep AS400 subprogram display from flashing the old data when reentered:

MOVE *OFF     PUTOVR          -- as the program is entered (not *INZSR)
                                                         and as another 
program with a display
                                                         is called.

MOVE PUTOVR *IN91            -- just before the EXFMT, *IN91 is the option
                                                        indicator on the 
DSPF next to the
                                                        PUTOVR keyword.

MOVE *ON       PUTOVR         -- just after the EXFMT.

PUTOVR  IFEQ  *OFF             -- just before writes to the display, must be
SFLREC  OREQ*ZERO               before the write to the message subfile.
         WRITE#CLRSCN            (SFLREC is number of SFL records and
         ENDIF                   is checked to clear/clean up the old
                                 subfile records previously displayed.

With the setup as described above you do not have to RSTDSP(*YES) which is 
a big advantage as it is a memory pig and you do not have to open and close 
your display files.  The key is that if pgm A calls pgm B and then control 
is returned to pgm A
you would normally receive an I/O error due to overlapping input capable 
fields.  There are two ways to correct this:

a) use RSTDSP(*YES), which will consume main storage and increase 
communications line time by forcing the system to save and restore the 
display for the program.

  b) use the setup as described above.   Difference; on a B30 .2 seconds on 
a locally attached

Tim Hawkins


Pete Hall
| This is the Midrange System Mailing List!
| To submit a new message, send your mail to
| To subscribe to this list send email to
| To unsubscribe from this list send email to
| Questions should be directed to the list owner/operator:

This thread ...


Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2020 by 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].