Solved: Ruby Gem Require LoadError (8-STABLE, Ruby 1.9.1)
Aaron Gifford
astounding at gmail.com
Fri Jan 29 04:50:41 UTC 2010
On Thu, Jan 28, 2010 at 7:25 PM, Aaron Gifford <astounding at gmail.com> wrote:
> I wrote:
>> One more interesting thing:
>>
>> % ruby19 -e 'p Gem.default_dir'
>> "/usr/local/lib/ruby19/gems/1.9"
>>
>> That is NOT right. It should be "/usr/local/lib/ruby/gems/1.9" instead.
>>
>> Where does Gem.default_dir get set, does anyone know?
>>
>> Aaron out.
>
> It looks like gem_prelude.rb sets up the gems include path.
>
> The relevant code section is:
>
> def self.default_dir
> File.join File.dirname(ConfigMap[:sitedir]), 'Gems',
> ConfigMap[:ruby_version]
> elsif RUBY_VERSION > '1.9' then
> File.join(ConfigMap[:libdir], ConfigMap[:ruby_install_name], 'gems',
> ConfigMap[:ruby_version])
> else
> File.join(ConfigMap[:libdir], ruby_engine, 'gems',
> ConfigMap[:ruby_version])
> end
> end
>
> So the Gem.default_dir is being set to:
> File.join(ConfigMap[:libdir], ConfigMap[:ruby_install_name], 'gems',
> ConfigMap[:ruby_version])
>
> (that's the middle "RUBY_VERSION > '1.9'" code chunk)
>
> So ConfigMap[:ruby_install_name] is "ruby19" in this case, and THAT's
> what is screwing this up.
>
>
>
> IDEAS:
>
> Either the FreeBSD Ruby 1.9 port needs to install things in
> "/usr/local/lib/ruby19" instead of "/usr/local/lib/ruby/" so the code
> will work as-is, or else something's gotta change with
> ConfigMap[:ruby_install_name], or else gem_prelude.rb code has to be
> changed...
>
> So... anyone with expertise, where does one go from here?
>
> Aaron out.
It looks like ConfigMap[:ruby_install_name] gets set earlier in the
same gem_prelude.rb code to RbConfig::CONFIG["ruby_install_name"]
which in turn is set in rbconfig.rb which sets it to "ruby19". That
file is autogenerated during the build process by the mkconfig.rb
script which gets passed an "install_name" variable setting I'm
assuming.
That in turn gets set during make. The Makefile shows:
$(RBCONFIG): $(srcdir)/mkconfig.rb config.status $(PREP)
@$(MINIRUBY) $(srcdir)/mkconfig.rb -timestamp=$@ \
-install_name=$(RUBY_INSTALL_NAME) \
-so_name=$(RUBY_SO_NAME) rbconfig.rb
So it's getting set to the RUBY_INSTALL_NAME value 'ruby19'. Of
course Makefile is created from the Makefile.in template by the GNU
Autoconf configure process. The configure.in template shows
RUBY_INSTALL_NAME getting set to:
RUBY_INSTALL_NAME="${ri_prefix}ruby${ri_suffix}"
That explains completely how Gem.default_dir is getting set to
""/usr/local/lib/ruby19/gems/1.9" instead of the actual path
"/usr/local/lib/ruby/gems/1.9"
ONE POSSIBLE FIX is this patch to gem_prelude.rb (in
/usr/ports/lang/ruby19/files/patch-gem_prelude.rb):
========================
--- gem_prelude.rb.orig 2010-01-28 21:22:27.307910440 -0700
+++ gem_prelude.rb 2010-01-28 21:22:43.177946726 -0700
@@ -116,7 +116,7 @@
File.join File.dirname(ConfigMap[:sitedir]), 'Gems',
ConfigMap[:ruby_version]
elsif RUBY_VERSION > '1.9' then
- File.join(ConfigMap[:libdir], ConfigMap[:ruby_install_name], 'gems',
+ File.join(ConfigMap[:libdir], 'ruby', 'gems',
ConfigMap[:ruby_version])
else
File.join(ConfigMap[:libdir], ruby_engine, 'gems',
========================
This works. Building/installing gems under 1.9.1 (with
RUBY_VERSION=1.9.1 in /etc/make.conf) did not break (still works), but
this time, no LoadErrors during require. AT LAST!
user at host:/home/user% irb19
irb(main):001:0> require 'net/ssh'
=> true
irb(main):002:0>
And that makes ruby19 -e 'p Gem.default_dir' output
"/usr/local/lib/ruby/gems/1.9" like it should.
Aaron out.
More information about the freebsd-ruby
mailing list