blob: 033b00ef9e5b63e921609a937abcf4d25bbba4af [file] [log] [blame]
/* gnu.classpath.tools.taglets.VersionTaglet
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;
/**
* The default Taglet which handles version information.
*
* @author Julian Scheid (julian@sektor37.de)
*/
public class VersionTaglet implements Taglet {
private static final String NAME = "version";
private static final String HEADER = "Version:";
private static boolean enabled = true;
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 static void register(Map tagletMap) {
VersionTaglet versionTaglet = new VersionTaglet();
tagletMap.put(versionTaglet.getName(), versionTaglet);
}
public String toString(Tag tag) {
if (enabled) {
return toString(new Tag[] { tag });
}
else {
return null;
}
}
public String toString(Tag[] tags) {
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("</dl>");
result.append("<dt class=\"tag section header\"><b>");
result.append(HEADER);
result.append("</b></dt><dd>");
boolean firstEntry = true;
for (int i = 0; i < tags.length; i++) {
if (tags[i].text().length() > 0) {
if (!firstEntry) {
result.append(", ");
}
else {
firstEntry = false;
}
result.append(tags[i].text());
}
}
result.append("</dd>");
result.append("</dl>");
return result.toString();
}
else {
return null;
}
}
}
/**
* Enables/disables this taglet.
*/
public static void setTagletEnabled(boolean enabled)
{
VersionTaglet.enabled = enabled;
}
}