|
While I don't recommend this approach, it isn't the end of the world
you make it out to be. You need to remember that you're passing by
reference, meaning it doesn't matter how big the DS is the only thing
passed in and out of the procedure is a 16 byte pointer.
Charles, Charles, Charles. I'm so surprised to hear you say that!
You're saying that, because only a 16-byte pointer is passed to my
routine, the actual size of the DS doesn't really matter? So that if
the routine is expecting, say, 100 bytes in but only 80 are provided by
the caller, then that's OK?
Or, if the called routine will pass back 100 bytes but the program has
allocated 80 for the effort -- then that's OK too?
These are not problems that can be circumvented by planning, design,
and use of features? Remember: "the problem with making anything
foolproof is that fools are so ingenious." This design opens the door
to that ingenuity.
Dang it, I sent too soon. (I guess I pressed CTRL+ENTER but I sure didn't
mean too. Anyway...) I understand what you're saying about the "number of
bytes to return" parameter. First off, I saw nothing about that in the OP,
so I won't assume that it's there. Secondly, IBM does that to ONE of its
parameters (generally speaking, except that there are some "control-block"
based APIs), not as an effort to future-proof against the addition of
alternate parameters.
This too is something IBM does quite often. In the early days, some of the
APIs didn't use an Error Structure return. Now that's been added as an
optional parameter. There are many, many examples of IBM's (proper) use of
this function.
Format of output is entirely a different thing, and I align with you on
that
thinking.
Dennis Lovelady
http://www.linkedin.com/in/dennislovelady
--
"People are usually more convinced by reasons they discovered themselves
than by those found by others."
-- Blaise Pascal
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.