Updated to 2.1 - added support for rpmorig files

This commit is contained in:
Jiri Vanek 2017-02-03 14:58:47 +01:00
parent cf4337c0d8
commit e95b93e314
2 changed files with 66 additions and 29 deletions

View File

@ -7,7 +7,7 @@ Name: copy-jdk-configs
# hash relevant to version tag # hash relevant to version tag
%global htag 3f9d6c4448f867a95fb166416a41c45c7e795c10 %global htag 3f9d6c4448f867a95fb166416a41c45c7e795c10
Version: 2.0 Version: 2.1
Release: 1%{?dist} Release: 1%{?dist}
Summary: JDKs configuration files copier Summary: JDKs configuration files copier
@ -72,6 +72,9 @@ rm "%{rpm_state_dir}/%{file}" 2> /dev/null || :
%license LICENSE %license LICENSE
%changelog %changelog
* Fri Feb 03 2017 Jiri Vanek <jvanek@redhat.com> - 2.1-1
- moved to newest release 2.1
* Fri Jan 20 2017 Jiri Vanek <jvanek@redhat.com> - 2.0-1 * Fri Jan 20 2017 Jiri Vanek <jvanek@redhat.com> - 2.0-1
- moved to new upstream at pagure.io - moved to new upstream at pagure.io
- moved to newest release 2.0 - moved to newest release 2.0

View File

@ -4,11 +4,10 @@ target=$2
debug="false" debug="false"
#we should be pretty strict about removing once used (even "used" [with fail]) config file, as it may corrupt another installation rma=""
clean(){ if [ "x$debug" == "xtrue" ] ; then
debug "cleanup: removing $config" rma="-v"
rm -rf $config fi
}
debug(){ debug(){
if [ "x$debug" == "xtrue" ] ; then if [ "x$debug" == "xtrue" ] ; then
@ -16,6 +15,12 @@ debug(){
fi fi
} }
#we should be pretty strict about removing once used (even "used" [with fail]) config file, as it may corrupt another installation
clean(){
debug "cleanup: removing $config"
rm -rf $config
}
if [ "x" == "x$config" ] ; then if [ "x" == "x$config" ] ; then
debug "no config file specified" debug "no config file specified"
exit 1 exit 1
@ -54,32 +59,61 @@ if [ ! -d "$source" ] ; then
fi fi
debug "source: $source" debug "source: $source"
debug "target: $target"
work(){
if [ "X$1" == "Xrpmnew" -o "X$1" == "Xrpmorig" ] ; then
debug "Working with $1 (1)"
else
debug "unknown parameter: $1"
return 1
fi
local files=`find $target | grep "\\.$1$"`
for file in $files ; do
local sf1=`echo $file | sed "s/\\.$1$//"`
local sf2=`echo $sf1 | sed "s/$targetName/$srcName/"`
# was file modified in origianl installation?
rpm -Vf $source | grep -q $sf2
if [ $? -gt 0 ] ; then
if [ "X$1" == "Xrpmnew" ] ; then
debug "$sf2 was NOT modified, removing possibly corrupted $sf1 and renaming from $file"
rm $rma $sf1
mv $rma $file $sf1
if [ $? -eq 0 ] ; then
echo "restored $file to $sf1"
else
echo "FAILED to restore $file to $sf1"
fi
fi
if [ "X$1" == "Xrpmorig" ] ; then
debug "$sf2 was NOT modified, removing possibly corrupted $file"
rm $rma $file
fi
else
debug "$sf2 was modified, keeping $file, and removing the duplicated original"
# information is now backuped, in new directory anyway. Removing future rpmsave to allow rpm -e
rm -f $rma $sf2
# or its corresponding backup
rm -f $rma $sf2.$1
fi
done
}
srcName=`basename $source` srcName=`basename $source`
targetName=`basename $target` targetName=`basename $target`
files=`find $target | grep "\\.rpmnew$"` work rpmnew
for file in $files ; do work rpmorig
sf1=`echo $file | sed "s/\\.rpmnew$//"`
sf2=`echo $sf1 | sed "s/$targetName/$srcName/"`
# was file modified in origianl installation?
rpm -Vf $source | grep -q $sf2
if [ $? -gt 0 ] ; then
debug "$sf2 was NOT modified, removing possibly corrupted $sf1 and renaming $file"
rm $sf1
mv $file $sf1
if [ $? -eq 0 ] ; then
echo "restored $file to $sf1"
else
echo "FAILED to restore $file to $sf1"
fi
else
debug "$sf2 was modified, keeping $file, and removing the duplicated original"
# information is now backuped, in new directory anyway. Removing future rpmsave to allow rpm -e
rm $sf2
# or its corresponding backup
rm $sf2.rpmnew
fi
done
debug "Working with rpmorig (2)"
# simply moving old rpmsaves to new dir
# fix for config (replace) leftovers
files=`find $source | grep "\\.rpmorig$"`
for file in $files ; do
rpmsaveTarget=`echo $file | sed "s/$srcName/$targetName/"`
debug "relocating $file to $rpmsaveTarget"
mv $rma $file $rpmsaveTarget
done
clean clean