|
It should be able to if it were completely implemented, but as of now, it
only supports character parameters.
On Wed, Oct 9, 2019 at 9:29 AM Vernon Hamberg <vhamberg@xxxxxxxxxxxxxxx>
wrote:
Jon
Could operational descriptor support help with any of this?
Vern
On 10/9/2019 1:24 AM, Jon Paris wrote:
"I'm not convinced it would be impossible."not do it by itself in any meaningful fashion. At present the information
Not impossible no - b ut it requires work at the OS level - RP{G could
is just not stored anywhere in the compiled objects. Foe example a program
knows its maximum an minimum number of parameters - but not what type of
data and size they should be. Same with service program procedures. that
data is just not stored by the system. The closest we come is when the
compiler generates on request the PCML data for a call. But even that would
require a lot more work before it could be used for the type of
introspection needed. PCML currently can only support a subset of the full
range of data that can be passed as parameters - so PCML has to be enhanced
significantly before you can even think of using it as the foundation for a
call mechanism.
time soon.
Not saying it wouldn't be nice - just that I don't see it happening any
PRs for every procedure. That eventually was resolved at the local level.
On Oct 8, 2019, at 9:24 PM, Peter Dow <petercdow@xxxxxxxxx> wrote:
I remember having this same feeling about having to include PIs and
Yes, it would be a lot more work for the compiler to have to look at the
service program to determine the prototypes for each candidate procedure;
I'm not convinced it would be impossible. Same thing with procedure
prototypes.
they can be composed of object subtypes, for example a file has metadata,
My understanding of programs and other objects on the IBM i is that
index data, actual data, etc. To make things simpler for the compiler, how
about a subtype object containing the prototypes?
adding all the other things we want RPG to do, and this is not that big a
I know, Barbara does a great job and has more than enough work just
deal. I just don't like to think that it's impossible.
present otherwise how would the overload one know which to pick? If they
On 10/8/2019 4:37 PM, Jon Paris wrote:
I thought that is what I had said Peter - but yes ALL have to be
are not there it has nothing to compare with.
procedures that are local and the parameter information can de derived from
The only time that an overloaded prototype is not required is for
the procedure interface.
just the overloading prototype? If it is indeed fundamentally a compiler
On Oct 8, 2019, at 3:52 PM, Peter Dow <petercdow@xxxxxxxxx> wrote:
Yes, but my question is, are the candidate prototypes *required*, or
directive, then it would seem they are all required. And if they're all
required, one might as well use the candidate prototypes.
called, a prototype (or the PI for internals) must be present.
On 10/8/2019 1:21 PM, Jon Paris wrote:
Basically the rules haven't changed. For a procedure/program to be
(say) three protos in a /Copy source - I'm just going to add the overload
That includes the overloading proto. Normally I would have all
one to that set. No increase in work except for the original definition of
the overload proto.
fundamentally a compiler directive in a different form.
This is all a compile time function and as I said earlier
in a service program, how do I use it in another RPG program? I would
On Oct 8, 2019, at 1:11 PM, Peter Dow <petercdow@xxxxxxxxx> wrote:
Jon,
Assuming the FORMAT procedure and its candidate procedures are all
guess that I have to put the prototype in the RPG program, yes? Do I have
to put all the candidate prototypes in there too? My thought was the RPG
program using it would simply have
the service program to check my usage against each of those candidate
Dcl-Pr Format Override( ProcA, PgmB, JavaC );
but now that I put it that way, the compiler would have to go to
prototypes to see if it's allowed.
directive.
--
*Peter Dow* /
Dow Software Services, Inc.
909 793-9050
petercdow@xxxxxxxxx <mailto:petercdow@xxxxxxxxx>
pdow@xxxxxxxxxxxxxx <mailto:pdow@xxxxxxxxxxxxxx>
/
On 10/8/2019 12:14 PM, Jon Paris wrote:
FORMAT is never exported because it is only really a compiler
compilation directive such as ...
For example thing of it this way.
Dcl-Pr Format Override( ProcA, PgmB, JavaC );
This is handled by the compiler much like a conditional
wrote:
/IF ParmMatches ProcA
CallP ProcA(parm);
/ELSEIF ParmMatches ProcB
CallP PgmB(parm);
/ELSE
....
It is that simple.
On Oct 8, 2019, at 11:28 AM, Justin Taylor <JUSTIN@xxxxxxxxxxxxx>
and other times I don't. My best guess is that it inherits from the actual
Is FORMAT exported? There will be times when I want it exported
procedures.
In fact the overloaded routines can include programs, Java calls, and
-----Original Message-----
From: Jon Paris [mailto:jon.paris@xxxxxxxxxxxxxx]
Sent: Tuesday, October 08, 2019 1:04 PM
To: RPG programming on IBM i <rpg400-l@xxxxxxxxxxxxxxxxxx>
Subject: Re: Latest RPG Updates
Actually it doesn't matter if the procedure is exported or not.
subprocs.
related questions.
--
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
affiliate link: https://amazon.midrange.com
Help support midrange.com by shopping at amazon.com with our
software.--
This email has been checked for viruses by Avast antivirus
questions.https://www.avast.com/antivirus
--
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
affiliate link: https://amazon.midrange.com
Help support midrange.com by shopping at amazon.com with our
questions.--
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
affiliate link: https://amazon.midrange.com
Help support midrange.com by shopping at amazon.com with our
questions.--
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
affiliate link: https://amazon.midrange.com
Help support midrange.com by shopping at amazon.com with our
--
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 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.