|
I did some researching back a ways, and I found that there have been a few
discussions regarding the use of the file I/O BIFs. It seemed to always
revolve around which of the basic CHAIN/SETLL/READE loops you used. Now,
ever since I was able to, I've used the following standard code:
CHAIN
*IN90 DOWEQ *OFF
(process)
READE
ENDDO
This, I know, is only one of many possible variations, but it's the one that
has always appealed to my sense of decorum. This is definitely not a good
argument for its use, but it has always worked quite nicely for me. The
only other mode I found nearly as appealing was the following:
SETLL
*OFF DOWEQ *ON
READE
*IN90 IFEQ *ON
LEAVE
ENDIF
(process)
ENDDO
This is basically the equivalent of the RCVF/GOTO loop I use in CL, with an
unconditional loop and a LEAVE being the "structured" equivalent. I'm not
happy with the four extra lines of code, but hey, it's relatively efficient
and has a couple of benefits, such as allowing the use of ITER.
The second form can fairly readily be converted to use the file I/O BIF
%eof, thereby removing indicator use. The first, however, because the CHAIN
and READE command set different BIFs, is a little harder. Has anyone
figured out a way to do it? I tried to use (%found or not %eof) along with
the operation extenders, and it seems to always return true (putting me in
an infinite loop reprocessing the last record over and over). Am I missing
something here (more than usual)?
Joe
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.