[Pharo-dev] [Vm-dev] modified method temp references in closures: possible bug?

Max Leske maxleske at gmail.com
Fri Aug 2 13:39:40 UTC 2013


On 02.08.2013, at 15:35, Igor Stasenko <siguctua at gmail.com> wrote:

> On 2 August 2013 15:27, Max Leske <maxleske at gmail.com> wrote:
>> 
>> Sorry, yes, "dict" should be "collection".
>> 
>> 
>> On 02.08.2013, at 15:16, Clément Béra <bera.clement at gmail.com> wrote:
>> 
>> This is not a bug.
>> 
> 
> yes, the expression:
> 
> [ methodScope ]
> 
> does not capturing the current value of methodScope variable.
> 
> means that closure, when evaluated will always return the value
> methodScope at the moment of evaluation.
> 
> Closures do not capturing values of free variables, because then it
> will mean different semantic than rest of code (in method's body).

Ok, thanks.


> 
> 
>> Here your variable methodScope is defined outside the block, therefore all the blocks and the method refers to the same variable when calling methodScope.
>> 
>> 
>> Yes, I understand that. I just wanted to make sure that's the intended functionality. The reason I ask is that the error isn't easy to spot and there's no cue that one might be doing something wrong (It's not my code by the way :P). Especially for newcomers this can be a tricky one.
>> 
>> I totally agree with you that the variables belong to the block and should be declared there.
>> 
>> 
>> Your code is the same as if you wrote :
>> | methodScope |
>> methodScope := 1.
>> methodScope := 2.
>> At the end, methodScope is of course 2.
>> 
>> If you want the result :
>> 1
>> 2
>> you have to declare the variable in the block (then there are different variable named methodScope, actually 1 per activation of the block.
>> 
>> collection := OrderedCollection new.
>> 1 to: 2 do: [ :index |
>>        | methodScope |
>>        methodScope := index.
>>        dict add: [ methodScope ] ].
>> collection do: [ :block | Transcript show: block value; cr ]
>> 
>> 
>> 2013/8/2 Max Leske <maxleske at gmail.com>
>>> 
>>> 
>>> I just came across this (possible) bug and I'm able to reproduce it in Pharo 2.0 and 3.0 with the latest PharoVM (found in a 1.3 with NBCog):
>>> 
>>> expected (by my feeble mind):
>>> 1
>>> 2
>>> 
>>> actual:
>>> 2
>>> 2
>>> 
>>> | methodScope |
>>> collection := OrderedCollection new.
>>> 1 to: 2 do: [ :index |
>>>        methodScope := index.
>>>        dict add: [ methodScope ] ].
>>> 
>>> collection do: [ :block | Transcript show: block value; cr ]
>>> 
>>> I'm aware that using method temps in this way is not good programming style (usually) but I still think this behavior is curious if not at least very likely to cause a lot of weird errors.
>>> 
>>> Should I open a bug report?
>>> 
>>> Cheers,
>>> Max
>> 
>> 
>> 
>> 
> 
> 
> 
> -- 
> Best regards,
> Igor Stasenko.
> 



More information about the Vm-dev mailing list