On 2017-10-10 5:26 PM, Dan wrote:
Thanks Joe,

Your assumption is what I presumed, but wasn't sure if there were other
instances where a procedure could have more than one procedure interface.

I'm trying to determine a good standard for our "*entry plist" procedure
interfaces, since we're fairly new at using them here. Personally, I think
I'd like to name these procedure interfaces Entry_Plist. For example:

dcl-pi Entry_Plist;
Parm1 char( 1);
Parm2 char( 1);
Parm3 char( 1);
end-pi;


If you are (now or ever) going to use prototyped calls to call your programs, then you'll need a different name for each prototype. And the procedure interface has to have the same name as the prototype to allow the compiler to check the parameters for consistency. Adding "*ENTRY PLIST" in a comment is a good way of letting people find the PI. Probably better than calling it Entry_Plist, since people would probably be searching for '*ENTRY', not just 'ENTRY'.

I recommend getting in the habit of putting the prototype in a /COPY file, and copying it into the program itself and any module that calls the program.

The only time I would have a program with an unnamed PI for a cycle-main program would be for something like a command-processing program that isn't ever intended to be called from another program.

For procedures that are exported from the module, the same thing applies: put the prototype in a copy file, and copy it into the module with the procedure and all calling modules. But you don't need to name the procedure interface in that case; you can just use *N because the name of the PI gets picked up from the name of the procedure.

For procedures that aren't exported from the module, a prototype isn't needed at all.


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.