/*
* Copyright (c) 2008-2014 MongoDB, 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 taglets;
import com.sun.javadoc.Tag;
import com.sun.tools.doclets.Taglet;
/**
* Provides a general base class for Morphia taglets
*/
public abstract class DocTaglet implements Taglet {
@Override
public boolean inConstructor() {
return true;
}
@Override
public boolean inField() {
return true;
}
@Override
public boolean inMethod() {
return true;
}
@Override
public boolean inOverview() {
return true;
}
@Override
public boolean inPackage() {
return true;
}
@Override
public boolean inType() {
return true;
}
@Override
public boolean isInlineTag() {
return false;
}
@Override
public String toString(final Tag[] tags) {
if (tags.length == 0) {
return null;
}
StringBuilder buf = new StringBuilder(String.format("\n<dl><dt><span class=\"strong\">%s</span></dt>\n", getHeader()));
for (Tag t : tags) {
buf.append(" <dd>").append(genLink(t.text())).append("</dd>\n");
}
return buf.toString();
}
protected abstract String getHeader();
@Override
public String toString(final Tag tag) {
return toString(new Tag[]{tag});
}
protected String genLink(final String text) {
String relativePath = text;
String display = text;
int firstSpace = text.indexOf(' ');
if (firstSpace != -1) {
relativePath = text.substring(0, firstSpace);
display = text.substring(firstSpace, text.length()).trim();
}
return String.format("<a href='%s%s'>%s</a>", getBaseDocURI(), relativePath, display);
}
protected abstract String getBaseDocURI();
}