Eu li que ls -lt
ordenará os arquivos por hora de modificação antes de classificá-los por ordem lexicográfica.
Porém, quando utilizo o comando com esta sintaxe, obtenho este resultado:
ls -lt
total 192
-rw-r--r-- 1 elfryskai staff 6988 Aug 20 21:17 sorting_files.o
-rw-r--r-- 1 elfryskai staff 4416 Aug 20 20:56 sorting_dirs.o
-rw-r--r-- 1 elfryskai staff 6552 Aug 20 15:12 lists.o
-rw-r--r-- 1 elfryskai staff 7692 Aug 20 15:12 printing.o
-rw-r--r-- 1 elfryskai staff 7868 Aug 20 01:05 assets.o
-rw-r--r-- 1 elfryskai staff 5344 Aug 20 01:05 freeing.o
-rw-r--r-- 1 elfryskai staff 4860 Aug 20 01:05 reversing.o
-rw-r--r-- 1 elfryskai staff 8028 Aug 20 01:04 listing.o
-rw-r--r-- 1 elfryskai staff 2620 Aug 19 23:24 errors.o
-rw-r--r-- 1 elfryskai staff 3096 Aug 19 23:24 main.o
-rw-r--r-- 1 elfryskai staff 5564 Aug 19 21:07 chmod.o
-rw-r--r-- 1 elfryskai staff 7140 Aug 19 21:07 sorting.o
-rw-r--r-- 1 elfryskai staff 4760 Aug 19 21:07 parsing.o
parsing.o
vem depois sorting.o
. Por que?
O uso ls -lT
mostra que esses dois (mais chmod.o
) têm o mesmo carimbo de data/hora:
ls -lT
total 192
[...]
-rw-r--r-- 1 elfryskai staff 5564 Aug 19 21:07:50 2018 chmod.o
[...]
-rw-r--r-- 1 elfryskai staff 4760 Aug 19 21:07:50 2018 parsing.o
[...]
-rw-r--r-- 1 elfryskai staff 7140 Aug 19 21:07:50 2018 sorting.o
[...]
EDIT: estou executando o MacOS com um volume APFS.
Responder1
O sistema de arquivos mais recente da Apple, APFS, armazena carimbos de data e hora em nanossegundos, em vez de segundos (como HFS+ costumava).
Isto pode explicar uma classificação diferente dos arquivos, mesmo que pareçam ter sido modificados ao mesmo tempo.
Para testar isso, desculpe meu C desleixado:
#include <stdio.h>
#include <sys/stat.h>
int main() {
struct stat attr;
stat("/path/to/file", &attr);
printf("Last modified time: %ld", (long)&attr.st_mtime);
}
Então:
gcc -o test.o test.c && test.o
Iria imprimir:
Last modified time: 140734785103288