[#44776] [ruby-trunk - Bug #6385][Open] mtime vie File.stat(filename).utime vs File.open(filename, 'r').mtime in Windows — "kolmanv (Kolman Vornovitsky)" <kolmanv@...>

9 messages 2012/05/01

[#44782] [ruby-trunk - Bug #6387][Open] 1.9.3p194 crashed on require in ubuntu — "ywen (Yi Wen)" <hayafirst@...>

12 messages 2012/05/01

[#44795] [ruby-trunk - Bug #6391][Open] Segment Fault while execute make_encmake.rb for Ruby 1.9.3 P194 ( MinGW64) — "raylinn@... (ray linn)" <raylinn@...>

13 messages 2012/05/02

[#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

[#44958] [ruby-trunk - Feature #6418][Assigned] Supporing a subset of ANSI escape code on Windows — "usa (Usaku NAKAMURA)" <usa@...>

11 messages 2012/05/09

[#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

[#45180] [ruby-trunk - Feature #6478][Open] BasicObject#__class__ — "trans (Thomas Sawyer)" <transfire@...>

14 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

[#45198] [ruby-trunk - Feature #6483][Open] parametric map — "prijutme4ty (Ilya Vorontsov)" <prijutme4ty@...>

14 messages 2012/05/23

[#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

[#45252] [ruby-trunk - Feature #6499][Open] Array::zip — "prijutme4ty (Ilya Vorontsov)" <prijutme4ty@...>

14 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

[#45316] [ruby-trunk - Feature #6515][Open] array.c: added method that verifies if an Array is part of another — "lellisga (Li Ellis Galardo)" <lellisga@...>

14 messages 2012/05/30

[ruby-core:44851] Re: help understanding weird bug

From: Jeremy Evans <code@...>
Date: 2012-05-03 15:35:57 UTC
List: ruby-core #44851
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

In This Thread