# HG changeset patch # User cin # Date 1422626837 -10800 # Node ID 671f60cd0250319594901aa43a488dd8a70dba60 # Parent 471f596b26037cfda5566b4b505fcd2ba38b452d fixed Resove method bug when calling it on already cancelled promise diff -r 471f596b2603 -r 671f60cd0250 Implab.Diagnostics.Interactive/InteractiveListener.cs --- a/Implab.Diagnostics.Interactive/InteractiveListener.cs Thu Jan 29 18:31:06 2015 +0300 +++ b/Implab.Diagnostics.Interactive/InteractiveListener.cs Fri Jan 30 17:07:17 2015 +0300 @@ -14,7 +14,7 @@ TraceForm m_form; SynchronizationContext m_syncGuiThread; - readonly Promise m_guiStarted = new Promise(); + readonly Promise m_guiStarted = new Promise(); readonly IPromise m_guiFinished; // readonly IPromise m_workerFinished = new Promise(); @@ -30,8 +30,8 @@ readonly ManualResetEvent m_pauseEvent = new ManualResetEvent(true); public InteractiveListener(bool global) : base(global) { - m_guiFinished = AsyncPool.InvokeNewThread(GuiThread); - /*m_workerFinished = */AsyncPool.InvokeNewThread(QueueThread); + m_guiFinished = AsyncPool.RunThread(GuiThread); + /*m_workerFinished = */AsyncPool.RunThread(QueueThread); m_guiStarted.Join(); } diff -r 471f596b2603 -r 671f60cd0250 Implab/AbstractPromise.cs --- a/Implab/AbstractPromise.cs Thu Jan 29 18:31:06 2015 +0300 +++ b/Implab/AbstractPromise.cs Fri Jan 30 17:07:17 2015 +0300 @@ -39,12 +39,14 @@ } } - protected void BeginSetResult() { + protected bool BeginSetResult() { if (!BeginTransit()) { WaitTransition(); if (m_state != CANCELLED_STATE) throw new InvalidOperationException("The promise is already resolved"); + return false; } + return true; } protected void EndSetResult() { diff -r 471f596b2603 -r 671f60cd0250 Implab/Parallels/AsyncQueue.cs --- a/Implab/Parallels/AsyncQueue.cs Thu Jan 29 18:31:06 2015 +0300 +++ b/Implab/Parallels/AsyncQueue.cs Fri Jan 30 17:07:17 2015 +0300 @@ -187,6 +187,8 @@ public void EnqueueRange(T[] data, int offset, int length) { if (data == null) throw new ArgumentNullException("data"); + if (length == 0) + return; if (offset < 0) throw new ArgumentOutOfRangeException("offset"); if (length < 1 || offset + length > data.Length) diff -r 471f596b2603 -r 671f60cd0250 Implab/Parallels/SharedLock.cs --- a/Implab/Parallels/SharedLock.cs Thu Jan 29 18:31:06 2015 +0300 +++ b/Implab/Parallels/SharedLock.cs Fri Jan 30 17:07:17 2015 +0300 @@ -17,6 +17,7 @@ return false; m_exclusive = true; m_locks = 1; + return true; } } @@ -31,7 +32,7 @@ return true; } - if (m_lock == 0) { + if (m_locks == 0) { m_exclusive = false; m_locks = 1; return true; diff -r 471f596b2603 -r 671f60cd0250 Implab/PromiseT.cs --- a/Implab/PromiseT.cs Thu Jan 29 18:31:06 2015 +0300 +++ b/Implab/PromiseT.cs Fri Jan 30 17:07:17 2015 +0300 @@ -302,9 +302,10 @@ T m_result; public virtual void Resolve(T value) { - BeginSetResult(); - m_result = value; - EndSetResult(); + if (BeginSetResult()) { + m_result = value; + EndSetResult(); + } } public void Reject(Exception error) {