Interface ClassFileBuilder<E extends ClassFileElement, B extends ClassFileBuilder<E,B>> 
- Type Parameters:
- E- the member element type
- B- the self type of this builder
- All Superinterfaces:
- Consumer<E>
- All Known Subinterfaces:
- ClassBuilder, CodeBuilder, CodeBuilder.BlockCodeBuilder, FieldBuilder, MethodBuilder
CompoundElement, which accepts the member elements
to be integrated into the built structure.  Builders are usually passed as
an argument to Consumer handlers, such as in ClassFile.build(ClassDesc, Consumer).  The handlers should deliver elements
to a builder similar to how a CompoundElement traverses its member
elements.
The basic way a builder accepts elements is through with(E), which
supports call chaining.  Concrete subtypes of builders usually define extra
methods to define elements directly to the builder, such as ClassBuilder.withFlags(int) or CodeBuilder.aload(int).
Whether a member element can appear multiple times in a compound structure
affects the behavior of the element in ClassFileBuilders.  If an
element can appear at most once but multiple instances are supplied to a
ClassFileBuilder, the last supplied instance appears on the built
structure.  If an element appears exactly once but no instance is supplied,
an unspecified default value element may be used in that structure.
Due to restrictions of the class file format, certain member elements
that can be modeled by the API cannot be represented in the built structure
under specific circumstances.  Passing such elements to the builder causes
IllegalArgumentException.  Some ClassFile.Options control
whether such elements should be altered or dropped to produce valid 
class files.
- 
Method SummaryModifier and TypeMethodDescriptiondefault voidIntegrates the member element into the structure being built.Returns the constant pool builder associated with this builder.default Btransform(CompoundElement<E> model, ClassFileTransform<?, E, B> transform) Applies a transform to a compound structure, directing results to this builder.Integrates the member element into the structure being built.
- 
Method Details- 
acceptIntegrates the member element into the structure being built.- Specified by:
- acceptin interface- Consumer<E extends ClassFileElement>
- API Note:
- This method exists to implement Consumer; users can usewith(E)for call chaining.
- Parameters:
- e- the member element
- Throws:
- IllegalArgumentException- if the member element cannot be represented in the- classfile format
 
- 
withIntegrates the member element into the structure being built.- Parameters:
- e- the member element
- Returns:
- this builder
- Throws:
- IllegalArgumentException- if the member element cannot be represented in the- classfile format
 
- 
constantPoolConstantPoolBuilder constantPool()Returns the constant pool builder associated with this builder.- Returns:
- the constant pool builder associated with this builder
 
- 
transformApplies a transform to a compound structure, directing results to this builder.The transform will receive each element of the compound structure, as well as this builder for building the structure. The transform is free to preserve, remove, or replace elements as it sees fit. A builder can run multiple transforms against different compound structures, integrating member elements of different origins. - API Note:
- Many subinterfaces have methods like ClassBuilder.transformMethod(MethodModel, MethodTransform)orMethodBuilder.transformCode(CodeModel, CodeTransform). However, calling them is fundamentally different from calling this method: those methods call thetransformon the child builders instead of on itself. For example,classBuilder.transformMethodcallsmethodBuilder.transformwith a new method builder instead of callingclassBuilder.transformon itself.
- Parameters:
- model- the structure to transform
- transform- the transform to apply
- Returns:
- this builder
- See Also:
 
 
-