Quindi in qualche modo il comando ls
sembra mostrarmi due file identici in una 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:36 tftp.plist
-rw-r--r-- 1 root wheel 715B Jun 18 10:35 tftp.plist
Posso spostare, rinominare, modificare ecc. Uno dei file, ma l'altro non sembra nemmeno essere lì. bash
il completamento della scheda mostra anche file identici.
Ad esempio, inserendo quanto segue e quindi premendo TAB
$ sudo mv /System/Library/LaunchDaemons/tftp
tftp.plist tftp.plist
Se rinomino il file:
$ sudo mv /System/Library/LaunchDaemons/tftp.plist /System/Library/LaunchDaemons/tftp.plist.derp
Il completamento della scheda mostra ancora il file:
$ ls -Blah /System/Library/LaunchDaemons/tf
tftp.plist tftp.plist.derp
Ma il file originale non modificato non sembra 'ls'
$ ls -Blah /System/Library/LaunchDaemons/tftp.plist
ls: /System/Library/LaunchDaemons/tftp.plist: No such file or directory
Tuttavia, se ho appena elencato i file come nel primo frammento di codice sopra, ecco:
$ 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
Hai idea di cosa stia succedendo qui e come posso liberarmi di questo file fantasma?
Questo è un mac che esegue OS X se aggiunge informazioni al problema. Stavo usando sed
questo file poco prima dell'inizio della follia.
modificare
Ho usato entrambe le blah
e le Blah
ls
bandiere con nessun cambiamento in uscita apparente.
Modifica 2
Ulteriori informazioni richieste nei commenti:
$ echo tftp* | xxd
0000000: 7466 7470 2e70 6c69 7374 2020 7466 7470 tftp.plist tftp
0000010: 2e70 6c69 7374 2e64 6572 700a .plist.derp.
Di Più:
$ printf '<%q>\n' tftp*
<tftp.plist\ >
<tftp.plist.derp>
Ancora di più:
$ 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"
Nota
La risposta qui sotto mi ha aiutato a vedere che c'era uno spazio finale nel nome.
ls test\
... Cosa succede se lo usi ls "*tftp.list*"
? o usare ls
con --show-control-chars
?
echo tftp* | xxd
o qualche altro hexdump?
printf '<%q>\n' tftp*
?
en_US.UTF-8
, ls -b
non mostrerà gli spazi vuoti nei nomi dei file in alcun modo speciale, sia nel mezzo che alla fine del nome del file. È possibile utilizzare una delle risposte (printf, echo) o filtrare l'output di ls con un programma progettato per evidenziare spazi vuoti finali comels -1 tftp* | cat -vet