/* ***** BEGIN LICENSE BLOCK ***** * Version: MPL 1.1/GPL 2.0/LGPL 2.1 * * The contents of this file are subject to the Mozilla 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/MPL/ * * 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.org code. * * The Initial Developer of the Original Code is * Christopher Blizzard. * Portions created by the Initial Developer are Copyright (C) 2001 * the Initial Developer. All Rights Reserved. * * Contributor(s): * Christopher Blizzard * * Alternatively, the contents of this file may be used under the terms of * either the GNU General Public License Version 2 or later (the "GPL"), or * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), * in which case the provisions of the GPL or the LGPL are applicable instead * of those above. If you wish to allow use of your version of this file only * under the terms of either the GPL or the LGPL, and not to allow others to * use your version of this file under the terms of the MPL, indicate your * decision by deleting the provisions above and replace them with the notice * and other provisions required by the GPL or the LGPL. If you do not delete * the provisions above, a recipient may use your version of this file under * the terms of any one of the MPL, the GPL or the LGPL. * * ***** END LICENSE BLOCK ***** */ #include "EmbedProgress.h" #include "nsIChannel.h" #include "nsIWebProgress.h" #include "nsIDOMWindow.h" #include "nsIURI.h" EmbedProgress::EmbedProgress(void) { mOwner = nsnull; } EmbedProgress::~EmbedProgress() { } NS_IMPL_ISUPPORTS2(EmbedProgress, nsIWebProgressListener, nsISupportsWeakReference) nsresult EmbedProgress::Init(EmbedPrivate *aOwner) { mOwner = aOwner; return NS_OK; } NS_IMETHODIMP EmbedProgress::OnStateChange(nsIWebProgress *aWebProgress, nsIRequest *aRequest, PRUint32 aStateFlags, nsresult aStatus) { // give the widget a chance to attach any listeners mOwner->ContentStateChange(); // if we've got the start flag, emit the signal if ((aStateFlags & GTK_MOZ_EMBED_FLAG_IS_NETWORK) && (aStateFlags & GTK_MOZ_EMBED_FLAG_START)) { g_signal_emit(G_OBJECT(mOwner->mOwningWidget), moz_embed_signals[NET_START], 0); } // get the uri for this request nsCAutoString uriString; RequestToURIString(aRequest, uriString); // is it the same as the current URI? if (mOwner->mURI.Equals(uriString)) { // for people who know what they are doing g_signal_emit(G_OBJECT(mOwner->mOwningWidget), moz_embed_signals[NET_STATE], 0, aStateFlags, aStatus); } g_signal_emit(G_OBJECT(mOwner->mOwningWidget), moz_embed_signals[NET_STATE_ALL], 0, uriString.get(), (gint)aStateFlags, (gint)aStatus); // and for stop, too if ((aStateFlags & GTK_MOZ_EMBED_FLAG_IS_NETWORK) && (aStateFlags & GTK_MOZ_EMBED_FLAG_STOP)) { g_signal_emit(G_OBJECT(mOwner->mOwningWidget), moz_embed_signals[NET_STOP], 0); // let our owner know that the load finished mOwner->ContentFinishedLoading(); } return NS_OK; } NS_IMETHODIMP EmbedProgress::OnProgressChange(nsIWebProgress *aWebProgress, nsIRequest *aRequest, PRInt32 aCurSelfProgress, PRInt32 aMaxSelfProgress, PRInt32 aCurTotalProgress, PRInt32 aMaxTotalProgress) { nsCAutoString uriString; RequestToURIString(aRequest, uriString); // is it the same as the current uri? if (mOwner->mURI.Equals(uriString)) { g_signal_emit(G_OBJECT(mOwner->mOwningWidget), moz_embed_signals[PROGRESS], 0, aCurTotalProgress, aMaxTotalProgress); } g_signal_emit(G_OBJECT(mOwner->mOwningWidget), moz_embed_signals[PROGRESS_ALL], 0, uriString.get(), aCurTotalProgress, aMaxTotalProgress); return NS_OK; } NS_IMETHODIMP EmbedProgress::OnLocationChange(nsIWebProgress *aWebProgress, nsIRequest *aRequest, nsIURI *aLocation) { nsCAutoString newURI; NS_ENSURE_ARG_POINTER(aLocation); aLocation->GetSpec(newURI); // Make sure that this is the primary frame change and not // just a subframe. PRBool isSubFrameLoad = PR_FALSE; if (aWebProgress) { nsCOMPtr domWindow; nsCOMPtr topDomWindow; aWebProgress->GetDOMWindow(getter_AddRefs(domWindow)); // get the root dom window if (domWindow) domWindow->GetTop(getter_AddRefs(topDomWindow)); if (domWindow != topDomWindow) isSubFrameLoad = PR_TRUE; } if (!isSubFrameLoad) { mOwner->SetURI(newURI.get()); g_signal_emit(G_OBJECT(mOwner->mOwningWidget), moz_embed_signals[LOCATION], 0); } return NS_OK; } NS_IMETHODIMP EmbedProgress::OnStatusChange(nsIWebProgress *aWebProgress, nsIRequest *aRequest, nsresult aStatus, const PRUnichar *aMessage) { g_signal_emit(G_OBJECT(mOwner->mOwningWidget), moz_embed_signals[STATUS_CHANGE], 0, static_cast(aRequest), static_cast(aStatus), static_cast(aMessage)); return NS_OK; } NS_IMETHODIMP EmbedProgress::OnSecurityChange(nsIWebProgress *aWebProgress, nsIRequest *aRequest, PRUint32 aState) { g_signal_emit(G_OBJECT(mOwner->mOwningWidget), moz_embed_signals[SECURITY_CHANGE], 0, static_cast(aRequest), aState); return NS_OK; } /* static */ void EmbedProgress::RequestToURIString(nsIRequest *aRequest, nsACString &aString) { // is it a channel nsCOMPtr channel; channel = do_QueryInterface(aRequest); if (!channel) return; nsCOMPtr uri; channel->GetURI(getter_AddRefs(uri)); if (!uri) return; uri->GetSpec(aString); }