Photomechanics API
AsyncDisposableExtendedBase Class Referenceabstract

Provides base implementation of IAsyncDisposableExtended with disposal behavior intended for this interface. More...

Inheritance diagram for AsyncDisposableExtendedBase:
[legend]

Public Member Functions

async ValueTask DisposeAsync ()
 

Protected Member Functions

 AsyncDisposableExtendedBase (ILogger logger)
 Base constructor for device api. More...
 
abstract ValueTask DisposeAsyncCore ()
 Derived type disposal logic. More...
 
void UpdateLoggerContext ()
 Unfortunately Serilog ForContext method does not store provided object as property value, calling its ToString method immediately instead. In some cases, we want to use information like device name/id as log context but it is only available when derived type is fully constructed and maybe some other initialization took place. For such cases, derived type can use this method to update Logger context value.
 

Properties

ILogger Logger [get]
 Logger associated with this instance. This way extension methods can use logging without requiring it as parameter. More...
 
Boolean IsDisposed [get]
 Determines whether the object is being disposed or already disposed and no longer functional. More...
 
virtual IAsyncDisposableExtended Owner [get]
 Type and ToString values of this object will appear when logging begin/end of DisposeAsync. This object will also be used as Disposed sender, essentially allowing seamlessly using AsyncDisposableExtendedBase logic even when directly inheriting from it is not possible. Usually it simply returns "this" value, but AsyncDisposableExtendedImpl overrides it to return its owner instance for the aforementioned reason.
 
- Properties inherited from IAsyncDisposableExtended
Boolean IsDisposed [get]
 Determines whether the object is being disposed or already disposed and no longer functional. More...
 
ILogger Logger [get]
 Logger associated with this instance. This way extension methods can use logging without requiring it as parameter. More...
 

Events

AsyncTypedEventHandler< IAsyncDisposableExtended >? Disposed
 
- Events inherited from IAsyncDisposableExtended
AsyncTypedEventHandler< IAsyncDisposableExtendedDisposed
 Occurs when object is disposed. It should be invoked at the end of IAsyncDisposable.DisposeAsync implementation in a Fire-and-Forget fashion (non-blocking).
 

Detailed Description

Provides base implementation of IAsyncDisposableExtended with disposal behavior intended for this interface.

Constructor & Destructor Documentation

◆ AsyncDisposableExtendedBase()

AsyncDisposableExtendedBase.AsyncDisposableExtendedBase ( ILogger  logger)
protected

Base constructor for device api.

Derived types should implement Object.ToString method to contain information for log context (like device name and ID) and call UpdateLoggerContext whenever this information becomes available. If Object.ToString provides constant value (like nameof(DerivedType)), call to UpdateLoggerContext is not needed.

Member Function Documentation

◆ DisposeAsyncCore()

abstract ValueTask AsyncDisposableExtendedBase.DisposeAsyncCore ( )
protectedpure virtual

Property Documentation

◆ Logger

ILogger AsyncDisposableExtendedBase.Logger
get

Logger associated with this instance. This way extension methods can use logging without requiring it as parameter.

Implements IAsyncDisposableExtended.

◆ IsDisposed

Boolean AsyncDisposableExtendedBase.IsDisposed
get

Determines whether the object is being disposed or already disposed and no longer functional.

Implements IAsyncDisposableExtended.