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



We *used* to do something similar to this.   Our old EDI software (which
we scrapped 5 years ago) was Sterling Software's GENTRAN: Basic for DOS.
It would output the EDI data in a file where all of the EDI elements had
been expanded to fixed-length fields in a flat file.
We would upload that file to our AS/400 and process it in an RPG program.

The way I implemented that was I wrote a program that ran on the PC that
would generate RPG source for all of the different segment types.  and
make a big SELEC group that moved the record data to the appopriate data
structure based on the segment ID.

Then I'd upload that source member to the iSeries...  add the code that
manipulated the data, etc.

As I recall, the fields in the data structure were all set to alphanumeric
so that I didn't have to deal with decimal data errors.   I had
subroutines (though, now I'd use subprocedures) that would do the data
conversion when I needed it.

To avoid problems in the namespace, I used the segment names followed
by a number to name the fields... so I'd have something like this:

     D***************************************************
     D*  Segment N9 -- Reference Number
     D***************************************************
     D dsSegN9         DS
     D* N901  = Reference Number Qualifier
     D  wkN901                18     19
     D* N902  = Reference Number
     D  wkN902                20     49
     D* N903  = Free-form Description
     D  wkN903                50     94
     D* N904  = Date
     D  wkN904                95    100
     D* N905  = Time
     D  wkN905               101    108
     D* N906  = Time Code
     D  wkN906               109    110

I'm not sure if this longwinded tale helps you... but who knows?


>
> There are dozens of fields on each record type.  I'm doing maintenance and
> want to make this RPG IV so I can use reasonable names, etc.  Unfortunately,
> I need to use FIXNBR(*ZONED *INPUTPACKED) in order for it to run as-is.
> This generates tens of thousands of messages in the job log as each
> 'invalid' number is 'fixed'.  Understand that for a 500 record type, the
> program only references the 500 fields.
>
> I want something like:
>      d struc0001       ds
>      d  sensType                      3p 0
>      d  sensID                        7p 0
>      d  roType                        3p 0
>      d  roID                          7p 0
>
>      d struc0360       ds
>      d  sensType                      3p 0
>      d  sensID                        7p 0
>      d  roType                        3p 0
>      d  roID                          7p 0
>
> But that won't compile because the same field is in a different DS.  I could
> use qualified, but as far as the calculations go, eval sensType=sensType0001
> isn't much different from eval sensType=struc0001.sensType.  I still have to
> copy all the fields by hand as it were.
>
> I have two goals:
> 1) I don't want to use FIXNBR; so I'm separating the fields
>    into separate structures
> 2) I'd rather use one set of names to describe the same fields;
>    not SEA500, SEA625, SEA364, but SEA.
>
> Since the input data is packed, I can't readily use the old standby I specs
> because I can't specify the hex codes needed to recognise the packed fields.
> I'm stuck, aren't I?  It gets worse when having to support this back to
> V4R5.  Just thought I'd post a tale of woe on a rainy Northeast US Friday.
>   --buck

As an Amazon Associate we earn from qualifying purchases.

This thread ...

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.