UIExtensionsExecuteWithExceptionCheckAsyncTExtensionContext - метод
Выполняет заданный метод расширений с обработкой исключений, при возникновении
которых они логируются и выводятся пользователю.
Пространство имён: Tessa.UIСборка: Tessa.UI (в Tessa.UI.dll) Версия: 4.0.4
public static Task<bool> ExecuteWithExceptionCheckAsync<TExtensionContext>(
this IExtensionExecutor executor,
string methodName,
TExtensionContext extensionContext,
Func<Exception, ValueTask> processExceptionAsync = null,
Func<IExtensionStrategyContext, ValueTask> handleExceptionAsync = null,
bool showMessageBox = true,
bool continueOnCapturedContext = false
)
where TExtensionContext : class, IExtensionContext
<ExtensionAttribute>
Public Shared Function ExecuteWithExceptionCheckAsync(Of TExtensionContext As {Class, IExtensionContext}) (
executor As IExtensionExecutor,
methodName As String,
extensionContext As TExtensionContext,
Optional processExceptionAsync As Func(Of Exception, ValueTask) = Nothing,
Optional handleExceptionAsync As Func(Of IExtensionStrategyContext, ValueTask) = Nothing,
Optional showMessageBox As Boolean = true,
Optional continueOnCapturedContext As Boolean = false
) As Task(Of Boolean)
public:
[ExtensionAttribute]
generic<typename TExtensionContext>
where TExtensionContext : ref class, IExtensionContext
static Task<bool>^ ExecuteWithExceptionCheckAsync(
IExtensionExecutor^ executor,
String^ methodName,
TExtensionContext extensionContext,
Func<Exception^, ValueTask>^ processExceptionAsync = nullptr,
Func<IExtensionStrategyContext^, ValueTask>^ handleExceptionAsync = nullptr,
bool showMessageBox = true,
bool continueOnCapturedContext = false
)
[<ExtensionAttribute>]
static member ExecuteWithExceptionCheckAsync :
executor : IExtensionExecutor *
methodName : string *
extensionContext : 'TExtensionContext *
?processExceptionAsync : Func<Exception, ValueTask> *
?handleExceptionAsync : Func<IExtensionStrategyContext, ValueTask> *
?showMessageBox : bool *
?continueOnCapturedContext : bool
(* Defaults:
let _processExceptionAsync = defaultArg processExceptionAsync null
let _handleExceptionAsync = defaultArg handleExceptionAsync null
let _showMessageBox = defaultArg showMessageBox true
let _continueOnCapturedContext = defaultArg continueOnCapturedContext false
*)
-> Task<bool> when 'TExtensionContext : not struct and IExtensionContext
- executor IExtensionExecutor
- Объект, исполняющий цепочку расширений.
- methodName String
- Имя метода расширения, который можно выполнить. Не должен быть равен null или пустой строке.
- extensionContext TExtensionContext
- Контекст расширений.
- processExceptionAsync FuncException, ValueTask (Optional)
-
Функция, обрабатывающая возникшее исключение, или null, если обработка не выполняется.
- handleExceptionAsync FuncIExtensionStrategyContext, ValueTask (Optional)
-
Метод, выполняющийся при обработке исключений для каждого экземпляра расширений после того, как была выполнена трассировка расширения.
Метод может изменить IExtensionStrategyContext, в т.ч. установить режим обработки исключений в свойстве ExceptionHandlingMode.
Укажите null, если метод не требуется выполнять.
- showMessageBox Boolean (Optional)
-
Признак того, что требуется отобразить диалог об ошибке при возникновении исключения.
Запись в лог будет сделана в любом случае.
- continueOnCapturedContext Boolean (Optional)
-
Признак того, что выполнение продолжается после ожидания на исходном SynchronizationContext.
- TExtensionContext
- Тип контекста расширений.
TaskBooleantrue, если цепочка расширений выполнена без исключений;
false, если при выполнении цепочки расширений обнаружено исключение,
которое было залогировано и отображено пользователю.
В Visual Basic и C# этот метод можно вызывать как метод экземпляра для любого объекта типа
IExtensionExecutor. При вызове метода для экземпляра следует опускать первый параметр. Дополнительные сведения см. в разделе
Методы расширения (Visual Basic) или
Методы расширения (Руководство по программированию в C#).