added back Lissas changes that I accidentally overwrote

git-svn-id: https://svn.code.sf.net/p/xcat/code/xcat-core/trunk@4822 8638fb3e-16cb-4fca-ae20-7b5d299a9bcd
This commit is contained in:
vallard 2009-12-17 21:06:41 +00:00
parent 6394de13d9
commit 0e13487eeb

View File

@ -1,8 +1,20 @@
#!/usr/bin/perl
BEGIN
{
$::XCATROOT =
$ENV{'XCATROOT'} ? $ENV{'XCATROOT'}
: -d '/opt/xcat' ? '/opt/xcat'
: '/usr';
}
use lib "$::XCATROOT/lib/perl";
use strict;
use Getopt::Long;
require xCAT::MsgUtils;
require xCAT::DSHCLI;
use xCAT::Utils;
use Term::ANSIColor;
use File::Basename;
use Getopt::Long;
# genimage is a wrapper to the genimages located in
# /opt/xcat/share/xcat/netboot/<os>/
# put tab completion
@ -12,18 +24,37 @@ $::XCATROOT = "/opt/xcat";
my $os = "";
my $profile = "";
my $interface = "";
my $version;
my $drivers = "";
my $otherInterfaces = "";
my $kernel = "";
my $method = "";
my @oses; # available OSes.
my @profiles; # available profiles
my $profDir; # root where you do ./genimage from
my $help;
my $match = 0;
my $color = 0;
my $method;
GetOptions(
#-----------------------------------------------------------------------------
=head3 print_usage - usage message
=cut
#-----------------------------------------------------------------------------
sub print_usage
{
print "Usage: genimage -h\n";
print " genimage -v\n";
print " genimage [-i <nodebootif>] [-n <nodenetdrivers>] [-r <additional_nics>]\n [-o <os>] [-p <profile>] [-k <kernal_version>] [-m <statelite>]\n";
print "Examples:\n";
print " genimage -i eth0 -n igb,e1000e,bnx2 -o centos5.4 -p compute\n";
print " genimage -o suse11\n";
print " genimage\n";
return;
}
if (!GetOptions(
'o=s' => \$os,
'i=s' => \$interface,
'p=s' => \$profile,
@ -31,20 +62,27 @@ GetOptions(
'k=s' => \$kernel,
'r=s' => \$otherInterfaces,
'h|help' => \$help,
'v|version' => \$version,
'm=s' => \$method,
'c' => \$color
);
if($help){
print 'genimage is a shell for the genimage located in /opt/xcat/share/xcat/netboot/<osfamily>/\n';
print 'Usage: genimage [-i <nodebootif>] [-n <nodenetdrivers>] [-r <otherifaces>] [-o <OSVER>] [-p <PROFILE>] [-k <KERNELVER>] <-m statelite>'."\n";
print "Examples:\n";
print " genimage -i eth0 -n igb,e1000e,bnx2 -o centos5.4 -p compute\n";
print " genimage -o suse11\n";
print " genimage\n";
)) {
&print_usage;
exit 1;
}
if($help){
print "genimage is a shell for the genimage located in /opt/xcat/share/xcat/netboot/<osfamily>.\n";
&print_usage;
exit 0;
}
if ($version){
my $version = xCAT::Utils->Version();
xCAT::MsgUtils->message("N", $version);
exit 0;
}
unless($os){
# get the install directory
my $installdir = `gettab key=installdir site.value`;
@ -75,13 +113,13 @@ unless($os){
# now they have the OSes, make sure they select one that is available
$match = 0;
while(1){
print color("bold") if $color;
print color("bold");
print "Available OSes: \n";
print color("reset") if $color;
print color("reset");
foreach(@oses){
print color("yellow bold") if $color;
print "$_\n";
print color("reset") if $color;
$color && print color("green" );
print "$_\n";
$color && print color("reset");
}
# default is the first OS cause in many cases, they'll only have 1.
print "Which OS to you want to build a netboot image for? [";
@ -109,10 +147,10 @@ unless($os){
chomp($os);
}
print color("cyan") if $color;
$color && print color("cyan");
print "os: $os\n";
print color("reset");
$color && print color("reset");
### Get the Profile ####
@ -148,9 +186,9 @@ unless($profile){
while(1){
print color("bold"), "Available Profiles for $os: \n", color("reset");
foreach(@profiles){
print color("yellow bold") if $color;
print "$_\n";
print color("reset") if $color;
$color && print color("green");
print "$_\n";
$color && print color("reset");
}
# default is the first OS cause in many cases, they'll only have 1.
print "Which profile do you want to use for $os? [";
@ -173,9 +211,9 @@ unless($profile){
}
}
}
print color("cyan") if $color;
print "profile: $profile\n";
print color("reset") if $color;
$color && print color("cyan");
print "profile: $profile\n";
$color && print color("reset");
# get the interface
unless($interface){
@ -190,9 +228,9 @@ unless($interface){
last;
}else{
print "You want your stateless machines to boot off of ";
print color("cyan") if $color;
print $interface;
print color("reset") if $color;
$color && print color("cyan");
print "$interface";
$color && print color("reset");
print "? ";
print color("bold"),"[Y/n] ", color("reset");
my $conf = <stdin>;
@ -206,18 +244,16 @@ unless($interface){
}
}
}
print color("cyan") if $color;
$color && print color("cyan");
print "interface: $interface\n";
print color("reset") if $color;
$color && print color("reset");
# get drivers
unless($drivers){
while(1){
print "Which network drivers will you need? (press enter if you're not sure) ";
print color("bold");
print "\n[igb,e1000e,e1000,bnx2,tg3] ";
print color("reset");
print color("bold"), "\n[igb,e1000e,e1000,bnx2,tg3] ", color("reset");
$drivers = <stdin>;
chomp($drivers);
@ -225,10 +261,10 @@ unless($drivers){
$drivers = "igb,e1000e,e1000,bnx2,tg3";
last;
}else{
print "You want to use the following driver(s):";
print color("cyan") if $color;
print $drivers;
print color("reset") if $color;
print "You want to use the following driver(s): ";
$color && print color("cyan");
print $drivers;
$color && color("reset");
print "? ";
print color("bold"),"[Y/n] ", color("reset");
my $conf = <stdin>;
@ -242,9 +278,9 @@ unless($drivers){
}
}
}
print color("cyan") if $color;
print "$drivers\n";
print color("reset") if $color;
$color && print color("cyan");
print "$drivers\n";
$color && print color("reset");
# get other interfaces
unless($otherInterfaces){
@ -269,10 +305,10 @@ unless($otherInterfaces){
if($tmp eq ""){
last;
}else{
print "You want to also set up:";
print color("cyan") if $color;
print $tmp ;
print color("reset") if $color;
print "You want to also set up: ";
$color && print color("cyan");
print $tmp;
$color && print color("reset");
print "? ";
print color("bold"),"[Y/n] ", color("reset");
my $conf = <stdin>;
@ -290,9 +326,9 @@ unless($otherInterfaces){
} # end question loop
} # end getting other interfaces
if($otherInterfaces){
print color("cyan") if $color;
print "Other Interfaces: $otherInterfaces\n";
print color("reset") if $color;
$color && print color("cyan");
print "Other Interfaces: $otherInterfaces\n";
$color && color("reset");
}
@ -307,15 +343,15 @@ unless($kernel){
if($kernel eq ""){
# special case of RHEL5.4 where kenrel must be specified or you
# get some other one
if($os =~ /rhels5.4|centos5.4/){
if($os =~ /rhels5.4|centos5.4|rhel5.4|sl5.4/){
$kernel = "2.6.18-164.el5";
}
last;
}else{
print "You want to use: ";
print color("cyan") if $color;
$color && print color("cyan");
print $kernel;
print color("reset") if $color;
$color && print color("reset");
print "? ";
print color("bold"),"[Y/n] ", color("reset");
my $conf = <stdin>;
@ -330,30 +366,31 @@ unless($kernel){
}
} # end unless kernel
unless($method){
while(1){
print "Do you want the image to be statelite? [";
print color("bold"), "[y/N] ", color("reset");
print color("bold"), '[y/N] ', color("reset");
my $conf = <stdin>;
chomp($conf);
if($conf =~ /Y|y|[Yy][Ee][Ss]/){
$method = "statelite";
if($conf =~ /^Y|^y|[Yy][Ee][Ss]/){
$method = "statelite";
last;
}
if($conf eq ""){
last;
}
if($conf eq ""){ last; }
if($conf =~ /N|n|[Nn][Oo]/){
last;
last;
}
}
}
if($kernel){
print color("blue") if $color;
$color && print color("blue");
print "kernel: $kernel\n";
print color("reset") if $color;
$color && print color("reset");
}
print "Generating image:\n";
@ -367,12 +404,8 @@ if($otherInterfaces){
if($method){
$cmd .= " -m $method";
}
print color("cyan") if $color;
print "cd $profDir\n";
print color("reset") if $color;
print color("cyan") if $color;
print "$cmd\n";
print color("reset") if $color;
$color && print color("cyan");
print "cd $profDir\n";
print "$cmd\n";
$color && print color("reset");
exec("cd $profDir; $cmd");