blob: fa082f488f62e963868f00895b678c500df8ab6f [file] [log] [blame]
/* gnu.classpath.tools.taglets.SinceTaglet
Copyright (C) 2001 Free Software Foundation, Inc.
This file is part of GNU Classpath.
GNU Classpath is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.
GNU Classpath is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License
along with GNU Classpath; see the file COPYING. If not, write to the
Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
02111-1307 USA. */
package gnu.classpath.tools.taglets;
import java.util.Map;
import com.sun.tools.doclets.Taglet;
import com.sun.javadoc.Tag;
import gnu.classpath.tools.doclets.InlineTagRenderer;
/**
* The default Taglet which handles since information.
*
* @author Julian Scheid (julian@sektor37.de)
*/
public class SinceTaglet implements GnuExtendedTaglet {
private static final String NAME = "since";
private static final String HEADER = "Since:";
private static boolean enabled = true;
private InlineTagRenderer inlineTagRenderer;
public SinceTaglet(InlineTagRenderer inlineTagRenderer)
{
this.inlineTagRenderer = inlineTagRenderer;
}
public String getName() {
return NAME;
}
public boolean inField() {
return true;
}
public boolean inConstructor() {
return true;
}
public boolean inMethod() {
return true;
}
public boolean inOverview() {
return true;
}
public boolean inPackage() {
return true;
}
public boolean inType() {
return true;
}
public boolean isInlineTag() {
return false;
}
public String toString(Tag tag) {
// should raise assertion
if (enabled) {
return toString(new Tag[] { tag });
}
else {
return null;
}
}
public String toString(Tag[] tags) {
// should raise assertion
return toString(tags, null);
}
public String toString(Tag tag, TagletContext context)
{
return null;
}
public String toString(Tag[] tags, TagletContext context)
{
if (!enabled || tags.length == 0) {
return null;
}
else {
boolean haveValidTag = false;
for (int i = 0; i < tags.length && !haveValidTag; ++i) {
if (tags[i].text().length() > 0) {
haveValidTag = true;
}
}
if (haveValidTag) {
StringBuffer result = new StringBuffer();
result.append("<dl class=\"tag list\">");
result.append("<dt class=\"tag section header\"><b>");
result.append(HEADER);
result.append("</b></dt>");
for (int i = 0; i < tags.length; ++i) {
if (tags[i].text().length() > 0) {
result.append("<dd>");
result.append(inlineTagRenderer.renderInlineTags(tags[i].inlineTags(), context));
result.append("</dd>");
}
}
result.append("</dl>");
return result.toString();
}
else {
return null;
}
}
}
/**
* Enables/disables this taglet.
*/
public static void setTagletEnabled(boolean enabled)
{
SinceTaglet.enabled = enabled;
}
}