Fix web based protocol handlers to work from link clicks in addition to the URL bar (bug 383396), r=biesi, sr=sicking

This commit is contained in:
dmose@mozilla.org 2007-06-15 14:43:51 -07:00
parent 386663f9bc
commit ad1c85f663
4 changed files with 180 additions and 5 deletions

View File

@ -477,7 +477,7 @@ nsExternalProtocolHandler::AllowPort(PRInt32 port, const char *scheme, PRBool *_
return NS_OK;
}
// returns TRUE if the OS can handle this protocol scheme and false otherwise.
PRBool nsExternalProtocolHandler::HaveOSProtocolHandler(nsIURI * aURI)
PRBool nsExternalProtocolHandler::HaveExternalProtocolHandler(nsIURI * aURI)
{
PRBool haveHandler = PR_FALSE;
if (aURI)
@ -485,7 +485,7 @@ PRBool nsExternalProtocolHandler::HaveOSProtocolHandler(nsIURI * aURI)
nsCAutoString scheme;
aURI->GetScheme(scheme);
if (gExtProtSvc)
gExtProtSvc->OSProtocolHandlerExists(scheme.get(), &haveHandler);
gExtProtSvc->ExternalProtocolHandlerExists(scheme.get(), &haveHandler);
}
return haveHandler;
@ -519,8 +519,8 @@ NS_IMETHODIMP nsExternalProtocolHandler::NewChannel(nsIURI *aURI, nsIChannel **_
{
// only try to return a channel if we have a protocol handler for the url
PRBool haveOSHandler = HaveOSProtocolHandler(aURI);
if (haveOSHandler)
PRBool haveExternalHandler = HaveExternalProtocolHandler(aURI);
if (haveExternalHandler)
{
nsCOMPtr<nsIChannel> channel;
NS_NEWXPCOM(channel, nsExtProtocolChannel);

View File

@ -62,7 +62,7 @@ public:
protected:
// helper function
PRBool HaveOSProtocolHandler(nsIURI * aURI);
PRBool HaveExternalProtocolHandler(nsIURI * aURI);
nsCString m_schemeName;
nsCOMPtr<nsIExternalProtocolService> m_extProtService;
};

View File

@ -0,0 +1,66 @@
#include "nsHandlerAppImpl.h"
// YYY why is nsMIMEInfoImpl threadsafe?
NS_IMPL_ISUPPORTS1(nsHandlerAppBase, nsIHandlerApp)
/* AString name; */
NS_IMETHODIMP nsHandlerAppBase::GetName(nsAString & aName)
{
aName.Assign(mName);
return NS_OK;
}
NS_IMETHODIMP nsHandlerAppBase::SetName(const nsAString & aName)
{
mName.Assign(aName);
return NS_OK;
}
NS_IMPL_ISUPPORTS_INHERITED1(nsLocalHandlerApp, nsHandlerAppBase, nsILocalHandlerApp)
// YYY should this be folded in instead of overwritten?
//
NS_IMETHODIMP nsLocalHandlerApp::GetName(nsAString& aName)
{
if (mName.IsEmpty() && mExecutable) {
// Don't want to cache this, just in case someone resets the app
// without changing the description....
mExecutable->GetLeafName(aName);
} else {
aName = mName;
}
return NS_OK;
}
NS_IMETHODIMP nsLocalHandlerApp::GetExecutable(nsIFile **aExecutable)
{
NS_IF_ADDREF(*aExecutable = mExecutable);
return NS_OK;
}
NS_IMETHODIMP nsLocalHandlerApp::SetExecutable(nsIFile *aExecutable)
{
mExecutable = aExecutable;
return NS_OK;
}
NS_IMPL_ISUPPORTS_INHERITED1(nsWebHandlerApp, nsHandlerAppBase,
nsIWebHandlerApp)
NS_IMETHODIMP nsWebHandlerApp::GetUriTemplate(nsACString &aUriTemplate)
{
aUriTemplate.Assign(mUriTemplate);
return NS_OK;
}
NS_IMETHODIMP nsWebHandlerApp::SetUriTemplate(const nsACString &aUriTemplate)
{
mUriTemplate.Assign(aUriTemplate);
return NS_OK;
}

View File

@ -0,0 +1,109 @@
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
* vim:expandtab:shiftwidth=2:tabstop=2:cin:
* ***** 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 the Mozilla browser.
*
* The Initial Developer of the Original Code is
* the Mozilla Corporation.
* Portions created by the Initial Developer are Copyright (C) 2007
* the Initial Developer. All Rights Reserved.
*
* Contributor(s):
* Dan Mosedale <dmose@mozilla.org>
*
* Alternatively, the contents of this file may be used under the terms of
* either of 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 ***** */
#ifndef __nshandlerappimpl_h__
#define __nshandlerappimpl_h__
#include "nsString.h"
#include "nsIMIMEInfo.h"
#include "nsIFile.h"
class nsHandlerAppBase : public nsIHandlerApp
{
public:
NS_DECL_ISUPPORTS
NS_DECL_NSIHANDLERAPP
nsHandlerAppBase() NS_HIDDEN {};
nsHandlerAppBase(const PRUnichar *aName) NS_HIDDEN { mName.Assign (aName); };
nsHandlerAppBase(const nsAString & aName) NS_HIDDEN { mName.Assign(aName); };
virtual ~nsHandlerAppBase() {};
protected:
nsString mName;
};
class nsLocalHandlerApp : public nsHandlerAppBase, public nsILocalHandlerApp
{
public:
NS_DECL_ISUPPORTS_INHERITED
NS_DECL_NSILOCALHANDLERAPP
nsLocalHandlerApp() : nsHandlerAppBase() {};
nsLocalHandlerApp(const PRUnichar *aName, nsIFile *aExecutable)
: nsHandlerAppBase(aName) {
mExecutable = aExecutable;
}
nsLocalHandlerApp(const nsAString & aName, nsIFile *aExecutable)
: nsHandlerAppBase(aName) {
mExecutable = aExecutable;
}
virtual ~nsLocalHandlerApp() {};
// overriding to keep old caching behavior
NS_IMETHOD GetName(nsAString & aName);
protected:
nsCOMPtr<nsIFile> mExecutable;
};
class nsWebHandlerApp : public nsHandlerAppBase, public nsIWebHandlerApp
{
public:
NS_DECL_ISUPPORTS_INHERITED
NS_DECL_NSIWEBHANDLERAPP
nsWebHandlerApp() : nsHandlerAppBase() {}
nsWebHandlerApp(const PRUnichar *aName, const nsACString &aUriTemplate)
: nsHandlerAppBase(aName) {
mUriTemplate = aUriTemplate;
}
virtual ~nsWebHandlerApp() {};
protected:
nsCString mUriTemplate;
};
#endif // __nshandlerappimpl_h__