Skip to content
This repository has been archived by the owner on Dec 4, 2023. It is now read-only.

Failed to load gem for Ruby 2.4.0 (related to the new Integer class) #428

Closed
ollie opened this issue Dec 27, 2016 · 5 comments
Closed

Failed to load gem for Ruby 2.4.0 (related to the new Integer class) #428

ollie opened this issue Dec 27, 2016 · 5 comments

Comments

@ollie
Copy link

ollie commented Dec 27, 2016

Hello,

I wanted to give our Rails app a try on Ruby 2.4.0 and got this error:

Gem Load Error is: wrong argument type Class (expected Module)
Backtrace for gem load error is:
/Users/olda/.rbenv/versions/2.4.0/lib/ruby/gems/2.4.0/gems/therubyracer-0.12.2/lib/v8/conversion.rb:26:in `include'
/Users/olda/.rbenv/versions/2.4.0/lib/ruby/gems/2.4.0/gems/therubyracer-0.12.2/lib/v8/conversion.rb:26:in `block (2 levels) in <top (required)>'
/Users/olda/.rbenv/versions/2.4.0/lib/ruby/gems/2.4.0/gems/therubyracer-0.12.2/lib/v8/conversion.rb:22:in `class_eval'
/Users/olda/.rbenv/versions/2.4.0/lib/ruby/gems/2.4.0/gems/therubyracer-0.12.2/lib/v8/conversion.rb:22:in `block in <top (re
...

So I investigated.

# conversion.rb
for type in [Class, Object, Array, Hash, String, Symbol, Time, Proc, Method, Fixnum] do
  type.class_eval do
    puts "#{type.inspect} -> #{V8::Conversion.const_get(type.name).inspect}"
    include V8::Conversion.const_get(type.name)
  end
end

Ruby 2.4.0 prints:

Class -> V8::Conversion::Class
Object -> V8::Conversion::Object
Array -> V8::Conversion::Array
Hash -> V8::Conversion::Hash
String -> V8::Conversion::String
Symbol -> V8::Conversion::Symbol
Time -> V8::Conversion::Time
Proc -> V8::Conversion::Proc
Method -> V8::Conversion::Method
Integer -> Integer

Ruby 2.3.0 prints:

Class -> V8::Conversion::Class
Object -> V8::Conversion::Object
Array -> V8::Conversion::Array
Hash -> V8::Conversion::Hash
String -> V8::Conversion::String
Symbol -> V8::Conversion::Symbol
Time -> V8::Conversion::Time
Proc -> V8::Conversion::Proc
Method -> V8::Conversion::Method
Fixnum -> V8::Conversion::Fixnum

Is this the correct way to handle the new Integer class? (I copy-pasted the Fixnum one.)

# lib/v8/conversion/integer.rb
class V8::Conversion
  module Integer
    def to_ruby
      self
    end

    def to_v8
      self.to_f.to_v8
    end
  end
end
# lib/v8.rb
require "v8/version"

require 'v8/weak'
require 'v8/init'
require 'v8/error'
require 'v8/stack'
require 'v8/conversion/fundamental'
require 'v8/conversion/indentity'
require 'v8/conversion/reference'
require 'v8/conversion/primitive'
require 'v8/conversion/code'
require 'v8/conversion/class'
require 'v8/conversion/object'
require 'v8/conversion/time'
require 'v8/conversion/hash'
require 'v8/conversion/array'
require 'v8/conversion/proc'
require 'v8/conversion/method'
require 'v8/conversion/symbol'
require 'v8/conversion/string'
require 'v8/conversion/fixnum'
require 'v8/conversion/integer' # <-- Added this.
require 'v8/conversion'
require 'v8/access/names'
require 'v8/access/indices'
require 'v8/access/invocation'
require 'v8/access'
require 'v8/context'
require 'v8/object'
require 'v8/array'
require 'v8/function'

I can make a PR if it's deemed worthy.
Thanks.

@ignisf
Copy link
Collaborator

ignisf commented Dec 27, 2016

Hello,

Ruby 2.4 support is already in: ec6adc8...2f1127b

@ignisf ignisf closed this as completed Dec 27, 2016
@ollie
Copy link
Author

ollie commented Dec 27, 2016

Right, I didn't check the master. Okay, thanks.

@ignisf
Copy link
Collaborator

ignisf commented Dec 27, 2016

No problem, hopefully we'll release soon

@ollie
Copy link
Author

ollie commented Dec 27, 2016

Um, don't you think it would be a good idea to keep one of these issues open in the mean time so people don't create tons of new issues?

@ignisf
Copy link
Collaborator

ignisf commented Dec 27, 2016

Good idea, #430

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants