it-swarm.com.ru

Mac OS X Lion больше не распознает environment.plist?

Только что установил Lion сегодня и моя переменная PATH env больше не устанавливается ~/.MacOSX/environment.plist. Что-то изменилось? Не могу найти какую-либо информацию об этом или как исправить. Есть идеи?

Вот содержимое PLIST:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.Apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>PATH</key>
    <string>/usr/local/bin:/usr/local/sbin:/usr/bin:/usr/sbin:/bin:/sbin:/usr/X11/bin:/Users/mdi/bin</string>
</dict>
</plist>
29
Michael Irwin

Вместо этого используйте ~/.launchd.conf (см. man launchctl).

Смотрите этот ответ для деталей.

14
LaC

Я столкнулся с той же проблемой сегодня. Я позвонил в службу поддержки Apple, и после того, как меня перевели к старшему советнику, а затем к ее руководителю, мне сказали, что они больше не поддерживают environment.plist и что в Mac OS 10.7 не существует официально поддерживаемого метода определения переменных среды.

15
sworisbreathing

Независимо от того, поддерживает ли Apple этот механизм официально, текущая техническая заметка Технические вопросы и ответы QA1067 остается точной. Важное предупреждение, однако, отсутствует: список свойств должен быть в двоичном формате. Xcode 4, когда используется для создания новых списков свойств, испускает файлы в текстовом формате (независимо от типа, указанного в File Inspector). Так что вам нужно либо конвертировать сохраненный файл, используя 'plutil': 

plutil -convert binary1 environment.plist

или используйте «значения по умолчанию», чтобы записать новый файл шаблона, который вы можете редактировать в XCode (который сохранит исходный двоичный формат при сохранении):

defaults write defaults write $HOME/.MacOSX/environment Root "1"
10
Shawn

Сделайте это как brew и создайте символическую ссылку в/usr/local/bin /. Идеально подходит для меня и является IMO более Unix-подобным решением, где все является файлом.

1
Programmer

Я просто сгорел от чего-то похожего в Snow Leopard, а потом понял, в чем проблема.

Я делал делаю:

$ cd
$ defaults write .MacOSX/environment FOO bar

... но оказывается, что это отличается от выполнения (в моем случае):

$ cd
$ defaults write /Users/ljnelson/.MacOSX/environment FOO bar

То есть «путь» (на самом деле это не путь) к вашему домену должен быть полным путем к файлу $HOME/.MacOSX/environment.plist (без суффикса .plist). Очевидно, что все остальное будет записывать переменные в другой домен (понятия не имею, куда он был помещен).

Итак, результат: всегда делайте defaults write /full/path/to/your/.MacOSX/environment VARNAME value; вообще не используйте ярлыки для первого аргумента подкоманды write.

1
Laird Nelson

Странно, потому что здесь это работает без нареканий. Мне пришлось настроить среду JRI для доступа к внутренним компонентам R из Java-приложений, и обновления .profile было недостаточно, чтобы NetBeans перехватывал все переменные env.

Создание файла environment.plist помогло.

Для справки это содержимое файла:

Malessere:~ xxxxx$ cat .MacOSX/environment.plist 
   <?xml version="1.0" encoding="UTF-8"?>
   <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.Apple.com/DTDs/PropertyList-1.0.dtd">
   <plist version="1.0">
   <dict>
      <key>DYLD_LIBRARY_PATH</key>
      <string>/Users/xxxxx/lib/jri-2.13</string>
      <key>R_HOME</key>
      <string>/Library/Frameworks/R.framework/Resources</string>
   </dict>
   </plist>
1
ostefano

Недавно я упаковал инструменты, используемые на этапе запуска сценариев Xcode, и поместил их в $ HOME/bin. Переменная окружения PATH моего bash Shell включила это, так что я предположил, что Xcode тоже.

Это никогда не работало, и я нашел такие проблемы, как здесь. 

Я напечатал переменную PATH из скрипта (echo $ PATH), вызванного Xcode, чтобы увидеть, на что была установлена ​​переменная PATH.

К счастью, один из этих путей, /Applications/Xcode.app/Contents/Developer/usr/local/bin, никогда не использовался.

Здесь было мое решение. Я создал символическую ссылку из вышеуказанного каталога на $ HOME/bin.

Перейдите в /Applications/Xcode.app/Contents/Developer/usr/local и выполните команду Sudo ln -s $ HOME/bin bin.

Мои инструменты теперь были доступны для платформы Xcode.

0
lazarus

[[Я копирую этот мой ответ сюда, потому что он может быть кому-то полезен:]]

Благодаря моим собственным исследованиям, теперь я знаю, как устанавливать переменные среды 7 из 8 различных способов. Я пытался получить envar для приложения, которое я разрабатываю под XCode. Я устанавливаю «трассирующие» envars, используя эти разные методы, чтобы сказать мне, какие из них попадают в сферу моего приложения. Ниже вы можете увидеть, что редактирование «схемы» в Xcode для добавления аргументов работает так же, как и «putenv». Что не устанавливало его в этой области: ~/.MACOS/environment.plist, специфичный для приложения plist, .profile и добавление фазы сборки для запуска пользовательского скрипта (я нашел другой способ в Xcode [как минимум] установить один, но забыл, что я назвал трассировщик и не могу найти его сейчас, может быть, на другой машине ....)

GPU_DUMP_DEVICE_KERNEL - 3 года

GPU_DUMP_TRK_ENVPLIST равен (null)

GPU_DUMP_TRK_APPPLIST равен (null)

GPU_DUMP_TRK_DOTPROFILE равно (null)

GPU_DUMP_TRK_RUNSCRIPT равно (null)

GPU_DUMP_TRK_SCHARGS равно 1

GPU_DUMP_TRK_PUTENV равно 1

... с другой стороны, если я зайду в Терминал и скажу "установить", кажется, что он получает только один из .profile (я бы подумал, что он также подберет environment.plist, и я уверен, что однажды я сделал увидел в Терминале второй трассирующий envar, так что с тех пор что-то, вероятно, пошло не так; долгий день ....)

0
Photovore

По умолчанию Mac OS X (10.7.4 и выше) больше не поддерживает его. Смотрите http://support.Apple.com/kb/TS4267

0
mac joost

Вы можете редактировать свой ~/.MacOSX/environment.plist с помощью этого примера $PATH:

defaults write $HOME/.MacOSX/environment PATH "/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/X11/bin:/opt/local/bin"

Это перепишет ваш ~/.MacOSX/environment.plist

или отредактируйте этот файл:

/etc/paths

изменить порядок системных переменных.

0
gylow