Не могу скомпилировать C программу на Mac после обновления до Catalina 10.15 - PullRequest
33 голосов
/ 08 октября 2019

Есть предыдущий вопрос Невозможно скомпилировать программу C на Mac после обновления до Mojave , и ответы на него охватили большинство вариантов того, что идет не так.

Сейчас- по состоянию на понедельник 2019-10-07 - вы можете перейти на macOS Catalina 10.15. Еще раз, во время обновления, каталог /usr/include был снесен обновлением, хотя XCode 11.0 был установлен до обновления (с Mojave 10.14.6) до Catalina. Следовательно, компиляторы, рассчитанные на то, что существует каталог /usr/include, больше не работают.

Основной рекомендуемый шаг для проблем Mojave - использование команды:

open /Library/Developer/CommandLineTools/Packages/macOS_SDK_headers_for_macOS_10.14.pkg

не работает вне шлюза, потому что каталог /Library/Developer/CommandLineTools/Packages/ не существует (поэтому еще нет файла .pkg, который нужно открыть).

Есть ли хороший (официальный) способ созданияи заполните каталог /usr/include?

Ответы [ 7 ]

14 голосов
/ 08 октября 2019

TL; DR

Похоже, что Apple считает /usr/include чем-то, что прошло путь додо - оно вымерло - или, может быть, оно похоже на Parrot Монти Пайтона. 1006 *

Использование предоставленного Apple GCC (на самом деле это Clang под любым другим именем, как показывает информация о версии) или Clang позволяет избежать проблем. И /usr/bin/gcc, и /usr/bin/clang найдут системные библиотеки четырьмя уровнями каталогов ниже:

/Applications/Xcode.app/Contents/Developer/Platforms/…

Если вы создаете свой собственный GCC или другой компилятор, вам (вероятно) потребуется настроить его, чтобы найти системубиблиотеки в каталоге приложения Xcode.

Исследования

Сразу после обновления я запустил XCode 11.0. Он хотел установить некоторые дополнительные компоненты, поэтому я позволил это сделать. Однако, это не восстановило /usr/include или каталог под /Library.

Один из других советов в предыдущем вопросе состоял в следующем:

xcode-select --install

При этом он утверждал, что загрузил утилиты командной строки, и обеспечил присутствие /usr/bin/gcc и /usr/bin/clang и т. Д. Это полезный шаг (хотя я точно не проверял, присутствовали ли они раньше).

$ /usr/bin/gcc --version
Configured with: --prefix=/Applications/Xcode.app/Contents/Developer/usr --with-gxx-include-dir=/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include/c++/4.2.1
Apple clang version 11.0.0 (clang-1100.0.33.8)
Target: x86_64-apple-darwin19.0.0
Thread model: posix
InstalledDir: /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin
$

Используя /usr/bin/gcc, теперь можно компилировать программы:

$ make CC=/usr/bin/gcc al
co  RCS/al.c,v al.c
RCS/al.c,v  -->  al.c
revision 1.7
done
/usr/bin/gcc -I/Users/jleffler/inc -g -O3 -std=c11 -pedantic -Wall -Wextra -Werror -Wshadow -Wmissing-prototypes -Wpointer-arith  -Wold-style-definition -Wcast-qual -Wstrict-prototypes -DHAVE_MEMMEM -DHAVE_STRNDUP -DHAVE_STRNLEN  -DHAVE_GETDELIM   -o al al.c -L/Users/jleffler/lib/64  -ljl
$

Тем не менее, /usr/include по-прежнему отсутствует. В каталоге /Library теперь есть каталог:

$ ls /Library/Developer
CommandLineTools  PrivateFrameworks
$ ls /Library/Developer/CommandLineTools
Library SDKs    usr
$ ls /Library/Developer/CommandLineTools/SDKs
MacOSX.sdk      MacOSX10.14.sdk MacOSX10.15.sdk
$ ls /Library/Developer/CommandLineTools/SDKs/MacOSX10.15.sdk/
Entitlements.plist SDKSettings.json   System
Library            SDKSettings.plist  usr
$

Ни в каталоге System, ни в Library нет ничего очень многообещающего.

Если ничего не помогает, прочтите руководство

Следующий шаг - найдите и прочитайте примечания к выпуску:

Там нет информации, которая имеет отношение к этому. Таким образом, вероятность (AFAICS, после всего лишь часа или двух усилий), что Apple больше не поддерживает /usr/include - хотя у него все еще есть полностью загруженный /usr/lib (хотя /lib нет).

Время проверить другую компиляцию с добавленной опцией GCC -v (в используемом мною make-файле настройка UFLAGS добавляет опцию в командную строку компилятора C):

