Interface ClassMaker
- All Superinterfaces:
- Maker
Allows new classes and interfaces to be defined dynamically.
- See Also:
- 
Method SummaryModifier and TypeMethodDescriptionSwitch this class to be abstract.Add code to the static initializer of this class.default MethodMakeraddConstructor(MethodTypeDesc desc) Add a constructor to this class.default MethodMakeraddConstructor(MethodType type) Add a constructor to this class.addConstructor(Object... paramTypes) Add a constructor to this class.Add a field to the class.addInnerClass(String className) Add an inner class to this class.Add a method to this class.default MethodMakeraddMethod(String name, MethodTypeDesc desc) Add a method to this class.default MethodMakeraddMethod(String name, MethodType type) Add a method to this class.Indicate that this class is defining an annotation interface.Begin defining another class with the same loader and lookup as this one.default TypearrayType(int dimensions) Returns a type object which represents the class being made as an array.asRecord()Convert this class to arecord, and return a newly added constructor for it.static ClassMakerbegin()Begin defining a class with an automatically assigned name.static ClassMakerBegin defining a class with the given name, but the actual name will have a suffix applied to ensure uniqueness.static ClassMakerbegin(String className, ClassLoader parentLoader) Begin defining a class with the given name, but the actual name will have a suffix applied to ensure uniqueness.static ClassMakerbegin(String className, ClassLoader parentLoader, Object key) Begin defining a class with the given name, but the actual name will have a suffix applied to ensure uniqueness.static ClassMakerbegin(String className, MethodHandles.Lookup lookup) Begin defining a class with the given name, but the actual name will have a suffix applied to ensure uniqueness.static ClassMakerbeginExplicit(String className, ClassLoader parentLoader, Object key) Begin defining a class with an explicitly specified name.static ClassMakerbeginExplicit(String className, MethodHandles.Lookup lookup) Begin defining a class with an explicitly specified name.static ClassMakerbeginExternal(String className) Begin defining a class intended to be loaded from a file.Returns the class loader that the finished class will be loaded into.enum_()Indicate that this class is defining an enum.Set a class that this class extends.final_()Switch this class to be final.Class<?> finish()Finishes the definition of the new class.byte[]Finishes the definition of the new class into a byte array.Finishes the definition of a new hidden class, returning a lookup which has full privilege access to the class.Finishes the definition of the new class, returning a lookup which has full privilege access to the class.voidfinishTo(OutputStream out) Finishes the definition of the new class and writes it to a stream.Add an interface that this class or interface implements.booleaninstallClass(Class<?> clazz) Directly install a dependent class into the class loader used by the finished class.Switch this class to be an interface.default Stringname()Returns the tentative name of the class being made.permitSubclass(Object subclass) Convert this class into a sealed class by permitting a subclass.private_()Switch this class to be private.Switch this class to be protected.public_()Switch this class to be public.Define a signature for this member, which is a string for supporting generic types.sourceFile(String fileName) Set the source file of this class file by adding a source file attribute.static_()Switch this class to be static.Indicate that this class is synthetic.type()Returns the type of this class being made.Returns the set of methods which would need to be implemented by this class in order for it to be non-abstract.Methods inherited from interface org.cojen.maker.MakeraddAnnotation, addAttribute, classMaker
- 
Method Details- 
beginBegin defining a class with an automatically assigned name.
- 
beginBegin defining a class with the given name, but the actual name will have a suffix applied to ensure uniqueness.- Parameters:
- className- fully qualified class name; pass null to automatically assign a name
 
- 
beginBegin defining a class with the given name, but the actual name will have a suffix applied to ensure uniqueness.- Parameters:
- className- fully qualified class name; pass null to automatically assign a name
- parentLoader- parent class loader; pass null to use default
 
- 
beginBegin defining a class with the given name, but the actual name will have a suffix applied to ensure uniqueness.- Parameters:
- className- fully qualified class name; pass null to automatically assign a name
- parentLoader- parent class loader; pass null to use default
- key- an opaque key used for creating distinct class loaders; can be null
 
