Você pode usar um comando wrapper que:
- renomeia o arquivo
- executa o visualizador em segundo plano
- limpa quando o visualizador retorna, em vez de deixar
mutt
fazer isso.
Algo como:
#! /bin/sh -
TMPDIR=$(
mutt -D 2> /dev/null |
awk -F\" '
$1 == "tmpdir=" {
gsub("~", ENVIRON["HOME"], $2)
print $2
exit
}'
)
[ -n "$TMPDIR" ] || exit
export TMPDIR
nargs=$#
nfiles=0
for i do
case $i in
("$TMPDIR"/?*)
new_file=$(mktemp -ut "XXXXX${i##*/}") &&
mv -- "$i" "$new_file" &&
nfiles=$(($nfiles + 1)) &&
set -- "$new_file" "$@" "$new_file" &&
continue
esac
set -- "$@" "$i"
done
run_command() (
shift "$(($nargs + $nfiles))"
exec "$@"
)
(
run_command "$@"
while [ "$nfiles" -gt 0 ]; do
set -- "$@" "$1"
shift
nfiles=$(($nfiles - 1))
done
shift "$((2*$nargs))"
rm -f -- "$@"
) &
E coloque algo como:
image/*; muttv eog %s;
Onde muttv
é o script acima.
O acima não faz nenhuma suposição sobre onde o (s) nome (s) do (s) arquivo (s) aparecem na lista de argumentos ou qual caractere eles contêm ... É por isso que perguntamos primeiro ao mutt
o que é tmpdir
use isso para determinar quais são os arquivos para ver ).
Na maioria dos casos, seria um exagero e, como Gilles aponta, pode não funcionar se o tmpdir for especificado como relativo à sua pasta de caixa de correio.
Um mais simples seria:
#! /bin/sh -
nargs=$#
eval "file=\${$nargs}"
newfile=$(dirname -- "$file")/new-$(basename -- "$file")
while [ "$nargs" -gt 1 ]; do
set -- "$@" "$1"
shift
nargs=$(($nargs - 1))
done
shift
mv -- "$file" "$newfile" || exit
(
"$@" "$newfile"
rm -f -- "$newfile"
) &
Substitua mv
por cp
se você não quiser tocar no arquivo original fornecido por mutt
.