Class InterfaceSpecImpl.BuilderImpl
- All Implemented Interfaces:
TypeSpec.Builder
- Enclosing class:
InterfaceSpecImpl
TypeSpec.Builder
for an interface.- Author:
- Square,Inc.
- Modified by:
- Thomas Thrien (thomas.thrien@tquadrat.org)
- Version:
- $Id: InterfaceSpecImpl.java 1064 2023-09-26 20:16:12Z tquadrat $
- Since:
- 0.2.0
- UML Diagram
-
UML Diagram for "org.tquadrat.foundation.javacomposer.internal.InterfaceSpecImpl.BuilderImpl"
-
Constructor Summary
ConstructorsConstructorDescriptionBuilderImpl
(JavaComposer composer, CharSequence name) Creates a newBuilderImpl
instance.BuilderImpl
(JavaComposer composer, Optional<String> name) Creates a newBuilderImpl
instance. -
Method Summary
Modifier and TypeMethodDescriptionaddAttribute
(FieldSpec fieldSpec, boolean readOnly) Adds an attribute to this type.Adds a field to this type.addInitializerBlock
(CodeBlock block) Adds code to the initializer block.addMethod
(MethodSpec methodSpec) Adds a method for the type.final TypeSpec.Builder
addProperty
(FieldSpec fieldSpec, boolean readOnly) Adds a JavaBean property to this type.final InterfaceSpecImpl
build()
Builds a newTypeSpec
instance from the added components.superclass
(TypeName superclass) Sets the superclass for the type.Methods inherited from class org.tquadrat.foundation.javacomposer.internal.TypeSpecImpl.BuilderImpl
addAnnotation, addAnnotation, addAnnotation, addAnnotations, addEnumConstant, addEnumConstant, addEnumConstant, addEnumConstant, addField, addField, addFields, addJavadoc, addJavadoc, addMethods, addModifiers, addOriginatingElement, addStaticBlock, addStaticImport, addStaticImport, addStaticImport, addSuperinterface, addSuperinterface, addSuperinterface, addSuperinterface, addSuperinterfaces, addSuppressableWarning, addType, addTypes, addTypeVariable, addTypeVariable, addTypeVariables, composer, getAnnotations, getAnonymousTypeArguments, getEnumConstants, getFactory, getFieldSpecs, getInitializerBlock, getJavadoc, getMethodSpecs, getModifiers, getName, getStaticBlock, getStaticImports, getSuperclass, getSuperinterfaces, getTypeSpecs, getTypeVariables, isAnonymousClass, superclass
-
Constructor Details
-
BuilderImpl
Creates a newBuilderImpl
instance.- Parameters:
composer
- The reference to the factory that created this builder instance.name
- The name of the type to build.
-
BuilderImpl
Creates a newBuilderImpl
instance.- Parameters:
composer
- The reference to the factory that created this builder instance.name
- The name of the type to build.
-
-
Method Details
-
addAttribute
@API(status=STABLE, since="0.2.0") public final InterfaceSpecImpl.BuilderImpl addAttribute(FieldSpec fieldSpec, boolean readOnly) Adds an attribute to this type.
An attribute is basically a field with the related accessor and mutator methods.
If the name for a non-final property will be
text
, and its type isjava.lang.String
, the generated code will look basically like this:… private String m_Text; … public final String text() { return m_Text; } … public final void text( final String value ) { m_Text = text; } …
If accessor or mutator needs to be more complex, the respective methods must be created manually.
- Specified by:
addAttribute
in interfaceTypeSpec.Builder
- Specified by:
addAttribute
in classTypeSpecImpl.BuilderImpl
- Parameters:
fieldSpec
- The field definition.readOnly
-true
if no mutator should be created even for a non-final field,false
if a mutator has to be created for a non-final field. Will ignored if the field is final.- Returns:
- This
Builder
instance.
-
addField
Adds a field to this type.- Specified by:
addField
in interfaceTypeSpec.Builder
- Overrides:
addField
in classTypeSpecImpl.BuilderImpl
- Parameters:
fieldSpec
- The field definition.- Returns:
- This
Builder
instance.
-
addInitializerBlock
Adds code to the initializer block.- Specified by:
addInitializerBlock
in interfaceTypeSpec.Builder
- Overrides:
addInitializerBlock
in classTypeSpecImpl.BuilderImpl
- Parameters:
block
- The code.- Returns:
- This
Builder
instance.
-
addMethod
Adds a method for the type.- Specified by:
addMethod
in interfaceTypeSpec.Builder
- Specified by:
addMethod
in classTypeSpecImpl.BuilderImpl
- Parameters:
methodSpec
- The method.- Returns:
- This
Builder
instance.
-
addProperty
Adds a JavaBean property to this type.
A property is basically a field with the related getter and setter methods.
If the name for a non-final property will be
text
, and its type isjava.lang.String
, the generated code will look basically like this:… private String m_Text; … public final String getText() { return m_Text; } … public final void setText( final String value ) { m_Text = text; } …
If getter or setter needs to be more complex, the respective methods must be created manually.
- Specified by:
addProperty
in interfaceTypeSpec.Builder
- Specified by:
addProperty
in classTypeSpecImpl.BuilderImpl
- Parameters:
fieldSpec
- The field definition.readOnly
-true
if no setter should be created even for a non-final field,false
if a setter has to be created for a non-final field. Will ignored if the field is final.- Returns:
- This
Builder
instance.
-
build
Builds a newTypeSpec
instance from the added components.- Specified by:
build
in interfaceTypeSpec.Builder
- Specified by:
build
in classTypeSpecImpl.BuilderImpl
- Returns:
- The new
TypeSpec
instance.
-
superclass
Sets the superclass for the type. This class is extended by the new type.
- Specified by:
superclass
in interfaceTypeSpec.Builder
- Overrides:
superclass
in classTypeSpecImpl.BuilderImpl
- Parameters:
superclass
- The superclass.- Returns:
- This
Builder
instance.
-