Ошибка компаса в gem install после обновления Mac OS Sierra 10.12.6 - PullRequest
0 голосов
/ 16 ноября 2018

Несколько дней назад я сделал обновление безопасности Mac OS Sierra 10.12.6 2018-005. Вчера я проворчал и получил:

Warning: Running "sass:dist" (sass) task
Warning: spawn sass ENOENT Use --force to continue.

Aborted due to warnings.

Я следовал инструкциям здесь: https://github.com/appseed-io/supermodular/issues/45

xcode-select --install
sudo gem update --system
sudo gem install -n /usr/local/bin compass

Я все еще получал грубые ошибки:

Running "sass:build" (sass) task
ERROR: Cannot load compass.
Warning: Exited with error code 1 Use --force to continue.

Aborted due to warnings.

Затем я следовал инструкции: https://halfelf.org/2017/grunt-cant-build-sass-on-high-sierra/

brew install rbenv ruby-build

rbenv install 2.4.2
rbenv global 2.4.2

sudo gem update --system

sudo gem install -n /usr/local/bin sass

Все еще хрюкает ERROR: Cannot load compass.

Затем снова попытался sudo gem install -n /usr/local/bin compass, но выдает следующую ошибку:

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

Я проверил файл mkmf.log, в котором написано:

"pkg-config --exists libffi"
package configuration for libffi is not found
"xcrun clang -o conftest -I/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/Ruby.framework/Versions/2.3/usr/include/ruby-2.3.0/universal-darwin16 -I/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/Ruby.framework/Versions/2.3/usr/include/ruby-2.3.0/ruby/backward -I/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/Ruby.framework/Versions/2.3/usr/include/ruby-2.3.0 -I. -D_XOPEN_SOURCE -D_DARWIN_C_SOURCE -D_DARWIN_UNLIMITED_SELECT -D_REENTRANT    -g -Os -pipe -DHAVE_GCC_ATOMIC_BUILTINS -iwithsysroot /usr/local/libressl/include conftest.c  -L. -L/System/Library/Frameworks/Ruby.framework/Versions/2.3/usr/lib -L.             -L /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.Internal.sdk/usr/local/libressl/lib -L/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.Internal.sdk/usr/local/lib   -arch x86_64 -arch i386   -lruby.2.3.0  -lpthread -ldl -lobjc "
In file included from conftest.c:1:
In file included from /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/Ruby.framework/Versions/2.3/usr/include/ruby-2.3.0/ruby.h:33:
/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/Ruby.framework/Versions/2.3/usr/include/ruby-2.3.0/ruby/ruby.h:24:10: fatal error: 'ruby/config.h' file not found
#include "ruby/config.h"
         ^~~~~~~~~~~~~~~
1 error generated.
checked program was:
/* begin */
1: #include "ruby.h"
2: 
3: int main(int argc, char **argv)
4: {
5:   return 0;
6: }
/* end */

Что я беру из этого (не совсем зная), это то, что package configuration for libffi is not found и fatal error: 'ruby/config.h' file not found.

Дополнительная информация:

Xcode Version 9.2 (9C40b)

ruby -v
ruby 2.3.7p456 (2018-03-28 revision 63024) [universal.x86_64-darwin16]

sass -v
Sass 3.4.25 (Selective Steve)

compass -v
-bash: /usr/local/bin/compass: 
/System/Library/Frameworks/Ruby.framework/Versions/2.0/usr/bin/ruby: bad interpreter: No such file or directory

Заранее спасибо.

UPDATE

Я побежал gem env. Это вывод:

RubyGems Environment:
  - RUBYGEMS VERSION: 2.7.8
  - RUBY VERSION: 2.3.7 (2018-03-28 patchlevel 456) [universal.x86_64-darwin16]
  - INSTALLATION DIRECTORY: /Library/Ruby/Gems/2.3.0
  - USER INSTALLATION DIRECTORY: /Users/username/.gem/ruby/2.3.0
  - RUBY EXECUTABLE: /System/Library/Frameworks/Ruby.framework/Versions/2.3/usr/bin/ruby
  - EXECUTABLE DIRECTORY: /usr/bin
  - SPEC CACHE DIRECTORY: /Users/username/.gem/specs
  - SYSTEM CONFIGURATION DIRECTORY: /Library/Ruby/Site
  - RUBYGEMS PLATFORMS:
    - ruby
    - universal-darwin-16
  - GEM PATHS:
     - /Library/Ruby/Gems/2.3.0
     - /Users/username/.gem/ruby/2.3.0
     - /System/Library/Frameworks/Ruby.framework/Versions/2.3/usr/lib/ruby/gems/2.3.0
  - GEM CONFIGURATION:
     - :update_sources => true
     - :verbose => true
     - :backtrace => false
     - :bulk_threshold => 1000
  - REMOTE SOURCES:
     - https://rubygems.org/
  - SHELL PATH:
     - /Users/username/.nvm/versions/node/v8.4.0/bin
     - /Users/username/.wp-cli/bin
     - /usr/local/bin
     - /usr/local/bin
     - /usr/bin
     - /bin
     - /usr/sbin
     - /sbin

1 Ответ

0 голосов
/ 17 ноября 2018

Не делай sudo gem install -n /usr/local/bin compass

Весь смысл использования rbenv состоит в том, чтобы позволить ему обрабатывать все ваши зависимости и вообще не иметь дело с рубином вашей операционной системы или его драгоценными камнями. Вам нужно правильно настроить $PATH, и вам не нужно будет когда-либо использовать sudo, на самом деле вы НЕ должны использовать gem install или какие-либо gem команды после правильной настройки вашей среды.

Вы случайно не пробовали npm install -g grunt-cli?

ОБНОВЛЕНИЕ: как и ожидалось, ваш $ PATH неверен.

Закройте все клеммы. Начните новый. Затем запустите это.

curl -fsSL https://github.com/rbenv/rbenv-installer/raw/master/bin/rbenv-doctor | bash

Это должно помочь вам понять, что не так в вашей настройке $PATH. См. https://github.com/rbenv/rbenv#installation

Но сначала попробуйте:

echo 'export PATH="$HOME/.rbenv/bin:$PATH"' >> ~/.bash_profile

Затем перезапустите терминал и снова проверьте gem env и посмотрите, включает ли ваш путь .rbenv

Если эти шаги не помогают вам работать, я предлагаю полностью удалить rbenv и начать заново с шага 1 из https://github.com/rbenv/rbenv#installation

...