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





I do that also, though what I'd really like is for the basic "types",
such as Indicator/Boolean, Pointer, Int, LongInt, etc... to be included
somehow in the compiler, so that I don't have to /COPY them into every
program.

They are. Indicator is called 'N', Pointer is '*', Int is 'I'... That's the way RPG works, it uses a single character to represent the type.


I don't feel that you gain anything at all by typing the following:

     D myVar           s                   like(int)

instead of the following:

     D myVar           s              10I 0

You're really saying the exact same thing. An RPG programmer knows (or SHOULD) what "10I 0" means. He reads the line of text as "10 digit integer". You explicitly using the word "int" doesn't really add anything to it... in either case he knows it's an integer. The programmer is reading the same thing, it's just a slightly different way of saying it.

You know what I mean?  Six of one, half a dozen of the other.

On the other hand, you can use likeds() and like() to create your OWN data types. Instead of just assigning "english" names to RPG's data types...

For example, your business may have a standard for how an address is defined. In the USA, you might have two lines that represent the street address, then a city name, state abbreviation and zip code.

So, you might define that in a /COPY file like this:

     D Address_T       ds                  qualified
     D                                     based(TEMPLATE)
     D   Line1                       40A
     D   Line2                       40A
     D   City                        13A
     D   State                        2A
     D   ZipCode                      9A

When you want to use it, you'd create your own copy like this:

     D myAddr          ds                  likeds(Address_T)

That's the same way that you'd use a typedef in C. In C you'd have something like the following:

     struct _Address {
        char line1[41];
        char line2[41];
        char city[14];
        char state[3];
        char zipcode[10];
     };
     typedef struct _Address Address_T;

(the lengths are one byte longer to save space for a x'00' at the end)
When you wanted to use it, you'd code:

     Address_T myAddr;

So, it's not really that different from what you can do in RPG.

Packed, zoned, and character might be problematic, but maybe
they could be handled with something like: like(packed:30:9), or
like(char:32), or even like(varchar:1024) for a varying length character
field.

For what you're trying to do (make English names for RPG data types) your idea of specifying a length makes sense -- but, again, if you were allowed to do that, it'd be the "six of one, half dozen of the other" thing again. Whether you code "32A" instead of like(char:32) doesn't really buy you anything except a program that looks slightly more like the English language.


On the other hand, if I were writing a service program, and that program accepted parameters of a fixed type... maybe Address, as in the previous example... I wouldn't WANT you to be able to specify a length. I would want your address to exactly match the one in the service program so that they'd be compatible with one another.

So, I put my ADDRESS_T data structure in a /copy member. You code LIKEDS(Address_T) to make your own copy of it... pass it as a parameter to a procedure in my srvpgm (the prototype would also specify LIKEDS, and would also be in the /copy member) and then we'd be working with the same thing.


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.