#!/usr/bin/perl # IBM(c) 2007 EPL license http://www.eclipse.org/legal/epl-v10.html # Runs each of the tools in the share/xcat/tools dir with the --help option # and compiles the output into a tools readme file (both text version and # html version). use strict; #use lib '.'; my $toolsdir = 'share/xcat/tools'; my $textreadme = "$toolsdir/README.txt"; my $htmlreadme = "$toolsdir/README.html"; #my $cachedir = '/tmp'; my @tools = getToolList($toolsdir); #foreach (@tools) { print "$_\n"; } # Put the intro text in the readme files print "Building tools README files...\n"; open(TXT, ">$textreadme") or die "Error: could not open $textreadme for writing.\n"; open(HTML, ">$htmlreadme") or die "Error: could not open $htmlreadme for writing.\n"; writeintro(\*TXT, \*HTML, @tools); # Run each tool with --help flag foreach my $toolfile (@tools) { my $cmd = "./$toolsdir/$toolfile --help"; my $output = `$cmd`; if ($?) { my $err = "Error: execution of '$cmd' failed with rc=" . ($?>>8) . ".\n"; print $err; $output .= $err; } writetoolhelp(\*TXT, \*HTML, $toolfile, $output); } # close files writeending(\*HTML); close TXT; close HTML; exit; # get the list of tool script files. sub getToolList { my $toolsdir = shift; # 1st get toplevel dir listing opendir(DIR, $toolsdir) or die "Error: could not read $toolsdir.\n"; my @files = grep !/^\./, readdir(DIR); # / close(DIR); # remove files that are not regular files (not dirs) and executable my @newlist; foreach my $f (@files) { my $file = "$toolsdir/$f"; if ((-f $file) && (-x $file)) { push @newlist, $f; } } #foreach (@files) { print "$_\n"; } #foreach (@newlist) { print "$_\n"; } return sort @newlist; } # print some text to both readmes sub printtoboth { my $txt = shift; my $html = shift; my $str = shift; print $txt $str; print $html $str; } # write the up front stuff of the readme sub writeintro { my $txt = shift; # the file handle to the txt readme file my $html = shift; # the file handle to the html readme file # the rest of @_ contains the tool files in the dir # write title part of readmes print $txt <<'TXTEOS1'; xCAT TOOL DESCRIPTIONS ---------------------- TXTEOS1 print $html <<'HTMLEOS1'; xCAT Tool Descriptions

xCAT Tool Descriptions

HTMLEOS1 # write the table of contents for the html readme print $html "\n"; # write the intro print $html "

Introduction

\n"; printtoboth $txt, $html, <<'EOS1'; This is a list of additional tools that are provided by xCAT. They are located in /opt/xcat/share/xcat/tools/, but should also be in your path. Many of these tools have been contributed by xCAT users that are not part of the core xCAT development team. That means they might not be supported as well as the main xCAT code. Read the help here, take a look at the code, and use at your own risk. If you have problems with a tool, post to the xCAT mailing list and the author will try to help you. EOS1 print $html "

\n"; } # write the help for one tool sub writetoolhelp { my $txt = shift; # the file handle to the txt readme file my $html = shift; # the file handle to the html readme file my $toolname = shift; # the script name of the tool my $toolhelp = shift; # the --help output from the tool # write the heading for this tool print $txt <<"TXTEOS2"; $toolname -------------------- TXTEOS2 print $html <<"HTMLEOS2";

$toolname

HTMLEOS2

	# write the actual contents of the tool help
	printtoboth $txt, $html, $toolhelp;

	# finish up
	print $html <<"HTMLEOS3";
HTMLEOS3 } sub writeending { my $html = shift; # finish up the html readme print $html <<'HTMLEOS4'; HTMLEOS4 }