|
Hi Phil,
As well, we have a situation where the users sometimes hold a session w/ a particular program. However, in the past, they have not been able to use the system values that pertain to ending sessions after a certain time has passed and a key was not hit.
Hmmm... there's no way to tell whether a key was hit. The system sends data to a terminal a full screen at a time. It then lets the terminal take care of all the editing of the data on the screen. The system doesn't receive control again until an AID-generating key is pressed, such as ENTER or a F-key, etc.
I'm sure you've encountered this behavior already.If you want, you can perform a timeout when no AID-generating key has been pressed for 30 minutes. Or whatever time limit you prefer. But there's no way to do it based on whether any key has been pressed (that is, short of writing your own emulator, and adding that functionality to the emulator itself.)
I know of 3 different ways to wait until a timeout has occurred on a screen, and have the program resume control:
a) The WAITRCD keyword for the CRTDSPF command.b) Attach a data queue to the display file, write the display with the INVITE keyword, and wait for a data queue entry before reading the display. Since data queues can time-out, this lets you check for a timeout.
c) Schedule the system to send an alarm signal (with the alarm() API) and set up a subprocedure that's called automatically when a signal is received. Then display the screen as normal. If a signal is received, a timeout has occurred, so use an *ESCAPE message to cancel the screen.
There are pros and cons to each method. Here are my experiences: Method A works okay, but has some drawbacks: -- You have to code MAXDEV(*FILE) on the F-spec, and always read the file with the READ op-code by FILE (not record format) name. -- You have to code an OVRDSPF to override WAITRCD before opening the display file (or before the program starts) -or- you to remember to type the WAITRCD parameter every time you rebuild the display file (I prefer the OVRDSPF method so I can't forget to specify the keyword.) -- Each time a timeout occurs, the user will see it. Input inhibited will go on until the screen is read again. For what you're doing, this won't matter. But, if you wanted to (for example) check %SHTDN every 5 seconds, this would be very annoying. Method B works very nicely as well, however: -- You still have to OVRDSPF before displaying the screen, but now you specify a data queue to attach to instead of WAITRCD -- The data queue has to be built first. -- You still have to use READ/WRITE instead of EXFMT, but you can use the record format name if you prefer. -- You have to call the data queue APIS, which might add complexity. -- Since the program is waiting on the data queue and not the display file, you have problems if the user turns the terminal off or loses communications before exiting the screen. The program doesn't know that the user has disconnected, since it's not waiting for the screen, it's waiting for the data queue. -- Unlike method A, this method is invisuble to the user until you display another screen or close the display file and cause the screen to change. Method C is much more unconventional, but it's the one I prefer. -- No special display file coding. You can use EXFMT as always. -- It doesn't interrupt the screen until you display something different. This makes it suitable for checking %SHTDN in a loop. (Using an interval timer, for example.) -- Since the program is still waiting on the EXFMT, it still receives errors if the user disconnects. -- You have to use the Unix-type APIs alarm(), setitimer() and sigaction() which can add complexity, though I generally find the Unix-type APIs to be much easier to read than the i5/OS APIs. -- Have to call the QMHSNDPM API to send the *ESCAPE message, and have to have some knowledge of how escape messages work.
As an Amazon Associate we earn from qualifying purchases.
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.