IPromise.cs
82 lines
| 3.9 KiB
| text/x-csharp
|
CSharpLexer
/ Implab / IPromise.cs
cin
|
r7 | using System; | ||
using System.Collections.Generic; | ||||
using System.Linq; | ||||
using System.Text; | ||||
cin
|
r66 | namespace Implab { | ||
public interface IPromise: ICancellable { | ||||
/// <summary> | ||||
/// Check whereather the promise has no more than one dependent promise. | ||||
/// </summary> | ||||
bool IsExclusive { | ||||
get; | ||||
} | ||||
cin
|
r26 | |||
cin
|
r66 | /// <summary> | ||
/// Тип результата, получаемого через данное обещание. | ||||
/// </summary> | ||||
Type PromiseType { get; } | ||||
cin
|
r25 | |||
cin
|
r74 | /// <summary> | ||
/// Обещание является выполненым, либо успешно, либо с ошибкой. | ||||
/// </summary> | ||||
cin
|
r66 | bool IsResolved { get; } | ||
cin
|
r74 | /// <summary> | ||
/// Обещание было отменено. | ||||
/// </summary> | ||||
cin
|
r66 | bool IsCancelled { get; } | ||
cin
|
r25 | |||
cin
|
r75 | IPromise Then(Action success, ErrorHandler error, Action cancel); | ||
IPromise Then(Action success, ErrorHandler error); | ||||
cin
|
r66 | IPromise Then(Action success); | ||
cin
|
r75 | |||
/// <summary> | ||||
/// Добавляет последнй обработчик в цепочку обещаний, не создает промежуточных обещаний. | ||||
/// </summary> | ||||
/// <param name="success">Success.</param> | ||||
/// <param name="error">Error.</param> | ||||
/// <param name="cancel">Cancel.</param> | ||||
void Last(Action success, ErrorHandler error, Action cancel); | ||||
void Last(Action success, ErrorHandler error); | ||||
void Last(Action success); | ||||
cin
|
r66 | IPromise Error(ErrorHandler error); | ||
cin
|
r74 | /// <summary> | ||
/// Обрабатывает либо ошибку, либо результат. Событие отмены не обрабатывается. | ||||
/// </summary> | ||||
/// <param name="handler">Обработчик.</param> | ||||
/// <remarks>После обработке ошибки, она передается дальше.</remarks> | ||||
/// <summary> | ||||
/// Обрабатывает либо ошибку, либо результат, либо отмену обещания. | ||||
/// </summary> | ||||
/// <param name="handler">Обработчик.</param> | ||||
/// <remarks>После обработке ошибки, она передается дальше.</remarks> | ||||
cin
|
r66 | IPromise Finally(Action handler); | ||
cin
|
r74 | /// <summary> | ||
/// Обработчик для регистрации отмены обещания, событие отмены не может быть подавлено. | ||||
/// </summary> | ||||
/// <returns>Новое обещание, связанное с текущим.</returns> | ||||
/// <param name="handler">Обработчик события.</param> | ||||
/// <remarks>Если обработчик вызывает исключение, то оно передается обработчику ошибки, результат работы | ||||
/// которого будет передан связанному обещанию</remarks> | ||||
cin
|
r66 | IPromise Cancelled(Action handler); | ||
cin
|
r7 | |||
cin
|
r74 | /// <summary> | ||
/// Преобразует результат обещания к заданному типу и возвращает новое обещание. | ||||
/// </summary> | ||||
cin
|
r66 | IPromise<T> Cast<T>(); | ||
cin
|
r26 | |||
cin
|
r74 | /// <summary> | ||
/// Синхронизирует текущий поток с обещанием. | ||||
/// </summary> | ||||
cin
|
r66 | void Join(); | ||
cin
|
r74 | /// <summary> | ||
/// Синхронизирует текущий поток с обещанием. | ||||
/// </summary> | ||||
/// <param name="timeout">Время ожидания, по его истечению возникнет исключение.</param> | ||||
/// <exception cref="TimeoutException">Превышено время ожидания.</exception> | ||||
cin
|
r66 | void Join(int timeout); | ||
cin
|
r7 | |||
} | ||||
} | ||||