Init(args)
Scripting Reference
Loading...
Searching...
No Matches
Sisus.Init.WrapperInitializerBase< TWrapper, TWrapped, TArgument > Class Template Referenceabstract

Description

A base class for a component that can specify the constructor argument used to initialize a plain old class object which then gets wrapped by a Wrapper<TWrapped> component.

The argument value can be assigned using the inspector and serialized as part of a scene or a prefab.

The TWrapped wrapped object gets created and injected to the TWrapper wrapper component during the Awake event.

After the object has been injected the WrapperInitializer<,,> is removed from the GameObject that holds it.

When you derive your Initializer class from WrapperInitializerBase<,,> you are responsible for implementing the argument properties and serializing their value. This means you will need to write a little bit more code, but it also grants you more options in how to handle the serialization, making it possible to support types that Unity can't serialize automatically. If you derive from WrapperInitializer<,,> instead, then these things will be handled for you.

Template Parameters
TWrapperType of the initialized wrapper component.
TWrappedType of the object wrapped by the wrapper.
TArgumentType of the argument passed to the wrapped object's constructor.
Type Constraints
TWrapper :Wrapper<TWrapped> 
Inheritance diagram for Sisus.Init.WrapperInitializerBase< TWrapper, TWrapped, TArgument >:
Sisus.Init.IInitializer< TClient, TArgument > Sisus.Init.IInitializable Sisus.Init.IInitializer< TClient > Sisus.Init.IValueProvider< TValue > Sisus.Init.IValueByTypeProvider Sisus.Init.IInitializer< TClient > Sisus.Init.IInitializer Sisus.Init.IValueProvider Sisus.Init.IInitializer Sisus.Init.WrapperInitializer< TWrapper, TWrapped, TArgument >

Protected Member Functions

override TWrapper InitTarget ([AllowNull] TWrapper wrapper)
 
TWrapped CreateWrappedObject (TArgument argument)
 Creates a new instance of TWrapped initialized using the provided argument and returns it.
 

Properties

TArgument Argument [get, set]
 The argument used to initialize the wrapped object.
 
- Properties inherited from Sisus.Init.IInitializer
Object Target [get, set]
 Existing target instance to initialize, if any.
 
bool ProvidesCustomInitArguments [get]
 Gets a value indicating whether this initializer is able to provide custom per-instance Init arguments for its client.
 

Additional Inherited Members

- Public Member Functions inherited from Sisus.Init.IInitializer< TClient >
new TClient InitTarget ()
 Initializes the client object of type TClient with the arguments specified by this initializer.
 
new System.Threading.Tasks.Task< TClient > InitTargetAsync ()
 Initializes the client object of type TClient asynchronously with the arguments specified by this initializer.
 
- Public Member Functions inherited from Sisus.Init.IInitializer
bool TargetIsAssignableOrConvertibleToType (Type type)
 Gets a value indicating whether an object of the given type can be assigned to the Target property directly, or if type implements IValueProvider<T>, IValueByTypeProvider or IValueByTypeProviderAsync.