mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-11 09:18:25 +03:00
Fix string parsing
Fix propagation of -e option - pass it via internal shell variable. Fix parsing of /proc/mounts files (don't check for substrings). as reported by O.Mangold with suggested patch: https://www.redhat.com/archives/linux-lvm/2012-February/msg00030.html Properly pass arguments with spaces ("$@") Add validation for YES and EXTOFF variable content.
This commit is contained in:
parent
3f5b1f651a
commit
de0e4e755a
@ -1,5 +1,8 @@
|
|||||||
Version 2.02.96 -
|
Version 2.02.96 -
|
||||||
================================
|
================================
|
||||||
|
Fix fsadm propagation of -e option.
|
||||||
|
Fix fsadm parsing of /proc/mounts files (don't check for substrings).
|
||||||
|
Fix fsadm usage of arguments with space.
|
||||||
Fix a regression in handling of lvchange/lvcreate --major/--minor.
|
Fix a regression in handling of lvchange/lvcreate --major/--minor.
|
||||||
Fix name conflicts that prevent down-converting RAID1 when specifying a device
|
Fix name conflicts that prevent down-converting RAID1 when specifying a device
|
||||||
Improve thin_check option passing and use configured path.
|
Improve thin_check option passing and use configured path.
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
#
|
#
|
||||||
# Copyright (C) 2007-2010 Red Hat, Inc. All rights reserved.
|
# Copyright (C) 2007-2012 Red Hat, Inc. All rights reserved.
|
||||||
#
|
#
|
||||||
# This file is part of LVM2.
|
# This file is part of LVM2.
|
||||||
#
|
#
|
||||||
@ -62,7 +62,7 @@ YES=${_FSADM_YES}
|
|||||||
DRY=0
|
DRY=0
|
||||||
VERB=
|
VERB=
|
||||||
FORCE=
|
FORCE=
|
||||||
EXTOFF=0
|
EXTOFF=${_FSADM_EXTOFF:-0}
|
||||||
DO_LVRESIZE=0
|
DO_LVRESIZE=0
|
||||||
FSTYPE=unknown
|
FSTYPE=unknown
|
||||||
VOLUME=unknown
|
VOLUME=unknown
|
||||||
@ -121,7 +121,7 @@ dry() {
|
|||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
verbose "Executing $@"
|
verbose "Executing $@"
|
||||||
$@
|
"$@"
|
||||||
}
|
}
|
||||||
|
|
||||||
cleanup() {
|
cleanup() {
|
||||||
@ -141,7 +141,8 @@ cleanup() {
|
|||||||
# start LVRESIZE with the filesystem modification flag
|
# start LVRESIZE with the filesystem modification flag
|
||||||
# and allow recursive call of fsadm
|
# and allow recursive call of fsadm
|
||||||
_FSADM_YES=$YES
|
_FSADM_YES=$YES
|
||||||
export _FSADM_YES
|
_FSADM_EXTOFF=$EXTOFF
|
||||||
|
export _FSADM_YES _FSADM_EXTOFF
|
||||||
unset FSADM_RUNNING
|
unset FSADM_RUNNING
|
||||||
test -n "$LVM_BINARY" && PATH=$_SAVEPATH
|
test -n "$LVM_BINARY" && PATH=$_SAVEPATH
|
||||||
dry exec "$LVM" lvresize $VERB $FORCE -r -L${NEWSIZE}b "$VOLUME_ORIG"
|
dry exec "$LVM" lvresize $VERB $FORCE -r -L${NEWSIZE}b "$VOLUME_ORIG"
|
||||||
@ -200,10 +201,10 @@ detect_fs() {
|
|||||||
detect_mounted() {
|
detect_mounted() {
|
||||||
test -e "$PROCMOUNTS" || error "Cannot detect mounted device \"$VOLUME\""
|
test -e "$PROCMOUNTS" || error "Cannot detect mounted device \"$VOLUME\""
|
||||||
|
|
||||||
MOUNTED=$("$GREP" ^"$VOLUME" "$PROCMOUNTS")
|
MOUNTED=$("$GREP" "^$VOLUME[ \t]" "$PROCMOUNTS")
|
||||||
|
|
||||||
# for empty string try again with real volume name
|
# for empty string try again with real volume name
|
||||||
test -z "$MOUNTED" && MOUNTED=$("$GREP" ^"$RVOLUME" "$PROCMOUNTS")
|
test -z "$MOUNTED" && MOUNTED=$("$GREP" "^$RVOLUME[ \t]" "$PROCMOUNTS")
|
||||||
|
|
||||||
# cut device name prefix and trim everything past mountpoint
|
# cut device name prefix and trim everything past mountpoint
|
||||||
# echo translates \040 to spaces
|
# echo translates \040 to spaces
|
||||||
@ -212,8 +213,8 @@ detect_mounted() {
|
|||||||
|
|
||||||
# for systems with different device names - check also mount output
|
# for systems with different device names - check also mount output
|
||||||
if test -z "$MOUNTED" ; then
|
if test -z "$MOUNTED" ; then
|
||||||
MOUNTED=$(LANG=C "$MOUNT" | "$GREP" ^"$VOLUME")
|
MOUNTED=$(LANG=C "$MOUNT" | "$GREP" "^$VOLUME[ \t]")
|
||||||
test -z "$MOUNTED" && MOUNTED=$(LANG=C "$MOUNT" | "$GREP" ^"$RVOLUME")
|
test -z "$MOUNTED" && MOUNTED=$(LANG=C "$MOUNT" | "$GREP" "^$RVOLUME[ \t]")
|
||||||
MOUNTED=${MOUNTED##* on }
|
MOUNTED=${MOUNTED##* on }
|
||||||
MOUNTED=${MOUNTED% type *} # allow type in the mount name
|
MOUNTED=${MOUNTED% type *} # allow type in the mount name
|
||||||
fi
|
fi
|
||||||
@ -484,6 +485,9 @@ do
|
|||||||
shift
|
shift
|
||||||
done
|
done
|
||||||
|
|
||||||
|
test "$YES" = "-y" || YES=
|
||||||
|
test "$EXTOFF" -eq 1 || EXTOFF=0
|
||||||
|
|
||||||
if [ -n "$CHECK" ]; then
|
if [ -n "$CHECK" ]; then
|
||||||
check "$CHECK"
|
check "$CHECK"
|
||||||
elif [ -n "$RESIZE" ]; then
|
elif [ -n "$RESIZE" ]; then
|
||||||
|
Loading…
Reference in New Issue
Block a user