/*
* @(#)SerialFieldSubWriter.java 1.15 99/01/20
*
* Copyright 1998 by Sun Microsystems, Inc.,
* 901 San Antonio Road, Palo Alto, California, 94303, U.S.A.
* All rights reserved.
*
* This software is the confidential and proprietary information
* of Sun Microsystems, Inc. ("Confidential Information"). You
* shall not disclose such Confidential Information and shall use
* it only in accordance with the terms of the license agreement
* you entered into with Sun.
*/
package com.sun.tools.doclets.standard;
import com.sun.javadoc.*;
import com.sun.tools.doclets.*;
import java.util.Arrays;
/**
* Generate serialized form for serializable fields.
* Documentation denoted by the tags serial
and
* serialField<\code> is processed.
*
* @author Joe Fialli
*/
public class SerialFieldSubWriter extends FieldSubWriter {
ProgramElementDoc[] members = null;
protected SerialFieldSubWriter(SubWriterHolderWriter writer) {
super(writer);
}
public ProgramElementDoc[] members(ClassDoc cd) {
if (members == null) {
FieldDoc[] array = cd.serializableFields();
Arrays.sort(array);
members = eligibleMembers(array);
}
return members;
}
void printSignature(MemberDoc member) {
FieldDoc field = (FieldDoc)member;
printHead(member);
writer.pre();
printTypeLink(field.type());
print(' ');
bold(field.name());
writer.preEnd();
}
protected void printHeader(ClassDoc cd) {
writer.anchor("serializedForm");
printSerializableClassComment(cd);
writer.printTableHeadingBackground(writer.getText("doclet.Serialized_Form_fields"));
}
/**
* javadoc comments for "serialPersistentFields" is considered
* as serializable class comments, not field comments.
*/
private void printSerializableClassComment(ClassDoc cd) {
if (cd.definesSerializableFields()) {
FieldDoc serialPersistentFields = (FieldDoc)(members(cd)[0]);
String comment = serialPersistentFields.commentText();
if (comment.length() > 0) {
writer.printTableHeadingBackground(writer.getText("doclet.Serialized_Form_class"));
printFullComment(serialPersistentFields);
}
}
}
protected void printBodyHtmlEnd(ClassDoc cd) {
}
/**
* Print a default Serializable field or
* print all Serializable fields documented by
* serialField
tags.
*/
protected void printMember(ProgramElementDoc member) {
FieldDoc field = (FieldDoc)member;
ClassDoc cd = field.containingClass();
if (cd.definesSerializableFields()) {
// Process Serializable Fields specified as array of ObjectStreamFields.
//Print a member for each serialField tag.
//(There should be one serialField tag per ObjectStreamField element.)
SerialFieldTag[] tags = field.serialFieldTags();
Arrays.sort(tags);
for (int i = 0; i < tags.length; i++) {
if (i > 0) {
writer.printMemberHeader();
}
printSignature(tags[i]);
printComment(tags[i]);
writer.printMemberFooter();
}
} else {
// Process default Serializable field.
if ((field.tags("serial").length == 0) && ! field.isSynthetic()) {
serialWarning("doclet.MissingSerialTag", cd.qualifiedName(),
field.name());
}
printSignature(field);
printFullComment(field);
}
}
/*
* Print comment for a default Serializable field.
*
* If serial tag has an optional comment, append the
* comment to the javadoc comment for the field.
*/
protected void printComment(ProgramElementDoc member) {
if (member.inlineTags().length > 0) {
writer.dd();
writer.printInlineComment(member);
}
Tag[] tags = member.tags("serial");
if (tags.length > 0) {
writer.dt();
writer.dd();
writer.printInlineComment(tags[0]);
}
}
/* Methods for processing serialField fieldName fieldType description.*/
void printSignature(SerialFieldTag sftag) {
writer.pre();
ClassDoc fieldTypeDoc = sftag.fieldTypeDoc();
if (fieldTypeDoc != null) {
writer.printClassLink(fieldTypeDoc);
} else {
writer.print(sftag.fieldType());
}
print(' ');
bold(sftag.fieldName());
writer.preEnd();
}
private void printComment(SerialFieldTag sftag) {
writer.dl();
writer.dd();
writer.printInlineComment(sftag);
writer.dlEnd();
}
/* The methods following this comment have no meaning for SerialFields.*/
protected void printDeprecatedLink(ProgramElementDoc member) {
}
public void printSummaryLabel(ClassDoc cd) {
}
public void printInheritedSummaryLabel(ClassDoc cd) {
}
protected void printSummaryLink(ClassDoc cd, ProgramElementDoc member) {
}
protected void printInheritedSummaryLink(ClassDoc cd,
ProgramElementDoc member) {
}
protected void printSummaryType(ProgramElementDoc member) {
}
}