BEGIN {
foreach (qw(Mac::Files)) {
$MOD_AVAIL{$_} = eval "use $_; 1";
}
}
package HeaderDoc::CPPClass;
use HeaderDoc::Utilities qw(findRelativePath safeName getAPINameAndDisc convertCharsForFileMaker printArray printHash);
use HeaderDoc::APIOwner;
@ISA = qw( HeaderDoc::APIOwner );
use strict;
use vars qw($VERSION @ISA);
$VERSION = '1.20';
my $isMacOS;
my $pathSeparator;
if ($^O =~ /MacOS/i) {
$pathSeparator = ":";
$isMacOS = 1;
} else {
$pathSeparator = "/";
$isMacOS = 0;
}
my $debugging = 0;
my $tracing = 0;
my $outputExtension = ".html";
my $tocFrameName = "toc.html";
my $defaultFrameName = "index.html";
my $compositePageName = "CompositePage.html";
my $theTime = time();
my ($sec, $min, $hour, $dom, $moy, $year, @rest);
($sec, $min, $hour, $dom, $moy, $year, @rest) = localtime($theTime);
$moy++;
$year += 1900;
my $dateStamp = "$moy/$dom/$year";
sub new {
my($param) = shift;
my($class) = ref($param) || $param;
my $self = {};
bless($self, $class);
$self->SUPER::_initialize();
$self->_initialize();
print "Created new CPPClass object\n" if ($debugging);
return($self);
}
sub _initialize {
my($self) = shift;
$self->{HEADEROBJECT} = undef;
}
sub headerObject {
my $self = shift;
if (@_) {
$self->{HEADEROBJECT} = shift;
}
return $self->{HEADEROBJECT};
}
sub createTOCFile {
my $self = shift;
my $rootDir = $self->outputDir();
my $outputFileName = "toc.html";
my $outputFile = "$rootDir$pathSeparator$outputFileName";
my $fileString = $self->tocString();
my $filename = $self->name();
open(OUTFILE, ">$outputFile") || die "Can't write $outputFile.\n$!\n";
if ($isMacOS) {MacPerl::SetFileInfo('MSIE', 'TEXT', "$outputFile");};
print OUTFILE "<html><head><title>Draft Documentation for $filename</title></head>\n";
print OUTFILE "<body bgcolor=\"#cccccc\">\n";
print OUTFILE "<table border=\"0\" cellpadding=\"0\" cellspacing=\"2\" width=\"148\">\n";
print OUTFILE "<tr><td colspan=\"2\"><font size=\"5\" color=\"#330066\"><b>Class:</b></font></td></tr>\n";
print OUTFILE "<tr><td width=\"15\"></td><td><b><font size=\"+1\">$filename</font></b></td></tr>\n";
print OUTFILE "</table><hr>\n";
print OUTFILE $fileString;
print OUTFILE "</body></html>\n";
close OUTFILE;
}
sub tocString {
my $self = shift;
my $contentFrameName = $self->name();
$contentFrameName =~ s/(.*)\.h/$1/;
if (1 || $isMacOS) {$contentFrameName = &safeName($contentFrameName);};
$contentFrameName = $contentFrameName . ".html";
my $header = $self->headerObject();
my @funcs = $self->functions();
my @constants = $self->constants();
my @typedefs = $self->typedefs();
my @structs = $self->structs();
my @enums = $self->enums();
my @vars = $self->vars();
my $tocString = "<h3><a href=\"$contentFrameName\" target =\"doc\">Introduction</a></h3>\n";
if (@funcs) {
my @publics;
my @protecteds;
my @privates;
$tocString .= "<br><h4>Member Functions</h4><hr>\n";
foreach my $obj (sort byAccessControl @funcs) {
my $access = $obj->accessControl();
if ($access =~ /public/){
push (@publics, $obj);
} elsif ($access =~ /protected/){
push (@protecteds, $obj);
} elsif ($access =~ /private/){
push (@privates, $obj);
}
}
if (@publics) {
$tocString .= "<h5>Public</h5>\n";
foreach my $obj (sort objName @publics) {
my $name = $obj->name();
$tocString .= "<nobr> <a href = \"Functions/Functions.html#$name\" target =\"doc\">$name</a></nobr><br>\n";
}
}
if (@protecteds) {
$tocString .= "<h5>Protected</h5>\n";
foreach my $obj (sort objName @protecteds) {
my $name = $obj->name();
$tocString .= "<nobr> <a href = \"Functions/Functions.html#$name\" target =\"doc\">$name</a></nobr><br>\n";
}
}
if (@privates) {
$tocString .= "<h5>Private</h5>\n";
foreach my $obj (sort objName @privates) {
my $name = $obj->name();
$tocString .= "<nobr> <a href = \"Functions/Functions.html#$name\" target =\"doc\">$name</a></nobr><br>\n";
}
}
}
if (@typedefs) {
$tocString .= "<h4>Defined Types</h4>\n";
foreach my $obj (sort objName @typedefs) {
my $name = $obj->name();
$tocString .= "<nobr> <a href = \"DataTypes/DataTypes.html#$name\" target =\"doc\">$name</a></nobr><br>\n";
}
}
if (@structs) {
$tocString .= "<h4>Structs</h4>\n";
foreach my $obj (sort objName @structs) {
my $name = $obj->name();
$tocString .= "<nobr> <a href = \"Structs/Structs.html#$name\" target =\"doc\">$name</a></nobr><br>\n";
}
}
if (@constants) {
$tocString .= "<h4>Constants</h4>\n";
foreach my $obj (sort objName @constants) {
my $name = $obj->name();
$tocString .= "<nobr> <a href = \"Constants/Constants.html#$name\" target =\"doc\">$name</a></nobr><br>\n";
}
}
if (@enums) {
$tocString .= "<h4>Enumerations</h4>\n";
foreach my $obj (sort objName @enums) {
my $name = $obj->name();
$tocString .= "<nobr> <a href = \"Enums/Enums.html#$name\" target =\"doc\">$name</a></nobr><br>\n";
}
}
if (@vars) {
my @publics;
my @protecteds;
my @privates;
$tocString .= "<br><h4>Member Data</h4><hr>\n";
foreach my $obj (sort byAccessControl @vars) {
my $access = $obj->accessControl();
if ($access =~ /public/){
push (@publics, $obj);
} elsif ($access =~ /protected/){
push (@protecteds, $obj);
} elsif ($access =~ /private/){
push (@privates, $obj);
}
}
if (@publics) {
$tocString .= "<h5>Public</h5>\n";
foreach my $obj (sort objName @publics) {
my $name = $obj->name();
$tocString .= "<nobr> <a href = \"Vars/Vars.html#$name\" target =\"doc\">$name</a></nobr><br>\n";
}
}
if (@protecteds) {
$tocString .= "<h5>Protected</h5>\n";
foreach my $obj (sort objName @protecteds) {
my $name = $obj->name();
$tocString .= "<nobr> <a href = \"Vars/Vars.html#$name\" target =\"doc\">$name</a></nobr><br>\n";
}
}
if (@privates) {
$tocString .= "<h5>Private</h5>\n";
foreach my $obj (sort objName @privates) {
my $name = $obj->name();
$tocString .= "<nobr> <a href = \"Vars/Vars.html#$name\" target =\"doc\">$name</a></nobr><br>\n";
}
}
}
$tocString .= "<br><h4>Other Reference</h4><hr>\n";
$tocString .= "<nobr> <a href = \"../../index.html\" target =\"_top\">Header</a></nobr><br>\n";
$tocString .= "<br><hr><a href=\"$compositePageName\" target =\"_blank\">[Printable HTML Page]</a>\n";
return $tocString;
}
sub _getCompositePageString {
my $self = shift;
my $name = $self->name();
my $compositePageString;
my $contentString;
$contentString= $self->_getFunctionDetailString();
if (length($contentString)) {
$compositePageString .= "<h2>Member Functions</h2>\n";
$compositePageString .= $contentString;
}
$contentString= $self->_getVarDetailString();
if (length($contentString)) {
$compositePageString .= "<h2>Member Data</h2>\n";
$compositePageString .= $contentString;
}
$contentString= $self->_getConstantDetailString();
if (length($contentString)) {
$compositePageString .= "<h2>Constants</h2>\n";
$compositePageString .= $contentString;
}
$contentString= $self->_getTypedefDetailString();
if (length($contentString)) {
$compositePageString .= "<h2>Typedefs</h2>\n";
$compositePageString .= $contentString;
}
$contentString= $self->_getStructDetailString();
if (length($contentString)) {
$compositePageString .= "<h2>Structs</h2>\n";
$compositePageString .= $contentString;
}
$contentString= $self->_getEnumDetailString();
if (length($contentString)) {
$compositePageString .= "<h2>Enumerations</h2>\n";
$compositePageString .= $contentString;
}
$contentString= $self->_getPDefineDetailString();
if (length($contentString)) {
$compositePageString .= "<h2>#defines</h2>\n";
$compositePageString .= $contentString;
}
return $compositePageString;
}
sub _getFunctionDetailString {
my $self = shift;
my @funcObjs = $self->functions();
my $className = $self->name();
my $contentString;
foreach my $obj (sort objName @funcObjs) {
my $name = $obj->name();
my $desc = $obj->discussion();
my $abstract = $obj->abstract();
my $declaration = $obj->declarationInHTML();
my $declarationRaw = $obj->declaration();
my $accessControl = $obj->accessControl();
my @params = $obj->taggedParameters();
my $result = $obj->result();
if ($declaration !~ / my $paramSignature = $self->getParamSignature($declarationRaw);
my $methodType = $self->getMethodType($declarationRaw);
$contentString .= "<a name=\"//apple_ref/cpp/$methodType/$className/$name/$paramSignature\"></a>\n";
}
$contentString .= "<h3><a name=\"$name\">$name</a></h3>\n";
if (length($abstract)) {
$contentString .= "<b>Abstract:</b> $abstract\n";
}
$contentString .= "<blockquote><pre><tt>$accessControl</tt>\n<br>$declaration</pre></blockquote>\n";
$contentString .= "<p>$desc</p>\n";
my $arrayLength = @params;
if ($arrayLength > 0) {
my $paramContentString;
foreach my $element (@params) {
my $pName = $element->name();
my $pDesc = $element->discussion();
if (length ($pName)) {
$paramContentString .= "<tr><td align = \"center\"><tt>$pName</tt></td><td>$pDesc</td><tr>\n";
}
}
if (length ($paramContentString)){
$contentString .= "<h4>Parameters</h4>\n";
$contentString .= "<blockquote>\n";
$contentString .= "<table border = \"1\" width = \"90%\">\n";
$contentString .= "<thead><tr><th>Name</th><th>Description</th></tr></thead>\n";
$contentString .= $paramContentString;
$contentString .= "</table>\n</blockquote>\n";
}
}
if (length($result)) {
$contentString .= "<b>Result:</b> $result\n";
}
$contentString .= "<hr>\n";
}
return $contentString;
}
sub _getVarDetailString {
my $self = shift;
my @varObjs = $self->vars();
my $contentString;
foreach my $obj (sort objName @varObjs) {
my $name = $obj->name();
my $desc = $obj->discussion();
my $declaration = $obj->declarationInHTML();
my $accessControl = $obj->accessControl();
my @fields = ();
my $fieldHeading;
if ($obj->can('fields')) { @fields = $obj->fields();
$fieldHeading = "Fields";
} elsif ($obj->can('constants')) { @fields = $obj->constants();
$fieldHeading = "Constants";
}
if ($obj->can('isFunctionPointer')) {
if ($obj->isFunctionPointer()) {
$fieldHeading = "Parameters";
}
}
$contentString .= "<h3><a name=\"$name\">$name</a></h3>\n";
$contentString .= "<blockquote><tt>$accessControl</tt>$declaration</blockquote>\n";
$contentString .= "<p>$desc</p>\n";
my $arrayLength = @fields;
if ($arrayLength > 0) {
$contentString .= "<h4>$fieldHeading</h4>\n";
$contentString .= "<blockquote>\n";
$contentString .= "<table border = \"1\" width = \"90%\">\n";
$contentString .= "<thead><tr><th>Name</th><th>Description</th></tr></thead>\n";
foreach my $element (@fields) {
my $fName = $element->name();
my $fDesc = $element->discussion();
$contentString .= "<tr><td align = \"center\"><tt>$fName</tt></td><td>$fDesc</td><tr>\n";
}
$contentString .= "</table>\n</blockquote>\n";
}
$contentString .= "<hr>\n";
}
return $contentString;
}
sub getParamSignature {
my $self = shift;
my $declaration = shift;
my $sig;
my @params;
$declaration =~ s/^[^(]+\(([^)]*)\).*/$1/;
@params = split (/,/, $declaration);
foreach my $paramString (@params) {
my @paramElements = split (/\s+/, $paramString);
my $lastElement = pop @paramElements;
$sig .= join ("", @paramElements);
if ($lastElement =~ /^\*.*/) {$sig .= "*";}; }
return $sig;
}
sub getMethodType {
my $self = shift;
my $declaration = shift;
my $methodType = "instm";
if ($declaration =~ /^\s*static/) {
$methodType = "clm";
}
return $methodType;
}
sub objName { my $obj1 = $a;
my $obj2 = $b;
return ($obj1->name() cmp $obj2->name());
}
sub byLinkage { my $obj1 = $a;
my $obj2 = $b;
return ($obj1->linkageState() cmp $obj2->linkageState());
}
sub byAccessControl { my $obj1 = $a;
my $obj2 = $b;
return ($obj1->accessControl() cmp $obj2->accessControl());
}
sub linkageAndObjName { my $obj1 = $a;
my $obj2 = $b;
my $linkAndName1 = $obj1->linkageState() . $obj1->name();
my $linkAndName2 = $obj2->linkageState() . $obj2->name();
return ($linkAndName1 cmp $linkAndName2);
}
sub printObject {
my $self = shift;
print "CPPClass\n";
$self->SUPER::printObject();
print "headerObject: $self->{HEADEROBJECT}\n";
print "\n";
}
1;