aboutsummaryrefslogtreecommitdiffstats
path: root/scripts
diff options
context:
space:
mode:
authorFlorent Villard <warly@mandriva.com>2006-04-10 15:54:05 +0000
committerFlorent Villard <warly@mandriva.com>2006-04-10 15:54:05 +0000
commit644d2f982aeb403fea58f851fadf0c26508aa67d (patch)
tree70c53ed8b23287ed1a4b4877dca0fca64cddef0a /scripts
parent1697e7a5fce440e9785055360673f11413fda59b (diff)
downloadbootsplash-644d2f982aeb403fea58f851fadf0c26508aa67d.tar
bootsplash-644d2f982aeb403fea58f851fadf0c26508aa67d.tar.gz
bootsplash-644d2f982aeb403fea58f851fadf0c26508aa67d.tar.bz2
bootsplash-644d2f982aeb403fea58f851fadf0c26508aa67d.tar.xz
bootsplash-644d2f982aeb403fea58f851fadf0c26508aa67d.zip
handle initramfs initrd in make-boot-splash and remove-boot-splash
Diffstat (limited to 'scripts')
-rwxr-xr-xscripts/make-boot-splash27
-rw-r--r--scripts/remove-boot-splash18
2 files changed, 41 insertions, 4 deletions
diff --git a/scripts/make-boot-splash b/scripts/make-boot-splash
index 177005c..9bf64a0 100755
--- a/scripts/make-boot-splash
+++ b/scripts/make-boot-splash
@@ -45,12 +45,31 @@ if [[ -z $config ]];then
exit 1;
fi
-$splash_dir/scripts/remove-boot-splash $initrd_file
+# warly: we cannot use file command which is in /usr/bin/
+# initrd_type=`zcat /boot/initrd-2.6.14-2mdk.ramfs.img | file -`
-if [[ -x /sbin/splash ]]; then
- /sbin/splash -s -f $config >> $initrd_file
-fi
+if `/bin/zcat $initrd_file 2> /dev/null | /bin/cpio -t &> /dev/null`; then
+ tmp_dir=`mktemp -d`
+ pushd $tmp_dir &> /dev/null
+ /bin/zcat $initrd_file 2>/dev/null | /bin/cpio -id 2>/dev/null
+ if [[ -x /sbin/splash ]]; then
+ /sbin/splash -s -f $config > $tmp_dir/bootsplash
+ else
+ if [[ -f $tmp_dir/bootsplash ]]; then
+ rm -f $tmp_dir/bootsplash
+ fi
+ fi
+ /bin/find . -print | /bin/cpio -o 2> /dev/null | gzip -c > $initrd_file
+ popd &> /dev/null
+ rm -rf $tmp_dir
+else
+ $splash_dir/scripts/remove-boot-splash $initrd_file
+ if [[ -x /sbin/splash ]]; then
+ /sbin/splash -s -f $config >> $initrd_file
+ fi
+fi
+
if [ -z "$DURING_INSTALL" ]; then
$splash_dir/scripts/switch-themes -u
fi
diff --git a/scripts/remove-boot-splash b/scripts/remove-boot-splash
index e63c3b5..3ab7425 100644
--- a/scripts/remove-boot-splash
+++ b/scripts/remove-boot-splash
@@ -6,6 +6,24 @@ my $magic = 'BOOTSPL3';
my $buffer_size = 15;
my ($initrd) = @ARGV;
+
+# FIXME it must have a clear way to do that in perl
+if (!system("/bin/zcat $initrd 2> /dev/null | /bin/cpio -t &> /dev/null")) {
+ print STDERR "remove-boot-splash: initrd in initramfs format\n";
+ chomp(my $tmp_dir = `mktemp -d`);
+ chdir $tmp_dir;
+ system("/bin/zcat $initrd 2>/dev/null | /bin/cpio -id 2>/dev/null");
+ if (-f "$tmp_dir/bootsplash") {
+ unlink "$tmp_dir/bootsplash" or die "FATAL: removing of $tmp_dir/bootsplash failed";
+ print STDERR "remove-boot-splash: removing bootsplash from initrd\n";
+ system("/bin/find . -print | /bin/cpio -o 2> /dev/null | gzip -c > $initrd")
+ } else {
+ print STDERR "ERROR remove-boot-splash: bootsplash image not found in $initrd\n"
+ }
+ system("rm -rf $tmp_dir");
+ exit
+}
+
open(my $F, "+< $initrd") or die "can't open $initrd: $!\n";
while (1) {