io.github.mmm.code.api.doc.CodeDoc Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of mmm-code-api Show documentation
Show all versions of mmm-code-api Show documentation
The API to parse, analyze, transform and generate code.
/* Copyright (c) The m-m-m Team, Licensed under the Apache License, Version 2.0
* http://www.apache.org/licenses/LICENSE-2.0 */
package io.github.mmm.code.api.doc;
import java.util.Collection;
import java.util.List;
import io.github.mmm.code.api.copy.CodeNodeItemCopyable;
import io.github.mmm.code.api.element.CodeElement;
import io.github.mmm.code.api.item.CodeItem;
import io.github.mmm.code.api.merge.CodeSimpleMergeableItem;
/**
* {@link CodeItem} representing API documentation (e.g. JavaDoc or JSDoc). Please read documentation of
* {@link #getLines()} before using.
*
* @author Joerg Hohwiller (hohwille at users.sourceforge.net)
* @since 1.0.0
*/
public interface CodeDoc extends CodeSimpleMergeableItem, CodeNodeItemCopyable {
/**
* Tag for the documentation of the parameter of a function. This tag will be invisible via this API as the according
* doc is accessed via the according {@link io.github.mmm.code.api.arg.CodeParameter}.
*/
String TAG_PARAM = "param";
/**
* Tag for the documentation of an exception. This tag will be invisible via this API as the according doc is accessed
* via the according {@link io.github.mmm.code.api.arg.CodeException}.
*/
String TAG_THROWS = "throws";
/**
* Tag for the documentation of returned result of a function. This tag will be invisible via this API as the
* according doc is accessed via the according {@link io.github.mmm.code.api.arg.CodeReturn}.
*/
String TAG_RETURN = "return";
/** {@link CodeDocFormat#replaceDocTag(String, java.util.function.Supplier, String) Doc tag} for a link. */
String TAG_LINK = "link";
/**
* {@link CodeDocFormat#replaceDocTag(String, java.util.function.Supplier, String) Doc tag} for a plain link.
*/
String TAG_LINKPLAIN = "linkplain";
/**
* {@link CodeDocFormat#replaceDocTag(String, java.util.function.Supplier, String) Doc tag} for a code format.
*/
String TAG_CODE = "code";
/**
* {@link CodeDocFormat#replaceDocTag(String, java.util.function.Supplier, String) Doc tag} for an un-escaped literal.
*/
String TAG_LITERAL = "literal";
/**
* {@link CodeDocFormat#replaceDocTag(String, java.util.function.Supplier, String) Doc tag} for a value reference.
*/
String TAG_VALUE = "value";
/**
* Empty {@link #getLinesAsArray() lines}.
*/
String[] NO_LINES = new String[0];
/**
* @param format the requested {@link CodeDocFormat}.
* @return this documentation as {@link String} in the given {@link CodeDocFormat}. Will be the
* {@link String#isEmpty() empty} {@link String} if not available and therefore never null
.
*/
default String getFormatted(CodeDocFormat format) {
return getFormatted(format, DEFAULT_NEWLINE);
}
/**
* @param format the requested {@link CodeDocFormat}.
* @param newline the newline {@link String}.
* @return this documentation as {@link String} in the given {@link CodeDocFormat}. Will be the
* {@link String#isEmpty() empty} {@link String} if not available and therefore never null
.
*/
String getFormatted(CodeDocFormat format, String newline);
/**
* Attention: Child elements such as {@link io.github.mmm.code.api.arg.CodeParameter}s,
* {@link io.github.mmm.code.api.arg.CodeException}s, {@link io.github.mmm.code.api.arg.CodeReturn}, and
* {@link io.github.mmm.code.api.type.CodeTypeVariable}s hold their specific {@link CodeDoc} that is not included in
* the {@link CodeDoc} of their parent {@link io.github.mmm.code.api.member.CodeOperation} or
* {@link io.github.mmm.code.api.type.CodeType}. Therefore you shall not see or {@link #add(String...) add} any lines
* with tags such as "@param", "@throws", or "@return". These will only be produced on-the-fly when the
* {@link #getSourceCode() source-code} is produced.
*
* @return the {@link List} with the raw lines of documentation without leading format prefix ("/**", "*", "/*").
*/
List getLines();
/**
* @return the {@link #getLines() documentation lines} as array.
* @see #getLines()
*/
default String[] getLinesAsArray() {
List lines = getLines();
if (lines.isEmpty()) {
return CodeDoc.NO_LINES;
}
return lines.toArray(new String[lines.size()]);
}
/**
* Please read documentation of {@link #getLines()} before using.
*
* @param lines the textual documentation lines to add to {@link #getLines()}.
* @throws io.github.mmm.base.exception.ReadOnlyException if {@link #isImmutable() immutable}.
*/
void add(Collection lines);
/**
* Please read documentation of {@link #getLines()} before using.
*
* @param lines the textual documentation lines to add to {@link #getLines()}.
* @throws io.github.mmm.base.exception.ReadOnlyException if {@link #isImmutable() immutable}.
*/
void add(String... lines);
/**
* @return {@code true} if this documentation is empty.
*/
boolean isEmpty();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy