Hi Barbara,

Thanks, that's what I needed -- question my assumptions!  The prototypes
were coming from different copy members.  Once I fixed that, everything was
as expected.

Although I'm still curious -- does VALUE conversion include size as well as
type?  If I'm passing 128 bytes (not varying) to a 32K parameter (also not
varying), will it place 32K on the stack (the 128 bytes + blanks)?

In the following procedure, I'm thinking I can reduce the amount of copying
(which as Scott Klement points out is, even if cheap, still more expensive
than simply
passing a pointer) by using the following:

p IFS_prt         b                   export

d IFS_prt         pi
d  hFile                              like(int) value
d  Text                      32766a   const varying

d Data            s          32766a   varying
d NbrWritten      s                   like(int)

c                   eval      Data = Text
c                   eval      NbrWritten = api_write(
c                                          hFile:
c                                          %addr(Data) + 2:
c                                          %len(Data))

p                 e

Note the "+ 2" to skip the embedded length.  Will this get me in trouble in
the future?  Is it possible IBM will decide to increase the length to 4
bytes?

tia,
Peter Dow
Dow Software Services, Inc.
909 425-0194 voice
909 425-0196 fax



----- Original Message -----
From: <bmorris@ca.ibm.com>
Sent: Friday, December 14, 2001 9:08 AM
Subject: Re: Procedure parameter with VALUE option
> Peter, conversion is done if necessary.  The value is put on the stack as
> dictated by the parameter's type in the prototype.  It's convenient to
> think of the compiler having a temporary of the prototype-type, and
> EVALing the passed parameter to this temporary, then copying the temporary
> to the parameter stack.  (A temporary may or may not be involved - some
> conversions can be done "on the stack", but the effect is the same.)
>
> I can't explain your debug session output.  Are you sure sure sure that
> those are the correct prototypes?

<snip>

> There are many ways to handle character parameters.  My personal
> recommendation is CONST VARYING.  Passing large VALUE parameters
> is always a bad idea (every language, every system).  If you
> need to modify the parameter within the procedure, but the
> caller doesn't need to see the change, declare a temporary and
> copy the passed parameter to the temp.  Copying is cheap.



_________________________________________________________
Do You Yahoo!?
Get your free @yahoo.com address at http://mail.yahoo.com



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.