blob: 757071e8e508f8ba27dd63490dba56ca9b6bbf8e [file] [log] [blame]
/* gnu.classpath.tools.taglets.GenericTaglet
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;
/**
* A taglet which can be configured at runtime.
*
* @author Julian Scheid (julian@sektor37.de)
*/
public class GenericTaglet implements Taglet {
private String name = "since";
private String header = "Since:";
private boolean scopeOverview;
private boolean scopePackage;
private boolean scopeType;
private boolean scopeConstructor;
private boolean scopeMethod;
private boolean scopeField;
private boolean enabled = true;
public GenericTaglet(String name,
String header,
boolean scopeOverview,
boolean scopePackage,
boolean scopeType,
boolean scopeConstructor,
boolean scopeMethod,
boolean scopeField)
{
this.name = name;
this.header = header;
this.scopeOverview = scopeOverview;
this.scopePackage = scopePackage;
this.scopeType = scopeType;
this.scopeConstructor = scopeConstructor;
this.scopeMethod = scopeMethod;
this.scopeField = scopeField;
}
public String getName() {
return name;
}
public boolean inField() {
return scopeField;
}
public boolean inConstructor() {
return scopeConstructor;
}
public boolean inMethod() {
return scopeMethod;
}
public boolean inOverview() {
return scopeOverview;
}
public boolean inPackage() {
return scopePackage;
}
public boolean inType() {
return scopeType;
}
public boolean isInlineTag() {
return false;
}
public void register(Map tagletMap) {
tagletMap.put(getName(), this);
}
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 {
StringBuffer result = new StringBuffer();
result.append("<div class=\"classdoc-tag-section-header\">");
result.append(header);
result.append("</div>");
result.append("<dl class=\"classdoc-list\">");
for (int i = 0; i < tags.length; i++) {
result.append("<dt>");
result.append(tags[i].text());
result.append("</dt>");
}
result.append("</dl>");
return result.toString();
}
}
/**
* Enables/disables this taglet.
*/
public void setTagletEnabled(boolean enabled)
{
this.enabled = enabled;
}
}