Почему «источник» и «.» не всегда то же самое, когда они должны быть одинаковыми?

У меня создалось впечатление, что source является синоним . в bash. Однако, похоже, что в файле .profile source не работает. Это видео youtube демонстрирует, что, когда source используется в ~/.profile для источника файла foo , переменная, определенная в этом файле, не экспортируется в последующие оболочки. Однако, если вместо этого файл используется с использованием . , переменная экспортируется, как ожидалось.

Обратите внимание, что когда я использую source , переменная среды НЕ экспортируется, но когда я использую . оно делает.

Они точно такие же, как объясняется в man bash :

 . filename [arguments] source filename [arguments] Read and execute commands from filename in the current shell environment and return the exit status of the last command executed from filename. If filename does not contain a slash, file names in PATH are used to find the directory containing filename. The file searched for in PATH need not be executable. When bash is not in posix mode, the current directory is searched if no file is found in PATH. If the sourcepath option to the shopt builtin command is turned off, the PATH is not searched. If any argu‐ ments are supplied, they become the positional parameters when filename is executed. Otherwise the positional parameters are unchanged. The return status is the status of the last command exited within the script (0 if no commands are executed), and false if filename is not found or cannot be read. 

Проблема здесь в том, что source – вещь bash , стандарт на самом деле . , Ваш .profile считывается только командами входа в систему и некоторыми (не все) менеджерами входа. Тем не менее, администраторы входа (например, lightdm) попытаются прочитать (источник) файл, используя стандартную оболочку системы, обычно /bin/sh . В Debian-производных системах /bin/sh является символической ссылкой на /bin/dash а dash – очень простая оболочка, совместимая с POSIX, которая не является bash и не знает ключевое слово source .

Поэтому команда игнорируется, файл не используется и переменная не определена. Проиллюстрировать:

 $ cat foo myvar='foo1' $ source foo $ echo $myvar foo1 

То же самое в dash :

 $ echo $0 dash $ source foo dash: 11: source: not found $ . ~/foo ## dash needs the full path $ echo $myvar foo1