$ make UFLAGS=-v CC=/usr/bin/gcc ww
co  RCS/ww.c,v ww.c
RCS/ww.c,v  -->  ww.c
revision 4.9
done
/usr/bin/gcc -I/Users/jleffler/inc -g -O3 -std=c11 -pedantic -Wall -Wextra -Werror -Wshadow -Wmissing-prototypes -Wpointer-arith  -Wold-style-definition -Wcast-qual -Wstrict-prototypes -DHAVE_MEMMEM -DHAVE_STRNDUP -DHAVE_STRNLEN  -DHAVE_GETDELIM -v  -o ww ww.c -L/Users/jleffler/lib/64  -ljl
Apple clang version 11.0.0 (clang-1100.0.33.8)
Target: x86_64-apple-darwin19.0.0
Thread model: posix
InstalledDir: /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin
 "/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/clang" -cc1 -triple x86_64-apple-macosx10.15.0 -Wdeprecated-objc-isa-usage -Werror=deprecated-objc-isa-usage -emit-obj -disable-free -disable-llvm-verifier -discard-value-names -main-file-name ww.c -mrelocation-model pic -pic-level 2 -mthread-model posix -mdisable-fp-elim -fno-strict-return -masm-verbose -munwind-tables -target-sdk-version=10.15 -target-cpu penryn -dwarf-column-info -debug-info-kind=standalone -dwarf-version=4 -debugger-tuning=lldb -ggnu-pubnames -target-linker-version 512.4 -v -resource-dir /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/lib/clang/11.0.0 -isysroot /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk -I /Users/jleffler/inc -D HAVE_MEMMEM -D HAVE_STRNDUP -D HAVE_STRNLEN -D HAVE_GETDELIM -I/usr/local/include -O3 -Wall -Wextra -Werror -Wshadow -Wmissing-prototypes -Wpointer-arith -Wold-style-definition -Wcast-qual -Wstrict-prototypes -Wno-framework-include-private-from-public -Wno-atimport-in-framework-header -Wno-extra-semi-stmt -Wno-quoted-include-in-framework-header -pedantic -std=c11 -fdebug-compilation-dir /Users/jleffler/src/cmd -ferror-limit 19 -fmessage-length 110 -stack-protector 1 -fstack-check -mdarwin-stkchk-strong-link -fblocks -fencode-extended-block-signature -fregister-global-dtors-with-atexit -fobjc-runtime=macosx-10.15.0 -fmax-type-align=16 -fdiagnostics-show-option -fcolor-diagnostics -vectorize-loops -vectorize-slp -o /var/folders/77/zx9nk6dn7_dg4xd4stvt42v00000gn/T/ww-4cb85b.o -x c ww.c
clang -cc1 version 11.0.0 (clang-1100.0.33.8) default target x86_64-apple-darwin19.0.0
ignoring nonexistent directory "/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/local/include"
ignoring nonexistent directory "/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/Library/Frameworks"
#include "..." search starts here:
#include <...> search starts here:
 /Users/jleffler/inc
 /usr/local/include
 /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/lib/clang/11.0.0/include
 /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/include
 /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include
 /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks (framework directory)
End of search list.
 "/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/ld" -demangle -lto_library /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/lib/libLTO.dylib -dynamic -arch x86_64 -macosx_version_min 10.15.0 -syslibroot /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk -o ww -L/Users/jleffler/lib/64 /var/folders/77/zx9nk6dn7_dg4xd4stvt42v00000gn/T/ww-4cb85b.o -ljl -L/usr/local/lib -lSystem /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/lib/clang/11.0.0/lib/darwin/libclang_rt.osx.a
 "/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/dsymutil" -o ww.dSYM ww
$

Ключевая информация в этой метелиданные:

-isysroot /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk

Это фактически корневой каталог для компиляции, поэтому в нем должны быть подкаталоги для usr и usr/include:

$ ls /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk
Entitlements.plist SDKSettings.json   System
Library            SDKSettings.plist  usr
$ ls /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr
bin     include lib     libexec share
$ ls /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include
AppleTextureEncoder.h  dns_util.h             memory.h               simd
AssertMacros.h         dtrace.h               menu.h                 slapi-plugin.h
Availability.h         editline               miscfs                 spawn.h
AvailabilityInternal.h err.h                  module.modulemap       sqlite3.h
AvailabilityMacros.h   errno.h                monetary.h             sqlite3ext.h
AvailabilityVersions.h eti.h                  monitor.h              stab.h
…lots more lines…
dirent.h               mach-o                 security               xcselect.h
disktab.h              mach_debug             semaphore.h            xlocale
dispatch               machine                servers                xlocale.h
dlfcn.h                malloc                 setjmp.h               xpc
dns.h                  math.h                 sgtty.h                zconf.h
dns_sd.h               membership.h           signal.h               zlib.h
$

