IPromise.cs
66 lines
| 2.8 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 { | ||||
cin
|
r26 | |||
cin
|
r66 | /// <summary> | ||
/// Тип результата, получаемого через данное обещание. | ||||
/// </summary> | ||||
Type PromiseType { get; } | ||||
cin
|
r25 | |||
cin
|
r74 | /// <summary> | ||
cin
|
r99 | /// Обещание является выполненым, либо успешно, либо с ошибкой, либо отменено. | ||
cin
|
r74 | /// </summary> | ||
cin
|
r66 | bool IsResolved { get; } | ||
cin
|
r74 | /// <summary> | ||
/// Обещание было отменено. | ||||
/// </summary> | ||||
cin
|
r66 | bool IsCancelled { get; } | ||
cin
|
r25 | |||
cin
|
r119 | /// <summary> | ||
cin
|
r138 | /// Исключение возникшее в результате выполнения обещания, либо причина отмены. | ||
/// </summary> | ||||
Exception Error { get; } | ||||
/// <summary> | ||||
cin
|
r119 | /// Adds specified listeners to the current promise. | ||
cin
|
r75 | /// </summary> | ||
cin
|
r119 | /// <param name="success">The handler called on the successful promise completion.</param> | ||
/// <param name="error">The handler is called if an error while completing the promise occurred.</param> | ||||
/// <param name="cancel">The handler is called in case of promise cancellation.</param> | ||||
/// <returns>The current promise.</returns> | ||||
cin
|
r138 | IPromise On(Action success, Action<Exception> error, Action<Exception> cancel); | ||
cin
|
r119 | IPromise On(Action success, Action<Exception> error); | ||
IPromise On(Action success); | ||||
cin
|
r75 | |||
cin
|
r74 | /// <summary> | ||
cin
|
r119 | /// Adds specified listeners to the current promise. | ||
/// </summary> | ||||
/// <param name="handler">The handler called on the specified events.</param> | ||||
/// <param name = "events">The combination of flags denoting the events for which the | ||||
/// handler shoud be called.</param> | ||||
/// <returns>The current promise.</returns> | ||||
IPromise On(Action handler, PromiseEventType events); | ||||
/// <summary> | ||||
cin
|
r74 | /// Преобразует результат обещания к заданному типу и возвращает новое обещание. | ||
/// </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 | |||
} | ||||
} | ||||