#! /usr/bin/perl # # Class name: PDefined # Synopsis: Holds headerDoc comments of the @define type, which # are used to comment symbolic constants declared with #define # # Author: Matt Morse (matt@apple.com) # Last Updated: $Date: 2001/11/30 22:43:18 $ # # Copyright (c) 1999 Apple Computer, Inc. All Rights Reserved. # The contents of this file constitute Original Code as defined in and are # subject to the Apple Public Source License Version 1.1 (the "License"). # You may not use this file except in compliance with the License. Please # obtain a copy of the License at http://www.apple.com/publicsource and # read it before using this file. # # This Original Code and all software distributed under the License are # distributed on an TAS ISU basis, WITHOUT WARRANTY OF ANY KIND, EITHER # EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, # INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS # FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the License for # the specific language governing rights and limitations under the # License. # ###################################################################### package HeaderDoc::PDefine; use HeaderDoc::Utilities qw(findRelativePath safeName getAPINameAndDisc convertCharsForFileMaker printArray printHash); use HeaderDoc::HeaderElement; @ISA = qw( HeaderDoc::HeaderElement ); use strict; use vars qw($VERSION @ISA); $VERSION = '1.20'; sub processPDefineComment { my($self) = shift; my $fieldArrayRef = shift; my @fields = @$fieldArrayRef; foreach my $field (@fields) { chomp($field); SWITCH: { ($field =~ /^\/\*\!/)&& do {last SWITCH;}; # ignore opening /*! ($field =~ s/^define(d)?\s+//) && do {$self->name($field); last SWITCH;}; ($field =~ s/^abstract\s+//) && do {$self->abstract($field); last SWITCH;}; ($field =~ s/^discussion\s+//) && do {$self->discussion($field); last SWITCH;}; print "Unknown field: $field\n"; } } } sub setPDefineDeclaration { my($self) = shift; my ($dec) = @_; my $localDebug = 0; print "============================================================================\n" if ($localDebug); print "Raw #define declaration is: $dec\n" if ($localDebug); $dec =~ s/^\s+//; $dec =~ s/[ \t]+/ /g; if (length ($dec)) {$dec = "
\n$dec
\n";}; print "#define: returning declaration:\n\t|$dec|\n" if ($localDebug); print "============================================================================\n" if ($localDebug); $self->declarationInHTML($dec); return $dec; } sub documentationBlock { my $self = shift; my $name = $self->name(); my $desc = $self->discussion(); my $declaration = $self->declarationInHTML(); my $abstract = $self->abstract(); my $contentString; $contentString .= "

$name

\n"; if (length($abstract)) { $contentString .= "Abstract: $abstract\n"; } $contentString .= "
$declaration
\n"; $contentString .= "

$desc

\n"; $contentString .= "
\n"; return $contentString; } sub printObject { my $self = shift; print "#Define\n"; $self->SUPER::printObject(); print "\n"; } 1;