blob: a17e0b332100e797d13be9df85968d320513e3d9 [file] [log] [blame]
/*
* Copyright 2006 Google Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/
package com.google.doctool.custom;
import com.sun.javadoc.Tag;
import com.sun.tools.doclets.Taglet;
import java.util.Map;
/**
* A taglet for including GWT tip tags in javadoc output.
*/
public class TipTaglet implements Taglet {
public static void register(Map tagletMap) {
TipTaglet tag = new TipTaglet();
Taglet t = (Taglet) tagletMap.get(tag.getName());
if (t != null) {
tagletMap.remove(tag.getName());
}
tagletMap.put(tag.getName(), tag);
}
public TipTaglet() {
}
public String getName() {
return "tip";
}
public boolean inConstructor() {
return true;
}
public boolean inField() {
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) {
return null;
}
public String toString(Tag[] tags) {
if (tags == null || tags.length == 0) {
return null;
}
String result = "<DT><B>Tip:</B></DT><DD>";
if (tags.length == 1) {
result += tags[0].text();
} else {
result += "<UL>";
for (int i = 0; i < tags.length; i++) {
result += "<LI>" + tags[i].text() + "</LI>";
}
result += "</UL>";
}
result += "</DD>";
return result;
}
}