use of com.webcohesion.enunciate.javac.decorations.element.DecoratedPackageElement in project enunciate by stoicflame.
the class ApiDocsJavaDocTagHandler method onInlineTag.
@Override
public String onInlineTag(String tagName, String tagText, DecoratedElement context) {
if ("link".equals(tagName)) {
JavaDocLink link = JavaDocLink.parse(tagText);
String classRef = link.getClassName();
String subelementRef = link.getMemberName();
String value = link.getLabel();
// use the current context as the class ref.
if ("".equals(classRef)) {
DecoratedElement type = context;
while (!(type instanceof DecoratedTypeElement)) {
type = (DecoratedElement) type.getEnclosingElement();
if (type == null || type instanceof PackageElement) {
break;
}
}
if (type instanceof DecoratedTypeElement) {
classRef = ((DecoratedTypeElement) type).getQualifiedName().toString();
}
}
if (!"".equals(classRef)) {
if (classRef.indexOf('.') < 0) {
// if it's a local reference, assume it's in the current package.
DecoratedElement pckg = context;
while (!(pckg instanceof DecoratedPackageElement)) {
pckg = (DecoratedElement) pckg.getEnclosingElement();
if (pckg == null) {
break;
}
}
if (pckg != null) {
classRef = ((DecoratedPackageElement) pckg).getQualifiedName() + "." + classRef;
}
}
// now find the reference
Set<Syntax> syntaxes = this.registry.getSyntaxes(this.context);
for (Syntax syntax : syntaxes) {
List<DataType> dataTypes = syntax.findDataTypes(classRef);
if (dataTypes != null && !dataTypes.isEmpty()) {
DataType dataType = dataTypes.get(0);
Value dataTypeValue = dataType.findValue(subelementRef);
if (dataTypeValue != null) {
return "<a href=\"" + dataType.getSlug() + ".html#" + dataTypeValue.getValue() + "\">" + (value != null ? value : dataTypeValue.getValue()) + "</a>";
}
Property property = dataType.findProperty(subelementRef);
if (property != null) {
return "<a href=\"" + dataType.getSlug() + ".html#prop-" + property.getName() + "\">" + (value != null ? value : property.getName()) + "</a>";
}
return "<a href=\"" + dataType.getSlug() + ".html\">" + (value != null ? value : (subelementRef.isEmpty() ? dataType.getLabel() : subelementRef)) + "</a>";
}
}
List<ResourceApi> resourceApis = this.registry.getResourceApis(this.context);
for (ResourceApi resourceApi : resourceApis) {
Method method = resourceApi.findMethodFor(classRef, subelementRef);
if (method != null) {
if (value == null) {
value = method.getLabel() + " " + method.getResource().getGroup().getLabel();
}
return "<a href=\"" + method.getResource().getGroup().getSlug() + ".html#" + method.getSlug() + "\">" + value + "</a>";
} else {
ResourceGroup resourceGroup = resourceApi.findResourceGroupFor(classRef);
if (resourceGroup != null) {
if (value == null) {
value = resourceGroup.getLabel();
}
return "<a href=\"" + resourceGroup.getSlug() + ".html\">" + value + "</a>";
}
}
}
List<ServiceApi> serviceApis = this.registry.getServiceApis(this.context);
for (ServiceApi serviceApi : serviceApis) {
Operation operation = serviceApi.findOperationFor(classRef, subelementRef);
if (operation != null) {
if (value == null) {
value = operation.getName();
}
return "<a href=\"" + operation.getService().getSlug() + ".html#" + operation.getSlug() + "\">" + value + "</a>";
} else {
Service service = serviceApi.findServiceFor(classRef);
if (service != null) {
if (value == null) {
value = service.getLabel();
}
return "<a href=\"" + service.getSlug() + ".html\">" + value + "</a>";
}
}
}
}
return value != null ? value : tagText.trim();
} else if ("code".equals(tagName)) {
return "<code>" + tagText + "</code>";
}
return tagText;
}
use of com.webcohesion.enunciate.javac.decorations.element.DecoratedPackageElement in project enunciate by stoicflame.
the class EnunciateConfiguration method readDescription.
public String readDescription(EnunciateContext context, boolean raw, JavaDocTagHandler tagHandler) {
String descriptionPackage = this.source.getString("description[@package]", null);
if (descriptionPackage != null) {
DecoratedPackageElement packageElement = (DecoratedPackageElement) context.getProcessingEnvironment().getElementUtils().getPackageElement(descriptionPackage);
if (packageElement != null) {
String docValue = packageElement.getDocValue(tagHandler);
if (docValue != null) {
return docValue;
}
}
}
String description = null;
String descriptionFile = this.source.getString("description[@file]", null);
if (descriptionFile != null) {
description = readFile(descriptionFile);
}
String specifiedDescription = this.source.getString("description", null);
if (specifiedDescription != null) {
description = specifiedDescription;
}
if (description != null && "markdown".equalsIgnoreCase(this.source.getString("description[@format]", "html")) && !raw) {
MutableDataSet options = new MutableDataSet().set(Parser.EXTENSIONS, Arrays.asList(TablesExtension.create(), StrikethroughExtension.create()));
description = HtmlRenderer.builder().build().render(Parser.builder(options).build().parse(description));
}
return description == null ? this.defaultDescription : description;
}
Aggregations