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



Kathie wrote:
>As you may remember, I am rewriting old icky stuff , still,
>I am creating transactions in a 64 character flat file.

Do you have to?  I mean, is this file under your control at all?  If it's
not, the client may be asking you to make a silk purse from a sow's ear...

>Some of the records are Batch Hdr records and some
>are detail records. I have the last 13 positions
>of the record to hold whatever I wish.

>I need to be able to retrieve the records later in the
>program for
>'REVIEW'. On one screen, I need to ROLL through the Header
>records and allow
>the user to modify them, on another screen, I need to ROLL
>through the Detail
>records for the associated Header record to allow modification
>of them. The
>records in the transaction file will be written by different
>workstations. I
>am only supposed to show the records written by the
>workstation the user is
>using. The program must run in 36 mode, and later will be
>'converted' (by a
>package) to a 400 program.
>Soooooo, I am thinking I must use my 13 positions to store
>Batch (4) Batch
>Start RRN (4) Prev Dtl Rcd RRN (4) and a 1? position WSID.

>I need to get the RRN of the record - how? the WSID of the
>record - how?

It's been a Real Long Time, but I do not think that information is available
to a S/36 RPG program.  There are other ways around the problem though...

If you need the RRN, store it in the 13 character "free" portion of the
record.  Run a batch program to re-calculate the RRN before you start.
Sure, performance will be horrible, but it will run, and in S/36 mode.
Giving this as an alternative to the client may help explain the artificial
constraints you are having to operate under.

Obviously, the best solution is to go to an indexed file.  If that's not
possible, make this a multiple program process.
1) Read all the records for the workstation
2) Write them to a scratch file - indexed
3) As you write them, tag them "in work" in the 13 column "free" area
4) Do the subfile work over that file
5) When the user hits F7 to update, pass back through the original file and
delete all the original records and write the new ones containing the
updates.  Alternately, update the original records in place.  You could use
a sequence number to identify the records - make it the same as the work
file index.  The point being that you'll have to read the flat file and
compare/chain against your work file.

How restricted are you?

  --buck


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.