Oops. Commit the changes corresponding to this ChangeLog entry:
* util/update-grub_lib.in (convert_system_path_to_grub_path): Split code to make path relative to its root into a separate function. * util/i386/pc/grub-install.in: Use newly provided make_system_path_relative_to_its_root() to convert ${grubdir}, then pass the result to grub-install --prefix. that I forgot to apply before.
This commit is contained in:
parent
ba50d28f33
commit
73167f1dc5
2 changed files with 54 additions and 14 deletions
|
@ -46,6 +46,9 @@ force_lba=
|
|||
recheck=no
|
||||
debug=no
|
||||
|
||||
# for make_system_path_relative_to_its_root()
|
||||
. ${libdir}/grub/update-grub_lib
|
||||
|
||||
# Usage: usage
|
||||
# Print the usage.
|
||||
usage () {
|
||||
|
@ -227,7 +230,7 @@ fi
|
|||
# _chain is often useful
|
||||
modules="$modules $fs_module $partmap_module _chain"
|
||||
|
||||
$grub_mkimage --output=${grubdir}/core.img $modules || exit 1
|
||||
$grub_mkimage --output=${grubdir}/core.img --prefix=`make_system_path_relative_to_its_root ${grubdir}` $modules || exit 1
|
||||
|
||||
# Now perform the installation.
|
||||
$grub_setup --directory=${grubdir} --device-map=${device_map} \
|
||||
|
|
|
@ -17,38 +17,75 @@
|
|||
|
||||
transform="@program_transform_name@"
|
||||
|
||||
prefix=@prefix@
|
||||
exec_prefix=@exec_prefix@
|
||||
sbindir=@sbindir@
|
||||
|
||||
grub_probe=${sbindir}/`echo grub-probe | sed ${transform}`
|
||||
|
||||
convert_system_path_to_grub_path ()
|
||||
make_system_path_relative_to_its_root ()
|
||||
{
|
||||
dir=$1
|
||||
# Abort if file doesn't exist
|
||||
test -e $dir
|
||||
dir=`readlink -f $dir`
|
||||
|
||||
drive=`${grub_probe} -t drive $dir`
|
||||
if [ "x$drive" = "x" ] ; then
|
||||
path=$1
|
||||
# abort if file doesn't exist
|
||||
if test -e $path ; then : ;else
|
||||
return 1
|
||||
fi
|
||||
|
||||
# Abort if file is in a filesystem we can't read
|
||||
${grub_probe} -t fs $dir > /dev/null 2>&1
|
||||
# canonicalize
|
||||
if path=`readlink -f $path` ; then : ; else
|
||||
return 1
|
||||
fi
|
||||
|
||||
# if not a directory, climb up to the directory containing it
|
||||
if test -d $path ; then
|
||||
dir=$path
|
||||
else
|
||||
dir=`echo $path | sed -e "s,/[^/]*$,,g"`
|
||||
fi
|
||||
|
||||
num=`stat -c %d $dir`
|
||||
relative_path=""
|
||||
|
||||
# this loop sets $dir to the root directory of the filesystem we're inspecting
|
||||
while : ; do
|
||||
parent=`echo $dir | sed -e "s,/[^/]*$,,g" -e "s,^$,/,g"`
|
||||
parent=`readlink -f $dir/..`
|
||||
if [ "x`stat -c %d $parent`" = "x$num" ] ; then : ; else
|
||||
# $parent is another filesystem; we found it.
|
||||
break
|
||||
fi
|
||||
if [ "x$dir" = "x/" ] ; then
|
||||
# / is our root.
|
||||
break
|
||||
fi
|
||||
relative_path=`echo $dir | sed -e "s,^.*/,/,g"`$relative_path
|
||||
dir=$parent
|
||||
done
|
||||
|
||||
echo $path | sed -e "s,^$dir,/,g" -e "s,//,/,g"
|
||||
}
|
||||
|
||||
convert_system_path_to_grub_path ()
|
||||
{
|
||||
path=$1
|
||||
|
||||
# abort if file doesn't exist
|
||||
if test -e $path ; then : ;else
|
||||
return 1
|
||||
fi
|
||||
|
||||
# abort if file is in a filesystem we can't read
|
||||
if ${grub_probe} -t fs $path > /dev/null 2>&1 ; then : ; else
|
||||
return 1
|
||||
fi
|
||||
|
||||
if drive=`${grub_probe} -t drive $path` ; then : ; else
|
||||
return 1
|
||||
fi
|
||||
|
||||
if relative_path=`make_system_path_relative_to_its_root $path` ; then : ; else
|
||||
return 1
|
||||
fi
|
||||
|
||||
# remove any trailing slash, even if that slash is everything we have
|
||||
relative_path=`echo ${relative_path} | sed -e "s,/*$,,g"`
|
||||
|
||||
echo ${drive}${relative_path}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue