Mercurial > pub > ImplabNet
view Implab/IPromise.cs @ 136:e9e7940c7d98 v2
shared locks + tests
author | cin |
---|---|
date | Mon, 16 Feb 2015 01:14:09 +0300 |
parents | 2573b562e328 |
children | f75cfa58e3d4 |
line wrap: on
line source
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Implab { public interface IPromise: ICancellable { /// <summary> /// Тип результата, получаемого через данное обещание. /// </summary> Type PromiseType { get; } /// <summary> /// Обещание является выполненым, либо успешно, либо с ошибкой, либо отменено. /// </summary> bool IsResolved { get; } /// <summary> /// Обещание было отменено. /// </summary> bool IsCancelled { get; } /// <summary> /// Creates a new promise dependend on the current one and resolved on /// executing the specified handlers. /// </summary> /// <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 newly created dependant promise.</returns> /// <remarks> /// <para> /// If the success handler is specified the dependend promise will be resolved after the handler is /// executed and the dependent promise will be linked to the current one, i.e. the cancellation /// of the dependent property will lead to the cancellation of the current promise. If the /// success handler isn't specified the dependent promise will not be linked to and /// will not be resolved after the successfull resolution of the current one. /// </para> /// <para> /// When the error handler is specified, the exception raised during the current promise completion /// will be passed to it as the parameter. If the error handler returns without raising an /// exception then the dependant promise will be resolved successfully, otherwise the exception /// raised by the handler will be transmitted to the dependent promise. If the handler wants /// to passthrough the original exception it needs to wrap the exception with /// the <see cref="PromiseTransientException"/>. /// </para> /// <para> /// If the cancelation handler is specified and the current promise is cancelled then the dependent /// promise will be resolved after the handler is executed. If the cancelation hendler raises the /// exception it will be passed to the dependent promise. /// </para> /// </remarks> IPromise Then(Action success, Action<Exception> error, Action cancel); IPromise Then(Action success, Action<Exception> error); IPromise Then(Action success); IPromise Chain(Func<IPromise> chained, Func<Exception, IPromise> error, Func<IPromise> cancel); IPromise Chain(Func<IPromise> chained, Func<Exception, IPromise> error); IPromise Chain(Func<IPromise> chained); /// <summary> /// Adds specified listeners to the current promise. /// </summary> /// <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> IPromise On(Action success, Action<Exception> error, Action cancel); IPromise On(Action success, Action<Exception> error); IPromise On(Action success); /// <summary> /// 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> /// Adds the specified error handler to the current promise /// and creates the new dependant promise. /// </summary> /// <param name="error"> /// The error handler. If the error handler returns without /// an error the dependant promise will be successfully resolved. /// </param> /// <returns> /// The new dependant promise which will be resolved after the error /// handler is executed. /// </returns> /// <remarks> /// The successfull result of the current promise will be ignored. /// </remarks> IPromise Error(Action<Exception> error); /// <summary> /// Adds the specified cncellation handler to the current promise /// and creates the new dependant promise. /// </summary> /// <returns> /// The new dependant promise which will be resolved after the cancellation /// handler is executed. /// </returns> /// <param name="handler"> /// The cancellation handler. /// </param> /// <remarks> /// If the cancellation handler is executed without an error the dependent /// promise will be successfully resolved, otherwise the raised exception /// will be passed to the dependant promise. The successful result of the /// current promise will be ignored. /// </remarks> IPromise Cancelled(Action handler); /// <summary> /// Преобразует результат обещания к заданному типу и возвращает новое обещание. /// </summary> IPromise<T> Cast<T>(); /// <summary> /// Синхронизирует текущий поток с обещанием. /// </summary> void Join(); /// <summary> /// Синхронизирует текущий поток с обещанием. /// </summary> /// <param name="timeout">Время ожидания, по его истечению возникнет исключение.</param> /// <exception cref="TimeoutException">Превышено время ожидания.</exception> void Join(int timeout); } }