似乎无法让bundler使用rails 2.3

时间:2011-12-13 01:23:12

标签: ruby-on-rails ruby ruby-on-rails-2 gem-bundler

我在rails 2.3.5和ruby 1.8.7

我一直在尝试运行bundler命令,它似乎不再起作用了。

我一直在

undefined method `[]' for nil:NilClass (NoMethodError)

这是运行bundler install

时的跟踪
  /Users/eric/.rvm/gems/ruby-1.8.7-p352/gems/bundler-1.0.21/lib/bundler/settings.rb:11:in `[]': undefined method `[]' for nil:NilClass (NoMethodError)
    from /Users/eric/.rvm/gems/ruby-1.8.7-p352/gems/bundler-1.0.21/lib/bundler/cli.rb:215:in `install'
    from /Users/eric/.rvm/gems/ruby-1.8.7-p352/gems/bundler-1.0.21/lib/bundler/cli.rb:325:in `package'
    from /Users/eric/.rvm/gems/ruby-1.8.7-p352/gems/bundler-1.0.21/lib/bundler/vendor/thor/task.rb:22:in `send'
    from /Users/eric/.rvm/gems/ruby-1.8.7-p352/gems/bundler-1.0.21/lib/bundler/vendor/thor/task.rb:22:in `run'
    from /Users/eric/.rvm/gems/ruby-1.8.7-p352/gems/bundler-1.0.21/lib/bundler/vendor/thor/invocation.rb:118:in `invoke_task'
    from /Users/eric/.rvm/gems/ruby-1.8.7-p352/gems/bundler-1.0.21/lib/bundler/vendor/thor.rb:263:in `dispatch'
    from /Users/eric/.rvm/gems/ruby-1.8.7-p352/gems/bundler-1.0.21/lib/bundler/vendor/thor/base.rb:386:in `start'
    from /Users/eric/.rvm/gems/ruby-1.8.7-p352/gems/bundler-1.0.21/bin/bundle:13
    from /Users/eric/.rvm/gems/ruby-1.8.7-p352/bin/bundle:19:in `load'
    from /Users/eric/.rvm/gems/ruby-1.8.7-p352/bin/bundle:19

