UIExtensionsExecuteWithExceptionCheckAsyncTExtension, TExtensionContext - метод |
Выполняет заданный метод расширений с обработкой исключений, при возникновении
которых они логируются и выводятся пользователю.
Пространство имён:
Tessa.UI
Сборка:
Tessa.UI (в Tessa.UI.dll) Версия: 3.5.0.19
Синтаксис public static Task<bool> ExecuteWithExceptionCheckAsync<TExtension, TExtensionContext>(
this IExtensionExecutor<TExtension> executor,
Expression<ExtensionMethodReferenceAsync<TExtension, TExtensionContext>> method,
TExtensionContext extensionContext,
Func<Exception, ValueTask> processExceptionAsync = null,
bool showMessageBox = true,
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,
Optional processExceptionAsync As Func(Of Exception, ValueTask) = Nothing,
Optional showMessageBox As Boolean = true,
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,
Func<Exception^, ValueTask>^ processExceptionAsync = nullptr,
bool showMessageBox = true,
bool continueOnCapturedContext = false
)
[<ExtensionAttribute>]
static member ExecuteWithExceptionCheckAsync :
executor : IExtensionExecutor<'TExtension> *
method : Expression<ExtensionMethodReferenceAsync<'TExtension, 'TExtensionContext>> *
extensionContext : 'TExtensionContext *
?processExceptionAsync : Func<Exception, ValueTask> *
?showMessageBox : bool *
?continueOnCapturedContext : bool
(* Defaults:
let _processExceptionAsync = defaultArg processExceptionAsync null
let _showMessageBox = defaultArg showMessageBox true
let _continueOnCapturedContext = defaultArg continueOnCapturedContext false
*)
-> Task<bool> when 'TExtension : not struct and IExtension when 'TExtensionContext : not struct and IExtensionContext
Параметры
- executor
- Тип: Tessa.ExtensionsIExtensionExecutorTExtension
Объект, исполняющий цепочку расширений. - method
- Тип: System.Linq.ExpressionsExpressionExtensionMethodReferenceAsyncTExtension, TExtensionContext
Выражение, ссылающееся на метод, который выполняется для каждого расширения в цепочке. - extensionContext
- Тип: TExtensionContext
Контекст расширений. - processExceptionAsync (Optional)
- Тип: SystemFuncException, ValueTask
Функция, обрабатывающая возникшее исключение, или null, если обработка не выполняется.
- showMessageBox (Optional)
- Тип: SystemBoolean
Признак того, что требуется отобразить диалог об ошибке при возникновении исключения.
Запись в лог будет сделана в любом случае.
- continueOnCapturedContext (Optional)
- Тип: SystemBoolean
Признак того, что выполнение продолжается после ожидания на исходном SynchronizationContext.
Параметры типа
- TExtension
- Ссылочный тип расширений, реализующий интерфейс IExtension.
- TExtensionContext
- Тип контекста расширений.
Возвращаемое значение
Тип:
TaskBooleantrue, если цепочка расширений выполнена без исключений;
false, если при выполнении цепочки расширений обнаружено исключение,
которое было залогировано и отображено пользователю.
Примечание об использовании
В Visual Basic и C# этот метод можно вызывать как метод экземпляра для любого объекта типа
IExtensionExecutorTExtension. При вызове метода для экземпляра следует опускать первый параметр. Дополнительные сведения см. в разделе
Методы расширения (Visual Basic) или
Методы расширения (Руководство по программированию в C#).
См. также