したがって、どういうわけか、コマンドls
は、ディレクトリ内の2つの同じファイルを表示しているようです。
$ ls -Blah /System/Library/LaunchDaemons
total 32
drwxr-xr-x 266 root wheel 8.8K Jun 18 10:41 .
drwxr-xr-x 79 root wheel 2.6K Mar 31 12:28 ..
[redacted]
-rw-r--r-- 1 root wheel 715B Jun 18 10:36 tftp.plist
-rw-r--r-- 1 root wheel 715B Jun 18 10:35 tftp.plist
ファイルの1つを移動、名前変更、編集などすることはできますが、もう1つはそこにないようです。 bash
タブ補完では、同一のファイルも表示されます。
たとえば、次のように入力してから、 TAB
$ Sudo mv /System/Library/LaunchDaemons/tftp
tftp.plist tftp.plist
ファイルの名前を変更した場合:
$ Sudo mv /System/Library/LaunchDaemons/tftp.plist /System/Library/LaunchDaemons/tftp.plist.derp
タブ補完はまだファイルを示しています:
$ ls -Blah /System/Library/LaunchDaemons/tf
tftp.plist tftp.plist.derp
しかし、元の変更されていないファイルは「ls」に表示されません
$ ls -Blah /System/Library/LaunchDaemons/tftp.plist
ls: /System/Library/LaunchDaemons/tftp.plist: No such file or directory
ただし、上記の最初のコードスニペットのようにファイルをリストするだけの場合は、次のようになります。
$ ls -Blah /System/Library/LaunchDaemons
total 32
drwxr-xr-x 266 root wheel 8.8K Jun 18 10:41 .
drwxr-xr-x 79 root wheel 2.6K Mar 31 12:28 ..
[redacted]
-rw-r--r-- 1 root wheel 715B Jun 18 10:35 tftp.plist
-rw-r--r-- 1 root wheel 715B Jun 18 10:36 tftp.plist.derp
ここで何が起こっているのか、そしてどのようにしてこのゴーストファイルを取り除くことができるのでしょうか?
問題に情報を追加する場合、これはOS Xを実行しているMacです。私は狂気が始まる直前にこのファイルでsed
を使用していました。
blah
フラグとBlah
ls
フラグの両方を使用しましたが、見かけ上の出力に変更はありません。
コメントでリクエストされた追加情報:
$ echo tftp* | xxd
0000000: 7466 7470 2e70 6c69 7374 2020 7466 7470 tftp.plist tftp
0000010: 2e70 6c69 7374 2e64 6572 700a .plist.derp.
もっと:
$ printf '<%q>\n' tftp*
<tftp.plist\ >
<tftp.plist.derp>
さらに:
$ locale │-rw-r--r-- 1 root wheel 495B Sep 9 2014 org.net-snmp.snmpd.plist
LANG="en_US.UTF-8" │-rw-r--r-- 1 root wheel 498B Jan 15 23:15 org.ntp.ntpd.plist
LC_COLLATE="en_US.UTF-8" │-rw-r--r-- 1 root wheel 1.0K Nov 13 2014 org.openldap.slapd.plist
LC_CTYPE="en_US.UTF-8" │-rw-r--r-- 1 root wheel 572B Sep 9 2014 org.postfix.master.plist
LC_MESSAGES="en_US.UTF-8" │-rw-r--r-- 1 root wheel 238B Sep 9 2014 Shell.plist
LC_MONETARY="en_US.UTF-8" │-rw-r--r-- 1 root wheel 941B Sep 9 2014 ssh.plist
LC_NUMERIC="en_US.UTF-8" │-rw-r--r-- 1 root wheel 260B Sep 9 2014 telnet.plist
LC_TIME="en_US.UTF-8" │-rw-r--r-- 1 root wheel 715B Jun 18 10:36 tftp.plist
LC_ALL="en_US.UTF-8"
以下の答えは、名前の後にスペースがあることを理解するのに役立ちました。
末尾に空白があるか、ファイルシステムが破損しています。
試す
for i in tftp.plist*
do
echo "'$i'"
done
それは次のようなものを出力するはずです
'tftp.plist'
'tftp.plist '
引用符と余分なスペースに注意してください。まったく同じものが2回出力される場合は、ファイルシステムが破損している可能性があります。
試す
ls -i tftp.plist*
これにより、ファイルのiノード番号がわかります。それらが同じ場合、ディレクトリに同じファイルが2回あります。それはReally Bad(tm)であり、fsck asapを実行する必要があります。しかし、それが問題だとは思いません。それはおそらく空白のことです。