以下是我尝试启动服务器时会发生的情况。

    /Users/sgedeveloper/.rvm/gems/ruby-1.8.7-p352/gems/bundler-1.0.21/lib/bundler/settings.rb:11:in `[]': undefined method `[]' for nil:NilClass (NoMethodError)
        from /Users/sgedeveloper/.rvm/gems/ruby-1.8.7-p352/gems/bundler-1.0.21/lib/bundler.rb:261:in `configure_gem_home_and_path'
        from /Users/sgedeveloper/.rvm/gems/ruby-1.8.7-p352/gems/bundler-1.0.21/lib/bundler.rb:82:in `configure'
        from /Users/sgedeveloper/.rvm/gems/ruby-1.8.7-p352/gems/bundler-1.0.21/lib/bundler.rb:136:in `definition'
        from /Users/sgedeveloper/.rvm/gems/ruby-1.8.7-p352/gems/bundler-1.0.21/lib/bundler.rb:126:in `load'
        from /Users/sgedeveloper/.rvm/gems/ruby-1.8.7-p352/gems/bundler-1.0.21/lib/bundler.rb:110:in `setup'
        from ./script/../config/../config/preinitializer.rb:23
        from ./script/../config/boot.rb:29:in `load'
        from ./script/../config/boot.rb:29:in `preinitialize'
        from ./script/../config/boot.rb:11:in `boot!'
        from ./script/../config/boot.rb:118
        from ./script/server:2:in `require'
        from ./script/server:2

这是Preinitialize.rb

    begin
      require "rubygems"
      require "bundler"
    rescue LoadError
      raise "Could not load the bundler gem. Install it with `gem install bundler`."
    end

    begin
      gem 'i18n', "~> 0.4.0"
    rescue LoadError
      raise 'Could not find i18n Gem'
    end


    if Gem::Version.new(Bundler::VERSION) <= Gem::Version.new("0.9.24")
      raise RuntimeError, "Your bundler version is too old for Rails 2.3." +
       "Run `gem install bundler` to upgrade."
    end

    begin
      # Set up load paths for all bundled gems
      ENV["BUNDLE_GEMFILE"] = File.expand_path("../../Gemfile", __FILE__)
      Bundler.setup
    rescue Bundler::GemNotFound
      raise RuntimeError, "Bundler couldn't find some gems." +
        "Did you run `bundle install`?"
    end

这是boot.rb

  # Don't change this file!
  # Configure your app in config/environment.rb and config/environments/*.rb
  require 'thread'

  RAILS_ROOT = "#{File.dirname(__FILE__)}/.." unless defined?(RAILS_ROOT)

  module Rails
    class << self
      def boot!
        unless booted?
          preinitialize
          pick_boot.run
        end
      end

      def booted?
        defined? Rails::Initializer
      end

      def pick_boot
        (vendor_rails? ? VendorBoot : GemBoot).new
      end

      def vendor_rails?
        File.exist?("#{RAILS_ROOT}/vendor/rails")
      end

      def preinitialize
        load(preinitializer_path) if File.exist?(preinitializer_path)
      end

      def preinitializer_path
        "#{RAILS_ROOT}/config/preinitializer.rb"
      end
    end

    class Boot
      def run
        load_initializer

        Rails::Initializer.class_eval do
          def load_gems
            @bundler_loaded ||= Bundler.require :default, Rails.env
          end
        end

        Rails::Initializer.run(:set_load_path)
      end
    end

    class VendorBoot < Boot
      def load_initializer
        require "#{RAILS_ROOT}/vendor/rails/railties/lib/initializer"
        Rails::Initializer.run(:install_gem_spec_stubs)
        Rails::GemDependency.add_frozen_gem_path
      end
    end

    class GemBoot < Boot
      def load_initializer
        self.class.load_rubygems
        load_rails_gem
        require 'initializer'
      end

      def load_rails_gem
        if version = self.class.gem_version
          gem 'rails', version
        else
          gem 'rails'
        end
      rescue Gem::LoadError => load_error
        $stderr.puts %(Missing the Rails #{version} gem. Please `gem install -v=#{version} rails`, update your RAILS_GEM_VERSION setting in config/environment.rb for the Rails version you do have installed, or comment out RAILS_GEM_VERSION to use the latest version installed.)
        exit 1
      end

      class << self
        def rubygems_version
          Gem::RubyGemsVersion rescue nil
        end

        def gem_version
          if defined? RAILS_GEM_VERSION
            RAILS_GEM_VERSION
          elsif ENV.include?('RAILS_GEM_VERSION')
            ENV['RAILS_GEM_VERSION']
          else
            parse_gem_version(read_environment_rb)
          end
        end

        def load_rubygems
          require 'rubygems'
          min_version = '1.3.1'
          unless rubygems_version >= min_version
            $stderr.puts %Q(Rails requires RubyGems >= #{min_version} (you have #{rubygems_version}). Please `gem update --system` and try again.)
            exit 1
          end

        rescue LoadError
          $stderr.puts %Q(Rails requires RubyGems >= #{min_version}. Please install RubyGems and try again: http://rubygems.rubyforge.org)
          exit 1
        end

        def parse_gem_version(text)
          $1 if text =~ /^[^#]*RAILS_GEM_VERSION\s*=\s*["']([!~<>=]*\s*[\d.]+)["']/
        end

        private
          def read_environment_rb
            File.read("#{RAILS_ROOT}/config/environment.rb")
          end
      end
    end
  end

  # All that for this:
  Rails.boot!

1 个答案:

答案 0 :(得分:2)

修改.bundle / config文件是导致此错误的原因。