[#44786] [ruby-trunk - Feature #2565] adding hooks for better tracing — "tenderlovemaking (Aaron Patterson)" <aaron@...>
8 messages
2012/05/01
[#44788] Re: [ruby-trunk - Feature #2565] adding hooks for better tracing
— SASADA Koichi <ko1@...>
2012/05/02
(2012/05/02 8:25), tenderlovemaking (Aaron Patterson) wrote:
[#44789] Re: [ruby-trunk - Feature #2565] adding hooks for better tracing
— SASADA Koichi <ko1@...>
2012/05/02
(2012/05/02 8:25), tenderlovemaking (Aaron Patterson) wrote:
[#44911] [ruby-trunk - Bug #6408][Open] DelegateClass#eql? and <=> don't work as expected — "tenderlovemaking (Aaron Patterson)" <aaron@...>
11 messages
2012/05/06
[#44951] [ruby-trunk - Feature #6414][Open] Destructuring Assignment — "edtsech (Edward Tsech)" <edtsech@...>
14 messages
2012/05/08
[#45001] [ruby-trunk - Bug #6425][Open] Psych issue with !!omap — "trans (Thomas Sawyer)" <transfire@...>
5 messages
2012/05/11
[#45009] [ruby-trunk - Bug #6427][Open] ruby ioctl: Error integer 2148012656 too big to convert to `int' — "hadmut (Hadmut Danisch)" <hadmut@...>
5 messages
2012/05/12
[#45014] [Backport93 - Backport #6429][Assigned] Backport r35631 - [mingw] Errno::EBADF in ruby/test_io.rb on ruby_1_9_3 — "luislavena (Luis Lavena)" <luislavena@...>
3 messages
2012/05/12
[#45015] Re: [ruby-changes:23580] luislavena:r35631 (trunk): * test/ruby/test_io.rb (class TestIO): Disable GC during IO tests to — Tanaka Akira <akr@...>
2012/5/13 luislavena <ko1@atdot.net>:
3 messages
2012/05/12
[#45035] [ruby-trunk - Bug #6433][Open] rb_thread_blocking_region(): ubf() function is executed with GVL — ibc (Iñaki Baz Castillo) <ibc@...>
12 messages
2012/05/14
[#45062] [ruby-trunk - Bug #6436][Open] Byte counting incorrect in BufferedIO (net/protocol.rb) — "jcast (Jeremie Castagna)" <jeremie.castagna@...>
6 messages
2012/05/15
[#45073] [PATCH] Ruby's port to NativeClient — Yuki Yugui Sonoda <yugui@...>
Hello Matz and rubyists,
9 messages
2012/05/16
[#45074] Re: [PATCH] Ruby's port to NativeClient
— SASADA Koichi <ko1@...>
2012/05/16
(2012/05/16 12:34), Yuki Yugui Sonoda wrote:
[#45075] Re: [PATCH] Ruby's port to NativeClient
— Yuki Yugui Sonoda <yugui@...>
2012/05/16
On Wed, May 16, 2012 at 12:43 PM, SASADA Koichi <ko1@atdot.net> wrote:
[#45102] ruby-mode maintainer? — Stefan Monnier <monnier@...>
Could the ruby-mode maintainer(s) contact me off-list?
6 messages
2012/05/17
[#45151] Re: ruby-mode maintainer?
— "NARUSE, Yui" <naruse@...>
2012/05/20
(2012/05/17 10:06), Stefan Monnier wrote:
[#45132] [ruby-trunk - Bug #6454][Open] Anonymous classes should delete tmp_classpath on dup — "tenderlovemaking (Aaron Patterson)" <aaron@...>
5 messages
2012/05/18
[#45176] [ruby-trunk - Bug #6476][Open] Proc unrolls an array even without splat — "prijutme4ty (Ilya Vorontsov)" <prijutme4ty@...>
3 messages
2012/05/22
[#45193] [ruby-trunk - Feature #6482][Open] Add URI requested to Net::HTTP request and response objects — "drbrain (Eric Hodel)" <drbrain@...7.net>
16 messages
2012/05/23
[#45268] [ruby-trunk - Feature #6482] Add URI requested to Net::HTTP request and response objects
— "mame (Yusuke Endoh)" <mame@...>
2012/05/26
[#45222] [ruby-trunk - Feature #6492][Open] Inflate all HTTP Content-Encoding: deflate, gzip, x-gzip responses by default — "drbrain (Eric Hodel)" <drbrain@...7.net>
23 messages
2012/05/24
[#45528] Re: [ruby-trunk - Feature #6492][Open] Inflate all HTTP Content-Encoding: deflate, gzip, x-gzip responses by default
— Eric Wong <normalperson@...>
2012/06/09
"drbrain (Eric Hodel)" <drbrain@segment7.net> wrote:
[#45253] [RFC] RubyVM::FrameInfo.caller method — SASADA Koichi <ko1@...>
Hi,
11 messages
2012/05/26
[#45302] Re: [RFC] RubyVM::FrameInfo.caller method
— Dice <tetradice@...>
2012/05/28
Hello.
[#45269] [ruby-trunk - Bug #6501][Open] Documentation for Exception#set_backtrace is incorrect — "djberg96 (Daniel Berger)" <redmine@...>
3 messages
2012/05/26
[#45272] [ruby-trunk - Feature #6503][Open] Support for the NPN extension to TLS/SSL — "igrigorik (Ilya Grigorik)" <ilya@...>
13 messages
2012/05/27
[ruby-core:44853] Re: help understanding weird bug
From:
Rodrigo Rosenfeld Rosas <rr.rosas@...>
Date:
2012-05-03 16:33:21 UTC
List:
ruby-core #44853
Thank you Aaron and Jeremy.
Basically it is a plain array which is modified by some hook when
setting an association.
Now that I know that, the fix is obvious. I was just trying to figure
out how to debug such kind of code in Ruby to understand where to look
for, I mean, which code was changing the array.
Whether this is a good design choice, I'll discuss in the sequel-talk list.
Thanks,
Rodrigo.
Em 03-05-2012 12:35, Jeremy Evans escreveu:
> On 05/03 08:56, Rodrigo Rosenfeld Rosas wrote:
>> Here is a sample application:
>>
>> https://github.com/rosenfeld/weird-sequel-bug
>>
>> And here is the strange behavior:
>>
>> https://github.com/rosenfeld/weird-sequel-bug/blob/master/example.rb
>>
>> children = Sq::Node[1].children
>> p children.class
>> parent = children.first.parent
>> p children.map&:id
>> 2.times { p children.map{|c| c.parent = parent; c.id} }
>>
>> Output:
>>
>> Array
>> [2, 3]
>> [2, 2]
>> [3, 3]
>>
>> For some strange reason, changing the parent of the element inside
>> children.map{} block will modify the children array itself.
>>
>> for example:
>>
>> p children.map&:id
>> children[0].parent = parent
>> p children.map&:id
>>
>> outputs:
>> [2, 3]
>> [3, 2]
>>
>> Maybe this is a Sequel bug (I didn't look for the code of
>> associations yet), but I'd like to understand how this could happen
>> in Ruby.
>
> This isn't a Sequel bug or a ruby bug. When you use c.parent= in
> Sequel, it will recognize that parent.children is the reciprocal, and
> c.parent= will modify parent.children.
>
> You issue is that you are modifying an array while you are iterating
> over it, which is generally a bad idea.
>
> Now, I can probably change it so that it doesn't make such a change
> if you pass in a object that is the same as the existing value, but I
> don't consider the current implementation incorrect.
>
>> For example, how can I know if this is an ordinary Array or not?
>> children.class is Array, so how can I differentiate it from a normal
>> Array.
> Sequel uses a plain array, it doesn't use a proxy object for
> associations. You could probably use an after_load hook to extend the
> array with a module, though I'm not sure what it is you want to do.
>
>> If I change the first line to the one below it works:
>> # children = Sq::Node[1].children
>> children = Sq::Node[1].children.map{|c| c}
> Here you are creating a duplicate of the array, similar to:
>
> children = Sq::Node[1].children.dup
>
> So you are not modifying the array you are iterating over, and hence,
> you don't have that problem.
>
> Jeremy
>