Bug #39323. Change nsSoftwareUpdate::mMasterListener to be a

dynamically allocated object instead of a member, so we don't have to
do ugly tricks AddRefing it manually not to get it destroyed (and thus
segfaulting). r=waterson,dvedit a=dvedit
This commit is contained in:
inaky.gonzalez%intel.com 2000-06-23 00:14:22 +00:00
Родитель 2986433dde
Коммит ca76f0133a
2 изменённых файлов: 31 добавлений и 15 удалений

Просмотреть файл

@ -125,8 +125,9 @@ nsSoftwareUpdate::nsSoftwareUpdate()
mReg(0)
{
NS_INIT_ISUPPORTS();
mMasterListener.AddRef(); // inflate refcount so it doesn't go away early
mMasterListener = new nsTopProgressListener;
NS_IF_ADDREF (mMasterListener);
mLock = PR_NewLock();
/***************************************/
@ -179,7 +180,7 @@ nsSoftwareUpdate::~nsSoftwareUpdate()
NR_ShutdownRegistry();
//NS_IF_RELEASE( mProgramDir );
NS_IF_RELEASE (mMasterListener);
mInstance = nsnull;
}
@ -261,9 +262,13 @@ nsSoftwareUpdate::RegisterListener(nsIXPIListener *aListener)
// register a Listener, you can not remove it. This should at some
// point be fixed.
(void) mMasterListener.RegisterListener(aListener);
if (mMasterListener)
{
mMasterListener->RegisterListener(aListener);
return NS_OK;
}
else
return NS_ERROR_FAILURE;
}
NS_IMETHODIMP
@ -273,17 +278,27 @@ nsSoftwareUpdate::GetMasterListener(nsIXPIListener **aListener)
if (!aListener)
return NS_ERROR_NULL_POINTER;
NS_ADDREF(&mMasterListener);
*aListener = &mMasterListener;
return NS_OK;
if (mMasterListener)
{
NS_ADDREF (mMasterListener);
*aListener = mMasterListener;
return NS_OK;
}
else
return NS_ERROR_FAILURE;
}
NS_IMETHODIMP
nsSoftwareUpdate::SetActiveListener(nsIXPIListener *aListener)
{
mMasterListener.SetActiveListener(aListener);
if (mMasterListener)
{
mMasterListener->SetActiveListener (aListener);
return NS_OK;
}
else
return NS_ERROR_FAILURE;
}
NS_IMETHODIMP

Просмотреть файл

@ -13,6 +13,7 @@
#include "prlock.h"
//#include "mozreg.h"
#include "NSReg.h"
#include "nsCOMPtr.h"
class nsInstallInfo;
@ -91,13 +92,13 @@ class nsSoftwareUpdate: public nsIAppShellComponent,
nsresult RunNextInstall();
nsresult RegisterNameset();
PRLock* mLock;
PRBool mInstalling;
PRBool mStubLockout;
nsVoidArray mJarInstallQueue;
nsTopProgressListener mMasterListener;
PRLock* mLock;
PRBool mInstalling;
PRBool mStubLockout;
nsVoidArray mJarInstallQueue;
nsTopProgressListener *mMasterListener;
HREG mReg;
HREG mReg;
};