Meu método mais curto usa zsh:
print -rl **/*(.Om)
Se você tiver o GNU find, imprima os tempos de modificação do arquivo e ordene-os. Eu suponho que não há novas linhas em nomes de arquivos.
find . -type f -printf '%T@ %p\n' | sort -k 1 -n | sed 's/^[^ ]* //'
Se você tiver o Perl (novamente, assumindo que não há novas linhas nos nomes dos arquivos):
find . -type f -print |
perl -l -ne '
$_{$_} = -M; # store file age (mtime - now)
END {
$,="\n";
print sort {$_{$b} <=> $_{$a}} keys %_; # print by decreasing age
}'
Se você tem Python (novamente, assumindo que não há novas linhas nos nomes dos arquivos):
find . -type f -print |
python -c 'import os, sys; times = {}
for f in sys.stdin.readlines(): f = f[0:-1]; times[f] = os.stat(f).st_mtime
for f in sorted(times.iterkeys(), key=lambda f:times[f]): print f'
Se você tiver acesso SSH a esse servidor, monte o diretório em sshfs em uma máquina melhor equipada:
mkdir mnt
sshfs server:/path/to/directory mnt
zsh -c 'cd mnt && print -rl **/*(.Om)'
fusermount -u mnt
Com apenas ferramentas POSIX, é muito mais complicado, porque não há uma boa maneira de encontrar o tempo de modificação de um arquivo. A única maneira padrão de recuperar os tempos de um arquivo é ls
, e o formato de saída é dependente do local e difícil de analisar.
Se você pode escrever nos arquivos, e se importar apenas com arquivos regulares, e não há novas linhas em nomes de arquivos, aqui está um kludge horrível: crie hard links para todos os arquivos em um único diretório e ordene-os por modificação tempo.
set -ef # disable globbing
IFS='
' # split $(foo) only at newlines
set -- $(find . -type f) # set positional arguments to the file names
mkdir links.tmp
cd links.tmp
i=0 list=
for f; do # hard link the files to links.tmp/0, links.tmp/1, …
ln "../$f" $i
i=$(($i+1))
done
set +f
for f in $(ls -t [0-9]*); do # for each file, in reverse mtime order:
eval 'list="${'$i'} # prepend the file name to $list
$list"'
done
printf %s "$list" # print the output
rm -f [0-9]* # clean up
cd ..
rmdir links.tmp