- 
beginBegin defining a class with the given name, but the actual name will have a suffix applied to ensure uniqueness.- Parameters:
- className- fully qualified class name; pass null to automatically assign a name
- lookup- finish loading the class using this lookup object
 
- 
beginExplicitBegin defining a class with an explicitly specified name.- Parameters:
- className- fully qualified class name
- parentLoader- parent class loader; pass null to use default
- key- an opaque key used for creating distinct class loaders; can be null
 
- 
beginExplicitBegin defining a class with an explicitly specified name.- Parameters:
- className- fully qualified class name
- lookup- finish loading the class using this lookup object
 
- 
beginExternalBegin defining a class intended to be loaded from a file. The class name exactly matches the one given, andsetExactis unsupported. All classes defined from this maker will also be external.- Parameters:
- className- fully qualified class name
- See Also:
 
- 
anotherBegin defining another class with the same loader and lookup as this one. The actual class name will have a suffix applied to ensure uniqueness, unless this maker creates explicit or external classes.The returned ClassMakerinstance isn't attached to this maker, and so it can be acted upon by a different thread.- Parameters:
- className- fully qualified class name; pass null to automatically assign a name (unless explicit or external)
- See Also:
 
- 
typeType type()Returns the type of this class being made.
- 
nameReturns the tentative name of the class being made. IffinishHiddenis called, then the actual class name will differ.
- 
public_ClassMaker public_()Switch this class to be public. Classes are package-private by default.
- 
private_ClassMaker private_()Switch this class to be private. Classes are package-private by default.
- 
protected_ClassMaker protected_()Switch this class to be protected. Classes are package-private by default.- Specified by:
- protected_in interface- Maker
- Returns:
- this
 
- 
static_ClassMaker static_()Switch this class to be static. Classes are non-static by default.
- 
final_ClassMaker final_()Switch this class to be final. Classes are non-final by default.
- 
interface_ClassMaker interface_()Switch this class to be an interface. Classes are classes by default.- Returns:
- this
 
- 
abstract_ClassMaker abstract_()Switch this class to be abstract. Classes are non-abstract by default.- Returns:
- this
 
- 
syntheticClassMaker synthetic()Indicate that this class is synthetic. Classes are non-synthetic by default.
- 
enum_ClassMaker enum_()Indicate that this class is defining an enum. No checks or modifications are performed to ensure that the enum class is defined correctly.- Returns:
- this
 
- 
annotation
- 
extendSet a class that this class extends.- Parameters:
- superClass- non-null type, specified by a Class or a String, etc.
- Returns:
- this
- Throws:
- IllegalArgumentException- if the type is unsupported
- IllegalStateException- if already assigned
 
- 
implementAdd an interface that this class or interface implements. Call this method multiple times to implement more interfaces.- Parameters:
- iface- non-null type, specified by a Class or a String, etc.
- Returns:
- this
- Throws:
- IllegalArgumentException- if the type is unsupported
 
- 
signatureDefine a signature for this member, which is a string for supporting generic types. The components can be strings or types (class, ClassMaker, etc.), which are concatenated into a single string. Consult the JVM specification for the signature syntax.
- 
permitSubclassConvert this class into a sealed class by permitting a subclass. Call this method multiple times to permit more subclasses.- Parameters:
- subclass- non-null type, specified by a Class or a String, etc.
- Returns:
- this
- Throws:
- IllegalArgumentException- if the type is unsupported
 
- 
addFieldAdd a field to the class.- Parameters:
- type- a class or name
- Throws:
- IllegalArgumentException- if the type is unsupported
- IllegalStateException- if field is already defined
 
- 
addMethodAdd a method to this class.- Parameters:
- retType- a class or name; can be null if the method returns void
- paramTypes- classes or names
- Throws:
- IllegalArgumentException- if a type is unsupported
 
