Package com.squareup.javapoet
Class CodeBlock
- java.lang.Object
-
- com.squareup.javapoet.CodeBlock
-
public final class CodeBlock extends java.lang.ObjectA fragment of a .java file, potentially containing declarations, statements, and documentation. Code blocks are not necessarily well-formed Java code, and are not validated. This class assumes javac will check correctness later!Code blocks support placeholders like
Format. WhereString.format(java.lang.String, java.lang.Object...)uses percent%to reference target values, this class uses dollar sign$and has its own set of permitted placeholders:$Lemits a literal value with no escaping. Arguments for literals may be strings, primitives, type declarations, annotations and even other code blocks.$Nemits a name, using name collision avoidance where necessary. Arguments for names may be strings (actually any character sequence), parameters, fields, methods, and types.$Sescapes the value as a string, wraps it with double quotes, and emits that. For example,6" sandwichis emitted"6\" sandwich".$Temits a type reference. Types will be imported if possible. Arguments for types may be classes, ,* type mirrors, and elements.$$emits a dollar sign.$Wemits a space or a newline, depending on its position on the line. This prefers to wrap lines before 100 columns.$Zacts as a zero-width space. This prefers to wrap lines before 100 columns.$>increases the indentation level.$<decreases the indentation level.$[begins a statement. For multiline statements, every line after the first line is double-indented.$]ends a statement.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classCodeBlock.Builderprivate static classCodeBlock.CodeBlockJoiner
-
Field Summary
Fields Modifier and Type Field Description (package private) java.util.List<java.lang.Object>args(package private) java.util.List<java.lang.String>formatPartsA heterogeneous list containing string literals and value placeholders.private static java.util.regex.PatternLOWERCASEprivate static java.util.regex.PatternNAMED_ARGUMENT
-
Constructor Summary
Constructors Modifier Constructor Description privateCodeBlock(CodeBlock.Builder builder)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description static CodeBlock.Builderbuilder()booleanequals(java.lang.Object o)inthashCode()booleanisEmpty()static CodeBlockjoin(java.lang.Iterable<CodeBlock> codeBlocks, java.lang.String separator)static java.util.stream.Collector<CodeBlock,?,CodeBlock>joining(java.lang.String separator)static java.util.stream.Collector<CodeBlock,?,CodeBlock>joining(java.lang.String separator, java.lang.String prefix, java.lang.String suffix)static CodeBlockof(java.lang.String format, java.lang.Object... args)CodeBlock.BuildertoBuilder()java.lang.StringtoString()
-
-
-
Field Detail
-
NAMED_ARGUMENT
private static final java.util.regex.Pattern NAMED_ARGUMENT
-
LOWERCASE
private static final java.util.regex.Pattern LOWERCASE
-
formatParts
final java.util.List<java.lang.String> formatParts
A heterogeneous list containing string literals and value placeholders.
-
args
final java.util.List<java.lang.Object> args
-
-
Constructor Detail
-
CodeBlock
private CodeBlock(CodeBlock.Builder builder)
-
-
Method Detail
-
isEmpty
public boolean isEmpty()
-
equals
public boolean equals(java.lang.Object o)
- Overrides:
equalsin classjava.lang.Object
-
hashCode
public int hashCode()
- Overrides:
hashCodein classjava.lang.Object
-
toString
public java.lang.String toString()
- Overrides:
toStringin classjava.lang.Object
-
of
public static CodeBlock of(java.lang.String format, java.lang.Object... args)
-
join
public static CodeBlock join(java.lang.Iterable<CodeBlock> codeBlocks, java.lang.String separator)
JoinscodeBlocksinto a singleCodeBlock, each separated byseparator. For example, joiningString s,Object oandint iusing", "would produceString s, Object o, int i.
-
joining
public static java.util.stream.Collector<CodeBlock,?,CodeBlock> joining(java.lang.String separator)
ACollectorimplementation that joinsCodeBlockinstances together into one separated byseparator. For example, joiningString s,Object oandint iusing", "would produceString s, Object o, int i.
-
joining
public static java.util.stream.Collector<CodeBlock,?,CodeBlock> joining(java.lang.String separator, java.lang.String prefix, java.lang.String suffix)
ACollectorimplementation that joinsCodeBlockinstances together into one separated byseparator. For example, joiningString s,Object oandint iusing", "would produceString s, Object o, int i.
-
builder
public static CodeBlock.Builder builder()
-
toBuilder
public CodeBlock.Builder toBuilder()
-
-