Fixes names collisions in content.js
This commit is contained in:
parent
d66314cfb3
commit
dd48d1c352
@ -20,79 +20,84 @@
|
|||||||
|
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
const Cc = Components.classes;
|
(function contentScriptClosure() {
|
||||||
const Ci = Components.interfaces;
|
// we need to use closure here -- we are running in the global context
|
||||||
const Cm = Components.manager;
|
|
||||||
const Cu = Components.utils;
|
|
||||||
const Cr = Components.results;
|
|
||||||
|
|
||||||
Cu.import('resource://gre/modules/XPCOMUtils.jsm');
|
const Cc = Components.classes;
|
||||||
Cu.import('resource://gre/modules/Services.jsm');
|
const Ci = Components.interfaces;
|
||||||
|
const Cm = Components.manager;
|
||||||
|
const Cu = Components.utils;
|
||||||
|
const Cr = Components.results;
|
||||||
|
|
||||||
var isRemote = Services.appinfo.processType ===
|
Cu.import('resource://gre/modules/XPCOMUtils.jsm');
|
||||||
Services.appinfo.PROCESS_TYPE_CONTENT;
|
Cu.import('resource://gre/modules/Services.jsm');
|
||||||
|
|
||||||
|
var isRemote = Services.appinfo.processType ===
|
||||||
|
Services.appinfo.PROCESS_TYPE_CONTENT;
|
||||||
|
|
||||||
// Factory that registers/unregisters a constructor as a component.
|
// Factory that registers/unregisters a constructor as a component.
|
||||||
function Factory() {}
|
function Factory() {
|
||||||
|
|
||||||
Factory.prototype = {
|
|
||||||
QueryInterface: XPCOMUtils.generateQI([Ci.nsIFactory]),
|
|
||||||
_targetConstructor: null,
|
|
||||||
|
|
||||||
register: function register(targetConstructor) {
|
|
||||||
this._targetConstructor = targetConstructor;
|
|
||||||
var proto = targetConstructor.prototype;
|
|
||||||
var registrar = Cm.QueryInterface(Ci.nsIComponentRegistrar);
|
|
||||||
registrar.registerFactory(proto.classID, proto.classDescription,
|
|
||||||
proto.contractID, this);
|
|
||||||
},
|
|
||||||
|
|
||||||
unregister: function unregister() {
|
|
||||||
var proto = this._targetConstructor.prototype;
|
|
||||||
var registrar = Cm.QueryInterface(Ci.nsIComponentRegistrar);
|
|
||||||
registrar.unregisterFactory(proto.classID, this);
|
|
||||||
this._targetConstructor = null;
|
|
||||||
},
|
|
||||||
|
|
||||||
// nsIFactory
|
|
||||||
createInstance: function createInstance(aOuter, iid) {
|
|
||||||
if (aOuter !== null) {
|
|
||||||
throw Cr.NS_ERROR_NO_AGGREGATION;
|
|
||||||
}
|
|
||||||
return (new (this._targetConstructor)()).QueryInterface(iid);
|
|
||||||
},
|
|
||||||
|
|
||||||
// nsIFactory
|
|
||||||
lockFactory: function lockFactory(lock) {
|
|
||||||
// No longer used as of gecko 1.7.
|
|
||||||
throw Cr.NS_ERROR_NOT_IMPLEMENTED;
|
|
||||||
}
|
}
|
||||||
};
|
|
||||||
|
|
||||||
var pdfStreamConverterFactory = new Factory();
|
Factory.prototype = {
|
||||||
|
QueryInterface: XPCOMUtils.generateQI([Ci.nsIFactory]),
|
||||||
|
_targetConstructor: null,
|
||||||
|
|
||||||
function startup() {
|
register: function register(targetConstructor) {
|
||||||
Cu.import('resource://pdf.js/PdfjsContentUtils.jsm');
|
this._targetConstructor = targetConstructor;
|
||||||
PdfjsContentUtils.init();
|
var proto = targetConstructor.prototype;
|
||||||
|
var registrar = Cm.QueryInterface(Ci.nsIComponentRegistrar);
|
||||||
|
registrar.registerFactory(proto.classID, proto.classDescription,
|
||||||
|
proto.contractID, this);
|
||||||
|
},
|
||||||
|
|
||||||
Cu.import('resource://pdf.js/PdfStreamConverter.jsm');
|
unregister: function unregister() {
|
||||||
pdfStreamConverterFactory.register(PdfStreamConverter);
|
var proto = this._targetConstructor.prototype;
|
||||||
}
|
var registrar = Cm.QueryInterface(Ci.nsIComponentRegistrar);
|
||||||
|
registrar.unregisterFactory(proto.classID, this);
|
||||||
|
this._targetConstructor = null;
|
||||||
|
},
|
||||||
|
|
||||||
function shutdown() {
|
// nsIFactory
|
||||||
// Remove the contract/component.
|
createInstance: function createInstance(aOuter, iid) {
|
||||||
pdfStreamConverterFactory.unregister();
|
if (aOuter !== null) {
|
||||||
// Unload the converter
|
throw Cr.NS_ERROR_NO_AGGREGATION;
|
||||||
Cu.unload('resource://pdf.js/PdfStreamConverter.jsm');
|
}
|
||||||
|
return (new (this._targetConstructor)()).QueryInterface(iid);
|
||||||
|
},
|
||||||
|
|
||||||
PdfjsContentUtils.uninit();
|
// nsIFactory
|
||||||
Cu.unload('resource://pdf.js/PdfjsContentUtils.jsm');
|
lockFactory: function lockFactory(lock) {
|
||||||
}
|
// No longer used as of gecko 1.7.
|
||||||
|
throw Cr.NS_ERROR_NOT_IMPLEMENTED;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
if (isRemote) {
|
var pdfStreamConverterFactory = new Factory();
|
||||||
startup();
|
|
||||||
|
|
||||||
addMessageListener('PDFJS:Child:shutdown', function (e) {
|
function startup() {
|
||||||
shutdown();
|
Cu.import('resource://pdf.js/PdfjsContentUtils.jsm');
|
||||||
});
|
PdfjsContentUtils.init();
|
||||||
}
|
|
||||||
|
Cu.import('resource://pdf.js/PdfStreamConverter.jsm');
|
||||||
|
pdfStreamConverterFactory.register(PdfStreamConverter);
|
||||||
|
}
|
||||||
|
|
||||||
|
function shutdown() {
|
||||||
|
// Remove the contract/component.
|
||||||
|
pdfStreamConverterFactory.unregister();
|
||||||
|
// Unload the converter
|
||||||
|
Cu.unload('resource://pdf.js/PdfStreamConverter.jsm');
|
||||||
|
|
||||||
|
PdfjsContentUtils.uninit();
|
||||||
|
Cu.unload('resource://pdf.js/PdfjsContentUtils.jsm');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isRemote) {
|
||||||
|
startup();
|
||||||
|
|
||||||
|
addMessageListener('PDFJS:Child:shutdown', function (e) {
|
||||||
|
shutdown();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
})();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user