You're reading a random programmers blog about software - go back to mainpage


Rails 4.2.0.rc3 - Fixing libiconv missing dependency on OSX 10.10 (Yosemite)

Written by: alexp on December 18, 2014


OK, so today I tried to install the newest release candidate of Rails - the 4.2.0.rc3 and again, I got the missing libiconv dependency error while installing nokogiri, version 1.6.5.

ERROR:  Error installing nokogiri:
     ERROR: Failed to build gem native extension.

    /Users/aps/.rvm/rubies/ruby-2.1.5/bin/ruby -r ./siteconf20141218-1242-b4o2ja.rb extconf.rb
checking if the C compiler accepts ... yes
checking if the C compiler accepts -Wno-error=unused-command-line-argument-hard-error-in-future... no
Building nokogiri using packaged libraries.
checking for iconv... no
-----
libiconv is missing.  Please locate mkmf.log to investigate how it is failing.
-----
*** 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
     --without-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/aps/.rvm/rubies/ruby-2.1.5/bin/ruby
     --help
     --clean
     --use-system-libraries
     --enable-static
     --disable-static
     --with-zlib-dir
     --without-zlib-dir
     --with-zlib-include
     --without-zlib-include=${zlib-dir}/include
     --with-zlib-lib
     --without-zlib-lib=${zlib-dir}/lib
     --enable-cross-build
     --disable-cross-build

extconf failed, exit code 1
Gem files will remain installed in /Users/aps/.rvm/gems/ruby-2.1.5/gems/nokogiri-1.6.5 for inspection.
Results logged to /Users/aps/.rvm/gems/ruby-2.1.5/extensions/x86_64-darwin-14/2.1.0-static/nokogiri-1.6.5/gem_make.out

I headed back to official Nokogiri website and reviewed their installation guidelines, which basically say that on OS X it should work out of the box, unless you encounter the libiconv issues ;).

But still, they claim that the following should do the trick:

% brew unlink gcc-4.2 # you might not need this step
% gem uninstall nokogiri
% xcode-select --install
% gem install nokogiri

Unfortunately that did not work for me, so I started investigating further.

I tried the solution from my previous blog post, which fixed the problem before by passing the additional parameter for non-standard iconv installations:

gem install nokogiri --with-iconv-include=/usr/local/Cellar/libiconv/1.14/include \ 
  --with-iconv-lib=/usr/local/Cellar/libiconv/1.14/lib

with no success, but really I wanted to get it working cleanly this time, without the custom steps and/or hacks involved.

So what's the deal here? With up-to-date Xcode developer tools installed, iconv actually installed at /usr/bin/iconv and still failing to install by pointing to the brew version of libiconv, I tried to unlink the libiconv at brew and finally got it working as expected!

So please find the actual steps I took, below:

# install the latest ruby 2.1.5
% rvm install ruby-2.1.5
% brew unlink libiconv
Unlinking /usr/local/Cellar/libiconv/1.14... 125 symlinks removed

% gem install nokogiri # you can skip it and and go directly to installing rails of course
% gem install rails —version 4.2.0.rc3
% rails -v
Rails 4.2.0.rc3

Nice and clean now, rockin' on a bleeding edge of Rails again :)

comments powered by Disqus