Ruby原生扩展gems安装失败

时间:2016-04-28 18:55:49

标签: ruby

当尝试安装使用本机扩展的ruby gem时,我的安装失败。

Gem::Ext::BuildError: ERROR: Failed to build gem native extension.

日志文件给出了以下输出

"gcc-mp-4.9 -o conftest -I/Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/include/ruby-1.9.1/x86_64-darwin13.4.0 -I/Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/include/ruby-1.9.1/ruby/backward -I/Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/include/ruby-1.9.1 -I. -D_XOPEN_SOURCE -D_DARWIN_C_SOURCE   -I/opt/local/include  -O3 -ggdb -Wall -Wextra -Wno-unused-parameter -Wno-parentheses -Wno-long-long -Wno-missing-field-initializers -Wpointer-arith -Wwrite-strings -Wdeclaration-after-statement -Wimplicit-function-declaration  -fno-common -pipe conftest.c  -L. -L/Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/lib -L/opt/local/lib -L.  -L/opt/local/lib      -lruby.1.9.1  -lpthread -ldl -lobjc "
checked program was:
/* begin */
1: #include "ruby.h"
2: 
3: int main(int argc, char **argv)
4: {
5:   return 0;
6: }
/* end */

看来这是在寻找gcc的macports版本,而不是使用系统gcc,但我甚至没有在系统上安装任何macports gcc。

------编辑从gem_make.out文件添加输出---------

/Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/bin/ruby -r ./siteconf20160428-64282-8h2kw8.rb extconf.rb
checking for main() in -lcups... *** extconf.rb failed ***
Could not create Makefile due to some reason, probably lack of
necessary libraries and/or headers.  Check the mkmf.log file for more
details.  You may need configuration options.

Provided configuration options:
    --with-opt-dir
    --with-opt-include
    --without-opt-include=${opt-dir}/include
    --with-opt-lib
    --without-opt-lib=${opt-dir}/lib
    --with-make-prog
    --without-make-prog
    --srcdir=.
    --curdir
    --ruby=/Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/bin/ruby
    --with-cupslib
    --without-cupslib
/Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/lib/ruby/1.9.1/mkmf.rb:381:in `try_do': The compiler failed to generate an executable file. (RuntimeError)
You have to install development tools first.
    from /Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/lib/ruby/1.9.1/mkmf.rb:461:in `try_link0'
    from /Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/lib/ruby/1.9.1/mkmf.rb:476:in `try_link'
    from /Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/lib/ruby/1.9.1/mkmf.rb:619:in `try_func'
    from /Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/lib/ruby/1.9.1/mkmf.rb:845:in `block in have_library'
    from /Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/lib/ruby/1.9.1/mkmf.rb:790:in `block in checking_for'
    from /Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/lib/ruby/1.9.1/mkmf.rb:284:in `block (2 levels) in postpone'
    from /Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/lib/ruby/1.9.1/mkmf.rb:254:in `open'
    from /Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/lib/ruby/1.9.1/mkmf.rb:284:in `block in postpone'
    from /Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/lib/ruby/1.9.1/mkmf.rb:254:in `open'
    from /Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/lib/ruby/1.9.1/mkmf.rb:280:in `postpone'
    from /Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/lib/ruby/1.9.1/mkmf.rb:789:in `checking_for'
    from /Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551/lib/ruby/1.9.1/mkmf.rb:840:in `have_library'
    from extconf.rb:3:in `<main>'

extconf failed, exit code 1

1 个答案:

答案 0 :(得分:0)

最终在rvm宝石集的rbconfig.rb文件中gcc设置是粘滞的。

我不得不去

new Document("Document.Details.Id":id);
new Document("Details.Id":id);
new Document("Document.Id":id);

我必须改变

~/.rvm/rubies/ruby-1.9.3-p551/lib/ruby/1.9.1/x86_64-darwin13.4.0/rbconfig.rb

CONFIG["CC"] = "gcc-mp-4.9"

并且还要改变

CONFIG["CC"] = "gcc"

CONFIG["configure_args"] = " '--prefix=/Users/bigtunacan/.rvm/rubies/ruby-1.9.3-p551' '--with-opt-dir=/opt/local' '--without-tcl' '--without-tk' '--disable-install-doc' '--enable-shared' 'CC=gcc-mp-4.9'"