Remove unneeded files for broken grub code

cleanup-cruft
agaffney 17 years ago
parent 6e47f147d8
commit 0a98792990

@ -2,6 +2,10 @@
# Copyright 1999-2008 Gentoo Foundation; 2008 Chris Gianelloni # Copyright 1999-2008 Gentoo Foundation; 2008 Chris Gianelloni
# Distributed under the GPL v2 # Distributed under the GPL v2
21 Aug 2008; Andrew Gaffney <agaffney@gentoo.org> -gen_bootloader.sh,
-gen_bootloader_grub.awk:
Remove unneeded files for broken grub code
21 Aug 2008; Andrew Gaffney <agaffney@gentoo.org> gen_cmdline.sh, 21 Aug 2008; Andrew Gaffney <agaffney@gentoo.org> gen_cmdline.sh,
gen_determineargs.sh, genkernel, genkernel.conf: gen_determineargs.sh, genkernel, genkernel.conf:
Remove broken grub code Remove broken grub code

@ -1,94 +0,0 @@
#!/bin/bash
set_bootloader() {
if [ "x${BOOTLOADER}" == 'xgrub' ]
then
set_grub_bootloader
else
return 0
fi
}
set_grub_bootloader() {
local GRUB_CONF="${BOOTDIR}/grub/grub.conf"
print_info 1 ''
print_info 1 "Adding kernel to ${GRUB_CONF}..."
if [ "${BOOTFS}" != '' ]
then
GRUB_BOOTFS=${BOOTFS}
else
# Extract block device information from /etc/fstab
GRUB_ROOTFS=$(awk 'BEGIN{RS="((#[^\n]*)?\n)"}( $2 == "/" ) { print $1; exit }' /etc/fstab)
GRUB_BOOTFS=$(awk 'BEGIN{RS="((#[^\n]*)?\n)"}( $2 == "'${BOOTDIR}'") { print $1; exit }' /etc/fstab)
# If ${BOOTDIR} is not defined in /etc/fstab, it must be the same as /
[ "x${GRUB_BOOTFS}" == 'x' ] && GRUB_BOOTFS=${GRUB_ROOTFS}
fi
# Read GRUB device map
[ ! -d ${TEMP} ] && mkdir ${TEMP}
grub --batch --device-map=${TEMP}/grub.map <<EOF >/dev/null 2>&1
quit
EOF
# Get the GRUB mapping for our device
local GRUB_BOOT_DISK1=$(echo ${GRUB_BOOTFS} | sed -e 's#\(/dev/.\+\)[[:digit:]]\+#\1#')
local GRUB_BOOT_DISK=$(awk '{if ($2 == "'${GRUB_BOOT_DISK1}'") {gsub(/(\(|\))/, "", $1); print $1;}}' ${TEMP}/grub.map)
local GRUB_BOOT_PARTITION=$(echo ${GRUB_BOOTFS} | sed -e 's#/dev/.\+\([[:digit:]]?*\)#\1#')
[ ! -d ${TEMP} ] && rm -r ${TEMP}
# Create grub configuration directory and file if it doesn't exist.
[ ! -e `dirname ${GRUB_CONF}` ] && mkdir -p `dirname ${GRUB_CONF}`
if [ ! -e ${GRUB_CONF} ]
then
if [ "${GRUB_BOOT_DISK}" != '' -a "${GRUB_BOOT_PARTITION}" != '' ]
then
GRUB_BOOT_PARTITION=`expr ${GRUB_BOOT_PARTITION} - 1`
# grub.conf doesn't exist - create it with standard defaults
touch ${GRUB_CONF}
echo 'default 0' >> ${GRUB_CONF}
echo 'timeout 5' >> ${GRUB_CONF}
echo >> ${GRUB_CONF}
# Add grub configuration to grub.conf
echo "# Genkernel generated entry, see GRUB documentation for details" >> ${GRUB_CONF}
echo "title=Gentoo Linux ($KV)" >> ${GRUB_CONF}
echo -e "\troot (${GRUB_BOOT_DISK},${GRUB_BOOT_PARTITION})" >> ${GRUB_CONF}
if [ "${BUILD_RAMDISK}" -eq '0' ]
then
echo -e "\tkernel /kernel-${KNAME}-${ARCH}-${KV} root=${GRUB_ROOTFS}" >> ${GRUB_CONF}
else
echo -e "\tkernel /kernel-${KNAME}-${ARCH}-${KV} root=/dev/ram0 init=/linuxrc real_root=${GRUB_ROOTFS}" >> ${GRUB_CONF}
echo -e "\tinitrd /initramfs-${KNAME}-${ARCH}-${KV}" >> ${GRUB_CONF}
fi
echo >> ${GRUB_CONF}
else
print_error 1 "Error! ${BOOTDIR}/grub/grub.conf does not exist and the correct settings can not be automatically detected."
print_error 1 "Please manually create your ${BOOTDIR}/grub/grub.conf file."
fi
else
# grub.conf already exists; so...
# ... Clone the first boot definition and change the version.
local TYPE='ramfs'
cp -f ${GRUB_CONF} ${GRUB_CONF}.bak
awk 'BEGIN { RS="\n"; }
{
if(match($0, "kernel-" KNAME "-" ARCH "-" KV))
{ have_k="1" }
if(match($0, "init" TYPE "-" KNAME "-" ARCH "-" KV))
{ have_i="1" }
if(have_k == "1" && have_i == "1")
{ exit 1; }
}' KNAME=${KNAME} ARCH=${ARCH} KV=${KV} TYPE=${TYPE} ${GRUB_CONF}.bak
if [ "$?" -eq '0' ]
then
local LIMIT=$(wc -l ${GRUB_CONF}.bak)
awk -f ${GK_SHARE}/gen_bootloader_grub.awk LIMIT=${LIMIT/ */} KNAME=${KNAME} ARCH=${ARCH} KV=${KV} TYPE=${TYPE} ${GRUB_CONF}.bak > ${GRUB_CONF}
else
print_info 1 "GRUB: Definition found, not duplicating."
fi
fi
}

