Class AbstractShapeBuilder<B extends AbstractShapeBuilder<B,S>,S extends Shape>
- java.lang.Object
- 
- software.amazon.smithy.model.shapes.AbstractShapeBuilder<B,S>
 
- 
- Type Parameters:
- B- Concrete builder type.
- S- Shape being created.
 - All Implemented Interfaces:
- FromSourceLocation,- SmithyBuilder<S>
 - Direct Known Subclasses:
- BigDecimalShape.Builder,- BigIntegerShape.Builder,- BlobShape.Builder,- BooleanShape.Builder,- ByteShape.Builder,- CollectionShape.Builder,- DocumentShape.Builder,- DoubleShape.Builder,- EntityShape.Builder,- FloatShape.Builder,- IntegerShape.Builder,- LongShape.Builder,- MapShape.Builder,- MemberShape.Builder,- OperationShape.Builder,- ShortShape.Builder,- StringShape.Builder,- StructureShape.Builder,- TimestampShape.Builder,- UnionShape.Builder
 
 public abstract class AbstractShapeBuilder<B extends AbstractShapeBuilder<B,S>,S extends Shape> extends java.lang.Object implements SmithyBuilder<S>, FromSourceLocation Abstract builder used to createShapes.
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description BaddMember(MemberShape member)Adds a member to the shape IFF the shape supports members.BaddMixin(Shape shape)Adds a mixin to the shape.BaddTrait(Trait trait)Adds a trait to the shape builder, replacing any conflicting traits.BaddTraits(java.util.Collection<? extends Trait> traitsToAdd)Adds traits from an iterator to the shape builder, replacing any conflicting traits.BclearMembers()Removes all members from the builder.BclearMixins()Removes all mixins.BclearTraits()Removes all traits.BflattenMixins()Removes mixins from a shape and flattens them into the shape.java.util.Map<ShapeId,Trait>getAllTraits()Get an immutable view of the traits applied to the builder.ShapeIdgetId()Gets the shape ID of the builder.abstract ShapeTypegetShapeType()Gets the type of shape being built.SourceLocationgetSourceLocation()Gets the source location of a value.Bid(java.lang.String shapeId)Sets the shape ID of the shape.Bid(ShapeId shapeId)Sets the shape ID of the shape.Bmixins(java.util.Collection<? extends Shape> mixins)Replaces the mixins of the shape.BremoveMixin(ToShapeId shape)Removes a mixin from the shape by shape or ID.BremoveTrait(java.lang.String traitId)Removes a trait from the shape builder.BremoveTrait(ShapeId traitId)Removes a trait from the shape builder.Bsource(java.lang.String filename, int line, int column)Sets the source location of the shape.Bsource(SourceLocation sourceLocation)Sets the source location of the shape.Btraits(java.util.Collection<Trait> traitsToSet)Replace all traits in the builder.- 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface software.amazon.smithy.utils.SmithyBuilderbuild
 
- 
 
- 
- 
- 
Method Detail- 
getSourceLocationpublic SourceLocation getSourceLocation() Description copied from interface:FromSourceLocationGets the source location of a value.- Specified by:
- getSourceLocationin interface- FromSourceLocation
- Returns:
- Returns the source location of the value.
 
 - 
getShapeTypepublic abstract ShapeType getShapeType() Gets the type of shape being built.- Returns:
- Returns the shape type.
 
 - 
getIdpublic ShapeId getId() Gets the shape ID of the builder.- Returns:
- Returns null if no shape ID is set.
 
 - 
idpublic B id(ShapeId shapeId) Sets the shape ID of the shape.- Parameters:
- shapeId- Shape ID to set.
- Returns:
- Returns the builder.
 
 - 
idpublic B id(java.lang.String shapeId) Sets the shape ID of the shape.- Parameters:
- shapeId- Absolute shape ID string to set.
- Returns:
- Returns the builder.
- Throws:
- ShapeIdSyntaxException- if the shape ID is invalid.
 
 - 
sourcepublic B source(SourceLocation sourceLocation) Sets the source location of the shape.- Parameters:
- sourceLocation- Source location to set.
- Returns:
- Returns the builder.
 
 - 
sourcepublic B source(java.lang.String filename, int line, int column) Sets the source location of the shape.- Parameters:
- filename- Name of the file in which the shape was defined.
- line- Line number in the file where the shape was defined.
- column- Column number of the line where the shape was defined.
- Returns:
- Returns the builder.
 
 - 
traitspublic B traits(java.util.Collection<Trait> traitsToSet) Replace all traits in the builder.- Parameters:
- traitsToSet- Sequence of traits to set on the builder.
- Returns:
- Returns the builder.
 
 - 
getAllTraitspublic java.util.Map<ShapeId,Trait> getAllTraits() Get an immutable view of the traits applied to the builder.- Returns:
- Returns the applied traits.
 
 - 
addTraitspublic B addTraits(java.util.Collection<? extends Trait> traitsToAdd) Adds traits from an iterator to the shape builder, replacing any conflicting traits.- Parameters:
- traitsToAdd- Sequence of traits to add to the builder.
- Returns:
- Returns the builder.
 
 - 
addTraitpublic B addTrait(Trait trait) Adds a trait to the shape builder, replacing any conflicting traits.- Parameters:
- trait- Trait instance to add.
- Returns:
- Returns the builder.
 
 - 
removeTraitpublic B removeTrait(java.lang.String traitId) Removes a trait from the shape builder.A relative trait name will attempt to remove a prelude trait with the given name. - Parameters:
- traitId- Absolute or relative ID of the trait to remove.
- Returns:
- Returns the builder.
 
 - 
removeTraitpublic B removeTrait(ShapeId traitId) Removes a trait from the shape builder.- Parameters:
- traitId- ID of the trait to remove.
- Returns:
- Returns the builder.
 
 - 
clearTraitspublic B clearTraits() Removes all traits.- Returns:
- Returns the builder.
 
 - 
addMemberpublic B addMember(MemberShape member) Adds a member to the shape IFF the shape supports members.- Parameters:
- member- Member to add to the shape.
- Returns:
- Returns the builder.
- Throws:
- java.lang.UnsupportedOperationException- if the shape does not support members.
 
 - 
clearMemberspublic B clearMembers() Removes all members from the builder.- Returns:
- Returns the builder.
 
 - 
addMixinpublic B addMixin(Shape shape) Adds a mixin to the shape.- Parameters:
- shape- Mixin to add.
- Returns:
- Returns the builder.
 
 - 
mixinspublic B mixins(java.util.Collection<? extends Shape> mixins) Replaces the mixins of the shape.- Parameters:
- mixins- Mixins to add.
- Returns:
- Returns the builder.
 
 - 
removeMixinpublic B removeMixin(ToShapeId shape) Removes a mixin from the shape by shape or ID.- Parameters:
- shape- Shape or shape ID to remove.
- Returns:
- Returns the builder.
 
 - 
clearMixinspublic B clearMixins() Removes all mixins.- Returns:
- Returns the builder.
 
 - 
flattenMixinspublic B flattenMixins() Removes mixins from a shape and flattens them into the shape.Flattening a mixin into a shape copies the traits and members of a mixin onto the shape, effectively resulting in the same shape but with no trace of the mixin relationship. - Returns:
- Returns the updated builder.
 
 
- 
 
-