RuntimeExtensionsExecuteWithExceptionCheckAsyncTExtension, TExtensionContext(IExtensionExecutorTExtension, ExpressionExtensionMethodReferenceAsyncTExtension, TExtensionContext, TExtensionContext, IMessageProvider, FuncIExtensionStrategyContext, ValueTask, Boolean) - метод
Выполняет заданный метод расширений с обработкой исключений, при возникновении
которых они обрабатываются объектом
IMessageProvider, например,
логируются и выводятся пользователю.
Пространство имён: Tessa.Platform.RuntimeСборка: Tessa (в Tessa.dll) Версия: 3.6.0.22
public static Task<bool> ExecuteWithExceptionCheckAsync<TExtension, TExtensionContext>(
this IExtensionExecutor<TExtension> executor,
Expression<ExtensionMethodReferenceAsync<TExtension, TExtensionContext>> method,
TExtensionContext extensionContext,
IMessageProvider messageProvider,
Func<IExtensionStrategyContext, ValueTask> handleExceptionAsync = null,
bool continueOnCapturedContext = false
)
where TExtension : class, IExtension
where TExtensionContext : class, IExtensionContext
<ExtensionAttribute>
Public Shared Function ExecuteWithExceptionCheckAsync(Of TExtension As {Class, IExtension}, TExtensionContext As {Class, IExtensionContext}) (
executor As IExtensionExecutor(Of TExtension),
method As Expression(Of ExtensionMethodReferenceAsync(Of TExtension, TExtensionContext)),
extensionContext As TExtensionContext,
messageProvider As IMessageProvider,
Optional handleExceptionAsync As Func(Of IExtensionStrategyContext, ValueTask) = Nothing,
Optional continueOnCapturedContext As Boolean = false
) As Task(Of Boolean)
public:
[ExtensionAttribute]
generic<typename TExtension, typename TExtensionContext>
where TExtension : ref class, IExtension
where TExtensionContext : ref class, IExtensionContext
static Task<bool>^ ExecuteWithExceptionCheckAsync(
IExtensionExecutor<TExtension>^ executor,
Expression<ExtensionMethodReferenceAsync<TExtension, TExtensionContext>^>^ method,
TExtensionContext extensionContext,
IMessageProvider^ messageProvider,
Func<IExtensionStrategyContext^, ValueTask>^ handleExceptionAsync = nullptr,
bool continueOnCapturedContext = false
)
[<ExtensionAttribute>]
static member ExecuteWithExceptionCheckAsync :
executor : IExtensionExecutor<'TExtension> *
method : Expression<ExtensionMethodReferenceAsync<'TExtension, 'TExtensionContext>> *
extensionContext : 'TExtensionContext *
messageProvider : IMessageProvider *
?handleExceptionAsync : Func<IExtensionStrategyContext, ValueTask> *
?continueOnCapturedContext : bool
(* Defaults:
let _handleExceptionAsync = defaultArg handleExceptionAsync null
let _continueOnCapturedContext = defaultArg continueOnCapturedContext false
*)
-> Task<bool> when 'TExtension : not struct and IExtension when 'TExtensionContext : not struct and IExtensionContext
- executor IExtensionExecutorTExtension
- Объект, исполняющий цепочку расширений.
- method ExpressionExtensionMethodReferenceAsyncTExtension, TExtensionContext
- Выражение, ссылающееся на метод, который выполняется для каждого расширения в цепочке.
- extensionContext TExtensionContext
- Контекст расширений.
- messageProvider IMessageProvider
- Объект, выполняющий обработку сообщения об исключении.
- handleExceptionAsync FuncIExtensionStrategyContext, ValueTask (Optional)
-
Метод, выполняющийся при обработке исключений для каждого экземпляра расширений после того, как была выполнена трассировка расширения.
Метод может изменить IExtensionStrategyContext, в т.ч. установить режим обработки исключений в свойстве ExceptionHandlingMode.
Укажите null, если метод не требуется выполнять.
- continueOnCapturedContext Boolean (Optional)
-
Признак того, что выполнение продолжается после ожидания на исходном SynchronizationContext.
- TExtension
- Ссылочный тип расширений, реализующий интерфейс IExtension.
- TExtensionContext
- Тип контекста расширений.
TaskBooleantrue, если цепочка расширений выполнена без исключений;
false, если при выполнении цепочки расширений обнаружено исключение,
которое было обработано.
В Visual Basic и C# этот метод можно вызывать как метод экземпляра для любого объекта типа
IExtensionExecutorTExtension. При вызове метода для экземпляра следует опускать первый параметр. Дополнительные сведения см. в разделе
Методы расширения (Visual Basic) или
Методы расширения (Руководство по программированию в C#).