/* ***** 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 Christopher Blizzard are Copyright (C) Christopher Blizzard. All Rights Reserved. * 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 #include #include #include #include "nsIURI.h" #include "nsCRT.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)) { gtk_signal_emit(GTK_OBJECT(mOwner->mOwningWidget), moz_embed_signals[NET_START]); } // get the uri for this request nsXPIDLCString uriString; RequestToURIString(aRequest, getter_Copies(uriString)); nsString tmpString; CopyUTF8toUTF16(uriString, tmpString); // is it the same as the current URI? if (mOwner->mURI.Equals(tmpString)) { // for people who know what they are doing gtk_signal_emit(GTK_OBJECT(mOwner->mOwningWidget), moz_embed_signals[NET_STATE], aStateFlags, aStatus); } gtk_signal_emit(GTK_OBJECT(mOwner->mOwningWidget), moz_embed_signals[NET_STATE_ALL], (const char *)uriString, (gint)aStateFlags, (gint)aStatus); // and for stop, too if ((aStateFlags & GTK_MOZ_EMBED_FLAG_IS_NETWORK) && (aStateFlags & GTK_MOZ_EMBED_FLAG_STOP)) { gtk_signal_emit(GTK_OBJECT(mOwner->mOwningWidget), moz_embed_signals[NET_STOP]); // 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) { nsXPIDLCString uriString; RequestToURIString(aRequest, getter_Copies(uriString)); nsString tmpString; CopyUTF8toUTF16(uriString, tmpString); // is it the same as the current uri? if (mOwner->mURI.Equals(tmpString)) { gtk_signal_emit(GTK_OBJECT(mOwner->mOwningWidget), moz_embed_signals[PROGRESS], aCurTotalProgress, aMaxTotalProgress); } gtk_signal_emit(GTK_OBJECT(mOwner->mOwningWidget), moz_embed_signals[PROGRESS_ALL], (const char *)uriString, 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()); gtk_signal_emit(GTK_OBJECT(mOwner->mOwningWidget), moz_embed_signals[LOCATION]); } return NS_OK; } NS_IMETHODIMP EmbedProgress::OnStatusChange(nsIWebProgress *aWebProgress, nsIRequest *aRequest, nsresult aStatus, const PRUnichar *aMessage) { // need to make a copy so we can safely cast to a void * PRUnichar *tmpString = nsCRT::strdup(aMessage); gtk_signal_emit(GTK_OBJECT(mOwner->mOwningWidget), moz_embed_signals[STATUS_CHANGE], NS_STATIC_CAST(void *, aRequest), NS_STATIC_CAST(int, aStatus), NS_STATIC_CAST(void *, tmpString)); nsMemory::Free(tmpString); return NS_OK; } NS_IMETHODIMP EmbedProgress::OnSecurityChange(nsIWebProgress *aWebProgress, nsIRequest *aRequest, PRUint32 aState) { gtk_signal_emit(GTK_OBJECT(mOwner->mOwningWidget), moz_embed_signals[SECURITY_CHANGE], NS_STATIC_CAST(void *, aRequest), aState); return NS_OK; } /* static */ void EmbedProgress::RequestToURIString(nsIRequest *aRequest, char **aString) { // is it a channel nsCOMPtr channel; channel = do_QueryInterface(aRequest); if (!channel) return; nsCOMPtr uri; channel->GetURI(getter_AddRefs(uri)); if (!uri) return; nsCAutoString uriString; uri->GetSpec(uriString); *aString = strdup(uriString.get()); }