Search code examples
ruby-on-railsrubyruby-debug

Rails with ruby-debugger throw 'Symbol not found: _ruby_current_thread (LoadError)'


I have standard ruby-head and Rails 3.1rc4. I installed ruby-debug with following instructions from http://dirk.net/2010/04/17/ruby-debug-with-ruby-19x-and-rails-3-on-rvm/

But when i run rails s --debugger it will throw this strange error

/Users/schovi/.rvm/gems/ruby-head/gems/activesupport-3.1.0.rc4/lib/active_support/dependencies.rb:237:in `require': dlopen(/Users/schovi/.rvm/gems/ruby-head/gems/linecache19-0.5.12/lib/trace_nums19.bundle, 9): Symbol not found: _ruby_current_thread (LoadError)
  Referenced from: /Users/schovi/.rvm/gems/ruby-head/gems/linecache19-0.5.12/lib/trace_nums19.bundle
  Expected in: flat namespace
in /Users/schovi/.rvm/gems/ruby-head/gems/linecache19-0.5.12/lib/trace_nums19.bundle - /Users/schovi/.rvm/gems/ruby-head/gems/linecache19-0.5.12/lib/trace_nums19.bundle
from /Users/schovi/.rvm/gems/ruby-head/gems/activesupport-3.1.0.rc4/lib/active_support/dependencies.rb:237:in `block in require'
from /Users/schovi/.rvm/gems/ruby-head/gems/activesupport-3.1.0.rc4/lib/active_support/dependencies.rb:223:in `block in load_dependency'

Any idea? Thanks, David


Solution

  • UPDATE:

    Looks like you only need to put this in your gemfile:

    gem "debugger"

    and now works.

    Old article follows

    ====================================

    Jerome is correct, but lacking in the details. Here is the blow by blow, taken from this https://gist.github.com/1331533, in particular thanks to andrewroth's post. I've tested this as of the time of this post. One hopes that the changes will be deployed somewhere standard soon.

    Installing ruby debugger on ruby 1.9.3-p125: 
    
    export PATCH_LEVEL=`ruby -e 'puts RUBY_PATCHLEVEL'`
    export RVM_SRC=$HOME/.rvm/rubies/ruby-1.9.3-p$PATCH_LEVEL/include/ruby-1.9.1
    gem install archive-tar-minitar
    gem install ruby_core_source -- --with-ruby-include=/$RVM_SRC
    export RVM_SRC=$HOME/.rvm/rubies/ruby-1.9.3-p$PATCH_LEVEL/include/ruby-1.9.1/ruby-1.9.3-p$PATCH_LEVEL
    
    wget http://rubyforge.org/frs/download.php/75415/ruby-debug-base19-0.11.26.gem
    wget http://rubyforge.org/frs/download.php/63094/ruby-debug19-0.11.6.gem
    wget http://rubyforge.org/frs/download.php/75414/linecache19-0.5.13.gem
    gem install linecache19-0.5.13.gem -- --with-ruby-include=/$RVM_SRC
    # if that step failed, and you are running OSX Lion, then following this post can help you: 
    # http://stackoverflow.com/questions/8032824/cant-install-ruby-under-lion-with-rvm-gcc-issues
    # this happens if you recently installed xcode from the app store. 
    # bizarrely, for me I had to do this: ln -s /usr/bin/gcc /usr/bin/gcc-4.2
    gem install ruby-debug-base19-0.11.26.gem -- --with-ruby-include=/$RVM_SRC
    
    Then edit Gemfile: 
    
    gem 'linecache19', '0.5.13', :path => "~/.rvm/gems/ruby-1.9.3-p#{RUBY_PATCHLEVEL}/gems/linecache19-0.5.13/"
    gem 'ruby-debug-base19', '0.11.26', :path => "~/.rvm/gems/ruby-1.9.3-p#{RUBY_PATCHLEVEL}/gems/ruby-debug-base19-0.11.26/"
    gem 'ruby-debug19', :require => 'ruby-debug'
    
    Then install: 
    
    bundle install