Bug 1186745 part 3 - Make nsThreadSyncDispatch leak the sync task by default when Run() is not called. r=froydnj

--HG--
extra : source : 3e192a3bcd8686bfc49c58012f4b17ed8fdc7c45
This commit is contained in:
Xidorn Quan 2015-09-29 09:28:22 +10:00
parent 5a61756f88
commit 8de4cf8292

View File

@ -8,20 +8,21 @@
#define nsThreadSyncDispatch_h_
#include "nsThreadUtils.h"
#include "LeakRefPtr.h"
class nsThreadSyncDispatch : public nsRunnable
{
public:
nsThreadSyncDispatch(nsIThread* aOrigin, already_AddRefed<nsIRunnable>&& aTask)
: mOrigin(aOrigin)
, mSyncTask(aTask)
, mSyncTask(mozilla::Move(aTask))
, mResult(NS_ERROR_NOT_INITIALIZED)
{
}
bool IsPending()
{
return mSyncTask != nullptr;
return !!mSyncTask;
}
nsresult Result()
@ -32,9 +33,8 @@ public:
private:
NS_IMETHOD Run() override
{
if (mSyncTask) {
mResult = mSyncTask->Run();
mSyncTask = nullptr;
if (nsCOMPtr<nsIRunnable> task = mSyncTask.take()) {
mResult = task->Run();
// unblock the origin thread
mOrigin->Dispatch(this, NS_DISPATCH_NORMAL);
}
@ -42,7 +42,9 @@ private:
}
nsCOMPtr<nsIThread> mOrigin;
nsCOMPtr<nsIRunnable> mSyncTask;
// The task is leaked by default when Run() is not called, because
// otherwise we may release it in an incorrect thread.
mozilla::LeakRefPtr<nsIRunnable> mSyncTask;
nsresult mResult;
};