Я создаю .desktop
файлы для использования в Unity Launcher.
У меня есть собственное местоположение в моем домашнем каталоге, куда я помещаю свои исполняемые файлы ( ~/usr/bin/
), которые правильно добавляются в мою PATH
переменную окружения в моем .pam_environment
файле, как указано в соответствующей документации по Ubuntu .
Это содержимое моего .pam_environment
файла:
LANGUAGE=en_AU:en_GB:en
LANG=en_AU.UTF-8
LC_NUMERIC=en_AU.UTF-8
LC_TIME=en_AU.UTF-8
LC_MONETARY=en_AU.UTF-8
LC_PAPER=en_AU.UTF-8
LC_NAME=en_AU.UTF-8
LC_ADDRESS=en_AU.UTF-8
LC_TELEPHONE=en_AU.UTF-8
LC_MEASUREMENT=en_AU.UTF-8
LC_IDENTIFICATION=en_AU.UTF-8
PATH DEFAULT=${PATH}:~/usr/bin/
В результате моя PATH
переменная выглядит следующим образом:
ben@ben-HPdv6:~$ echo $PATH
/usr/lib/lightdm/lightdm:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:~/usr/bin/:~/usr/bin/
Я знаю, что он добавляется дважды, но все в этом .pam_environment
файле, кажется, добавляется дважды, независимо от того, что при использовании правильного синтаксиса, рекомендованного в той документации по Ubuntu, на которую я ссылался.
Это один из примеров проблемы (это происходит во всех случаях). У меня есть скрипт (называется eclipse
), в ~/usr/bin/
котором работает Eclipse IDE.
Я могу открыть любой терминал и просто набрать, eclipse
и он работает нормально, как вы ожидаете.
Но при использовании следующего .desktop
файла:
#!/usr/bin/env xdg-open
[Desktop Entry]
Version=1.0
Type=Application
Terminal=false
Name=Eclipse - Juno (4.2)
Icon=/home/ben/.icons/eclipse.svg
Exec=eclipse
Я получаю ошибку:
Но когда я изменяю Exec=
строку на:
Exec=/home/ben/usr/bin/eclipse
это работает отлично.
Документация Unity Пусковые и файлы рабочего стола Официальный предполагает , что это должно работать:
Exec - это путь к исполняемому файлу. Полный путь к исполняемому файлу должен использоваться только в том случае, если его нет ни в одном из путей, указанных в переменной $ PATH. Например, любые файлы, которые находятся внутри пути / usr / bin, не обязательно должны указывать полный путь в поле Exec, а только свое имя файла.
Любые предложения о том, что происходит?
Ответы:
Тильда расширяется не
.pam_environment
так, как в скрипте профиля, и файлы рабочего стола не выполняют расширение оболочки в своихExec
строках так, как это делает оболочка , поэтому она ищет файл с буквальным именем~/usr/bin/eclipse
, что, конечно, не ' не существует.Замените тильду в назначении PATH на $ {HOME}, и это похоже на работу.
источник
$PATH
происходит дважды?То, что сказано в документации по Ubuntu, имеет смысл, однако в разделе «больше не рекомендуется» не хватает некоторых деталей. По этой причине мой ответ будет включать использование одного из этих методов. Кроме того: он уже используется для этой же цели.
Быстро посетите ваш файл ./.profile.
Мой содержит это:
Как вы можете видеть в последнем разделе этого файла (строки ниже # устанавливают PATH, так что он включает в себя личный ящик пользователя, если он существует), это уже делается. Поэтому, если вы хотите добавить что-то в переменную $ PATH, вы просто сделаете то же самое. В документации упоминалось, что это будет выполняться каждый раз при запуске системы.
В вашем случае все, что вам нужно сделать, это добавить это:
В этот момент я начинаю думать, что единственная причина, по которой этот метод больше не рекомендуется, это использование сценариев при запуске, которое очень чувствительно к небольшим ошибкам. Однако, когда кто-то работает с чем-то подобным, небольшая ошибка может быть исправлена простым изменением файла на прежний.
Если вы не уверены, как это сделать:
1) Сначала нажмите CTRL + ALT + F3
2) Войдите в систему, следуя подсказкам на экране
3) Введите это в командной строке:
4) удалите эти строки: (мы просто добавили их)
5) нажмите CTRL + O (как в Out)
6) нажмите CTRL + X (как в eXit)
7) введите
exit
и нажмите ENTER (иногда RETURN)8) теперь нажмите CTRL + ALT + F7
9) Вы должны получить свой экран входа или рабочий стол, в зависимости от того, когда возникла проблема. Если нет, нажмите CTRL + ALT + DEL (иногда CTRL + ALT + DELETE), и ваша система должна перезагрузиться безопасно.
Надеюсь это поможет!
источник