From a2b053d8bdd3fe4f1e661b476b9820422f5e4299 Mon Sep 17 00:00:00 2001 From: linggao Date: Fri, 19 Mar 2010 21:12:56 +0000 Subject: [PATCH] added support for #INCLUDE tag in pkglist file git-svn-id: https://svn.code.sf.net/p/xcat/code/xcat-core/trunk@5537 8638fb3e-16cb-4fca-ae20-7b5d299a9bcd --- xCAT-server/share/xcat/netboot/rh/genimage | 134 ++++++----------- xCAT-server/share/xcat/netboot/sles/genimage | 145 ++++++------------- 2 files changed, 90 insertions(+), 189 deletions(-) diff --git a/xCAT-server/share/xcat/netboot/rh/genimage b/xCAT-server/share/xcat/netboot/rh/genimage index 645ec7535..4328b3722 100755 --- a/xCAT-server/share/xcat/netboot/rh/genimage +++ b/xCAT-server/share/xcat/netboot/rh/genimage @@ -228,42 +228,44 @@ unless ($onlyinitrd) { mkpath("$rootimg_dir/var/lib/yum"); if (!$imagename) { - $pkglist= get_pkglist_file_name($customdir); + $pkglist= get_profile_def_filename($customdir, "pkglist"); if (!$pkglist) { - $pkglist= get_pkglist_file_name($pathtofiles); + $pkglist= get_profile_def_filename($pathtofiles, "pkglist"); } } - print "pkglist=$pkglist\n"; if (!$pkglist) { print "Unable to find package list for $profile!"; exit 1; } - open($yumconfig,"<","$pkglist"); - while (<$yumconfig>) { - chomp; - $yumcmd .= $_ . " "; + my %pkg_hash=get_package_names($pkglist); + my $index=1; + foreach (keys(%pkg_hash)) { + if (($_ eq "PRE_REMOVE") || ($_ eq "POST_REMOVE")) { next;} + my $pa=$pkg_hash{$_}; + $pkgnames .= " " . join(' ', @$pa); } - close($yumconfig); - $yumcmd =~ s/ $/\n/; - - #debug - #print "yumcmd=$yumcmd\n"; - #my $repo=`cat /tmp/genimage.$$.yum.conf`; - #print "repo=$repo"; - my $rc = system($yumcmd); + print "$yumcmd $pkgnames\n"; + my $rc = system("$yumcmd $pkgnames"); if ($rc) { print "yum invocation failed\n"; exit 1; } #Now let's handle extra packages - my %extra_hash=get_extra_package_names(); - my $extrapkgnames; + if (!$imagename) { + $otherpkglist=get_profile_def_filename($customdir, "otherpkgs.pkglist"); + if (!$otherpkglist) { $otherpkglist=get_profile_def_filename($pathtofiles, "otherpkgs.pkglist"); } + } + my %extra_hash=(); + if ($otherpkglist) { + %extra_hash=get_package_names($otherpkglist); + } + my $extrapkgnames; - if (keys(%extra_hash) > 0) { + if (keys(%extra_hash) > 0) { open($yumconfig,">>","/tmp/genimage.$$.yum.conf"); my $index=1; foreach (keys(%extra_hash)) { @@ -289,6 +291,7 @@ unless ($onlyinitrd) { my $pa=$extra_hash{'PRE_REMOVE'}; my $rm_packges= join(' ', @$pa); if ($rm_packges) { + print "$yumcmd_remove $rm_packges\n"; $rc = system("$yumcmd_remove $rm_packges"); } } @@ -304,7 +307,7 @@ unless ($onlyinitrd) { $yumcmd =~ s/ $/\n/; #debug - #print "yumcmd=$yumcmd\n"; + print "yumcmd=$yumcmd\n"; #my $repo=`cat /tmp/genimage.$$.yum.conf`; #print "repo=$repo"; @@ -319,6 +322,7 @@ unless ($onlyinitrd) { my $pa=$extra_hash{'POST_REMOVE'}; my $rm_packges= join(' ', @$pa); if ($rm_packges) { + print "$yumcmd_remove $rm_packges\n"; $rc = system("$yumcmd_remove $rm_packges"); } } @@ -354,9 +358,9 @@ unlink "/tmp/genimage.$$.yum.conf"; #-- run postinstall script if (!$imagename) { - $postinstall_filename= get_postinstall_file_name($customdir); + $postinstall_filename= get_profile_def_filename($customdir, "postinstall"); if (!$postinstall_filename) { - $postinstall_filename= get_postinstall_file_name($pathtofiles); + $postinstall_filename= get_profile_def_filename($pathtofiles, "postinstall"); } } @@ -1082,21 +1086,15 @@ sub generic_post { #This function is meant to leave the image in a state approxi rename(<$rootimg_dir/boot/vmlinuz*>,"$destdir/kernel"); } -#get th extra package name -sub get_extra_package_names { - if (!$imagename) { - $otherpkglist=get_extra_pkglist_file_name($customdir); - if (!$otherpkglist) { $otherpkglist=get_extra_pkglist_file_name($pathtofiles); } - } - - #print "customdir=$customdir,pathtofiles=$pathtofiles,otherpkglist=$otherpkglist\n"; +sub get_package_names { + my $plist_file_name=shift; my %pkgnames=(); my @tmp_array=(); - if ($otherpkglist) { + if ($plist_file_name) { my $pkgfile; - open($pkgfile,"<","$otherpkglist"); + open($pkgfile,"<","$plist_file_name"); while (<$pkgfile>) { chomp; s/\s+$//; #remove trailing white spaces @@ -1109,7 +1107,7 @@ sub get_extra_package_names { my $pkgtext=join(',',@tmp_array); #handle the #INLCUDE# tag recursively - my $idir = dirname($otherpkglist); + my $idir = dirname($plist_file_name); my $doneincludes=0; while (not $doneincludes) { $doneincludes=1; @@ -1173,64 +1171,28 @@ sub include_file } -sub get_extra_pkglist_file_name { + +sub get_profile_def_filename { my $base=shift; - if (-r "$base/$profile.$osver.$arch.otherpkgs.pkglist") { - return "$base/$profile.$osver.$arch.otherpkgs.pkglist"; - } elsif (-r "$base/$profile.$arch.otherpkgs.pkglist") { - return "$base/$profile.$arch.otherpkgs.pkglist"; - } elsif (-r "$base/$profile.$osver.otherpkgs.pkglist") { - return "$base/$profile.$osver.otherpkgs.pkglist"; - } elsif (-r "$base/$profile.otherpkgs.pkglist") { - return "$base/$profile.otherpkgs.pkglist"; - } - return ""; -} - -sub get_pkglist_file_name { - my $base=shift; - if (-r "$base/$profile.$osver.$arch.pkglist") { - return "$base/$profile.$osver.$arch.pkglist"; - } elsif (-r "$base/$profile.$arch.pkglist") { - return "$base/$profile.$arch.pkglist"; - } elsif (-r "$base/$profile.$osver.pkglist") { - return "$base/$profile.$osver.pkglist"; - } elsif (-r "$base/$profile.pkglist") { - return "$base/$profile.pkglist"; - } - return ""; -} - -sub get_rwfiles_file_name { - my $base=shift; - if (-r "$base/$profile.$osver.$arch.rwfiles") { - return "$base/$profile.$osver.$arch.rwfiles"; - } elsif (-r "$base/$profile.$arch.rwfiles") { - return "$base/$profile.$arch.rwfiles"; - } elsif (-r "$base/$profile.$osver.rwfiles") { - return "$base/$profile.$osver.rwfiles"; - } elsif (-r "$base/$profile.rwfiles") { - return "$base/$profile.rwfiles"; - } - return ""; -} - - - - -sub get_postinstall_file_name { - my $base=shift; - if (-x "$base/$profile.$osver.$arch.postinstall") { - return "$base/$profile.$osver.$arch.postinstall"; - } elsif (-x "$base/$profile.$arch.postinstall") { - return "$base/$profile.$arch.postinstall"; - } elsif (-x "$base/$profile.$osver.postinstall") { - return "$base/$profile.$osver.postinstall"; - } elsif (-x "$base/$profile.postinstall") { - return "$base/$profile.postinstall"; + my $ext=shift; + my $dotpos = rindex($osver, "."); + my $osbase = substr($osver, 0, $dotpos); + if (-r "$base/$profile.$osver.$arch.$ext") { + return "$base/$profile.$osver.$arch.$ext"; + } elsif (-r "$base/$profile.$osbase.$arch.$ext") { + return "$base/$profile.$osbase.$arch.$ext"; + } elsif (-r "$base/$profile.$arch.$ext") { + return "$base/$profile.$arch.$ext"; + } elsif (-r "$base/$profile.$osver.$ext") { + return "$base/$profile.$osver.$ext"; + } elsif (-r "$base/$profile.$osbase.$ext") { + return "$base/$profile.$osbase.$ext"; + } elsif (-r "$base/$profile.$ext") { + return "$base/$profile.$ext"; } return ""; } + diff --git a/xCAT-server/share/xcat/netboot/sles/genimage b/xCAT-server/share/xcat/netboot/sles/genimage index 22e2763ef..154ae2a8f 100755 --- a/xCAT-server/share/xcat/netboot/sles/genimage +++ b/xCAT-server/share/xcat/netboot/sles/genimage @@ -239,9 +239,15 @@ if(`grep VERSION /etc/SuSE-release` =~ /VERSION = (\d+)/) { $osver_host=11; } - unless ($onlyinitrd) { - my %extra_hash=get_extra_package_names(); + if (!$imagename) { + $otherpkglist=get_profile_def_filename($customdir, "otherpkgs.pkglist"); + if (!$otherpkglist) { $otherpkglist=get_profile_def_filename($pathtofiles, "otherpkgs.pkglist"); } + } + my %extra_hash=(); + if ($otherpkglist) { + %extra_hash=get_package_names($otherpkglist); + } mkpath "$rootimg_dir/etc"; @@ -335,31 +341,26 @@ unless ($onlyinitrd) { }else { $yumcmd = "zypper -R $rootimg_dir install "; } + + #install pakages from pkglist file + my $pkgnames; if (!$imagename) { - $pkglist= get_pkglist_file_name($customdir); - if (!$pkglist) { - $pkglist= get_pkglist_file_name($pathtofiles); - } + $pkglist=get_profile_def_filename($customdir, "pkglist"); + if (!$pkglist) { $pkglist=get_profile_def_filename($pathtofiles, "pkglist"); } } - #print "pkglist=$pkglist\n"; if (!$pkglist) { print "Unable to find package list for $profile!"; exit 1; } - my $pkgnames; - open($yumconfig,"<","$pkglist"); - while (<$yumconfig>) { - chomp; - s/\s*#.*//; #-- remove comments - next if /^\s*$/; #-- skip empty lines - $pkgnames .= $_ . " "; + my %pkg_hash=get_package_names($pkglist); + my $index=1; + foreach (keys(%pkg_hash)) { + if (($_ eq "PRE_REMOVE") || ($_ eq "POST_REMOVE")) { next;} + my $pa=$pkg_hash{$_}; + $pkgnames .= " " . join(' ', @$pa); } - close($yumconfig); - - - #$yumcmd =~ s/ $/\n/; #print "$yumcmd $pkgnames\n"; my $rc = system("$yumcmd $pkgnames"); if ($rc) { @@ -410,13 +411,14 @@ unlink "/tmp/genimage.$$.yum.conf"; #-- run postinstall script if (!$imagename) { - $postinstall_filename= get_postinstall_file_name($customdir); + $postinstall_filename= get_profile_def_filename($customdir, "postinstall"); if (!$postinstall_filename) { - $postinstall_filename= get_postinstall_file_name($pathtofiles); + $postinstall_filename= get_profile_def_filename($pathtofiles, "postinstall"); } } if (($postinstall_filename) && (-x $postinstall_filename)) { + #print "postinstall_filename=$postinstall_filename\n"; my $rc = system($postinstall_filename, $rootimg_dir,$osver,$arch,$profile); if($rc) { print "postinstall script failed\n"; @@ -1163,21 +1165,16 @@ sub generic_post { #This function is meant to leave the image in a state approxi } } -#get th extra package name -sub get_extra_package_names { - if (!$imagename) { - $otherpkglist=get_extra_pkglist_file_name($customdir); - if (!$otherpkglist) { $otherpkglist=get_extra_pkglist_file_name($pathtofiles); } - } - #print "customdir=$customdir,pathtofiles=$pathtofiles,otherpkglist=$otherpkglist\n"; +sub get_package_names { + my $plist_file_name=shift; my %pkgnames=(); my @tmp_array=(); - if ($otherpkglist) { + if ($plist_file_name) { my $pkgfile; - open($pkgfile,"<","$otherpkglist"); + open($pkgfile,"<","$plist_file_name"); while (<$pkgfile>) { chomp; s/\s+$//; #remove trailing white spaces @@ -1190,7 +1187,7 @@ sub get_extra_package_names { my $pkgtext=join(',',@tmp_array); #handle the #INLCUDE# tag recursively - my $idir = dirname($otherpkglist); + my $idir = dirname($plist_file_name); my $doneincludes=0; while (not $doneincludes) { $doneincludes=1; @@ -1200,7 +1197,7 @@ sub get_extra_package_names { } } - print "pkgtext=$pkgtext\n"; + #print "pkgtext=$pkgtext\n"; my @tmp=split(',', $pkgtext); foreach (@tmp) { my $idir; @@ -1252,86 +1249,28 @@ sub include_file return join(',', @text); } -sub get_extra_pkglist_file_name { +sub get_profile_def_filename { my $base=shift; + my $ext=shift; my $dotpos = rindex($osver, "."); my $osbase = substr($osver, 0, $dotpos); - - if (-r "$base/$profile.$osver.$arch.otherpkgs.pkglist") { - return "$base/$profile.$osver.$arch.otherpkgs.pkglist"; - } elsif (-r "$base/$profile.$osbase.$arch.otherpkgs.pkglist") { - return "$base/$profile.$osbase.$arch.otherpkgs.pkglist"; - } elsif (-r "$base/$profile.$arch.otherpkgs.pkglist") { - return "$base/$profile.$arch.otherpkgs.pkglist"; - } elsif (-r "$base/$profile.$osver.otherpkgs.pkglist") { - return "$base/$profile.$osver.otherpkgs.pkglist"; - } elsif (-r "$base/$profile.$osbase.otherpkgs.pkglist") { - return "$base/$profile.$osbase.otherpkgs.pkglist"; - } elsif (-r "$base/$profile.otherpkgs.pkglist") { - return "$base/$profile.otherpkgs.pkglist"; - } - return ""; -} - -sub get_pkglist_file_name { - my $base=shift; - my $dotpos = rindex($osver, "."); - my $osbase = substr($osver, 0, $dotpos); - if (-r "$base/$profile.$osver.$arch.pkglist") { - return "$base/$profile.$osver.$arch.pkglist"; - } elsif (-r "$base/$profile.$osbase.$arch.pkglist") { - return "$base/$profile.$osbase.$arch.pkglist"; - } elsif (-r "$base/$profile.$arch.pkglist") { - return "$base/$profile.$arch.pkglist"; - } elsif (-r "$base/$profile.$osver.pkglist") { - return "$base/$profile.$osver.pkglist"; - } elsif (-r "$base/$profile.$osbase.pkglist") { - return "$base/$profile.$osbase.pkglist"; - } elsif (-r "$base/$profile.pkglist") { - return "$base/$profile.pkglist"; + if (-r "$base/$profile.$osver.$arch.$ext") { + return "$base/$profile.$osver.$arch.$ext"; + } elsif (-r "$base/$profile.$osbase.$arch.$ext") { + return "$base/$profile.$osbase.$arch.$ext"; + } elsif (-r "$base/$profile.$arch.$ext") { + return "$base/$profile.$arch.$ext"; + } elsif (-r "$base/$profile.$osver.$ext") { + return "$base/$profile.$osver.$ext"; + } elsif (-r "$base/$profile.$osbase.$ext") { + return "$base/$profile.$osbase.$ext"; + } elsif (-r "$base/$profile.$ext") { + return "$base/$profile.$ext"; } return ""; } -sub get_postinstall_file_name { - my $base=shift; - my $dotpos = rindex($osver, "."); - my $osbase = substr($osver, 0, $dotpos); - if (-x "$base/$profile.$osver.$arch.postinstall") { - return "$base/$profile.$osver.$arch.postinstall"; - } elsif (-x "$base/$profile.$osbase.$arch.postinstall") { - return "$base/$profile.$osbase.$arch.postinstall"; - } elsif (-x "$base/$profile.$arch.postinstall") { - return "$base/$profile.$arch.postinstall"; - } elsif (-x "$base/$profile.$osver.postinstall") { - return "$base/$profile.$osver.postinstall"; - } elsif (-x "$base/$profile.$osbase.postinstall") { - return "$base/$profile.$osbase.postinstall"; - } elsif (-x "$base/$profile.postinstall") { - return "$base/$profile.postinstall"; - } - return ""; -} -sub get_rwfiles_file_name { - my $base = shift; - my $dotpos = rindex($osver, "."); - my $osbase = substr($osver, 0, $dotpos); - if( -r "$base/$profile.$osver.$arch.rwfiles") { - return "$base/$profile.$osver.$arch.rwfiles"; - } elsif (-r "$base/$profile.$osbase.$arch.rwfiles") { - return "$base/$profile.$osbase.$arch.rwfiles"; - } elsif (-r "$base/$profile.$arch.rwfiles") { - return "$base/$profile.$arch.rwfiles"; - } elsif (-r "$base/$profile.$osver.rwfiles") { - return "$base/$profile.$osver.rwfiles"; - } elsif (-r "$base/$profile.$osbase.rwfiles") { - return "$base/$profile.$osbase.rwfiles"; - } elsif( -r "$base/$profile.rwfiles") { - return "$base/$profile.rwfiles"; - } - return ""; -}