Это показывает, что имя каталога длиной в милю и полностью не запоминающееся содержит стандартные заголовки C и POSIX, а также дополнительные функции, специфичные для Apple.

Предыдущий каталог /usr/local/ выглядит неповрежденным;предупреждение о том, что usr/local/include не существует в -isysrootdir, является безвредным (и не отображается без параметра -v).

13 голосов
/ 12 октября 2019

Прежде чем продолжить, обязательно установите инструменты командной строки xcode.

xcode-select --install

На самом деле, вы можете это сделать! На самом деле все заголовки C находятся здесь в этой папке:

/Library/Developer/CommandLineTools/SDKs/MacOSX.sdk/usr/include/

Нам просто нужно создать символическую ссылку для всех файлов заголовков в эту папку:

/usr/local/include/

Это сработало для меня! Следующая командная строка позаботится обо всех проблемах:

sudo ln -s /Library/Developer/CommandLineTools/SDKs/MacOSX.sdk/usr/include/* /usr/local/include/

Вы получите предупреждение. Некоторые из заголовков уже существуют, как это:

ln: /usr/local/include//tcl.h: File exists
ln: /usr/local/include//tclDecls.h: File exists
ln: /usr/local/include//tclPlatDecls.h: File exists
ln: /usr/local/include//tclTomMath.h: File exists
ln: /usr/local/include//tclTomMathDecls.h: File exists
ln: /usr/local/include//tk.h: File exists
ln: /usr/local/include//tkDecls.h: File exists
ln: /usr/local/include//tkPlatDecls.h: File exists

совершенно нормально игнорировать. это все.

13 голосов
/ 10 октября 2019

Для меня добавление следующего пути к CPATH решило проблему:

export CPATH=/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include
3 голосов
/ 13 октября 2019

Установите следующие неявные Make переменные, чтобы указать, где теперь расположены заголовки для инструментов командной строки Xcode (XCI CLI):

export CFLAGS=-isysroot /Library/Developer/CommandLineTools/SDKs/MacOSX.sdk
export CCFLAGS=-isysroot /Library/Developer/CommandLineTools/SDKs/MacOSX.sdk
export CXXFLAGS=-isysroot /Library/Developer/CommandLineTools/SDKs/MacOSX.sdk
export CPPFLAGS=-isysroot /Library/Developer/CommandLineTools/SDKs/MacOSX.sdk

Опция -isysroot обновляет расположение корневых файлов вдали от корневого каталога системы /.

Таким образом, это гарантирует, что общие файлы /usr/* будут найдены на новом месте.

То естьфайлы на /Library/Developer/CommandLineTools/SDKs/MacOSX.sdk теперь найдены. Эти файлы:

Entitlements.plist 
Library
SDKSettings.json
SDKSettings.plist
System
usr
0 голосов
/ 29 октября 2019

В моем случае, мне показалось, что llvm и gcc также установлены с помощью homebrew. Когда я удалил их и, таким образом, полностью полагался на лязг MacOS, он мог найти заголовки, и компиляция снова заработала.

0 голосов
/ 14 октября 2019

Я новичок с компилятором C ++ для R в OSX, и у меня возникла та же проблема, что C ++ не мог найти заголовок после обновления ОС ( отсутствует math.h, хотя он там был ). Я следовал инструкциям https://thecoatlessprofessor.com/programming/cpp/r-compiler-tools-for-rcpp-on-macos/, но ничего не изменилось.

Наконец-то, это сработало для меня после того, как я переустановил Xcode CLI

xcode-select --install

и затем изменил флаги на Var как @Без пальто предложил:

export CFLAGS=-isysroot /Library/Developer/CommandLineTools/SDKs/MacOSX.sdk
export CCFLAGS=-isysroot /Library/Developer/CommandLineTools/SDKs/MacOSX.sdk
export CXXFLAGS=-isysroot /Library/Developer/CommandLineTools/SDKs/MacOSX.sdk
export CPPFLAGS=-isysroot /Library/Developer/CommandLineTools/SDKs/MacOSX.sdk
0 голосов
/ 13 октября 2019

apue.h зависимость все еще отсутствовала в моем /usr/local/include после следующего Komol Nath Roy ответа на этот вопрос.

Я загрузил зависимость вручную из git и поместил ее в /usr/local/include

...