[#54738] [ruby-trunk - Bug #8358][Open] TestSprintf#test_float test failuer on mingw32 — "phasis68 (Heesob Park)" <phasis@...>

36 messages 2013/05/02

[#54749] [ruby-trunk - Feature #8361][Open] Alternative syntax for block parameter — "alexeymuranov (Alexey Muranov)" <redmine@...>

12 messages 2013/05/02

[#54798] [ruby-trunk - Bug #8370][Open] Constants MAX_MULTIPART_LENGTH in cgi\core.rb — "xibbar (Takeyuki FUJIOKA)" <xibbar@...>

17 messages 2013/05/05

[#54850] [ruby-trunk - Feature #8377][Open] Deprecate :: for method calls in 2.1 — "charliesome (Charlie Somerville)" <charliesome@...>

27 messages 2013/05/07

[#54881] [ruby-trunk - Bug #8384][Open] Cannot build ruby against OpenSSL build with "no-ec2m" — "vo.x (Vit Ondruch)" <v.ondruch@...>

16 messages 2013/05/09

[#54921] [ruby-trunk - Bug #8393][Open] A class who's parent class is in a module can go wrong if files are required in the wrong order — "eLobato (Daniel Lobato Garcia)" <elobatocs@...>

15 messages 2013/05/12

[#54939] [ruby-trunk - Bug #8399][Open] Remove usage of RARRAY_PTR in C extensions when not needed — "dbussink (Dirkjan Bussink)" <d.bussink@...>

32 messages 2013/05/12

[#55053] [ruby-trunk - Feature #8426][Open] Implement class hierarchy method caching — "charliesome (Charlie Somerville)" <charliesome@...>

21 messages 2013/05/19

[#55096] [ruby-trunk - Feature #8430][Open] Rational number literal — "mrkn (Kenta Murata)" <muraken@...>

28 messages 2013/05/21

[#55197] [ruby-trunk - Feature #8461][Open] Easy way to disable certificate checking in XMLRPC::Client — "herwinw (Herwin Weststrate)" <herwin@...>

11 messages 2013/05/29

[ruby-core:54946] [Ruby 1.8 - Bug #4181] Backport Ruby 1.9 singleton.rb, since 1.8's is not thread-safe

From: "testredmine (Test Redmine)" <larry.kubin@...>
Date: 2013-05-13 00:38:20 UTC
List: ruby-core #54946
Issue #4181 has been updated by testredmine (Test Redmine).


My 2 cents
----------------------------------------
Bug #4181: Backport Ruby 1.9 singleton.rb, since 1.8's is not thread-safe
https://bugs.ruby-lang.org/issues/4181#change-39286

Author: headius (Charles Nutter)
Status: Closed
Priority: Normal
Assignee: shyouhei (Shyouhei Urabe)
Category: 
Target version: Ruby 1.8.7
ruby -v: Any Ruby 1.8 version


=begin
 Ruby 1.9 modified singleton.rb by eliminating much of the lazy init logic, using a real mutex instead of Thread.critical, and eliminating the redefinition of "instance" on first call. None of these changes have been backported into a 1.8 release, which means all 1.8 releases have a broken singleton.rb.
 
 The following script breaks under any version of 1.8:
 
 <code>
  require 'singleton'
  $jruby = RUBY_PLATFORM =~ /java/
  require 'jruby/synchronized' if $jruby
  
  loop do
    $inits = []
    $inits.extend JRuby::Synchronized if $jruby
    classes = []
    1000.times do
      classes << Class.new do
        include Singleton
      end
    end
    
    (0..10).map do
      Thread.new do
        classes.each do |cls|
          cls.instance
        end
      end
    end.map(&:join)
    puts "loop completed"
  end
 </code>
 
 Results:
 
 ~/projects/jruby ➔ ruby -v singleton_killer.rb 
 ruby 1.8.7 (2010-08-16 patchlevel 302) [i686-darwin10.4.0]
 loop completed
 loop completed
 loop completed
 loop completed
 loop completed
 loop completed
 loop completed
 loop completed
 loop completed
 singleton_killer.rb:18: undefined method `instance' for #<Class:0x1001896a0> (NoMethodError)
 	from singleton_killer.rb:1:in `join'
 	from singleton_killer.rb:1:in `to_proc'
 	from singleton_killer.rb:21:in `map'
 	from singleton_killer.rb:21
 	from singleton_killer.rb:5:in `loop'
 	from singleton_killer.rb:5
 
 
 ~/projects/jruby ➔ ruby -v singleton_killer.rb 
 ruby 1.8.7 (2009-06-12 patchlevel 174) [universal-darwin10.0]
 loop completed
 loop completed
 loop completed
 loop completed
 singleton_killer.rb:18: undefined method `instance' for #<Class:0x100348c70> (NoMethodError)
 	from singleton_killer.rb:1:in `join'
 	from singleton_killer.rb:1:in `to_proc'
 	from singleton_killer.rb:21:in `map'
 	from singleton_killer.rb:21
 	from singleton_killer.rb:5:in `loop'
 	from singleton_killer.rb:5
 
 This can lead to lazy failures in any library that uses singleton.rb. See also this commit to Nokogiri, where they had to stop using Singleton because of this issue:
 
 https://github.com/tenderlove/nokogiri/commit/5eb036e39ea85a8e12eebee11bc5086b0e4ce6e3
=end



-- 
http://bugs.ruby-lang.org/

In This Thread

Prev Next