Class JavaStyleDocumentationWriterBuilder
- java.lang.Object
-
- software.amazon.smithy.codegen.core.writer.JavaStyleDocumentationWriterBuilder
-
public final class JavaStyleDocumentationWriterBuilder extends java.lang.Object
A builder used to create aDocumentationWriter
for Java style documentation comments.Documentation comments are automatically sanitized by escaping a closing documentation comment (i.e., star (*) followed by a forward slash (/)). This should also work for JavaScript, PHP, and other languages that use Java-style comments.
-
-
Constructor Summary
Constructors Constructor Description JavaStyleDocumentationWriterBuilder()
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description <T extends CodeWriter>
DocumentationWriter<T>build()
Creates aDocumentationWriter
configured by the builder.JavaStyleDocumentationWriterBuilder
escapeAtSignWithEntity(boolean escapeAtSignWithEntity)
Sets whether or not the "@" sign is escaped with an HTML entity.static java.lang.String
escapeAtSignWithEntity(java.lang.String contents)
A function used to escape the @ sign of a documentation comment with an HTML entity of @.static java.lang.String
escapeClosingChars(java.lang.String contents)
A function used to escape the closing tokens of a documentation comment.JavaStyleDocumentationWriterBuilder
mappingFunction(java.util.function.Function<java.lang.String,java.lang.String> mappingFunction)
Sets a custom mapping function to use when filtering documentation.JavaStyleDocumentationWriterBuilder
namedDocumentationSection(java.lang.String namedDocumentationSection)
Sets a specific named section to use when writing documentation.
-
-
-
Method Detail
-
escapeClosingChars
public static java.lang.String escapeClosingChars(java.lang.String contents)
A function used to escape the closing tokens of a documentation comment.- Parameters:
contents
- Contents to sanitize.- Returns:
- Returns the sanitized contents.
-
escapeAtSignWithEntity
public static java.lang.String escapeAtSignWithEntity(java.lang.String contents)
A function used to escape the @ sign of a documentation comment with an HTML entity of @.- Parameters:
contents
- Contents to sanitize.- Returns:
- Returns the sanitized contents.
-
build
public <T extends CodeWriter> DocumentationWriter<T> build()
Creates aDocumentationWriter
configured by the builder.- Type Parameters:
T
- The type of writer to create.- Returns:
- Returns the created documentation writer.
-
namedDocumentationSection
public JavaStyleDocumentationWriterBuilder namedDocumentationSection(java.lang.String namedDocumentationSection)
Sets a specific named section to use when writing documentation.- Parameters:
namedDocumentationSection
- The name of the state's section to use.- Returns:
- Returns the builder.
-
mappingFunction
public JavaStyleDocumentationWriterBuilder mappingFunction(java.util.function.Function<java.lang.String,java.lang.String> mappingFunction)
Sets a custom mapping function to use when filtering documentation.Setting a custom mapping function will disable the default mapping function that is used to escape the closing tokens of a block comment. However, other mapping functions will still compose with a custom mapping function if provided (e.g., escaping @ symbols via
escapeAtSignWithEntity(boolean)
still compose with a custom mapping function).- Parameters:
mappingFunction
- Mapping function to use. Set tonull
to use the default.- Returns:
- Returns the builder.
-
escapeAtSignWithEntity
public JavaStyleDocumentationWriterBuilder escapeAtSignWithEntity(boolean escapeAtSignWithEntity)
Sets whether or not the "@" sign is escaped with an HTML entity.At signs are not escaped by default.
- Parameters:
escapeAtSignWithEntity
- Set to true to escape, false to not.- Returns:
- Returns the builder.
-
-