using Implab.Diagnostics;
using System;
using System.Threading;
namespace Implab.Parallels {
///
/// Класс для распаралеливания задач.
///
///
/// Используя данный класс и лямда выражения можно распараллелить
/// вычисления, для этого используется концепция обещаний.
///
public static class AsyncPool {
public static IPromise Invoke(Func func) {
var p = new Promise();
var caller = TraceContext.Snapshot();
ThreadPool.QueueUserWorkItem(param => {
TraceContext.Fork(caller);
try {
p.Resolve(func());
} catch(Exception e) {
p.Reject(e);
}
});
return p;
}
public static IPromise InvokeNewThread(Func func) {
var p = new Promise();
var caller = TraceContext.Snapshot();
var worker = new Thread(() => {
TraceContext.Fork(caller);
try {
p.Resolve(func());
} catch (Exception e) {
p.Reject(e);
}
});
worker.IsBackground = true;
worker.Start();
return p;
}
public static IPromiseBase InvokeNewThread(Action func) {
var p = new Promise