use of com.google.copybara.doc.DocBase.DocField in project copybara by google.
the class MarkdownRenderer method module.
private CharSequence module(DocModule module, int level) {
StringBuilder sb = new StringBuilder();
sb.append(title(level, module.name));
sb.append(module.description).append("\n\n");
if (!module.fields.isEmpty()) {
sb.append(title(level + 2, "Fields:"));
sb.append(tableHeader("Name", "Description"));
for (DocField field : module.fields) {
sb.append(tableRow(field.name, String.format("%s<br><p>%s</p>", typeName(field.type), field.description)));
}
sb.append("\n");
}
sb.append(flags(module.flags));
for (DocFunction func : module.functions) {
sb.append("<a id=\"").append(func.name).append("\" aria-hidden=\"true\"></a>");
sb.append(title(level + 1, func.name));
sb.append(func.description);
sb.append("\n\n");
if (func.returnType != null) {
sb.append(typeName(func.returnType)).append(" ");
}
sb.append("`").append(func.name).append("(");
Joiner.on(", ").appendTo(sb, Lists.transform(func.params, p -> p.name + (p.defaultValue == null ? "" : "=" + p.defaultValue)));
sb.append(")`\n\n");
if (!func.params.isEmpty()) {
sb.append(title(level + 2, "Parameters:"));
sb.append(tableHeader("Parameter", "Description"));
for (DocParam param : func.params) {
sb.append(tableRow(param.name, String.format("%s<br><p>%s</p>", param.allowedTypes.stream().map(this::typeName).collect(joining(" or ")), param.description)));
}
sb.append("\n");
}
if (!func.examples.isEmpty()) {
sb.append(title(level + 2, func.examples.size() == 1 ? "Example:" : "Examples:"));
for (DocExample example : func.examples) {
sb.append(example(level + 3, example.example));
}
sb.append("\n");
}
sb.append(flags(func.flags));
}
return sb;
}
Aggregations