Counting problem
Dar Scott
dsc at swcp.com
Sat May 25 11:41:57 EDT 2013
Putting
local tcount
at the top of the handler fixes this for me. (Maybe somebody already said that.)
This is a scary bug for me. I quit LiveCode after the tests.
Dar
On May 25, 2013, at 2:44 AM, Jacques Hausser wrote:
> Craig,
>
> A way to have the second script working correctly (sum on the counter array = 10) is to declare and fill the counter explicitly before using it; my version:
>
> on mouseup
> put "a,b,c,d,e,f,g,h,i,j" into temp
> repeat with i = 1 to 10
> put 0 into tcount[item i of temp]
> end repeat
> repeat 10
> add 1 to tcount[any item of temp]
> end repeat
> put "" into fld "F1"
> put 0 into tSum
> repeat with i = 1 to 10
> put item i of temp & " : " & tcount[item i of temp] & return after fld "F1"
> add tcount[item i of temp] to tSum
> end repeat
> put return & "Sum = " & tSum after fld "F1"
> end mouseUp
>
> the sum is always 10 - if you want to go back to craziness, just comment out the first loop. Sums between 6 and 17 in my trials.
> I also noticed that the automatic indent doesn't work correctly for the "repeat 10" loop - perhaps an indication that the interpreter doesn't understand exactly what we mean…
>
> For Alex: I didn't observe the correcting effect of adding "put counter["b"] into tJunk" to the loop (OS 10.8.3, either with 6.0.1 or 5.5.4). The result was as bad as without the command.
>
> A very intriguing bug anyway ! I filled a bug report, # 10925 (giving credit to Craig for his amazing discovery)
>
> Jacques
>
>
>
>
> Le 25 mai 2013 à 04:26, dunbarx at aol.com a écrit :
>
>> Alex.
>>
>>
>> I am the kind of guy that is happy to solve a problem without understanding it. But this one is, er, bugging me.
>>
>>
>> Craig
>>
>>
>>
>> -----Original Message-----
>> From: Alex Tweedly <alex at tweedly.net>
>> To: use-livecode <use-livecode at lists.runrev.com>
>> Sent: Fri, May 24, 2013 7:11 pm
>> Subject: Re: Counting problem
>>
>>
>> I see the same problem on both 5.5.3 and 6.0.1 - but testing in the
>> message box.
>>
>> Oddly, I happened to notice that if I change the script to be
>>
>> put "a,b,c,d,e,f,g,h,i,j" into temp
>> repeat 10
>> add 1 to counter[any item of temp]
>> put counter["b"] into tJunk -- i.e. I add a single useless line
>> !!
>> end repeat
>>
>>
>>
>> it works just fine every time.
>> Don't know if that helps you or makes it worse :-)
>>
>> -- Alex.
>>
>> On 24/05/2013 22:56, dunbarx at aol.com wrote:
>>> I know I am going to feel like a dope, but why does the first script always
>>> properly give ten counts in the array variable "counter", but the second can
>>> give anywhere from five to sixteen, and maybe others?
>>>
>>>
>>>
>>> on mouseUp
>>> put "a,b,c,d,e,f,g,h,i,j" into temp
>>> repeat 10
>>> get any item of temp --always gives ten
>>> add 1 to counter[it]
>>> end repeat
>>> end mouseUp
>>>
>>>
>>> on mouseup
>>> put "a,b,c,d,e,f,g,h,i,j" into temp
>>> repeat 10
>>> add 1 to counter[any item of temp]
>>> end repeat
>>> end mouseUp
>>>
>>>
>>>
>>>
>>> I have deconstructed the problem line by watching the array in the debugger on
>>> the sly after each iteration. It goes crazy, sometimes the count of a particular
>>> char going DOWN.
>>>
>>>
>>> Craig Newman
>
>
> _______________________________________________
> use-livecode mailing list
> use-livecode at lists.runrev.com
> Please visit this url to subscribe, unsubscribe and manage your subscription preferences:
> http://lists.runrev.com/mailman/listinfo/use-livecode
More information about the use-livecode
mailing list