- 
addMethodAdd a method to this class.- Parameters:
- type- defines the return type and parameter types
 
- 
addMethodAdd a method to this class.- Parameters:
- desc- defines the return type and parameter types
 
- 
addConstructorAdd a constructor to this class.- Parameters:
- paramTypes- classes or names
- Throws:
- IllegalArgumentException- if a type is unsupported
 
- 
addConstructorAdd a constructor to this class.- Parameters:
- type- defines the parameter types
- Throws:
- IllegalArgumentException- if the return type isn't void
 
- 
addConstructorAdd a constructor to this class.- Parameters:
- desc- defines the parameter types
- Throws:
- IllegalArgumentException- if the return type isn't void
 
- 
addClinitMethodMaker addClinit()Add code to the static initializer of this class. Multiple initializers can be added, and they're all stitched together when the class definition is finished. Returning from one initializer only breaks out of the local scope.
- 
asRecordMethodMaker asRecord()Convert this class to arecord, and return a newly added constructor for it. Each field which is currently defined in this class is treated as a record component, and each is also represented by a constructor parameter. The constructor shouldn't set the fields directly, since this is performed automatically at the end.Unless already defined, the equals,hashCode, andtoStringmethods are automatically added. The same rule applies for the component accessor methods.
- 
addInnerClassAdd an inner class to this class. The actual class name will have a suitable suffix applied to ensure uniqueness.The returned ClassMakerinstance isn't attached to this maker, and so it can be acted upon by a different thread.- Parameters:
- className- simple class name; pass null to use default
- Throws:
- IllegalArgumentException- if not given a simple class name
- See Also:
 
- 
sourceFileSet the source file of this class file by adding a source file attribute.- Returns:
- this
 
- 
arrayTypeReturns a type object which represents the class being made as an array.- Parameters:
- dimensions- must be at least 1
- Throws:
- IllegalArgumentException- if the given dimensions is less than 1 or greater than 255
 
- 
classLoaderClassLoader classLoader()Returns the class loader that the finished class will be loaded into.
- 
installClassDirectly install a dependent class into the class loader used by the finished class. This is necessary when the given class cannot be found by the normal hierarchical class loading technique.Note: When installed, the given class is held by a weak reference, to facilitate unloading. If the installed class isn't already referenced by this ClassMakerand it can be unloaded before finishing the new class, areachability fencemight be required.- Returns:
- true if installed, or else false if the class was already installed
- Throws:
- IllegalStateException- if this maker was begun with a lookup object, or if the class loader already refers to a different class with the same name
 
- 
unimplementedMethods
- 
finishClass<?> finish()Finishes the definition of the new class.- Throws:
- IllegalStateException- if already finished or if the definition is broken
 
- 
finishLookupMethodHandles.Lookup finishLookup()Finishes the definition of the new class, returning a lookup which has full privilege access to the class. Calling this method has the side effect of forcing the new class to be initialized.- Returns:
- the lookup for the class; call lookupClassto obtain the actual class
- Throws:
- IllegalStateException- if already finished or if the definition is broken
 
- 
finishHiddenMethodHandles.Lookup finishHidden()Finishes the definition of a new hidden class, returning a lookup which has full privilege access to the class. Hidden classes are automatically unloaded when no longer referenced, even if the class loader still is. If a lookup object was passed to thebeginmethod, the hidden class is defined in the same nest as the lookup class.- Returns:
- the lookup for the class; call lookupClassto obtain the actual class
- Throws:
- IllegalStateException- if already finished or if the definition is broken
 
- 
finishBytesbyte[] finishBytes()Finishes the definition of the new class into a byte array.- Throws:
- IllegalStateException- if already finished or if the definition is broken
 
- 
finishToFinishes the definition of the new class and writes it to a stream.- Throws:
- IllegalStateException- if already finished or if the definition is broken
- IOException
 
 
-