diff options
author | Tomas Chvatal <scarabeus@gentoo.org> | 2011-10-04 18:23:19 +0000 |
---|---|---|
committer | Tomas Chvatal <scarabeus@gentoo.org> | 2011-10-04 18:23:19 +0000 |
commit | 66ed4eed8e02bdd45c7dc165bb5e2aedf2399238 (patch) | |
tree | b8f6f88e2f0d7944bde76909be382e795752d6d1 /sys-boot/grub | |
parent | Stable for HPPA (bug #355085). (diff) | |
download | gentoo-2-66ed4eed8e02bdd45c7dc165bb5e2aedf2399238.tar.gz gentoo-2-66ed4eed8e02bdd45c7dc165bb5e2aedf2399238.tar.bz2 gentoo-2-66ed4eed8e02bdd45c7dc165bb5e2aedf2399238.zip |
Include option to prompt for grub1 configuration. Thanks to Robert Trace rtrace{at}farcaster.org for the patch.
(Portage version: 2.2.0_alpha60/cvs/Linux x86_64)
Diffstat (limited to 'sys-boot/grub')
-rw-r--r-- | sys-boot/grub/ChangeLog | 7 | ||||
-rw-r--r-- | sys-boot/grub/grub-1.99-r2.ebuild | 75 | ||||
-rw-r--r-- | sys-boot/grub/grub-9999.ebuild | 75 |
3 files changed, 104 insertions, 53 deletions
diff --git a/sys-boot/grub/ChangeLog b/sys-boot/grub/ChangeLog index c84676626967..3165d221d9df 100644 --- a/sys-boot/grub/ChangeLog +++ b/sys-boot/grub/ChangeLog @@ -1,6 +1,11 @@ # ChangeLog for sys-boot/grub # Copyright 1999-2011 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/sys-boot/grub/ChangeLog,v 1.168 2011/10/03 09:10:13 scarabeus Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-boot/grub/ChangeLog,v 1.169 2011/10/04 18:23:19 scarabeus Exp $ + + 04 Oct 2011; Tomáš Chvátal <scarabeus@gentoo.org> grub-1.99-r2.ebuild, + grub-9999.ebuild: + Include option to prompt for grub1 configuration. Thanks to Robert Trace + rtrace{at}farcaster.org for the patch. 03 Oct 2011; Tomáš Chvátal <scarabeus@gentoo.org> grub-1.99-r2.ebuild, grub-9999.ebuild: diff --git a/sys-boot/grub/grub-1.99-r2.ebuild b/sys-boot/grub/grub-1.99-r2.ebuild index 846e65dff81b..e83dd270524d 100644 --- a/sys-boot/grub/grub-1.99-r2.ebuild +++ b/sys-boot/grub/grub-1.99-r2.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2011 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/sys-boot/grub/grub-1.99-r2.ebuild,v 1.4 2011/10/03 09:10:13 scarabeus Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-boot/grub/grub-1.99-r2.ebuild,v 1.5 2011/10/04 18:23:19 scarabeus Exp $ EAPI=4 @@ -187,7 +187,7 @@ src_prepare() { use grub_platforms_${i} && GRUB_ENABLED_PLATFORMS+=" ${i}" done [[ -z ${GRUB_ENABLED_PLATFORMS} ]] && GRUB_ENABLED_PLATFORMS="guessed" - einfo "Going to build following platforms: ${GRUB_ENABLED_PLATFORMS}" + elog "Going to build following platforms: ${GRUB_ENABLED_PLATFORMS}" } src_configure() { @@ -246,43 +246,66 @@ src_install() { GRUB_DISTRIBUTOR="Gentoo" EOF - elog "Remember to run emerge --config =${CATEGORY}/${PF} in order" - elog "to set up basic settings for this package." -} - -setup_boot_dir() { - local dir=$1 + elog + elog "To configure GRUB 2, check the defaults in /etc/default/grub and" + elog "then run 'emerge --config =${CATEGORY}/${PF}'." # display the link to guide + show_doc_url +} + +show_doc_url() { + elog elog "For informations how to configure grub-2 please refer to the guide:" elog " http://dev.gentoo.org/~scarabeus/grub-2-guide.xml" +} + +setup_boot_dir() { + local dir=$1 + local use_legacy='n' # Make sure target directory exists mkdir -p "${dir}" - if [[ ! -e ${dir}/grub.cfg && -e ${dir/2/}/menu.lst ]] ; then - # This is first grub2 install and we have old configuraton for - # grub1 around. Lets try to generate grub.cfg from it so user - # does not loose any stuff when rebooting. - # NOTE: in long term he still NEEDS to migrate to grub.d stuff. - einfo "Running: grub2-menulst2cfg '${dir/2/}/menu.lst' '${dir}/grub.cfg'" - grub2-menulst2cfg "${dir/2/}/menu.lst" "${dir}/grub.cfg" || \ - ewarn "Running grub2-menulst2cfg failed!" + if [[ -e ${dir/2/}/menu.lst ]] ; then + # Legacy config exists, ask user what to do + einfo "Found legacy GRUB configuration. Do you want to convert it" + einfo "instead of using autoconfig (y/N)?" + read use_legacy + + use_legacy=${use_legacy,,[A-Z]} + fi + + if [[ ${use_legacy} == y* ]] ; then + grub1_cfg=${dir/2/}/menu.lst + grub2_cfg=${dir}/grub.cfg + + # GRUB legacy configuration exists. Use it instead of doing + # our normal autoconfigure. + # + + einfo "Converting legacy config at '${grub1_cfg}' for use by GRUB2." + ebegin "Running: grub2-menulst2cfg '${grub1_cfg}' '${grub2_cfg}'" + grub2-menulst2cfg "${grub1_cfg}" "${grub2_cfg}" &> /dev/null + eend $? - einfo "Even if we just created configuration for your grub2 using old" - einfo "grub-legacy configuration file you should migrate to use new style" - einfo "configuration in '${ROOT}/etc/grub.d' and '${ROOT}/etc/defaults/grub'." - einfo + ewarn + ewarn "Even though the conversion above succeeded, you are STRONGLY" + ewarn "URGED to upgrade to the new GRUB2 configuration format." + # Remind the user about the documentation + show_doc_url else - # we need to refresh the grub.cfg everytime just to play it safe - einfo "Running: grub2-mkconfig -o '${dir}/grub.cfg'" - grub2-mkconfig -o "${dir}/grub.cfg" || \ - ewarn "Running grub2-mkconfig failed! Check your configuration files!" + # Run GRUB 2 autoconfiguration + einfo "Running GRUB 2 autoconfiguration." + ebegin "grub2-mkconfig -o '${dir}/grub.cfg'" + grub2-mkconfig -o "${dir}/grub.cfg" &> /dev/null + eend $? fi - elog "Remember to run grub2-install to install your grub every time" - elog "you update this package!" + einfo + einfo "Remember to run grub2-install to activate GRUB2 as your default" + einfo "bootloader." } pkg_config() { diff --git a/sys-boot/grub/grub-9999.ebuild b/sys-boot/grub/grub-9999.ebuild index d9d99c5c7465..c5cc7d7a546a 100644 --- a/sys-boot/grub/grub-9999.ebuild +++ b/sys-boot/grub/grub-9999.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2011 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/sys-boot/grub/grub-9999.ebuild,v 1.43 2011/10/03 09:10:13 scarabeus Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-boot/grub/grub-9999.ebuild,v 1.44 2011/10/04 18:23:19 scarabeus Exp $ EAPI=4 @@ -183,7 +183,7 @@ src_prepare() { use grub_platforms_${i} && GRUB_ENABLED_PLATFORMS+=" ${i}" done [[ -z ${GRUB_ENABLED_PLATFORMS} ]] && GRUB_ENABLED_PLATFORMS="guessed" - einfo "Going to build following platforms: ${GRUB_ENABLED_PLATFORMS}" + elog "Going to build following platforms: ${GRUB_ENABLED_PLATFORMS}" } src_configure() { @@ -242,43 +242,66 @@ src_install() { GRUB_DISTRIBUTOR="Gentoo" EOF - elog "Remember to run emerge --config =${CATEGORY}/${PF} in order" - elog "to set up basic settings for this package." -} - -setup_boot_dir() { - local dir=$1 + elog + elog "To configure GRUB 2, check the defaults in /etc/default/grub and" + elog "then run 'emerge --config =${CATEGORY}/${PF}'." # display the link to guide + show_doc_url +} + +show_doc_url() { + elog elog "For informations how to configure grub-2 please refer to the guide:" elog " http://dev.gentoo.org/~scarabeus/grub-2-guide.xml" +} + +setup_boot_dir() { + local dir=$1 + local use_legacy='n' # Make sure target directory exists mkdir -p "${dir}" - if [[ ! -e ${dir}/grub.cfg && -e ${dir/2/}/menu.lst ]] ; then - # This is first grub2 install and we have old configuraton for - # grub1 around. Lets try to generate grub.cfg from it so user - # does not loose any stuff when rebooting. - # NOTE: in long term he still NEEDS to migrate to grub.d stuff. - einfo "Running: grub2-menulst2cfg '${dir/2/}/menu.lst' '${dir}/grub.cfg'" - grub2-menulst2cfg "${dir/2/}/menu.lst" "${dir}/grub.cfg" || \ - ewarn "Running grub2-menulst2cfg failed!" + if [[ -e ${dir/2/}/menu.lst ]] ; then + # Legacy config exists, ask user what to do + einfo "Found legacy GRUB configuration. Do you want to convert it" + einfo "instead of using autoconfig (y/N)?" + read use_legacy + + use_legacy=${use_legacy,,[A-Z]} + fi + + if [[ ${use_legacy} == y* ]] ; then + grub1_cfg=${dir/2/}/menu.lst + grub2_cfg=${dir}/grub.cfg + + # GRUB legacy configuration exists. Use it instead of doing + # our normal autoconfigure. + # + + einfo "Converting legacy config at '${grub1_cfg}' for use by GRUB2." + ebegin "Running: grub2-menulst2cfg '${grub1_cfg}' '${grub2_cfg}'" + grub2-menulst2cfg "${grub1_cfg}" "${grub2_cfg}" &> /dev/null + eend $? - einfo "Even if we just created configuration for your grub2 using old" - einfo "grub-legacy configuration file you should migrate to use new style" - einfo "configuration in '${ROOT}/etc/grub.d' and '${ROOT}/etc/defaults/grub'." - einfo + ewarn + ewarn "Even though the conversion above succeeded, you are STRONGLY" + ewarn "URGED to upgrade to the new GRUB2 configuration format." + # Remind the user about the documentation + show_doc_url else - # we need to refresh the grub.cfg everytime just to play it safe - einfo "Running: grub2-mkconfig -o '${dir}/grub.cfg'" - grub2-mkconfig -o "${dir}/grub.cfg" || \ - ewarn "Running grub2-mkconfig failed! Check your configuration files!" + # Run GRUB 2 autoconfiguration + einfo "Running GRUB 2 autoconfiguration." + ebegin "grub2-mkconfig -o '${dir}/grub.cfg'" + grub2-mkconfig -o "${dir}/grub.cfg" &> /dev/null + eend $? fi - elog "Remember to run grub2-install to install your grub every time" - elog "you update this package!" + einfo + einfo "Remember to run grub2-install to activate GRUB2 as your default" + einfo "bootloader." } pkg_config() { |