|
(I do come across installationsof
where standards expressly forbid the use of /COPY - hence another appeal
the V7.1 enhancements.)
Brian ParkinsPR/PI to
Barbara, thank you for clearly outlining "best practice" for coding
replace the old-style *ENTRY PLIST.the
The (RPG Reference) Manual confused me somewhat. In the V7.1 "What's
New" section it states:
"Optional prototypes
If a program or procedure is not called by another RPG module, it is
optional to specify the prototype. The prototype may be omitted for the
following types of programs and procedures:
- A program that is only intended to be used as an exit program or as
command-processing program for a commandprogramming
- A program that is only intended to be called from a different
language <<<<<are
- A procedure that is not exported from the module
- A procedure that is exported from the module but only intended to be
called from a different programming language"
The above text suggests Program A cannot call Program B if both programs
written in RPG _and_ Program B has no prototype defined within themodule.
This has never made sense to me. But perhaps I am misinterpreting?EXTPGM
The following example works perfectly well - now that we can specify
on the PI in Program B. Yet the code appears to contradict the Manual.
========================================
// Module/program name is PROGRAMA
D CallParms Pr ExtPgm('PROGRAMB')
D 10A Const
D String S 10A Inz('String 8')
/Free
CallP CallParms(String);
*InLR = *On;
/End-Free
========================================
// Module/program name is PROGRAMB
// No Prototype (PR)
D EntryPlist Pi ExtPgm('PROGRAMB')
D String 10A Const
/Free
Dsply String '*REQUESTER';
*InLR = *On;
/End-Free
========================================
PLEASE NOTE: I am _not_ suggesting the above example is good practice! I
appreciate it would be far wiser to code the prototype in a separatesource
member and /COPY in both of the above programs.example
I know I am "splitting hairs" and probably wearing out my welcome. The
reason I am trying to nail down the semantics is because the above
is an easier starting point from which to teach the use of PI/PR tostudents
familiar with the old PLIST way of doing things. (Duplicating the PR is
both Caller and Called programs does not make a good impression at first
look.)is
I agree wholeheartedly that using /COPY to embed the PR in both programs
desirable for building more robust code. (I do come across installations
where standards expressly forbid the use of /COPY - hence another appealof
the V7.1 enhancements.)
Thanks again for everyone's patience!
Brian Parkins.
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2024 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.