forked from mirrors/nixpkgs
Merge pull request #78773 from layus/sane-override
sane module: support overriding config files
This commit is contained in:
commit
b78092a551
|
@ -6,7 +6,7 @@ with stdenv.lib;
|
|||
let installSanePath = path: ''
|
||||
if [ -e "${path}/lib/sane" ]; then
|
||||
find "${path}/lib/sane" -maxdepth 1 -not -type d | while read backend; do
|
||||
ln -s "$backend" "$out/lib/sane/$(basename "$backend")"
|
||||
symlink "$backend" "$out/lib/sane/$(basename "$backend")"
|
||||
done
|
||||
fi
|
||||
|
||||
|
@ -16,14 +16,14 @@ let installSanePath = path: ''
|
|||
if [ "$name" = "dll.conf" ] || [ "$name" = "saned.conf" ] || [ "$name" = "net.conf" ]; then
|
||||
cat "$conf" >> "$out/etc/sane.d/$name"
|
||||
else
|
||||
ln -s "$conf" "$out/etc/sane.d/$name"
|
||||
symlink "$conf" "$out/etc/sane.d/$name"
|
||||
fi
|
||||
done
|
||||
fi
|
||||
|
||||
if [ -e "${path}/etc/sane.d/dll.d" ]; then
|
||||
find "${path}/etc/sane.d/dll.d" -maxdepth 1 -not -type d | while read conf; do
|
||||
ln -s "$conf" "$out/etc/sane.d/dll.d/$(basename $conf)"
|
||||
symlink "$conf" "$out/etc/sane.d/dll.d/$(basename $conf)"
|
||||
done
|
||||
fi
|
||||
'';
|
||||
|
@ -33,6 +33,14 @@ stdenv.mkDerivation {
|
|||
phases = "installPhase";
|
||||
|
||||
installPhase = ''
|
||||
function symlink () {
|
||||
local target=$1 linkname=$2
|
||||
if [ -e "$linkname" ]; then
|
||||
echo "warning: conflict for $linkname. Overriding $(readlink $linkname) with $target."
|
||||
fi
|
||||
ln -sfn "$target" "$linkname"
|
||||
}
|
||||
|
||||
mkdir -p $out/etc/sane.d $out/etc/sane.d/dll.d $out/lib/sane
|
||||
'' + concatMapStrings installSanePath paths;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue