打包脚本时Ocra会抛出错误

Ele*_*ios 5 ruby scripting packaging compiler-errors ocra

情景

我已经安装了Ruby 2.1.5(x64)包,然后成功安装了Ocra gem:

gem install ocra
Fetching: ocra-1.3.3.gem (100%)
Successfully installed ocra-1.3.3
Parsing documentation for ocra-1.3.3
Installing ri documentation for ocra-1.3.3
Done installing documentation for ocra after 0 seconds
1 gem installed
Run Code Online (Sandbox Code Playgroud)

问题

我正在尝试打包测试脚本:

# -*- coding: UTF-8 -*-

# require ''
exit if Object.const_defined?(:Ocra)

print "Hello World!"
sleep 3

__END__
Run Code Online (Sandbox Code Playgroud)

但是当我尝试使用Ocra时,它会抛出错误:

ocra "TestScript.rb"

=== Loading script to check dependencies
=== Detected gem ocra-1.3.3 (loaded, files)
===     6 files, 190931 bytes
=== Detected gem io-console-0.4.2 (loaded, files)
C:/Program Files/Ruby/lib/ruby/gems/2.1.0/gems/ocra-1.3.3/bin/ocra:86:in `open':
 No such file or directory @ dir_initialize - C:/Program Files/Ruby/lib/ruby/gem
s/2.1.0/gems/io-console-0.4.2 (Errno::ENOENT)
        from C:/Program Files/Ruby/lib/ruby/gems/2.1.0/gems/ocra-1.3.3/bin/ocra:
86:in `entries'
        from C:/Program Files/Ruby/lib/ruby/gems/2.1.0/gems/ocra-1.3.3/bin/ocra:
86:in `entries'
        from C:/Program Files/Ruby/lib/ruby/gems/2.1.0/gems/ocra-1.3.3/bin/ocra:
92:in `find_all_files'
        from C:/Program Files/Ruby/lib/ruby/gems/2.1.0/gems/ocra-1.3.3/bin/ocra:
665:in `block (2 levels) in find_gem_files'
        from C:/Program Files/Ruby/lib/ruby/gems/2.1.0/gems/ocra-1.3.3/bin/ocra:
658:in `each'
        from C:/Program Files/Ruby/lib/ruby/gems/2.1.0/gems/ocra-1.3.3/bin/ocra:
658:in `block in find_gem_files'
        from C:/Program Files/Ruby/lib/ruby/gems/2.1.0/gems/ocra-1.3.3/bin/ocra:
611:in `each'
        from C:/Program Files/Ruby/lib/ruby/gems/2.1.0/gems/ocra-1.3.3/bin/ocra:
611:in `find_gem_files'
        from C:/Program Files/Ruby/lib/ruby/gems/2.1.0/gems/ocra-1.3.3/bin/ocra:
728:in `build_exe'
        from C:/Program Files/Ruby/lib/ruby/gems/2.1.0/gems/ocra-1.3.3/bin/ocra:
1165:in `block in <top (required)>'
Run Code Online (Sandbox Code Playgroud)

为什么会这样?怎么解决?

Dan*_*ner 2

tl;dr:我能够使用 Ocra 以及 Ruby 版本 2.0.0p481 和 ruby​​gems 2.0.14 从您的脚本成功构建可执行文件。如果您可以切换 Ruby 版本,您应该能够获得相同的结果。(这是我写的关于在 Windows 上使用多个 Ruby 版本以及很棒的 uru 的文章。)

更深入的潜水:

这个io-console问题困扰了很多Ocra gem的用户,目前github上有一个未解决的问题:

https://github.com/larsch/ocra/issues/77

Ocra 调用Gem::Specification#gem_dir脚本中所有已加载的 gem,其中包括io-console. 该操作返回一个不存在的路径,因此会出现错误。

(这里还有 ruby​​gems 的gem_dir方法的链接,供您参考。)

你可以自己尝试一下:

irb(main):001:0>require "io/console"
=> true
irb(main):002:0>io_console_spec = Gem.loaded_specs["io-console"]
=> #<Gem::Specification:0xblahblah io-console-0.4.2>
irb(main):003:0>proposed_path = io_console_spec.gem_dir
=> "$YOUR_RUBY_DIRECTORY/lib/ruby/gems/2.1.0/gems/io-console-0.4.2"
irb(main):004:0>File.directory? proposed_path
=> false
Run Code Online (Sandbox Code Playgroud)

使用 Ruby 2.0.0p481 时,Ocra 从此脚本成功创建了可执行文件:

ocra-成功

这让我相信,结果Gem.loaded_specs在 ruby​​gems 2.0.14(这是在我的 2.0.0p481 版本上运行的版本)和 ruby​​gems 2.2.2(这是在我的 2.1.5 版本上运行的版本)之间发生了变化。我将进一步深入了解为什么Gem::Specification#gem_dirforio-console是这样的(我对 Ocra 和 Rubygems 的内部工作原理非常陌生),但希望这对您有所帮助。