Thanks Dave - glad I'm not the only one who sees this.

Actually though I'm not convinced there were "other ways" - at least not simple ones. There is no underlying OS support that allows for introspection - so that is a no go. Naming conventions work in a given show maybe - but not as a broad brush approach. By doing it this way anything can be overloaded be it a program, a procedure, or a Java method. For sure there is room for enhancement and improvement but IBM have right;y erred on the side of caution rather than lock themselves into a position that they can't change without breaking compatibility.



On Oct 8, 2019, at 4:07 PM, dlclark@xxxxxxxxxxxxxxxx wrote:

"RPG400-L" <rpg400-l-bounces@xxxxxxxxxxxxxxxxxx> wrote on 10/08/2019
06:52:59 PM:
Yes, but my question is, are the candidate prototypes *required*, or
just the overloading prototype? If it is indeed fundamentally a
compiler directive, then it would seem they are all required. And if
they're all required, one might as well use the candidate prototypes.


That is true. However, I see the purpose of this enhancement as
providing an end-user a means of emulating what IBM can do with their
built-in functions. For example, the %date function can accept arguments
of different data types while delivering a uniform returned result. IBM
*could* have delivered multiple date functions with a distinct and unique
naming convention in order to portray the nature (type) of the expected
argument. That is what we had to do up to this point with the procedures
we developed.

But, with this enhancement, you too can use a single procedure
name on the front end but be able to pass different data types and get a
uniform returned result. I have done this by using a character data type
and having to convert my data to character format before passing it to the
procedure. Now I don't have to convert it on the front end and can let
that be done automatically by the compiler.

Sure, there are more procedures on the back end but it is the
front end that is cleaner and easier to understand. With multiple
procedures on the back end, that makes maintenance easier, too, because
each back-end procedure only handles a single data type instead of having
to manipulate things in a single back-end procedure.

I can think of other ways this enhancement could have been
delivered. But, I don't see anything inherently wrong with the way it was
done, either.


Sincerely,

Dave Clark
--
int.ext: 91078
direct: (937) 531-6378
home: (937) 751-3300

Winsupply Group Services
3110 Kettering Boulevard
Dayton, Ohio 45439 USA
(937) 294-5331




*********************************************************************************************
This email message and any attachments is for use only by the named
addressee(s) and may contain confidential, privileged and/or proprietary
information. If you have received this message in error, please
immediately notify the sender and delete and destroy the message and all
copies. All unauthorized direct or indirect use or disclosure of this
message is strictly prohibited. No right to confidentiality or privilege
is waived or lost by any error in transmission.
*********************************************************************************************
--
This is the RPG programming on IBM i (RPG400-L) mailing list
To post a message email: RPG400-L@xxxxxxxxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: https://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxxxxxxxx
Before posting, please take a moment to review the archives
at https://archive.midrange.com/rpg400-l.

Please contact support@xxxxxxxxxxxx for any subscription related questions.

Help support midrange.com by shopping at amazon.com with our affiliate link: https://amazon.midrange.com


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.