On 01/10/2012 00:15, Richard Gaskin wrote:

I would have expected it, but I can see value in allowing what you suggest. I'm just not sure how to go about it.

Args are evaluated before being passed in, so:

   increment tA[1]

...becomes:

   increment (the value of element "1" in the array tA)

?
So doesn't
   increment t
become
  increment (the value of t)

?

If you look closely at the simple case
command increment @p
   add 1 to p
end increment

on mouseUp
   local t, tA
   put 2 into t
   increment t
   put t &CR after msg
you see that *because the parameter specifies 'pass-by-ref',* a reference to the container is passed, without evaluating the actual parameter. So what I woudl expect (or at least, wht I want :-) is for
   increment tA[1]
to be evaluated as far as
   increment (the reference to the container tA[1])

One option for passing the array would be to pass the whole thing with a specifier for the element to be affected as a separate argument:

  increment tA, 1

But you've probably already considered that.

Yeah. My problem is that I have a whole set of functions that take in an array, passed by ref, and update that array; I've now realized that *in some cases* the calling handlers don't need just one (or two) array(s) - they need to handle a large number of arrays. So I changed all the code from something like

   ("read the data into gArray")
   put myFn(gArray) into tResult

into something like
   repeat for each dataset D
      read data into gArray[D]
      put myFn(gArray[D]) into wherever
   end repeat

But of course, in other places, I still only have a single array to deal with.

For now I've inserted the ugly construct

   repeat for each dataset D
      read data into gArray[D]
      put gArray[D] into temparray
      put myFn(temparray) into wherever
      put temparray into Array[D]
end repeat

(ick !! - but it works)

So we have a question: if enough folks find this sort of suggested syntax useful, by what syntactic means could we tell the interpreter not to evaluate the argument?

There's no need for any syntactic means - the use of "by-ref" in the handler specification is already there, and is already used to differentiate how to pass it in the "simple case" (unless I'm missing something).

-- Alex.
_______________________________________________
use-livecode mailing list
use-livecode@lists.runrev.com
Please visit this url to subscribe, unsubscribe and manage your subscription 
preferences:
http://lists.runrev.com/mailman/listinfo/use-livecode

Reply via email to