@ -1,84 +0,0 @@
BEGIN { RS="\n"; FS=""; OFS=""; ORS=""; state="0"; }
{
if(state == "0")
{
if (match($0, /^title=/) || match($0, /^title */))
{
state = "1";
ORIG = ORIG $0 "\n";
next;
} else {
if(match($0, /^[[:space:]]*#/))
ORIG = ORIG $0 "\n";
extraA = extraA $0 "\n";
}
}
if(state == "1")
{
if(match($0, /^[[:space:]]*kernel /))
{
ORIG = ORIG $0 "\n";
i = 0;
have_k = "1";
my_kernel = $0;
sub(/kernel-[[:alnum:][:punct:]]+/, "kernel-" KNAME "-" ARCH "-" KV, my_kernel);
} else {
if(match($0, /^[[:space:]]*initrd /))
{
ORIG = ORIG $0 "\n";
i = 0;
extraC = extraC commentLookahead;
have_i = "1";
my_initrd = "\n" $0;
sub(/initr(d|amfs)-[[:alnum:][:punct:]]+/, "init" TYPE "-" KNAME "-" ARCH "-" KV, my_initrd);
} else {
if($0 == "\n")
next;
ORIG = ORIG $0 "\n";
if(match($0, /^[[:space:]]*#/))
{
i = 1;
if(commentLookahead)
commentLookahead = commentLookahead "\n" $0;
else
commentLookahead = $0;
next;
}
if(!(match($0, /^title=/) || match($0, /^title */) ))
{
i = 0;
commentLookahead = "";
if(have_k != "1")
extraB = extraB commentLookahead $0 "\n";
else
{
if(have_i != "1")
extraC = extraC commentLookahead $0 "\n";
else
extraD = extraD commentLookahead $0 "\n";
}
}
}
}
if(have_k == "1" && ((match($0, /^title=/) || match($0, /^title */)) || NR == LIMIT))
{
state = "2";
print extraA "title=Gentoo Linux (" KV ")\n";
print extraB my_kernel;
if(extraC)
print "\n" extraC;
print my_initrd extraD "\n";
if(i == 0)
print commentLookahead;
print ORIG;
next;
}
}
if(state == "2")
print $0 "\n";
}
Loading…
Cancel
Save