Mercurial > pub > ImplabNet
view MonoPlay/Program.cs @ 209:a867536c68fc v2
Bound promise to CancellationToken
Added new states to ExecutionSate enum.
Added Safe.Guard() method to handle cleanup of the result of the promise
author | cin |
---|---|
date | Wed, 16 Nov 2016 03:06:08 +0300 |
parents | d7cd7a83189a |
children |
line wrap: on
line source
using Implab; using Implab.Parallels; using Implab.Diagnostics; using System.Threading; namespace MonoPlay { class MainClass { public static void Main(string[] args) { var pool = new WorkerPool(10); var listerner = new ConsoleTraceListener(); listerner.Subscribe<TraceEvent>(); TraceLog.StartLogicalOperation("Main"); var d = pool.Invoke(() => { TraceLog.StartLogicalOperation("Worker"); Thread.Sleep(100); TraceLog.TraceInformation("worker done"); TraceLog.EndLogicalOperation(); }); var op = TraceContext.Instance.CurrentOperation; ThreadPool.QueueUserWorkItem((o) => { TraceContext.Instance.EnterLogicalOperation(op, false); TraceLog.StartLogicalOperation("Thread"); Thread.Sleep(100); TraceLog.TraceInformation("thread done"); TraceLog.EndLogicalOperation(); }); TraceLog.TraceInformation("main done"); TraceLog.EndLogicalOperation(); d.Join(); } } }