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(java.lang.classfile.MethodModel, java.lang.classfile.MethodTransform)orMethodBuilder.transformCode(java.lang.classfile.CodeModel, java.lang.classfile.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:
 
 
-