diff --git a/vfs/ChangeLog b/vfs/ChangeLog index 2a230515d..a0bc1fec9 100644 --- a/vfs/ChangeLog +++ b/vfs/ChangeLog @@ -1,3 +1,8 @@ +Wed Dec 9 12:24:52 1998 Pavel Machek + + * extfs/rpm: commit fix for files with spaces in name by Marc + Merlin (marcsoft@merlins.org) + Mon Dec 7 11:04:57 1998 Pavel Machek * fish.c: default to normal ssh diff --git a/vfs/extfs/rpm b/vfs/extfs/rpm index 6a7c1e99e..3054014f1 100644 --- a/vfs/extfs/rpm +++ b/vfs/extfs/rpm @@ -5,6 +5,7 @@ # Tomasz Kłoczko (kloczek@rudy.mif.pg.gda.pl) 1997 # minor changes by Wojtek Pilorz (wpilorz@bdk.lublin.pl) 1997 # minor changes by Michele Marziani (marziani@fe.infn.it) 1997 +# bug files by Marc Merlin (marcsoft@merlins.org) 1998 # (C) 1996 The Free Software Foundation. # # @@ -18,8 +19,8 @@ mcrpmfs_list () MCFASTRPM=$MCFASTRPM_DFLT fi FILEPREF="-r--r--r-- 1 root root " - DESC=`rpm -qip $1` - DATE=`rpm -qp --qf "%{BUILDTIME:date}\n" $1 | cut -c 5-11,21-24` + DESC=`rpm -qip "$1"` + DATE=`rpm -qp --qf "%{BUILDTIME:date}\n" "$1" | cut -c 5-11,21-24` HEADERSIZE=`echo "$DESC" | wc -c` echo "-r--r--r-- 1 root root $HEADERSIZE $DATE HEADER" echo "-r-xr-xr-x 1 root root 39 $DATE INSTALL" @@ -30,25 +31,25 @@ mcrpmfs_list () echo "$FILEPREF 0 $DATE INFO/BUILDHOST" echo "$FILEPREF 0 $DATE INFO/SOURCERPM" if test "$MCFASTRPM" = 0 ; then - test "`rpm -qp --qf \"%{DISTRIBUTION}\" $1`" = "(none)" || + test "`rpm -qp --qf \"%{DISTRIBUTION}\" \"$1\"`" = "(none)" || echo "$FILEPREF 0 $DATE INFO/DISTRIBUTION" - test "`rpm -qp --qf \"%{VENDOR}\" $1`" = "(none)" || + test "`rpm -qp --qf \"%{VENDOR}\" \"$1\"`" = "(none)" || echo "$FILEPREF 0 $DATE INFO/VENDOR" - test "`rpm -qp --qf \"%{DESCRIPTION}\" $1`" = "(none)" || + test "`rpm -qp --qf \"%{DESCRIPTION}\" \"$1\"`" = "(none)" || echo "$FILEPREF 0 $DATE INFO/DESCRIPTION" - test "`rpm -qp --qf \"%{SUMMARY}\" $1`" = "(none)" || + test "`rpm -qp --qf \"%{SUMMARY}\" \"$1\"`" = "(none)" || echo "$FILEPREF 0 $DATE INFO/SUMMARY" - if test "`rpm -qp --qf \"%{RPMTAG_PREIN}%{RPMTAG_POSTIN}%{RPMTAG_PREUN}%{RPMTAG_POSTUN}%{VERIFYSCRIPT}\" $1`" != "(none)(none)(none)(none)(none)"; then + if test "`rpm -qp --qf \"%{RPMTAG_PREIN}%{RPMTAG_POSTIN}%{RPMTAG_PREUN}%{RPMTAG_POSTUN}%{VERIFYSCRIPT}\" \"$1\"`" != "(none)(none)(none)(none)(none)"; then echo "dr-xr-xr-x 1 root root 0 $DATE INFO/SCRIPTS" - test "`rpm -qp --qf \"%{RPMTAG_PREIN}\" $1`" = '(none)' || + test "`rpm -qp --qf \"%{RPMTAG_PREIN}\" \"$1\"`" = '(none)' || echo "$FILEPREF 0 $DATE INFO/SCRIPTS/PREIN" - test "`rpm -qp --qf \"%{RPMTAG_POSTIN}\" $1`" = '(none)' || + test "`rpm -qp --qf \"%{RPMTAG_POSTIN}\" \"$1\"`" = '(none)' || echo "$FILEPREF 0 $DATE INFO/SCRIPTS/POSTIN" - test "`rpm -qp --qf \"%{RPMTAG_PREUN}\" $1`" = '(none)' || + test "`rpm -qp --qf \"%{RPMTAG_PREUN}\" \"$1\"`" = '(none)' || echo "$FILEPREF 0 $DATE INFO/SCRIPTS/PREUN" - test "`rpm -qp --qf \"%{RPMTAG_POSTUN}\" $1`" = '(none)' || + test "`rpm -qp --qf \"%{RPMTAG_POSTUN}\" \"$1\"`" = '(none)' || echo "$FILEPREF 0 $DATE INFO/SCRIPTS/POSTUN" - test "`rpm -qp --qf \"%{VERIFYSCRIPT}\" $1`" = '(none)' || + test "`rpm -qp --qf \"%{VERIFYSCRIPT}\" \"$1\"`" = '(none)' || echo "$FILEPREF 0 $DATE INFO/SCRIPTS/VERIFYSCRIPT" echo "$FILEPREF 0 $DATE INFO/SCRIPTS/ALL" fi @@ -66,15 +67,15 @@ mcrpmfs_list () echo "$FILEPREF 0 $DATE INFO/SCRIPTS/ALL" fi if test "$MCFASTRPM" = 0 ; then - test "`rpm -qp --qf \"%{PACKAGER}\" $1`" = "(none)" || + test "`rpm -qp --qf \"%{PACKAGER}\" \"$1\"`" = "(none)" || echo "$FILEPREF 0 $DATE INFO/PACKAGER" - test "`rpm -qp --qf \"%{URL}\" $1`" = "(none)" || + test "`rpm -qp --qf \"%{URL}\" \"$1\"`" = "(none)" || echo "$FILEPREF 0 $DATE INFO/URL" - test "`rpm -qp --qf \"%{SERIAL}\" $1`" = "(none)" || + test "`rpm -qp --qf \"%{SERIAL}\" \"$1\"`" = "(none)" || echo "$FILEPREF 0 $DATE INFO/SERIAL" - test "`rpm -qp --qf \"%{COPYRIGHT}\" $1`" = "(none)" || + test "`rpm -qp --qf \"%{COPYRIGHT}\" \"$1\"`" = "(none)" || echo "$FILEPREF 0 $DATE INFO/COPYRIGHT" - test "`rpm -qp --qf \"%{LICENSE}\" $1`" = "(none)" || + test "`rpm -qp --qf \"%{LICENSE}\" \"$1\"`" = "(none)" || echo "$FILEPREF 0 $DATE INFO/LICENSE" else echo "$FILEPREF 0 $DATE INFO/PACKAGER" @@ -88,13 +89,13 @@ mcrpmfs_list () echo "$FILEPREF 0 $DATE INFO/OS" echo "$FILEPREF 0 $DATE INFO/SIZE" if test "$MCFASTRPM" != 0 ; then - rpm -qp --qf "[%{REQUIRENAME}\n]" $1 | grep "(none)" > /dev/null || + rpm -qp --qf "[%{REQUIRENAME}\n]" "$1" | grep "(none)" > /dev/null || echo "$FILEPREF 0 $DATE INFO/REQUIRENAME" - rpm -qp --qf "[%{OBSOLETES}\n]" $1 | grep "(none)" > /dev/null || + rpm -qp --qf "[%{OBSOLETES}\n]" "$1" | grep "(none)" > /dev/null || echo "$FILEPREF 0 $DATE INFO/OBSOLETES" - rpm -qp --qf "[%{PROVIDES}\n]" $1 | grep "(none)" > /dev/null || + rpm -qp --qf "[%{PROVIDES}\n]" "$1" | grep "(none)" > /dev/null || echo "$FILEPREF 0 $DATE INFO/PROVIDES" - test "`rpm -qp --qf \"%{CHANGELOGTEXT}\" $1`" = "(none)" || + test "`rpm -qp --qf \"%{CHANGELOGTEXT}\" \"$1\"`" = "(none)" || echo "$FILEPREF 0 $DATE INFO/CHANGELOG" else echo "$FILEPREF 0 $DATE INFO/REQUIRENAME" @@ -103,50 +104,47 @@ mcrpmfs_list () echo "$FILEPREF 0 $DATE INFO/CHANGELOG" fi - rpm -qlvp $1 | sed -e 's/^\(..........\) /\1 1 /' + rpm -qlvp "$1" | sed -e 's/^\(..........\)[-t]* /\1 1 /' } mcrpmfs_copyout () { case "$2" in - HEADER) rpm -qip $1 > $3; exit 0;; - INSTALL) echo "# Run this to install this RPM package" > $3; exit 0;; - UPGRADE) echo "# Run this to upgrade this RPM package" > $3; exit 0;; - INFO/NAME-VERSION-RELEASE) rpm -qp --qf "%{NAME}-%{VERSION}-%{RELEASE}\n" $1 > $3; exit 0;; - INFO/RELEASE) rpm -qp --qf "%{RELEASE}\n" $1 > $3; exit 0;; - INFO/GROUP) rpm -qp --qf "%{GROUP}\n" $1 > $3; exit 0;; - INFO/DISTRIBUTION) rpm -qp --qf "%{DISTRIBUTION}\n" $1 > $3; exit 0;; - INFO/VENDOR) rpm -qp --qf "%{VENDOR}\n" $1 > $3; exit 0;; - INFO/BUILDHOST) rpm -qp --qf "%{BUILDHOST}\n" $1 > $3; exit 0;; - INFO/SOURCERPM) rpm -qp --qf "%{SOURCERPM}\n" $1 > $3; exit 0;; - INFO/DESCRIPTION) rpm -qp --qf "%{DESCRIPTION}\n" $1 > $3; exit 0;; - INFO/PACKAGER) rpm -qp --qf "%{PACKAGER}\n" $1 > $3; exit 0;; - INFO/URL) rpm -qp --qf "%{URL}\n" $1 >$3; exit 0;; - INFO/BUILDTIME) rpm -qp --qf "%{BUILDTIME:date}\n" $1 >$3; exit 0;; - INFO/SERIAL) rpm -qp --qf "%{SERIAL}\n" $1 >$3; exit 0;; - INFO/COPYRIGHT) rpm -qp --qf "%{COPYRIGHT}\n" $1 >$3; exit 0;; - INFO/LICENSE) rpm -qp --qf "%{LICENSE}\n" $1 >$3; exit 0;; - INFO/OBSOLETES) rpm -qp --qf "[%{OBSOLETES}\n]" $1 >$3; exit 0;; - INFO/RPMVERSION) rpm -qp --qf "%{RPMVERSION}\n" $1 >$3; exit 0;; - INFO/REQUIRENAME) rpm -qp --qf "[%{REQUIRENAME} %{REQUIREFLAGS:depflags} %{REQUIREVERSION}\n]" $1 >$3; exit 0;; - INFO/PROVIDES) rpm -qp --qf "[%{PROVIDES}\n]" $1 >$3; exit 0;; - INFO/SCRIPTS/PREIN) rpm -qp --qf "%{RPMTAG_PREIN}\n" $1 >$3; exit 0;; - INFO/SCRIPTS/POSTIN) rpm -qp --qf "%{RPMTAG_POSTIN}\n" $1 >$3; exit 0;; - INFO/SCRIPTS/PREUN) rpm -qp --qf "%{RPMTAG_PREUN}\n" $1 >$3; exit 0;; - INFO/SCRIPTS/POSTUN) rpm -qp --qf "%{RPMTAG_POSTUN}\n" $1 >$3; exit 0;; - INFO/SCRIPTS/VERIFYSCRIPT) rpm -qp --qf "%{VERIFYSCRIPT}\n" $1 >$3; exit 0;; - INFO/SCRIPTS/ALL) rpm -qp --scripts $1 > $3; exit 0;; - INFO/SUMMARY) rpm -qp --qf "%{SUMMARY}\n" $1 > $3; exit 0;; - INFO/OS) rpm -qp --qf "%{OS}\n" $1 > $3; exit 0;; - INFO/CHANGELOG) rpm -qp --qf "[* %{CHANGELOGTIME:date} %{CHANGELOGNAME}\n%{CHANGELOGTEXT}\n\n]\n" $1 > $3; exit 0;; - INFO/SIZE) rpm -qp --qf "%{SIZE} bytes\n" $1 > $3; exit 0;; + HEADER) rpm -qip "$1" > "$3"; exit 0;; + INSTALL) echo "# Run this to install this RPM package" > "$3"; exit 0;; + UPGRADE) echo "# Run this to upgrade this RPM package" > "$3"; exit 0;; + INFO/NAME-VERSION-RELEASE) rpm -qp --qf "%{NAME}-%{VERSION}-%{RELEASE}\n" "$1" > "$3"; exit 0;; + INFO/RELEASE) rpm -qp --qf "%{RELEASE}\n" "$1" > "$3"; exit 0;; + INFO/GROUP) rpm -qp --qf "%{GROUP}\n" "$1" > "$3"; exit 0;; + INFO/DISTRIBUTION) rpm -qp --qf "%{DISTRIBUTION}\n" "$1" > "$3"; exit 0;; + INFO/VENDOR) rpm -qp --qf "%{VENDOR}\n" "$1" > "$3"; exit 0;; + INFO/BUILDHOST) rpm -qp --qf "%{BUILDHOST}\n" "$1" > "$3"; exit 0;; + INFO/SOURCERPM) rpm -qp --qf "%{SOURCERPM}\n" "$1" > "$3"; exit 0;; + INFO/DESCRIPTION) rpm -qp --qf "%{DESCRIPTION}\n" "$1" > "$3"; exit 0;; + INFO/PACKAGER) rpm -qp --qf "%{PACKAGER}\n" "$1" > "$3"; exit 0;; + INFO/URL) rpm -qp --qf "%{URL}\n" "$1" >"$3"; exit 0;; + INFO/BUILDTIME) rpm -qp --qf "%{BUILDTIME:date}\n" "$1" >"$3"; exit 0;; + INFO/SERIAL) rpm -qp --qf "%{SERIAL}\n" "$1" >"$3"; exit 0;; + INFO/COPYRIGHT) rpm -qp --qf "%{COPYRIGHT}\n" "$1" >"$3"; exit 0;; + INFO/RPMVERSION) rpm -qp --qf "%{RPMVERSION}\n" "$1" >"$3"; exit 0;; + INFO/REQUIRENAME) rpm -qp --qf "[%{REQUIRENAME} %{REQUIREFLAGS:depflags} %{REQUIREVERSION}\n]" "$1" >"$3"; exit 0;; + INFO/PROVIDES) rpm -qp --qf "[%{PROVIDES}\n]" "$1" >"$3"; exit 0;; + INFO/SCRIPTS/PREIN) rpm -qp --qf "%{RPMTAG_PREIN}\n" "$1" >"$3"; exit 0;; + INFO/SCRIPTS/POSTIN) rpm -qp --qf "%{RPMTAG_POSTIN}\n" "$1" >"$3"; exit 0;; + INFO/SCRIPTS/PREUN) rpm -qp --qf "%{RPMTAG_PREUN}\n" "$1" >"$3"; exit 0;; + INFO/SCRIPTS/POSTUN) rpm -qp --qf "%{RPMTAG_POSTUN}\n" "$1" >"$3"; exit 0;; + INFO/SCRIPTS/VERIFYSCRIPT) rpm -qp --qf "%{VERIFYSCRIPT}\n" "$1" >"$3"; exit 0;; + INFO/SCRIPTS/ALL) rpm -qp --scripts "$1" > "$3"; exit 0;; + INFO/SUMMARY) rpm -qp --qf "%{SUMMARY}\n" "$1" > "$3"; exit 0;; + INFO/OS) rpm -qp --qf "%{OS}\n" "$1" > "$3"; exit 0;; + INFO/CHANGELOG) rpm -qp --qf "[* %{CHANGELOGTIME:date} %{CHANGELOGNAME}\n%{CHANGELOGTEXT}\n\n]\n" "$1" > "$3"; exit 0;; + INFO/SIZE) rpm -qp --qf "%{SIZE} bytes\n" "$1" > "$3"; exit 0;; *) TMPDIR=/tmp/mctmpdir.$$ -# FIXME: TMP RACE - if mkdir fails, we go there, anyway - mkdir $TMPDIR + mkdir $TMPDIR || exit 1 cd $TMPDIR - rpm2cpio $1 | cpio -iumd --quiet $2 >/dev/null - mv $2 $3 + rpm2cpio "$1" | cpio -iumd --quiet "$2" >/dev/null + mv "$2" "$3" cd / rm -rf $TMPDIR;; esac @@ -155,8 +153,8 @@ mcrpmfs_copyout () mcrpmfs_run () { case "$2" in - INSTALL) echo "Installing $1"; rpm -ivh $1; exit 0;; - UPGRADE) echo "Upgrading $1"; rpm -iUvh $1; exit 0;; + INSTALL) echo "Installing \"$1\""; rpm -ivh "$1"; exit 0;; + UPGRADE) echo "Upgrading \"$1\""; rpm -iUvh "$1"; exit 0;; esac } @@ -165,8 +163,8 @@ LC_ALL=C export LC_ALL case "$1" in - list) mcrpmfs_list $2; exit 0;; - copyout) mcrpmfs_copyout $2 $3 $4; exit 0;; - run) mcrpmfs_run $2 $3; exit 1;; + list) mcrpmfs_list "$2"; exit 0;; + copyout) mcrpmfs_copyout "$2" "$3" "$4"; exit 0;; + run) mcrpmfs_run "$2" "$3"; exit 1;; esac exit 1