Per la portabilità, non mi affido a funzionalità di sed specifiche per Linux o BSD. Invece io uso lo overwrite
script dal libro di Kernighan e Pike sull'ambiente di programmazione Unix.
Il comando è quindi
find /the/folder -type f -exec overwrite '{}' sed 's/old/new/g' {} ';'
E lo overwrite
script (che uso ovunque) lo è
#!/bin/sh
# overwrite: copy standard input to output after EOF
# (final version)
# set -x
case $# in
0|1) echo 'Usage: overwrite file cmd [args]' 1>&2; exit 2
esac
file=$1; shift
new=/tmp/$$.new; old=/tmp/$$.old
trap 'rm -f $new; exit 1' 1 2 15 # clean up files
if "$@" >$new # collect input
then
cp $file $old # save original file
trap 'trap "" 1 2 15; cp $old $file # ignore signals
rm -f $new $old; exit 1' 1 2 15 # during restore
cp $new $file
else
echo "overwrite: $1 failed, $file unchanged" 1>&2
exit 1
fi
rm -f $new $old
L'idea è che sovrascrive un file solo se un comando riesce. Utile in find
e anche dove non vorresti usare
sed 's/old/new/g' file > file # THIS CODE DOES NOT WORK
perché la shell tronca il file prima di sed
poterlo leggere.