Para la portabilidad, no confío en características de sed que sean específicas de Linux o BSD. En su lugar, utilizo el overwrite
script del libro de Kernighan y Pike sobre el entorno de programación Unix.
El comando es entonces
find /the/folder -type f -exec overwrite '{}' sed 's/old/new/g' {} ';'
Y el overwrite
guión (que utilizo en todas partes) es
#!/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
La idea es que sobrescriba un archivo solo si un comando tiene éxito. Útil en find
y también donde no querrías usar
sed 's/old/new/g' file > file # THIS CODE DOES NOT WORK
porque el shell trunca el archivo antes de sed
poder leerlo.