105
votes

I was trying run gem install json and got the following error

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

    /System/Library/Frameworks/Ruby.framework/Versions/2.0/usr/bin/ruby extconf.rb 
creating Makefile

make "DESTDIR=" clean

make "DESTDIR="
compiling generator.c
linking shared-object json/ext/generator.bundle
clang: error: unknown argument: '-multiply_definedsuppress' [-Wunused-command-line-argument-hard-error-in-future]
clang: note: this will be a hard error (cannot be downgraded to a warning) in the future
make: *** [generator.bundle] Error 1

make failed, exit code 2

Gem files will remain installed in /opt/boxen/repo/.bundle/ruby/2.0.0/gems/json-1.8.0 for inspection.
Results logged to /opt/boxen/repo/.bundle/ruby/2.0.0/extensions/universal-darwin-13/2.0.0/json-1.8.0/gem_make.out

I'm using:

Os X: 10.9.2
Xcode: 5.1 Build version 5B130a
Command Line Tools (CLT): 5.1.0.0.1.1393561416
Ruby: ruby 2.0.0p247 (2013-06-27 revision 41674) [universal.x86_64-darwin13]
Ruby Gem: 2.2.2
GCC: 4.2.1 Apple LLVM version 5.1 (clang-503.0.38) (based on LLVM 3.4svn)

11
I did lots of stuff trying to solve this problem and I don't know exactly which solved but I installed the new ruby version, downloaded previous version of Command Line Tools (Late October) and executed the command @Muncken 's answer (ARCHFLAGS=-Wno-error=unused-command-line-argument-hard-error-in-future {original command}). That solved my problem. In my specific case I was using boxen to install my environment so the final command I used was ARCHFLAGS=-Wno-error=unused-command-line-argument-hard-error-in-future /opt/boxen/repo/script/boxen --no-fde. Thanks everyone that helped.g8M
Mavericks 10.9.3 updates ruby to: ruby 2.0.0p451 (2014-02-24 revision 45167) [universal.x86_64-darwin13] This seems to resolves the issue.Shahar Hadas
The issue is with old version of ruby like @Sash says. I had to update to 2.0.0p451 manually from 2.0.0p2.. using rvm: rvm install ruby-2.0.0-p451. rvm should set it as default version then you just need to reinstall your gemsAdam Spence
I'm having this issue with rvm ruby 2.2.0p0 (2014-12-25 revision 49005)Sonny Parlin

11 Answers

146
votes

I am encountering the exact same problem after updating Xcode to 5.1 and news from Apple aren't good. From Xcode 5.1 Release Notes:

  • The Apple LLVM compiler in Xcode 5.1 treats unrecognized command-line options as errors. This issue has been seen when building both Python native extensions and Ruby Gems, where some invalid compiler options are currently specified.

Projects using invalid compiler options will need to be changed to remove those options. To help ease that transition, the compiler will temporarily accept an option to downgrade the error to a warning:

-Wno-error=unused-command-line-argument-hard-error-in-future

To workaround this issue, set the ARCHFLAGS environment variable to downgrade the error to a warning.

ARCHFLAGS=-Wno-error=unused-command-line-argument-hard-error-in-future gem install GemName

It seems that all gems violating the compiler options must be updated to use valid options. It is explicitly stated that: This option [downgrading error to warning] will not be supported in the future.

The clang note we are seeing (this will be a hard error (cannot be downgraded to a warning) in the future) corresponds to the change announced in the release notes.


To answer your question specifically, use the following to install the json gem:

ARCHFLAGS=-Wno-error=unused-command-line-argument-hard-error-in-future gem install json

Note, however, that this is only a temporary fix.

107
votes

One-liner to fix that

curl https://gist.githubusercontent.com/Paulche/9713531/raw/1e57fbb440d36ca5607d1739cc6151f373b234b6/gistfile1.txt | sudo patch /System/Library/Frameworks/Ruby.framework/Versions/2.0/usr/lib/ruby/2.0.0/universal-darwin13/rbconfig.rb
19
votes

To address the issue you can install the most recent version of ruby as described by @Sash. You can use the following commands to do so. In case you already have installed rvm, you don't need to reinstall it.

#Install rvm
\curl -sSL https://get.rvm.io | bash -s stable

#Install ruby version 2.0.0-p451
rvm install ruby-2.0.0-p451

#Print ruby version to verify that it was installed successfully
ruby -v

#Install json gem
sudo gem install json
12
votes

Issue already addressed by Ruby:

https://bugs.ruby-lang.org/issues/9624

now we just need to wait for Apple to update their ruby version (2.0.0p247) to the one after the latest one (2.0.0p451) which hasn't come out yet ... (or brew/macport it)

Update (2014-05-15): Mavericks 10.9.3 updates ruby to ruby 2.0.0p451 (2014-02-24 revision 45167) [universal.x86_64-darwin13] And this seems to resolves the issue.

4
votes

@Muncken has already provided an answer to install gem one by one:

ARCHFLAGS=-Wno-error=unused-command-line-argument-hard-error-in-future gem install GemName

Base on Muncken's answer, I've tried that it also works when using bundle install

ARCHFLAGS=-Wno-error=unused-command-line-argument-hard-error-in-future bundle install
2
votes

In my case, I actually have similar problem, but not on the system ruby, but on rubies installed by rvm from OSX 10.8, and it has issues after upgrading to OSX 10.9.

A simple reinstall works: rvm reinstall ruby-2.1.1

1
votes

On OSX 10.10, I had several issues when running rails new firstapp such as:

ERROR:  Error installing json:
ERROR: Failed to build gem native extension.
fatal error: 'ruby/config.h' file not found

I updated rvm with this configuration and all the errors are gone!:

rvm get stable --auto-dotfiles

You can tell from the app name that I just started fiddling with Ruby on Rails, so the above advice may or may not work for you.

1
votes

Paul Chechetin's one-liner doesn't appear to work anymore (9/21/15). However, this reply to the post mentioned in Pete's reply solved the problem for me:

  • (a) Install Apple's XCode, then (b) launch it and accept the licensing terms (I had done (a), but not (b).)
  • sudo gem uninstall compass
  • sudo gem install compass
1
votes

None of these worked for me.

What finally worked is running the command with a sudo -

gem install byebug -v '9.0.6'

1
votes

It's been a while and I've got similar error. An alternative to folks using bundler is to add the flag to the build configuration like below example:

bundle config build.<gemname> --with-cflags="-Wno-error=implicit-function-declaration"

followed by

bundle install

Please note that you must replace <gemname> above with the name of the actual gem that is throwing the error while building native extensions.

I hope this becomes helpful to others that face similar issues in the future!

-2
votes

I used a simple solution... install through brew

brew install name