Mozilla/mozilla/xpinstall/src/nsTopProgressNotifier.cpp
mkaply%us.ibm.com 5472be58bb Adding newlines at the end of these files to proactively prevent HPUX bustage
git-svn-id: svn://10.0.0.236/trunk@117310 18797224-902f-48f8-a5cc-f745e15eee43
2002-03-23 15:02:41 +00:00

209 lines
5.0 KiB
C++

/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* The contents of this file are subject to the Netscape Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/NPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* The Original Code is Mozilla Communicator client code,
* released March 31, 1998.
*
* The Initial Developer of the Original Code is Netscape Communications
* Corporation. Portions created by Netscape are
* Copyright (C) 1998 Netscape Communications Corporation. All
* Rights Reserved.
*
* Contributor(s):
* Douglas Turner <dougt@netscape.com>
* Daniel Veditz <dveditz@netscape.com>
* Pierre Phaneuf <pp@ludusdesign.com>
*/
#include "nsTopProgressNotifier.h"
nsTopProgressListener::nsTopProgressListener()
{
NS_INIT_ISUPPORTS();
mListeners = new nsVoidArray();
mActive = 0;
mLock = PR_NewLock();
}
nsTopProgressListener::~nsTopProgressListener()
{
if (mLock) PR_Lock(mLock);
if (mListeners)
{
PRInt32 i=0;
for (; i < mListeners->Count(); i++)
{
nsIXPIListener* element = (nsIXPIListener*)mListeners->ElementAt(i);
NS_IF_RELEASE(element);
}
mListeners->Clear();
delete (mListeners);
}
if (mLock)
{
PR_Unlock(mLock);
PR_DestroyLock(mLock);
}
}
NS_IMPL_THREADSAFE_ISUPPORTS1(nsTopProgressListener, nsIXPIListener);
long
nsTopProgressListener::RegisterListener(nsIXPIListener * newListener)
{
if (mLock) PR_Lock(mLock);
NS_IF_ADDREF( newListener );
long retval = mListeners->AppendElement( newListener );
if (mLock) PR_Unlock(mLock);
return retval;
}
void
nsTopProgressListener::UnregisterListener(long id)
{
if (mLock) PR_Lock(mLock);
if (id < mListeners->Count())
{
nsIXPIListener *item = (nsIXPIListener*)mListeners->ElementAt(id);
mListeners->ReplaceElementAt(nsnull, id);
NS_IF_RELEASE(item);
}
if (mLock) PR_Unlock(mLock);
}
NS_IMETHODIMP
nsTopProgressListener::OnInstallStart(const PRUnichar *URL)
{
if (mActive)
mActive->OnInstallStart(URL);
if (mListeners)
{
PRInt32 i=0;
for (; i < mListeners->Count(); i++)
{
nsIXPIListener* element = (nsIXPIListener*)mListeners->ElementAt(i);
if (element != NULL)
element->OnInstallStart(URL);
}
}
return NS_OK;
}
NS_IMETHODIMP
nsTopProgressListener::OnPackageNameSet(const PRUnichar *URL, const PRUnichar* UIPackageName)
{
if (mActive)
mActive->OnPackageNameSet(URL, UIPackageName);
if (mListeners)
{
PRInt32 i=0;
for (; i < mListeners->Count(); i++)
{
nsIXPIListener* element = (nsIXPIListener*)mListeners->ElementAt(i);
if (element != NULL)
element->OnPackageNameSet(URL, UIPackageName);
}
}
return NS_OK;
}
NS_IMETHODIMP
nsTopProgressListener::OnItemScheduled( const PRUnichar* message )
{
long rv = 0;
if (mActive)
mActive->OnItemScheduled( message );
if (mListeners)
{
PRInt32 i=0;
for (; i < mListeners->Count(); i++)
{
nsIXPIListener* element = (nsIXPIListener*)mListeners->ElementAt(i);
if (element != NULL)
element->OnItemScheduled( message );
}
}
return rv;
}
NS_IMETHODIMP
nsTopProgressListener::OnFinalizeProgress( const PRUnichar* message, PRInt32 itemNum, PRInt32 totNum )
{
if (mActive)
mActive->OnFinalizeProgress( message, itemNum, totNum );
if (mListeners)
{
PRInt32 i=0;
for (; i < mListeners->Count(); i++)
{
nsIXPIListener* element = (nsIXPIListener*)mListeners->ElementAt(i);
if (element != NULL)
element->OnFinalizeProgress( message, itemNum, totNum );
}
}
return NS_OK;
}
NS_IMETHODIMP
nsTopProgressListener::OnInstallDone(const PRUnichar *URL, PRInt32 status)
{
if (mActive)
mActive->OnInstallDone(URL, status);
if (mListeners)
{
PRInt32 i=0;
for (; i < mListeners->Count(); i++)
{
nsIXPIListener* element = (nsIXPIListener*)mListeners->ElementAt(i);
if (element != NULL)
element->OnInstallDone(URL,status);
}
}
return NS_OK;
}
NS_IMETHODIMP
nsTopProgressListener::OnLogComment(const PRUnichar* comment)
{
if (mActive)
mActive->OnLogComment(comment);
if (mListeners)
{
PRInt32 i=0;
for (; i < mListeners->Count(); i++)
{
nsIXPIListener* element = (nsIXPIListener*)mListeners->ElementAt(i);
if (element != NULL)
element->OnLogComment(comment);
}
}
return NS_OK;
}