Bug 544550 - Ubufox addon incompatible with new plugin-crashed UI. r=gavin

This commit is contained in:
Justin Dolske 2010-02-18 13:43:22 -08:00
parent 20ebe4931a
commit 08adb94c35
4 changed files with 66 additions and 40 deletions

View File

@ -21,6 +21,7 @@ toolkit.jar:
content/mozapps/plugins/pluginInstallerService.js (plugins/content/pluginInstallerService.js)
content/mozapps/plugins/pluginProblem.xml (plugins/content/pluginProblem.xml)
content/mozapps/plugins/pluginProblemBinding.css (plugins/content/pluginProblemBinding.css)
content/mozapps/plugins/pluginFinderBinding.css (plugins/content/pluginFinderBinding.css)
content/mozapps/handling/handler.css (handling/content/handler.css)
content/mozapps/handling/handler.xml (handling/content/handler.xml)
content/mozapps/handling/dialog.xul (handling/content/dialog.xul)

View File

@ -0,0 +1,47 @@
/* ***** 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 stylesheet for the pluginfinder XBL binding.
*
* The Initial Developer of the Original Code is
* Christian Biesinger <cbiesinger@web.de>.
* Portions created by the Initial Developer are Copyright (C) 2005
* the Initial Developer. All Rights Reserved.
*
* Contributor(s):
*
* Justin Dolske <dolske@mozilla.com>
*
* 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 ***** */
@namespace url(http://www.w3.org/1999/xhtml); /* set default namespace to HTML */
/* This binding is specified separately from the others so that Linux distros can
override the default Mozilla plugin finder service with their own mechanism. */
embed:-moz-type-unsupported,
applet:-moz-type-unsupported,
object:-moz-has-handlerref:-moz-type-unsupported {
-moz-binding: url('chrome://mozapps/content/plugins/pluginProblem.xml#pluginProblem') !important;
}

View File

@ -38,15 +38,12 @@
@namespace url(http://www.w3.org/1999/xhtml); /* set default namespace to HTML */
embed:-moz-type-unsupported,
embed:-moz-handler-disabled,
embed:-moz-handler-blocked,
embed:-moz-handler-crashed,
applet:-moz-type-unsupported,
applet:-moz-handler-disabled,
applet:-moz-handler-blocked,
applet:-moz-handler-crashed,
object:-moz-has-handlerref:-moz-type-unsupported,
object:-moz-has-handlerref:-moz-handler-disabled,
object:-moz-has-handlerref:-moz-handler-blocked,
object:-moz-has-handlerref:-moz-handler-crashed {

View File

@ -20,6 +20,8 @@
*
* Contributor(s):
*
* Justin Dolske <dolske@mozilla.com>
*
* 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"),
@ -34,45 +36,24 @@
*
* ***** END LICENSE BLOCK ***** */
/**
* @file
* This file contains the agent style sheet registration code for the
* pluginfinder XBL binding. It's not a real module, it only exists so that we
* can call addCategoryEntry / deleteCategoryEntry.
*/
Components.utils.import("resource://gre/modules/XPCOMUtils.jsm");
var module = {
categoryEntry: "pluginfinder xbl binding",
categoryValue: "chrome://mozapps/content/plugins/pluginProblemBinding.css",
function pluginBindings() { }
// registerSelf: Register this component.
registerSelf: function (compMgr, fileSpec, location, type) {
var catman = Components.classes['@mozilla.org/categorymanager;1']
.getService(Components.interfaces.nsICategoryManager);
catman.addCategoryEntry("agent-style-sheets", this.categoryEntry,
this.categoryValue, true, true);
pluginBindings.prototype = {
// This isn't a real component, we're just using categories to
// automatically add our stylesheets during module registration.
classDescription: "plugin bindings",
classID: Components.ID("12663f3a-a311-4606-83eb-b6b9108dcc36"),
contractID: "@mozilla.org/plugin-bindings;1",
QueryInterface: XPCOMUtils.generateQI([]),
},
// unregisterSelf: Unregister this component.
unregisterSelf: function (aCompMgr, aLocation, aLoaderStr) {
catman.deleteCategoryEntry("agent-style-sheets", this.categoryEntry,
true);
},
// getClassObject: Return this component's factory object.
getClassObject: function (compMgr, cid, iid) {
throw Components.results.NS_ERROR_NOT_IMPLEMENTED;
},
// canUnload: n/a (returns true)
canUnload: function(compMgr) {
return true;
}
_xpcom_categories: [{ category: "agent-style-sheets",
entry: "pluginfinder xbl binding",
value: "chrome://mozapps/content/plugins/pluginFinderBinding.css"},
{ category: "agent-style-sheets",
entry: "pluginproblem xbl binding",
value: "chrome://mozapps/content/plugins/pluginProblemBinding.css"}]
};
// NSGetModule: Return the nsIModule object.
function NSGetModule(compMgr, fileSpec) {
return module;
}
var NSGetModule = XPCOMUtils.generateNSGetModule([pluginBindings]);