Kurt,

> If Parm3 does go at the end, and doesn't meet the criteria above, then
> Parm2 must have Options( *NoPass ) removed (and more than likely replace
> it with Options( *Omit )), and in doing so, all modules that call this
> procedure that don't pass the 2nd parameter must now pass the parameter
> or pass *Omit.  And you now have to code this program to check for a
> null address.

In the event a 3rd parm is someday added beyond a Options( *NoPass ),
I'd then change the second to become Options( *NoPass: *Omit ) and the
third to to Options( *NoPass ).

That way existing callers of the service program can continue to still
pass either one or two arguments as they see fit.  No existing program
will require the 3rd argument unless you are making changes anyway,
and then if it needs the 1st and 3rd but not the 2nd, you can pass the
middle one as *Omit.

Only the service program, which is already changing, needs to be
revised to test the second argument for *Omit.

 While you should never say never, there is no good reason to not
allow existing callers to use the previous prototype unless/until they
need changing anyway for passing the new argument.

IMHO,
Doug

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.