ソースで「バイナリファイルを実行できません」というエラーが発生するのはなぜですか?

ソースで「バイナリファイルを実行できません」というエラーが発生するのはなぜですか?

tmuxセッションを初期化してからいくつかのウィンドウを作成する小さなファイルがあります。いくつかのデバッグと調整の後、次のテキストファイル名を変更するまですべてがうまくいきました(コマンドを使用tmux)。spamxset

$ source xset
bash: source: /usr/bin/xset: cannot execute binary file

さて、ファイル名を変更し直してもsource spam動作しますが、理由を知りたいです。ファイルは.dllファイルではなく、私のホームディレクトリにあります/usr/bin

答え1

bash内部コマンドソースは、ファイル名にスラッシュ()がない限り、最初にPATHでファイル名を探します。 PATHの実行ファイルなので問題になります。/xset

次のコマンドを実行するsource ./xsetか、sourcepath オプションを off に変更できます。

shopt -u sourcepath

bashマニュアルページから:

      source filename [arguments]
          Read and execute commands from filename  in  the  current  shell
          environment  and return the exit status of the last command exe‐
          cuted from filename.  If filename does not contain a slash, file
          names  in  PATH  are used to find the directory containing file‐
          name.  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 arguments are supplied, they become the  posi‐
          tional  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.

答え2

これsourceコマンドは:

次のコマンドを読んで実行します。ファイル名現在のシェルコンテキストのパラメータです。もしファイル名スラッシュがない場合は、このPATH変数を使用して以下を見つけます。ファイル名

そのような行動.POSIXによって定義される(エイリアス)。なぜ?さて、そこにインポートできる設定スクリプトを入れて、PATHパスを制限することなくアクセスできます。必要なファイルにアクセスするには、絶対パスまたは相対パスを指定します。

source ./xset
source ~/xset
source /home/shawn/xset

上記のすべての作業は、最初に期待どおりに機能します。sourcepath無効にすることもできます。shopt

関連情報